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.

search.js 28 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702
  1. var token;
  2. if(isEmpty(token)){
  3. var meta = $("meta[name=_uid]");
  4. if(!isEmpty(meta)){
  5. token = meta.attr("content");
  6. console.log("token is uid:" + token);
  7. }
  8. }
  9. var html =document.documentElement;
  10. var lang = html.attributes["lang"]
  11. var isZh = true;
  12. if(lang != null && lang.nodeValue =="en-US" ){
  13. console.log("the language is " + lang.nodeValue);
  14. isZh=false;
  15. }else{
  16. console.log("default lang=zh");
  17. }
  18. function isEmpty(str){
  19. if(typeof str == "undefined" || str == null || str == ""){
  20. return true;
  21. }
  22. return false;
  23. }
  24. var itemType={
  25. "1":"repository",
  26. "2":"issue",
  27. "3":"user",
  28. "4":"org",
  29. "5":"dataset",
  30. "6":"pr"
  31. };
  32. var sortBy={
  33. "11":"updated_unix.keyword",
  34. "12":"num_watches",
  35. "13":"num_stars",
  36. "14":"num_forks",
  37. "21":"updated_unix.keyword",
  38. "31":"created_unix.keyword",
  39. "32":"name.keyword",
  40. "41":"created_unix.keyword",
  41. "42":"name.keyword",
  42. "51":"download_times.keyword",
  43. "61":"updated_unix.keyword"
  44. };
  45. var sortAscending={
  46. "11":"false",
  47. "12":"false",
  48. "13":"false",
  49. "14":"false",
  50. "21":"false",
  51. "31":"false",
  52. "32":"true",
  53. "41":"false",
  54. "42":"true",
  55. "51":"false",
  56. "61":"false"
  57. };
  58. var currentPage = 1;
  59. var pageSize = 15;
  60. var currentSearchTableName ="";
  61. var currentSearchKeyword="";
  62. var currentSearchSortBy="";
  63. var currentSearchAscending=false;
  64. var OnlySearchLabel=false;
  65. var startIndex =1;
  66. var endIndex = 5;
  67. var totalPage = 1;
  68. var totalNum = 0;
  69. function initPageInfo(){
  70. currentPage = 1;
  71. startIndex =1;
  72. endIndex = 5;
  73. }
  74. function searchItem(type,sortType){
  75. console.log("enter item 2.");
  76. currentSearchKeyword = document.getElementById("keyword_input").value;
  77. if(!isEmpty(currentSearchKeyword)){
  78. initPageInfo();
  79. currentSearchTableName = itemType[type];
  80. currentSearchSortBy = sortBy[sortType];
  81. currentSearchAscending = sortAscending[sortType];
  82. OnlySearchLabel =false;
  83. page(currentPage);
  84. }
  85. }
  86. function search(){
  87. console.log("enter here 1.");
  88. currentSearchKeyword = document.getElementById("keyword_input").value;
  89. initPageInfo();
  90. if(!isEmpty(currentSearchKeyword)){
  91. currentSearchTableName = "repository";
  92. currentSearchSortBy = sortBy[11];
  93. currentSearchAscending = false;
  94. OnlySearchLabel =false;
  95. page(currentPage);
  96. doSearch("issue",currentSearchKeyword,1,pageSize,true,"",false);
  97. doSearch("user",currentSearchKeyword,1,pageSize,true,"",false);
  98. doSearch("org",currentSearchKeyword,1,pageSize,true,"",false);
  99. doSearch("dataset",currentSearchKeyword,1,pageSize,true,"",false);
  100. doSearch("pr",currentSearchKeyword,1,pageSize,true,"",false);
  101. }
  102. }
  103. function initDiv(isSearchLabel=false){
  104. if(isSearchLabel){
  105. document.getElementById("search_div").style.display="none";
  106. document.getElementById("search_label_div").style.display="block";
  107. document.getElementById("dataset_item").style.display="none";
  108. document.getElementById("issue_item").style.display="none";
  109. document.getElementById("pr_item").style.display="none";
  110. document.getElementById("user_item").style.display="none";
  111. document.getElementById("org_item").style.display="none";
  112. }else{
  113. document.getElementById("search_div").style.display="block";
  114. document.getElementById("search_label_div").style.display="none";
  115. document.getElementById("dataset_item").style.display="block";
  116. document.getElementById("issue_item").style.display="block";
  117. document.getElementById("pr_item").style.display="block";
  118. document.getElementById("user_item").style.display="block";
  119. document.getElementById("org_item").style.display="block";
  120. }
  121. }
  122. function searchLabel(tableName,keyword,sortBy="",ascending=false){
  123. console.log("enter label search.");
  124. initDiv(true);
  125. //document.getElementById("search_div").style.display="none";
  126. //document.getElementById("search_label_div").style.display="block";
  127. document.getElementById("search_label_div").innerHTML="<p class=\"searchlabel\">#" + keyword + "</p>";
  128. currentSearchKeyword = keyword;
  129. initPageInfo();
  130. currentSearchTableName = tableName;
  131. currentSearchSortBy = sortBy;
  132. currentSearchAscending = ascending;
  133. OnlySearchLabel =true;
  134. page(currentPage);
  135. }
  136. function doSearch(tableName,keyword,page,pageSize=15,onlyReturnNum=true,sortBy="",OnlySearchLabel=false){
  137. $.ajax({
  138. type:"GET",
  139. url:"/all/dosearch/",
  140. headers: {
  141. authorization:token,
  142. },
  143. dataType:"json",
  144. data:{
  145. 'TableName': tableName,
  146. 'Key': keyword,
  147. 'Page': page,
  148. 'PageSize': pageSize,
  149. 'OnlyReturnNum':onlyReturnNum,
  150. 'SortBy':sortBy,
  151. 'OnlySearchLabel':OnlySearchLabel,
  152. 'Ascending':currentSearchAscending
  153. },
  154. async:true,
  155. success:function(json){
  156. console.log("tableName=" + tableName);
  157. console.log(json);
  158. displayResult(tableName,page,json,onlyReturnNum,keyword);
  159. },
  160. error:function(response) {
  161. console.log(response);
  162. }
  163. });
  164. }
  165. function displayResult(tableName,page,jsonResult,onlyReturnNum,keyword){
  166. if(tableName == "repository") {
  167. displayRepoResult(page,jsonResult,onlyReturnNum,keyword);
  168. } else if (tableName == "issue") {
  169. displayIssueResult(page,jsonResult,onlyReturnNum,keyword);
  170. } else if (tableName == "user") {
  171. displayUserResult(page,jsonResult,onlyReturnNum,keyword);
  172. } else if (tableName == "org") {
  173. displayOrgResult(page,jsonResult,onlyReturnNum,keyword);
  174. } else if (tableName == "dataset") {
  175. displayDataSetResult(page,jsonResult,onlyReturnNum,keyword);
  176. } else if (tableName == "pr") {
  177. displayPrResult(page,jsonResult,onlyReturnNum,keyword);
  178. }
  179. if(!onlyReturnNum){
  180. console.log("set total num." + tableName);
  181. totalPage =Math.ceil(jsonResult.Total/pageSize);
  182. totalNum = jsonResult.Total;
  183. setPage(page);
  184. }
  185. }
  186. function displayPrResult(page,jsonResult,onlyReturnNum,keyword){
  187. var data = jsonResult.Result;
  188. var total = jsonResult.Total;
  189. $('#pr_total').text(total);
  190. if(!onlyReturnNum){
  191. setActivate("pr_item");
  192. $('#keyword_desc').text(keyword);
  193. $('#obj_desc').text("合并请求");
  194. $('#child_total').text(total);
  195. setIssueOrPrInnerHtml(data,"pulls");
  196. }
  197. }
  198. var categoryDesc={
  199. "computer_vision":"计算机视觉",
  200. "natural_language_processing":"自然语言处理",
  201. "speech_processing":"语音处理",
  202. "computer_vision_natural_language_processing":"计算机视觉、自然语言处理"
  203. };
  204. var taskDesc={
  205. "machine_translation":"机器翻译",
  206. "question_answering_system":"问答系统",
  207. "information_retrieval":"信息检索",
  208. "knowledge_graph":"知识图谱",
  209. "text_annotation":"文本标注",
  210. "text_categorization":"文本分类",
  211. "emotion_analysis":"情感分析",
  212. "language_modeling":"语言建模",
  213. "speech_recognition":"语音识别",
  214. "automatic_digest":"自动文摘",
  215. "information_extraction":"信息抽取",
  216. "description_generation":"说明生成",
  217. "image_classification":"图像分类",
  218. "face_recognition":"人脸识别",
  219. "image_search":"图像搜索",
  220. "target_detection":"目标检测",
  221. "image_description_generation":"图像描述生成",
  222. "vehicle_license_plate_recognition":"车辆车牌识别",
  223. "medical_image_analysis":"医学图像分析",
  224. "unmanned":"无人驾驶",
  225. "unmanned_security":"无人安防",
  226. "drone":"无人机",
  227. "vr_ar":"VR/AR",
  228. "2_d_vision":"2-D视觉",
  229. "2_5_d_vision":"2.5-D视觉",
  230. "3_d_reconstruction":"3D重构",
  231. "image_processing":"图像处理",
  232. "video_processing":"视频处理",
  233. "visual_input_system":"视觉输入系统",
  234. "speech_coding":"语音编码",
  235. "speech_enhancement":"语音增强",
  236. "speech_recognition":"语音识别",
  237. "speech_synthesis":"语音合成"
  238. };
  239. function getCategoryDesc(key){
  240. var re = categoryDesc[key];
  241. if(isEmpty(re)){
  242. return key;
  243. }
  244. return re;
  245. }
  246. function getTaskDesc(key){
  247. var re = taskDesc[key];
  248. if(isEmpty(re)){
  249. return key;
  250. }
  251. return re;
  252. }
  253. function displayDataSetResult(page,jsonResult,onlyReturnNum,keyword){
  254. var data = jsonResult.Result;
  255. var total = jsonResult.Total;
  256. $('#dataset_total').text(total);
  257. if(!onlyReturnNum){
  258. setActivate("dataset_item");
  259. $('#keyword_desc').text(keyword);
  260. $('#obj_desc').text("数据集");
  261. $('#child_total').text(total);
  262. var sortHtml = "";
  263. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(5,51);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_1\">下载次数</a>";
  264. document.getElementById("sort_type").innerHTML=sortHtml;
  265. var html = "";
  266. var currentTime = new Date().getTime();
  267. for(var i = 0; i < data.length;i++){
  268. var recordMap = data[i];
  269. html += "<div class=\"item\">";
  270. html += " <div class=\"content\">";
  271. html += " <div class=\"ui right metas\">" ;
  272. if(!isEmpty(recordMap["category"])){
  273. html += " <span class=\"text grey\"><svg class=\"svg octicon-tasklist\" width=\"16\" height=\"16\" aria-hidden=\"true\"><use xlink:href=\"#octicon-tasklist\" /></svg> " + getCategoryDesc(recordMap["category"]) + "</span>";
  274. }
  275. if(!isEmpty(recordMap["task"])){
  276. html += " <span class=\"text grey\"><svg class=\"svg octicon-tag\" width=\"16\" height=\"16\" aria-hidden=\"true\"><use xlink:href=\"#octicon-tag\" /></svg>" + getTaskDesc(recordMap["task"]) + "</span>";
  277. }
  278. html += " <span class=\"text grey\"><i class=\"ri-fire-line\"></i> " +recordMap["download_times"] + "</span> ";
  279. html +=" </div>";
  280. html += " <div class=\"ui header\">";
  281. html += " <a class=\"name\" href=\"/" +recordMap["repoUrl"] +"/datasets?type=0\">" + recordMap["title"] + "</a>";
  282. html +=" <span class=\"middle\"><svg class=\"svg octicon-repo-clone\" width=\"16\" height=\"16\" aria-hidden=\"true\"><use xlink:href=\"#octicon-repo-clone\"></use></svg></span>";
  283. html +=" </div>";
  284. html += " <div class=\"description\">";
  285. html += " <p class=\"has-emoji\"> " + recordMap["description"] + "</p>";
  286. if(!isEmpty(recordMap["file_name"])){
  287. html += " <p class=\"has-emoji\"> " + recordMap["file_name"] + "</p>";
  288. }
  289. html +=" <p class=\"time\">";
  290. html +=" <span class=\"am-ml-10\"></span> 最后更新于 <span class=\"time-since poping up\" title=\"\" data-content=\"\" data-variation=\"inverted tiny\">" + getTime(recordMap["created_unix"],currentTime) +"</span>";
  291. html +=" </p>";
  292. html +=" </div>";
  293. html +=" </div>";
  294. html +="</div>";
  295. }
  296. document.getElementById("child_search_item").innerHTML=html;
  297. }
  298. }
  299. function displayOrgResult(page,jsonResult,onlyReturnNum,keyword){
  300. var data = jsonResult.Result;
  301. var total = jsonResult.Total;
  302. $('#org_total').text(total);
  303. if(!onlyReturnNum){
  304. setActivate("org_item");
  305. $('#keyword_desc').text(keyword);
  306. $('#obj_desc').text("组织");
  307. $('#child_total').text(total);
  308. var sortHtml = "";
  309. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(4,41);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_1\">加入时间</a>";
  310. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(4,42);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_2\">名称自然序</a>";
  311. document.getElementById("sort_type").innerHTML=sortHtml;
  312. var html = "";
  313. var currentTime = new Date().getTime();
  314. for(var i = 0; i < data.length;i++){
  315. var recordMap = data[i];
  316. html += "<div class=\"item members\">";
  317. html += "<img class=\"ui avatar image\" src=\"" + recordMap["avatar"] + "\"></img>";
  318. html += " <div class=\"content\">";
  319. html += " <div class=\"ui header\">";
  320. html += " <a class=\"name\" href=\"/" + recordMap["real_name"] +"\">" + recordMap["name"] + "</a>";
  321. html +=" </div>";
  322. html += " <div class=\"description\">";
  323. html += " <p class=\"has-emoji\"> " + recordMap["description"] + "</p>";
  324. html +=" <p class=\"has-emoji\">";
  325. html +=" <i class=\"ri-map-pin-2-line\"></i> " + recordMap["location"];
  326. html +=" <span class=\"am-ml-10\"></span>";
  327. if(!isEmpty(recordMap["website"]) && recordMap["website"] != "null"){
  328. html +=" <i class=\"ri-links-line\"></i>" + "<a href=\""+ recordMap["website"] + "\" target=\"_blank\">" + recordMap["website"] + "</a>";
  329. }
  330. html +=" <i class=\"ri-time-line am-ml-10\"></i> 加入于 ";
  331. var userAddDate = new Date(recordMap["created_unix"]*1000);
  332. html += monthDisplay[userAddDate.getMonth()] + " " + userAddDate.getDay() + " " + userAddDate.getFullYear();
  333. html +=" </p>";
  334. html +=" </div>";
  335. html +=" </div>";
  336. html +="</div>";
  337. }
  338. document.getElementById("child_search_item").innerHTML=html;
  339. }
  340. }
  341. var monthDisplay=new Array("Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Spt","Oct","Nov","Dec");
  342. function displayUserResult(page,jsonResult,onlyReturnNum,keyword){
  343. var data = jsonResult.Result;
  344. var total = jsonResult.Total;
  345. $('#user_total').text(total);
  346. if(!onlyReturnNum){
  347. setActivate("user_item");
  348. $('#keyword_desc').text(keyword);
  349. $('#obj_desc').text("用户");
  350. $('#child_total').text(total);
  351. var sortHtml = "";
  352. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(3,31);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_1\">加入时间</a>";
  353. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(3,32);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_2\">名称自然序</a>";
  354. document.getElementById("sort_type").innerHTML=sortHtml;
  355. var html = "";
  356. var currentTime = new Date().getTime();
  357. for(var i = 0; i < data.length;i++){
  358. var recordMap = data[i];
  359. html += "<div class=\"item members\">";
  360. html += "<img class=\"ui avatar image\" src=\"" + recordMap["avatar"] + "\"></img>";
  361. html += " <div class=\"content\">";
  362. html += " <div class=\"ui header\">";
  363. html += " <a class=\"name\" href=\"/" + recordMap["real_name"] +"\">" + recordMap["name"] + "</a>";
  364. html +=" </div>";
  365. html += " <div class=\"description\">";
  366. html += " <p class=\"has-emoji\"> " + recordMap["description"] + "</p>";
  367. html +=" <p class=\"has-emoji\">";
  368. html +=" <i class=\"ri-mail-line\"></i>" + recordMap["email"];
  369. html +=" <i class=\"ri-time-line am-ml-10\"></i> 加入于 ";
  370. var userAddDate = new Date(recordMap["created_unix"]*1000);
  371. html += monthDisplay[userAddDate.getMonth()] + " " + userAddDate.getDay() + " " + userAddDate.getFullYear();
  372. html +=" </p>";
  373. html +=" </div>";
  374. html +=" </div>";
  375. html +="</div>";
  376. }
  377. document.getElementById("child_search_item").innerHTML=html;
  378. }
  379. }
  380. function setIssueOrPrInnerHtml(data,path){
  381. var sortHtml = "";
  382. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(2,21);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_1\">最近更新</a>";
  383. document.getElementById("sort_type").innerHTML=sortHtml;
  384. var html = "";
  385. var currentTime = new Date().getTime();
  386. for(var i = 0; i < data.length;i++){
  387. var recordMap = data[i];
  388. html += "<div class=\"item\">";
  389. html += " <div class=\"content\">";
  390. html += " <div class=\"ui header\">";
  391. html += " <a class=\"name\" href=\"/" + recordMap["repoUrl"] +"\">" + recordMap["name"] + "</a>";
  392. html +=" </div>";
  393. html += " <div class=\"description\">";
  394. html += " <p class=\"has-emoji\"> " + recordMap["content"] + "</p>";
  395. html +=" <p class=\"time\">";
  396. html +=" <i class=\"ri-code-box-line\"></i>";
  397. html +=" <a class=\"am-text grey\" href=\"/" + recordMap["repoUrl"] +"/" + path + "/" + recordMap["index"] + "\"> " + recordMap["repoUrl"] +"#" + recordMap["index"] + "</a>";
  398. html +=" <i class=\"ri-information-line am-ml-10\"></i> ";
  399. if(isEmpty(recordMap["is_closed"]) || recordMap["is_closed"]=="f"){
  400. html += "关闭";
  401. }else{
  402. html += "开启中";
  403. }
  404. html +=" <span class=\"am-ml-10\"></span> 最后更新于 <span class=\"time-since poping up\" title=\"\" data-content=\"\" data-variation=\"inverted tiny\">" + getTime(recordMap["updated_unix"],currentTime) +"</span>";
  405. html +=" </p>";
  406. html +=" </div>";
  407. html +=" </div>";
  408. html +="</div>";
  409. }
  410. document.getElementById("child_search_item").innerHTML=html;
  411. }
  412. function displayIssueResult(page,jsonResult,onlyReturnNum,keyword){
  413. var data = jsonResult.Result;
  414. var total = jsonResult.Total;
  415. $('#issue_total').text(total);
  416. if(!onlyReturnNum){
  417. setActivate("issue_item");
  418. $('#keyword_desc').text(keyword);
  419. $('#obj_desc').text("任务");
  420. $('#child_total').text(total);
  421. setIssueOrPrInnerHtml(data,"issues");
  422. }
  423. }
  424. function setActivate(name){
  425. $('#repo_item').removeClass("active");
  426. $('#user_item').removeClass("active");
  427. $('#issue_item').removeClass("active");
  428. $('#dataset_item').removeClass("active");
  429. $('#org_item').removeClass("active");
  430. $('#pr_item').removeClass("active");
  431. var tmp = "#" + name;
  432. $(tmp).addClass("active");
  433. }
  434. function displayRepoResult(page,jsonResult,onlyReturnNum,keyword){
  435. var data = jsonResult.Result;
  436. var total = jsonResult.Total;
  437. $('#repo_total').text(total);
  438. if(!onlyReturnNum){
  439. setActivate("repo_item");
  440. $('#keyword_desc').text(keyword);
  441. $('#obj_desc').text("项目");
  442. $('#child_total').text(total);
  443. var sortHtml = "";
  444. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(1,11);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_1\">最近更新</a>";
  445. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(1,12);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_1\">关注数</a>";
  446. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(1,13);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_1\">点赞数</a>";
  447. sortHtml +="<a class=\"item\" href=\"javascript:searchItem(1,14);\" tabindex=\"-1\" role=\"menuitem\" id=\"menuitem_1\">Fork数</a>";
  448. document.getElementById("sort_type").innerHTML=sortHtml;
  449. var html = "";
  450. var currentTime = new Date().getTime();
  451. for(var i = 0; i < data.length;i++){
  452. var recordMap = data[i];
  453. html += "<div class=\"item\">";
  454. if(!isEmpty(recordMap['avatar'])){
  455. html += "<img class=\"ui avatar image\" src=\"" + recordMap['avatar'] + "\">";
  456. }
  457. html += " <div class=\"content\">";
  458. html += " <div class=\"ui header\">";
  459. html += " <a class=\"name\" href=\"/" + recordMap["owner_name"] + "/" + recordMap["real_name"] +"\"> <span>" + recordMap["owner_name"] +"</span> <span>/</span> <strong>" + recordMap["alias"] + "</strong></a>";
  460. html +=" <span class=\"middle\"><svg class=\"svg octicon-repo-clone\" width=\"16\" height=\"16\" aria-hidden=\"true\"><use xlink:href=\"#octicon-repo-clone\"></use></svg></span>";
  461. html +=" </div>";
  462. html += " <div class=\"description\">";
  463. html += " <p class=\"has-emoji\"> " + recordMap["description"] + "</p>";
  464. html += " <div class=\"ui tags\">";
  465. if(!isEmpty(recordMap["topics"]) && recordMap["topics"] !="null"){
  466. for(var j = 0; j < recordMap["topics"].length;j++){
  467. //function searchLabel(tableName,keyword,sortBy="",ascending=false)
  468. html +=" <a href=\"javascript:searchLabel('repository','" + recordMap["topics"][j] + "','updated_unix.keyword',false);\"><div class=\"ui small label topic\">"+ recordMap["hightTopics"][j] + "</div></a>";
  469. }
  470. }
  471. html +=" </div>";
  472. html +=" <p class=\"time\">";
  473. html +=" <i class=\"icon fa-eye\">" +recordMap["num_watches"] + "</i>&nbsp;&nbsp;<i class=\"ri-star-line\"></i>" + recordMap["num_stars"] + "&nbsp;&nbsp;<i class=\"ri-git-branch-line am-ml-10\"></i>" + recordMap["num_forks"] +"&nbsp;&nbsp;";
  474. html +="&nbsp;&nbsp;&nbsp;&nbsp;最后更新于 <span class=\"time-since poping up\" title=\"\" data-content=\"\" data-variation=\"inverted tiny\">" + getTime(recordMap["updated_unix"],currentTime) +"</span>";
  475. if(!isEmpty(recordMap["lang"])){
  476. html +=" <span class=\"text grey am-ml-10\"><i class=\"color-icon\" style=\"background-color: #3572A5\"></i>" + recordMap["lang"] + "</span>";
  477. }
  478. html +=" </p>";
  479. html +=" </div>";
  480. html +=" </div>";
  481. html +="</div>";
  482. }
  483. document.getElementById("child_search_item").innerHTML=html;
  484. }
  485. }
  486. function getTime(UpdatedUnix,currentTime){
  487. UpdatedUnix = UpdatedUnix;
  488. currentTime = currentTime / 1000;
  489. var timeEscSecond = currentTime - UpdatedUnix;
  490. if( timeEscSecond < 0){
  491. timeEscSecond = 1;
  492. }
  493. console.log("currentTime=" + currentTime + " updateUnix=" + UpdatedUnix);
  494. var hours= Math.floor(timeEscSecond / 3600);
  495. //计算相差分钟数
  496. var leave2 = Math.floor(timeEscSecond % (3600)); //计算小时数后剩余的秒数
  497. var minutes= Math.floor(leave2 / 60);//计算相差分钟数
  498. var leave3=Math.floor(leave2 % 60); //计算分钟数后剩余的秒数
  499. var seconds= leave3;
  500. if(hours == 0 && minutes == 0){
  501. return seconds + getRepoOrOrg(6,isZh);
  502. }else{
  503. if(hours > 0){
  504. if(hours >= 24){
  505. return Math.ceil(hours/24) + getRepoOrOrg(7,isZh);
  506. }else{
  507. return hours + getRepoOrOrg(4,isZh);
  508. }
  509. }else{
  510. return minutes + getRepoOrOrg(5,isZh);
  511. }
  512. }
  513. }
  514. function getRepoOrOrg(key,isZhLang){
  515. if(isZhLang){
  516. return repoAndOrgZH[key];
  517. }else{
  518. return repoAndOrgEN[key];
  519. }
  520. }
  521. var repoAndOrgZH={
  522. "1":"项目",
  523. "2":"成员",
  524. "3":"团队",
  525. "4":"小时前",
  526. "5":"分钟前",
  527. "6":"秒前",
  528. "7":"天前"
  529. };
  530. var repoAndOrgEN={
  531. "1":"repository",
  532. "2":"Members ",
  533. "3":"Teams",
  534. "4":" hours ago",
  535. "5":" minutes ago",
  536. "6":" seconds ago",
  537. "7":" days ago"
  538. };
  539. function page(current){
  540. //function doSearch(tableName,keyword,page,pageSize=15,onlyReturnNum=true,sortBy="",OnlySearchLabel=false){
  541. currentPage=current;
  542. doSearch(currentSearchTableName,currentSearchKeyword,current,pageSize,false,currentSearchSortBy,OnlySearchLabel);
  543. }
  544. function nextPage(){
  545. currentPage = currentPage+1;
  546. console.log("currentPage=" + currentPage);
  547. if(currentPage >= endIndex){
  548. startIndex=startIndex+1;
  549. endIndex = endIndex +1;
  550. }
  551. page(currentPage);
  552. }
  553. function prePage(){
  554. console.log("currentPage=" + currentPage);
  555. if(currentPage > 1){
  556. currentPage = currentPage-1;
  557. if(currentPage <= startIndex && startIndex > 1){
  558. startIndex = startIndex -1;
  559. endIndex = endIndex - 1;
  560. }
  561. console.log("currentPage=" + (currentPage));
  562. page(currentPage);
  563. }
  564. }
  565. function goPage(){
  566. var goNum = $('#inputpage').val();
  567. if (goNum<=0){
  568. alert("请输入大于0的数值");
  569. }
  570. else if(goNum<=totalPage){
  571. page(goNum);
  572. }
  573. else{
  574. alert("不能超出总页数!");
  575. }
  576. }
  577. function setPage(currentPage){
  578. console.log("totalPage=" + totalPage);
  579. var html ="";
  580. console.log("currentPage=" + currentPage);
  581. if(totalPage==0){
  582. return;
  583. }
  584. html += "<span class=\"item\">共 " + totalNum + " 条</span>"
  585. if(currentPage > 1){
  586. html += "<a class=\"item navigation\" href=\"javascript:page(1)\"><span class=\"navigation_label\">首页</span></a>";
  587. html += "<a class=\"item navigation\" href=\"javascript:prePage()\"><i class=\"left arrow icon\"></i></a>";
  588. }else{
  589. html += "<a class=\"disabled item navigation\" href=\"javascript:page(1)\"><span class=\"navigation_label\">首页</span></a>";
  590. html += "<a class=\"disabled item navigation\" href=\"javascript:prePage()\"><i class=\"left arrow icon\"></i></a>";
  591. }
  592. for(var i=startIndex; i <= endIndex; i++){
  593. var page_i = i;
  594. if(page_i > totalPage){
  595. break;
  596. }
  597. if( page_i == currentPage){
  598. html += "<a id=\"page_" + page_i+ "\" class=\"active item\" href=\"javascript:page(" + page_i +")\">" + page_i + "</a>";
  599. }else{
  600. html += "<a id=\"page_" + page_i+ "\" class=\"item\" href=\"javascript:page(" + page_i +")\">" + page_i + "</a>";
  601. }
  602. }
  603. if(currentPage >=totalPage){
  604. html += "<a class=\"disabled item navigation\" href=\"javascript:nextPage()\"><i class=\"icon right arrow\"></i></a>";
  605. html += "<a class=\"disabled item navigation\" href=\"javascript:page(" + totalPage + ")\"><span class=\"navigation_label\">末页</span></a>";
  606. }else{
  607. html += "<a class=\"item navigation\" href=\"javascript:nextPage()\"><i class=\"icon right arrow\"></i></a>";
  608. html += "<a class=\"item navigation\" href=\"javascript:page(" + totalPage + ")\"><span class=\"navigation_label\">末页</span></a>";
  609. }
  610. html +="<div class=\"item\"> 前往<div class=\"ui input\"><input id=\"inputpage\" type=\"text\"></div>页</div>";
  611. console.log("html=" + html)
  612. document.getElementById("page_menu").innerHTML=html;
  613. $('#inputpage').on('keypress',function(event){
  614. if(event.keyCode == 13){
  615. goPage();
  616. }
  617. });
  618. }
  619. $('#keyword_input').on('keypress',function(event){
  620. if(event.keyCode == 13){
  621. var keyword = $('#keyword_input').val();
  622. if(!isEmpty(keyword)){
  623. search();
  624. }
  625. }
  626. });
  627. initDiv(false);
  628. document.onreadystatechange = function() {
  629. if (document.readyState === "complete") {
  630. var keyword = $('#keyword_input').val();
  631. if(!isEmpty(keyword)){
  632. search();
  633. }
  634. }
  635. }