api-detail.php 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. <?php
  2. include($_SERVER['DOCUMENT_ROOT'] . "/Authorization/script/php/permission/check_right.php");
  3. ?>
  4. <!doctype html>
  5. <html class="fixed sidebar-left-collapsed">
  6. <head>
  7. <!-- jstree CSS -->
  8. <link rel="stylesheet" href="/Common/assets/vendor/jstree/themes/default/style.css" />
  9. <link href="https://vjs.zencdn.net/7.17.0/video-js.css" rel="stylesheet">
  10. <?php include("bim-support-header.html"); ?>
  11. <script src="./script/js/global.js"></script>
  12. <style>
  13. th {
  14. width: 10%;
  15. text-align: center;
  16. }
  17. .vjs-tech {
  18. height: 100%;
  19. }
  20. </style>
  21. <script type="application/javascript">
  22. var i = 0;
  23. var api = [];
  24. var fileName;
  25. var folder;
  26. var software;
  27. var userName = "<?php echo $_SESSION['name'] ?>";
  28. var role = "<?php echo ($groupName); ?>";
  29. var right = <?php echo ($right); ?>;
  30. var webLink;
  31. var source;
  32. var searchURL = window.location.search;
  33. searchURL = searchURL.substring(1, searchURL.length);
  34. object = decodeURIComponent(searchURL.split("&")[0].split("=")[1]);
  35. if (object == 'undefined') {
  36. window.location.href = "./api-list.php";
  37. }
  38. $.ajax({
  39. url: "./script/php/api_group_detail.php",
  40. type: "GET",
  41. async: false,
  42. data: {
  43. object: object,
  44. },
  45. contentType: "application/json",
  46. dataType: "json"
  47. }).done(function(data) {
  48. if (data.APIID == null)
  49. data.APIID = '';
  50. folder = data.software + '/' + data.APIID + data.APIName;
  51. data[1] = data[1] == "Dynamo" ? data.software + " " + data.dynamoVersion : data.software + " " + data.revitVersion;
  52. for (i = 0; i < 6; i++) {
  53. if (data[i] != null)
  54. table.push(data[i]);
  55. else
  56. table.push("空");
  57. }
  58. webLink = data.webLink;
  59. source = data.source;
  60. }).error(function(error) {
  61. console.log(error);
  62. });
  63. $.ajax({
  64. url: "./script/php/update_popularity.php",
  65. type: "GET",
  66. async: false,
  67. data: {
  68. api_id: object,
  69. update_type: "viewTimes",
  70. },
  71. contentType: "application/json",
  72. dataType: "json"
  73. });
  74. pageHeader = "BIM程式庫";
  75. </script>
  76. </head>
  77. <body>
  78. <canvas id="c"></canvas>
  79. <section class="body">
  80. <!-- start: header -->
  81. <header-menu></header-menu>
  82. <!-- end: header -->
  83. <div class="inner-wrapper">
  84. <!-- start: sidebar -->
  85. <side-bar></side-bar>
  86. <!-- end: sidebar -->
  87. <section role="main" class="content-body">
  88. <header class="page-header">
  89. <h2>{{pageHeader}}</h2>
  90. </header>
  91. <!-- start: page -->
  92. <section class="content-with-menu content-with-menu-has-toolbar media-gallery">
  93. <div class="content-with-menu-container">
  94. <inner-menu>
  95. <template v-slot:inner-equipment>
  96. <api-list></api-list>
  97. </template>
  98. </inner-menu>
  99. <div class="inner-body mg-main">
  100. <div class="inner-toolbar">
  101. <ul>
  102. <li class="right">
  103. <a href="#" onclick="window.history.go(-1); return false;"><i class="fa fa-undo"></i> 返回</a>
  104. </li>
  105. </ul>
  106. </div>
  107. <div class="row">
  108. <div class="col-md-8">
  109. <section class="panel">
  110. <div class="panel-body">
  111. <h2 style="color: black;font-weight: bold;">{{table[0]}}</h2>
  112. <br>
  113. <h4 style="color: black;">{{table[2]}}</h2>
  114. <div class="table-responsive">
  115. <table class="table table-bordered mb-none">
  116. <tbody>
  117. <tr>
  118. <th>開發版本</th>
  119. <td>{{table[1]}}</td>
  120. </tr>
  121. <tr>
  122. <th>操作方式</th>
  123. <td>{{table[3]}}</td>
  124. </tr>
  125. <tr>
  126. <th width="5%">開發者</th>
  127. <td id="webLink"></td>
  128. </tr>
  129. <tr>
  130. <th>備註</th>
  131. <td>{{table[5]}}</td>
  132. </tr>
  133. </tbody>
  134. </table>
  135. </div>
  136. </div>
  137. </section>
  138. </div>
  139. <div class="col-md-4">
  140. <section class="panel">
  141. <div class="panel-body">
  142. <img id="thumbnail" style="width:100%;" src="/Common/assets/images/not-found-image.png" alt="成果縮圖">
  143. </div>
  144. </section>
  145. </div>
  146. </div>
  147. <div class="row">
  148. <div class="col-md-5">
  149. <section class="panel">
  150. <div class="panel-body">
  151. <h4 style="color: black;font-weight: bold;">操作影片</h4>
  152. <video style="width:100%;height:320px;" id="my-video" class="video-js" autoplay controls preload="auto" data-setup="{}">
  153. <source id="video-src" src='/Common/assets/images/not-found-video.mp4'>
  154. </video>
  155. </div>
  156. </section>
  157. </div>
  158. <div class="col-md-7">
  159. <section class="panel">
  160. <div class="panel-body">
  161. <img v-if="table[1].includes('ynamo')" src="/Common/assets/images/dynamo-icon.png" style="height:80px; display: inline-block; vertical-align: top;"></img>
  162. <img v-else-if="table[1].includes('Revit')" src="/Common/assets/images/revit-icon.png" style="height:80px; display: inline-block; vertical-align: top;"></img>
  163. <div class="summary" style="display: inline-block;">
  164. <div class="title"><strong>程式下載</strong></div>
  165. <div class="info" id="apiList">
  166. </div>
  167. </div>
  168. </div>
  169. </section>
  170. <section class="panel">
  171. <div class="panel-body">
  172. <h5 class="text-semibold text-dark text-uppercase">參考檔案下載</h5>
  173. <div id="treeAjaxHTML"></div>
  174. </div>
  175. </section>
  176. <button type="button" class="mb-xs mt-xs mr-xs btn btn-info col-md-offset-11" onclick="window.history.go(-1); return false;">返回</button>
  177. </div>
  178. </div>
  179. </div>
  180. </div>
  181. </section>
  182. <!-- end: page -->
  183. </section>
  184. </div>
  185. </section>
  186. <script>
  187. /*Vue */
  188. vm.mount('.body');
  189. addUserImage(userName.charAt(0), role);
  190. const downloads = ["dll", "dyn", "exe", "msi"];
  191. const videos = ["mp4", "m3u8", "ts", "avi"];
  192. const hidden = ["png"];
  193. if (webLink != null) {
  194. $("#webLink").append("<a href='" + webLink + "' target='_blank'>" + source + "</a>");
  195. } else if (webLink == null) {
  196. $("#webLink").append("<span>" + source + "</span>");
  197. }
  198. $(document).ready(function() {
  199. $("#apiList a").on("click", function() {
  200. $.ajax({
  201. url: "./script/php/update_popularity.php",
  202. type: "GET",
  203. async: false,
  204. data: {
  205. api_id: object,
  206. update_type: "downloadTimes",
  207. },
  208. contentType: "application/json",
  209. dataType: "json"
  210. });
  211. });
  212. $('#treeAjaxHTML').jstree({
  213. 'core': {
  214. 'themes': {
  215. 'responsive': false
  216. },
  217. 'check_callback': true,
  218. 'data': {
  219. 'url': './script/php/getTree.php?folder=' + folder,
  220. }
  221. },
  222. 'types': {
  223. 'default': {
  224. 'icon': 'fa fa-folder'
  225. },
  226. 'file': {
  227. 'icon': 'fa fa-file'
  228. }
  229. },
  230. 'plugins': ['types']
  231. }).on("ready.jstree", function(e, data) {
  232. var jsonNodes = $('#treeAjaxHTML').jstree(true).get_json('#', {
  233. flat: true
  234. });
  235. $.each(jsonNodes, function(i, val) {
  236. var treeNode = document.getElementById($(val).attr('id'));
  237. var nodeText = $(val).attr('text');
  238. var video = videojs("my-video");
  239. let href = $(val).attr('a_attr').href;
  240. let exts = href.split('.');
  241. let ext = exts[exts.length - 1]
  242. if (downloads.includes(ext)) {
  243. $("#apiList").append("<a download href='" + href + "' id='api" + 1 + "'>" + nodeText + "</a><br>");
  244. }
  245. if (ext.toLowerCase().includes('m3u8')) {
  246. video.src({
  247. src: href,
  248. });
  249. }
  250. if (ext.toLowerCase().includes('png')) {
  251. $("#thumbnail").attr("src", href);
  252. }
  253. if (videos.includes(ext.toLowerCase()) || downloads.includes(ext.toLowerCase()) || hidden.includes(ext.toLowerCase())) {
  254. $(treeNode).hide();
  255. }
  256. })
  257. }).on('select_node.jstree', function(event, data) {
  258. data.instance.toggle_node(data.node);
  259. if (data.node.text.includes(".")) {
  260. console.log(data.node);
  261. var link = document.createElement("a");
  262. link.download = data.node.text;
  263. link.href = data.node.a_attr.href;
  264. document.body.appendChild(link);
  265. link.click();
  266. document.body.removeChild(link);
  267. }
  268. });
  269. var player = videojs("my-video");
  270. player.on("fullscreenchange", () => {
  271. $(".vjs-tech").css("height","100%");
  272. })
  273. });
  274. </script>
  275. <script src="/Common/assets/vendor/jstree/jstree.js"></script>
  276. <!-- <script src="assets/javascripts/ui-elements/examples.treeview.js"></script> -->
  277. <?php include("bim-support-body.html"); ?>
  278. <script src="https://vjs.zencdn.net/7.17.0/video.min.js"></script>
  279. </body>
  280. </html>