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 24 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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569
  1. <!-- 头部导航栏 -->
  2. {{template "base/head" .}}
  3. <style>
  4. .inline.fields .right.aligned label{
  5. width: 100% !important;
  6. text-align: right;
  7. }
  8. .inline .ui.dropdown .text {
  9. color: rgba(0, 0, 0, .87) !important;
  10. max-width: 360px;
  11. }
  12. .newtext{
  13. left: 15px !important
  14. }
  15. .menuContent{
  16. position: absolute;
  17. background: #ffffff;
  18. left: 0;
  19. right: 26px;
  20. top: 36px;
  21. z-index:999;
  22. border: 1px solid #96c8da;
  23. border-top: 0;
  24. border-bottom-right-radius: 4px;
  25. border-bottom-left-radius: 4px;
  26. box-shadow: 0 2px 3px 0 rgb(34 36 38 / 15%);
  27. }
  28. </style>
  29. <link rel="stylesheet" href="/self/ztree/css/zTreeStyle/zTreeStyle.css" type="text/css">
  30. <!-- 弹窗 -->
  31. <div id="mask">
  32. <div id="loadingPage">
  33. <div class="rect1"></div>
  34. <div class="rect2"></div>
  35. <div class="rect3"></div>
  36. <div class="rect4"></div>
  37. <div class="rect5"></div>
  38. </div>
  39. </div>
  40. {{$repository := .Repository.ID}}
  41. <!-- 提示框 -->
  42. <div class="alert"></div>
  43. <div class="repository release dataset-list view">
  44. {{template "repo/header" .}}
  45. <!-- 列表容器 -->
  46. <div class="ui container {{if ne $.MODEL_COUNT 0}}active loader {{end}}" id="loadContainer">
  47. {{template "base/alert" .}}
  48. <div class="ui two column stackable grid">
  49. <div class="column">
  50. <div class="ui blue small menu compact selectcloudbrain">
  51. <a class="active item" href="{{.RepoLink}}/modelmanage/show_model">{{$.i18n.Tr "repo.model.list"}}</a>
  52. <a class="item" href="{{.RepoLink}}/modelmanage/convert_model">{{$.i18n.Tr "repo.model.convert"}}</a>
  53. </div>
  54. </div>
  55. <div class="column right aligned">
  56. <!-- -->
  57. <a class="ui button {{if .Permission.CanWrite $.UnitTypeModelManage}} green {{else}} disabled {{end}}"
  58. onclick="showcreate(this)">{{$.i18n.Tr "repo.model.manage.import_new_model"}}</a>
  59. </div>
  60. </div>
  61. {{if eq $.MODEL_COUNT 0}}
  62. <div class="ui placeholder segment bgtask-none">
  63. <div class="ui icon header bgtask-header-pic"></div>
  64. <div class="bgtask-content-header">未创建过模型</div>
  65. <div class="bgtask-content">
  66. {{if $.RepoIsEmpty}}
  67. <div class="bgtask-content-txt">代码版本:您还没有初始化代码仓库,请先<a href="{{.RepoLink}}">创建代码版本;</a></div>
  68. {{end}}
  69. {{if eq $.TRAIN_COUNT 0}}
  70. <div class="bgtask-content-txt">训练任务:您还没创建过训练任务,请先创建<a
  71. href="{{.RepoLink}}/modelarts/train-job">训练任务</a>。</div>
  72. {{end}}
  73. <div class="bgtask-content-txt">使用说明:可以参考启智AI协作平台<a
  74. href="https://git.openi.org.cn/zeizei/OpenI_Learning">小白训练营课程。</a></div>
  75. </div>
  76. <div style="display: none;">
  77. <div id="model_list"></div>
  78. </div>
  79. </div>
  80. {{else}}
  81. <!-- 中下列表展示区 -->
  82. <div class="ui grid" style="display: none;">
  83. <div class="row" style="padding-top: 0;">
  84. <div class="ui sixteen wide column">
  85. <!-- 任务展示 -->
  86. <div class="dataset list" id="model_list">
  87. <!-- 表头 -->
  88. </div>
  89. </div>
  90. </div>
  91. </div>
  92. {{end}}
  93. </div>
  94. </div>
  95. <!-- div full height-->
  96. </div>
  97. <!-- 确认模态框 -->
  98. <div id="deletemodel">
  99. <div class="ui basic modal first">
  100. <div class="ui icon header">
  101. <i class="trash icon"></i> 删除模型
  102. </div>
  103. <div class="content">
  104. <p>你确认删除该模型么?此模型一旦删除不可恢复。</p>
  105. </div>
  106. <div class="actions">
  107. <div class="ui red basic inverted cancel button">
  108. <i class="remove icon"></i> {{.i18n.Tr "cloudbrain.operate_cancel"}}
  109. </div>
  110. <div class="ui green basic inverted ok button">
  111. <i class="checkmark icon"></i> {{.i18n.Tr "cloudbrain.operate_confirm"}}
  112. </div>
  113. </div>
  114. </div>
  115. </div>
  116. <div id="newmodel">
  117. <div class="ui modal second">
  118. <div class="header" style="padding: 1rem;background-color: rgba(240, 240, 240, 100);">
  119. <h4 id="model_header"></h4>
  120. </div>
  121. <div class="content content-padding">
  122. <form id="formId" method="POST" class="ui form">
  123. <input type="hidden" name="initModel" value="{{$.MODEL_COUNT}}">
  124. <div class="ui error message">
  125. <!-- <p>asdasdasd</p> -->
  126. </div>
  127. <input type="hidden" name="_csrf" value="">
  128. <div class="inline fields">
  129. <div class="required two wide field right aligned">
  130. <label for="JobId">选择训练任务</label>
  131. </div>
  132. <div class="required thirteen wide inline field">
  133. <div class="ui dropdown selection search loading" id="choice_model">
  134. <input type="hidden" id="JobId" name="JobId" required>
  135. <div class="default text">选择训练任务</div>
  136. <i class="dropdown icon"></i>
  137. <div class="menu" id="job-name">
  138. </div>
  139. </div>
  140. <label for="VersionName">版本</label>
  141. <span>&nbsp;</span>
  142. <div class="ui dropdown selection search" id="choice_version">
  143. <input type="hidden" id="VersionName" name="VersionName" required>
  144. <div class="default text">选择版本</div>
  145. <i class="dropdown icon"></i>
  146. <div class="menu" id="job-version">
  147. </div>
  148. </div>
  149. </div>
  150. </div>
  151. <div class="required inline fields" id="modelname">
  152. <div class="two wide field right aligned">
  153. <label for="Name">模型名称</label>
  154. </div>
  155. <div class="eight wide field">
  156. <input id="name" name="Name" required maxlength="25" onkeyup="this.value=this.value.replace(/[, ]/g,'')">
  157. </div>
  158. </div>
  159. <div class="required inline fields" id="verionname">
  160. <div class="two wide field right aligned">
  161. <label for="Version">模型版本</label>
  162. </div>
  163. <div class="eight wide field">
  164. <input id="version" name="Version" value="" readonly required maxlength="255">
  165. </div>
  166. </div>
  167. <div class="unite min_title inline fields required">
  168. <div class="two wide field right aligned">
  169. <label for="Engine">模型框架</label>
  170. </div>
  171. <div class="ui ten wide field dropdown selection search" id="choice_Engine">
  172. <input type="hidden" id="Engine" name="Engine" required>
  173. <div class="default text newtext">选择模型框架</div>
  174. <i class="dropdown icon"></i>
  175. <div class="menu" id="job-Engine">
  176. </div>
  177. </div>
  178. </div>
  179. <div class="unite min_title inline fields required">
  180. <div class="two wide field right aligned">
  181. <label for="modelSelectedFile">模型文件</label>
  182. </div>
  183. <div class="thirteen wide field" style="position:relative">
  184. <input id="modelSelectedFile" type="text" readonly required onclick="showMenu();" name="modelSelectedFile" >
  185. <div id="menuContent" class="menuContent" style="display:none;">
  186. <ul id="treeDemo" class="ztree"></ul>
  187. </div>
  188. </div>
  189. </div>
  190. <div class="inline fields">
  191. <div class="two wide field right aligned">
  192. <label for="Label">模型标签 &nbsp</label>
  193. </div>
  194. <div class="thirteen wide field">
  195. <input id="label" name="Label" maxlength="255" placeholder='{{.i18n.Tr "repo.modelarts.train_job.label_place"}}'>
  196. </div>
  197. </div>
  198. <div class="inline fields">
  199. <div class="two wide field right aligned">
  200. <label for="description">模型描述 &nbsp</label>
  201. </div>
  202. <div class="thirteen wide field">
  203. <textarea id="Description" name="Description" rows="3"
  204. maxlength="255" placeholder='{{.i18n.Tr "repo.modelarts.train_job.new_place"}}'
  205. onchange="this.value=this.value.substring(0, 255)"
  206. onkeydown="this.value=this.value.substring(0, 255)"
  207. onkeyup="this.value=this.value.substring(0, 256)"></textarea>
  208. </div>
  209. </div>
  210. <div class="inline field" style="margin-left: 105px;">
  211. <button id="submitId" type="button" class="ui create_train_job green button"
  212. style="position: absolute;">
  213. {{.i18n.Tr "repo.model.manage.sava_model"}}
  214. </button>
  215. </div>
  216. </form>
  217. <div class="actions" style="display: inline-block;margin-left: 220px;">
  218. <button class="ui button cancel">{{.i18n.Tr "repo.cloudbrain.cancel"}}</button>
  219. </div>
  220. </div>
  221. </div>
  222. {{template "base/footer" .}}
  223. <script type="text/javascript" src="/self/ztree/js/jquery.ztree.core.js"></script>
  224. <script type="text/javascript" src="/self/ztree/js/jquery.ztree.excheck.js"></script>
  225. <script type="text/javascript">
  226. var setting = {
  227. check: {
  228. enable: true,
  229. chkboxType: {"Y":"ps", "N":"ps"}
  230. },
  231. view: {
  232. dblClickExpand: false
  233. },
  234. callback: {
  235. beforeClick: beforeClick,
  236. onCheck: onCheck
  237. }
  238. };
  239. function beforeClick(treeId, treeNode) {
  240. var zTree = $.fn.zTree.getZTreeObj("treeDemo");
  241. zTree.checkNode(treeNode, !treeNode.checked, null, true);
  242. return false;
  243. }
  244. function onCheck(e, treeId, treeNode) {
  245. var zTree = $.fn.zTree.getZTreeObj("treeDemo"),
  246. nodes = zTree.getCheckedNodes(true),
  247. v = "";
  248. for (var i=0, l=nodes.length; i<l; i++) {
  249. if(nodes[i].isParent){
  250. continue;
  251. }
  252. var pathNodes = nodes[i].getPath();
  253. var path ="";
  254. for(var j=0;j<pathNodes.length;j++){
  255. if(j ==0){
  256. path += pathNodes[j].name;
  257. }else{
  258. path += "/" + pathNodes[j].name;
  259. }
  260. }
  261. v += path + ";";
  262. }
  263. if (v.length > 0 ) v = v.substring(0, v.length-1);
  264. var cityObj = $("#modelSelectedFile");
  265. cityObj.attr("value", v);
  266. }
  267. function showMenu() {
  268. var cityObj = $("#modelSelectedFile");
  269. var cityOffset = $("#modelSelectedFile").offset();
  270. // $("#menuContent").css({left:cityOffset.left + "px", top:cityOffset.top + cityObj.outerHeight() + "px"}).slideDown("fast");
  271. $("#menuContent").slideDown("fast");
  272. $("body").bind("mousedown", onBodyDown);
  273. }
  274. function hideMenu() {
  275. $("#menuContent").fadeOut("fast");
  276. $("body").unbind("mousedown", onBodyDown);
  277. }
  278. function onBodyDown(event) {
  279. if (!(event.target.id == "menuBtn" || event.target.id == "modelSelectedFile" || event.target.id == "menuContent" || $(event.target).parents("#menuContent").length>0)) {
  280. hideMenu();
  281. }
  282. }
  283. $(document).ready(function(){
  284. //$.fn.zTree.init($("#treeDemo"), setting, zNodes);
  285. });
  286. let repolink = {{.RepoLink }}
  287. let repoId = {{ $repository }}
  288. const { _AppSubUrl, _StaticUrlPrefix, csrf } = window.config;
  289. $('input[name="_csrf"]').val(csrf)
  290. let modelData;
  291. function createModelName() {
  292. let repoName = location.pathname.split('/')[2]
  293. let modelName = repoName + '_model_' + Math.random().toString(36).substr(2, 4)
  294. $('#name').val(modelName)
  295. $('#version').val("0.0.1")
  296. }
  297. let dirKey="isOnlyDir--:&";
  298. function showcreate(obj) {
  299. $('.ui.modal.second')
  300. .modal({
  301. centered: false,
  302. onShow: function () {
  303. $('#model_header').text("导入新模型")
  304. $('input[name="Version"]').addClass('model_disabled')
  305. $('.ui.dimmer').css({ "background-color": "rgb(136, 136, 136,0.7)" })
  306. $("#job-name").empty()
  307. createModelName()
  308. loadTrainList()
  309. },
  310. onHide: function () {
  311. var cityObj = $("#modelSelectedFile");
  312. cityObj.attr("value", "");
  313. document.getElementById("formId").reset();
  314. $('#choice_model').dropdown('clear')
  315. $('#choice_version').dropdown('clear')
  316. $('#choice_Engine').dropdown('clear')
  317. $('.ui.dimmer').css({ "background-color": "" })
  318. $('.ui.error.message').text()
  319. $('.ui.error.message').css('display', 'none')
  320. }
  321. })
  322. .modal('show')
  323. }
  324. $(function () {
  325. $('#choice_model').dropdown({
  326. onChange: function (value) {
  327. $("#choice_version").addClass("loading")
  328. $('#choice_version').dropdown('clear')
  329. $("#job-version").empty()
  330. loadTrainVersion(value)
  331. }
  332. })
  333. $('#choice_version').dropdown({
  334. onChange: function (value) {
  335. console.log("model version:" + value);
  336. if (modelData != null) {
  337. for (var i = 0; i < modelData.length; i++) {
  338. if (modelData[i].VersionName == value) {
  339. setEngine(modelData[i])
  340. loadModelFile(modelData[i])
  341. break;
  342. }
  343. }
  344. }
  345. }
  346. })
  347. })
  348. function versionAdd(version) {
  349. let versionArray = version.split('.')
  350. if (versionArray[2] == '9') {
  351. if (versionArray[1] == '9') {
  352. versionArray[0] = String(Number(versionArray[1]) + 1)
  353. versionArray[1] = '0'
  354. } else {
  355. versionArray[1] = String(Number(versionArray[1]) + 1)
  356. }
  357. versionArray[2] = '0'
  358. } else {
  359. versionArray[2] = String(Number(versionArray[2]) + 1)
  360. }
  361. return versionArray.join('.')
  362. }
  363. function loadTrainList() {
  364. $.get(`${repolink}/modelmanage/query_train_job?repoId=${repoId}`, (data) => {
  365. const n_length = data.length
  366. if(n_length > 0){
  367. let train_html = ''
  368. for (let i = 0; i < n_length; i++) {
  369. train_html += `<div class="item" data-value="${data[i].JobID}">${data[i].DisplayJobName}</div>`
  370. train_html += '</div>'
  371. }
  372. $("#job-name").append(train_html)
  373. $("#choice_model").removeClass("loading")
  374. $('#choice_model .default.text').text(data[0].DisplayJobName)
  375. $('#choice_model input[name="JobId"]').val(data[0].JobID)
  376. loadTrainVersion()
  377. }else{
  378. $("#choice_model").removeClass("loading")
  379. }
  380. })
  381. }
  382. function loadTrainVersion(value) {
  383. let JobID = !value ? $('#choice_model input[name="JobId"]').val() : value
  384. $.get(`${repolink}/modelmanage/query_train_job_version?JobID=${JobID}`, (data) => {
  385. const n_length = data.length
  386. let train_html = '';
  387. modelData = data;
  388. for (let i = 0; i < n_length; i++) {
  389. train_html += `<div class="item" data-value="${data[i].VersionName}">${data[i].VersionName}</div>`
  390. train_html += '</div>'
  391. }
  392. if (data.length) {
  393. $("#job-version").append(train_html)
  394. $("#choice_version").removeClass("loading")
  395. var versionName = data[0].VersionName;
  396. if (versionName == null || versionName == "") {
  397. versionName = "V0001";
  398. }
  399. $('#choice_version .default.text').text(versionName)
  400. $('#choice_version input[name="VersionName"]').val(versionName)
  401. setEngine(data[0])
  402. loadModelFile(data[0])
  403. }
  404. })
  405. }
  406. function loadModelFile(trainJob){
  407. console.log("trainJob=" + trainJob);
  408. $('#choice_file').dropdown('clear')
  409. $("#model-file").empty()
  410. if(trainJob ==null || trainJob ==""){
  411. console.log("trainJob is null");
  412. }else{
  413. let type = trainJob.Type;
  414. if(type == 2){
  415. if(trainJob.ComputeResource=="NPU"){
  416. type=1;
  417. }else{
  418. type=0;
  419. }
  420. }
  421. $.get(`${repolink}/modelmanage/query_train_model?jobName=${trainJob.JobName}&type=${type}&VersionName=${trainJob.VersionName}`, (data) => {
  422. const n_length = data.length
  423. let file_html=''
  424. let firstFileName =''
  425. var zNodes=[];
  426. var nodesMap={};
  427. for (let i=0;i<n_length;i++){
  428. var parentNodeMap = nodesMap;
  429. var fileSplits = data[i].FileName.split("/");
  430. for(let j=0;j < fileSplits.length;j++){
  431. if(fileSplits[j] == ""){
  432. break;
  433. }
  434. if(parentNodeMap[fileSplits[j]] == null){
  435. parentNodeMap[fileSplits[j]] = {};
  436. }
  437. parentNodeMap = parentNodeMap[fileSplits[j]];
  438. }
  439. }
  440. for (let i=0;i<n_length;i++){
  441. var parentNodeMap = nodesMap;
  442. var fileSplits = data[i].FileName.split("/");
  443. for(let j=0;j < fileSplits.length;j++){
  444. if(fileSplits[j] == ""){
  445. if(data[i].FileName[data[i].FileName.length -1] =="/"){
  446. if(Object.keys(parentNodeMap).length ==0){
  447. parentNodeMap[dirKey]="true";
  448. }
  449. }
  450. break;
  451. }
  452. parentNodeMap = parentNodeMap[fileSplits[j]];
  453. }
  454. }
  455. convertToNode(zNodes,nodesMap);
  456. $.fn.zTree.init($("#treeDemo"), setting, zNodes);
  457. })
  458. }
  459. }
  460. function convertToNode(nodeList,nodesMap){
  461. var keyList = Object.keys(nodesMap);
  462. keyList.sort(function(a,b){
  463. return a-b;
  464. });
  465. var isFirst = true;
  466. for(var i=0; i<keyList.length;i++){
  467. var node = {};
  468. node["name"] = keyList[i];
  469. nodeList.push(node);
  470. if(nodesMap[keyList[i]] != null && Object.keys(nodesMap[keyList[i]]).length >0){
  471. if(nodesMap[keyList[i]][dirKey] != null){
  472. node["open"] = false;
  473. node["isParent"] = true;
  474. }else{
  475. node["children"]=[];
  476. if(isFirst){
  477. node["open"] = true;
  478. isFirst= false;
  479. }
  480. convertToNode(node["children"],nodesMap[keyList[i]]);
  481. }
  482. }
  483. }
  484. }
  485. function setEngine(modelVersion) {
  486. console.log("modelVersion=" + modelVersion);
  487. $('#choice_Engine').dropdown('clear')
  488. $("#job-Engine").empty()
  489. if (modelVersion.EngineName != null && modelVersion.EngineName != "") {
  490. srcEngine = modelVersion.EngineName.split('-')[0]
  491. srcEngine = srcEngine.trim().toLowerCase();
  492. let selectedText = "PyTorch";
  493. let selectedValue = 0;
  494. let itemHtml = "<option class=\"item\" data-value=\"0\">PyTorch</option>";
  495. if (srcEngine == 'tensorflow') {
  496. selectedText = "TensorFlow";
  497. selectedValue = 1;
  498. itemHtml += "<option class=\"active item\" data-value=\"1\">TensorFlow</option>";
  499. } else {
  500. itemHtml += "<option class=\"item\" data-value=\"1\">TensorFlow</option>";
  501. }
  502. if (srcEngine == 'mindspore') {
  503. selectedText = "MindSpore";
  504. selectedValue = 2;
  505. itemHtml += "<option class=\"active item\" data-value=\"2\">MindSpore</option>";
  506. } else {
  507. itemHtml += "<option class=\"item\" data-value=\"2\">MindSpore</option>";
  508. }
  509. itemHtml += "<option class=\"item\" data-value=\"4\">PaddlePaddle</option>"
  510. itemHtml += "<option class=\"item\" data-value=\"5\">OneFlow</option>"
  511. itemHtml += "<option class=\"item\" data-value=\"6\">MXNet</option>"
  512. itemHtml += "<option class=\"item\" data-value=\"3\">Other</option>"
  513. $('#choice_Engine .default.text').text(selectedText)
  514. $('#choice_Engine input[name="Engine"]').val(selectedValue)
  515. $("#job-Engine").append(itemHtml);
  516. $("#choice_Engine").removeClass('disabled');
  517. } else {
  518. let itemHtml = "<option class=\"active item\" data-value=\"0\">PyTorch</option>";
  519. itemHtml += "<option class=\"item\" data-value=\"1\">TensorFlow</option>"
  520. itemHtml += "<option class=\"item\" data-value=\"2\">MindSpore</option>"
  521. itemHtml += "<option class=\"item\" data-value=\"4\">PaddlePaddle</option>"
  522. itemHtml += "<option class=\"item\" data-value=\"5\">OneFlow</option>"
  523. itemHtml += "<option class=\"item\" data-value=\"6\">MXNet</option>"
  524. itemHtml += "<option class=\"item\" data-value=\"3\">Other</option>"
  525. $('#choice_Engine .default.text').text("PyTorch");
  526. $('#choice_Engine input[name="Engine"]').val(0)
  527. $("#job-Engine").append(itemHtml);
  528. $("#choice_Engine").removeClass('disabled');
  529. }
  530. }
  531. </script>