DataSyncEdit.vue 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. <template>
  2. <div class="container-fluid">
  3. <div>
  4. <Navbar
  5. :title="$t('lang.DataSyncEdit.u8AssetNumberSynchronization')"
  6. :is-go-back="false"
  7. />
  8. </div>
  9. <ul class="nav nav-tabs">
  10. <li
  11. role="presentation"
  12. :class="{'active': step == 1}"
  13. @click="showU8AssetPage"
  14. >
  15. <a href="javascript:void(0);">{{ $t('lang.DataSyncEdit.assetsToBeAdded') }}</a>
  16. </li>
  17. <li
  18. role="presentation"
  19. :class="{'active': step == 2}"
  20. @click="showProdogAssetPage"
  21. >
  22. <a href="javascript:void(0);">{{ $t('lang.DataSyncEdit.prodogUnnumberedAssets') }}</a>
  23. </li>
  24. </ul>
  25. <div
  26. v-show="step == 1"
  27. class="row div-content"
  28. >
  29. <button
  30. type="button"
  31. class="btn btn-primary btn-block"
  32. @click="getU8Asset"
  33. >
  34. {{ $t('lang.DataSyncEdit.refresh') }}
  35. </button>
  36. <h5 />
  37. <div ref="table1" />
  38. </div>
  39. <div
  40. v-show="step == 2"
  41. class="row div-content"
  42. >
  43. <div class="row">
  44. <div class="col-md-6">
  45. <button
  46. type="button"
  47. class="btn btn-primary btn-block"
  48. @click="getProdogNoAssetNoData"
  49. >
  50. {{ $t('lang.DataSyncEdit.refresh') }}
  51. </button>
  52. </div>
  53. <div class="col-md-6">
  54. <button
  55. type="button"
  56. class="btn btn-success btn-block"
  57. @click="save"
  58. >
  59. {{ $t('lang.DataSyncEdit.save') }}
  60. </button>
  61. </div>
  62. </div>
  63. <h5 />
  64. <div ref="table2" />
  65. </div>
  66. <Loading v-if="loading" />
  67. </div>
  68. </template>
  69. <script>
  70. import Common from '../../common/Common.js';
  71. import { Notify } from 'pc-component-v3';
  72. import DynamicJsLoader from '../../common/DynamicJsLoader.js';
  73. export default {
  74. components: {
  75. },
  76. data: function () {
  77. return {
  78. U8SyncItems: [],
  79. adds: [],
  80. updates: [],
  81. processAllAdds: true,
  82. processAllUpdates: true,
  83. root: 'test-hot',
  84. step: 1,
  85. loading: false,
  86. };
  87. },
  88. watch: {
  89. processAllAdds: function (to) {
  90. this.adds.forEach(function (item) {
  91. item.isDispose = to;
  92. });
  93. },
  94. processAllUpdates: function (to) {
  95. this.updates.forEach(function (item) {
  96. item.isDispose = to;
  97. });
  98. },
  99. },
  100. mounted: function () {
  101. this.getU8Asset();
  102. },
  103. methods: {
  104. /**
  105. * 显示U8资产界面
  106. */
  107. showU8AssetPage: function () {
  108. this.step = 1;
  109. },
  110. /**
  111. * 显示Prodog资产界面
  112. */
  113. showProdogAssetPage: function () {
  114. this.step = 2;
  115. this.getProdogNoAssetNoData();
  116. },
  117. /**
  118. * 获取u8资产数据
  119. */
  120. getU8Asset: function () {
  121. var _self = this;
  122. _self.loading=true;
  123. $.ajax({
  124. url: Common.getApiURL('dataSyncResource/listNeedAddAssetU8'),
  125. type: 'get',
  126. dataType: 'json',
  127. beforeSend: function (request) {
  128. Common.addTokenToRequest(request);
  129. },
  130. success: function (data) {
  131. if (data) {
  132. _self.showTable1Data(_self.$refs.table1, data);
  133. }
  134. _self.loading=false;
  135. },
  136. error: function (XMLHttpRequest, textStatus, errorThrown) {
  137. _self.loading=false;
  138. Common.processException(XMLHttpRequest, textStatus, errorThrown);
  139. },
  140. });
  141. },
  142. /**
  143. * 获取Prodog无资产编码的数据
  144. */
  145. getProdogNoAssetNoData: function () {
  146. var _self = this;
  147. $.ajax({
  148. url: Common.getApiURL('AssetInstanceResource/getNoAssetNo'),
  149. type: 'get',
  150. dataType: 'json',
  151. beforeSend: function (request) {
  152. Common.addTokenToRequest(request);
  153. },
  154. success: function (data) {
  155. if (data) {
  156. DynamicJsLoader.loadHandsonTable(_self.showTable2Data(_self.$refs.table2, data));
  157. }
  158. _self.loading=false;
  159. },
  160. error: function (XMLHttpRequest, textStatus, errorThrown) {
  161. _self.loading=false;
  162. Common.processException(XMLHttpRequest, textStatus, errorThrown);
  163. },
  164. });
  165. },
  166. /**
  167. * 保存数据
  168. */
  169. save: function () {
  170. var _self = this;
  171. _self.loading=true;
  172. var sendData = _self.hotTable2.getSourceData();
  173. $.ajax({
  174. url: Common.getApiURL('AssetInstanceResource/saveNoAssetNo'),
  175. type: 'post',
  176. data: JSON.stringify(sendData),
  177. contentType: 'application/json',
  178. beforeSend: function (request) {
  179. Common.addTokenToRequest(request);
  180. },
  181. success: function (data) {
  182. _self.loading=false;
  183. Notify.success('成功', '保存成功', true);
  184. _self.getNoAssetNoData();
  185. },
  186. error: function (XMLHttpRequest, textStatus, errorThrown) {
  187. _self.loading=false;
  188. Common.processException(XMLHttpRequest, textStatus, errorThrown);
  189. },
  190. });
  191. },
  192. /**
  193. * 显示U8未同步资产数据
  194. * @param {Object} container
  195. * @param {Object} datas
  196. */
  197. showTable1Data: function (container, datas) {
  198. var _self = this;
  199. if (_self.hotTable1) {
  200. _self.hotTable1.loadData(datas);
  201. } else {
  202. // _self.hotTable1 = new Handsontable(container, {
  203. // data: datas,
  204. // rowHeaders: false,
  205. // colHeaders: ['资产名称', '资产编号', '规格型号', '部门编号'],
  206. // stretchH: 'all',
  207. // columnHeaderHeight: 36,
  208. // rowHeights: 36,
  209. // columns: [{
  210. // data: 'name',
  211. // type: 'text',
  212. // }, {
  213. // data: 'assetNo',
  214. // type: 'text',
  215. // }, {
  216. // data: 'type',
  217. // type: 'text',
  218. // }, {
  219. // data: 'deptNum',
  220. // type: 'text',
  221. // }],
  222. // });
  223. }
  224. },
  225. /**
  226. * 显示Prodog无资产号的数据
  227. * @param {Object} container
  228. * @param {Object} datas
  229. */
  230. showTable2Data: function (container, datas) {
  231. var _self = this;
  232. if (_self.hotTable2) {
  233. _self.hotTable2.loadData(datas);
  234. } else {
  235. // _self.hotTable2 = new Handsontable(container, {
  236. // data: datas,
  237. // rowHeaders: false,
  238. // colHeaders: ['资产名称', '资产编号', '规格型号', '部门编号'],
  239. // stretchH: 'all',
  240. // columnHeaderHeight: 36,
  241. // rowHeights: 36,
  242. // columns: [{
  243. // data: 'name',
  244. // type: 'text',
  245. // }, {
  246. // data: 'assetNo',
  247. // type: 'text',
  248. // }, {
  249. // data: 'type',
  250. // type: 'text',
  251. // }, {
  252. // data: 'organizationName',
  253. // type: 'text',
  254. // }],
  255. // });
  256. }
  257. },
  258. },
  259. };
  260. </script>
  261. <style scoped>
  262. .noMargin {
  263. margin: 0 !important;
  264. }
  265. .div-content {
  266. margin: 15px 0px;
  267. }
  268. .sync-base-btn {
  269. margin-bottom: 10px;
  270. }
  271. .table-box {
  272. max-height: 500px;
  273. overflow: auto;
  274. margin-bottom: 15px;
  275. }
  276. td {
  277. text-align: center;
  278. }
  279. .span-refresh {
  280. margin: 10px 0px 0px 10px;
  281. }
  282. .div-content {
  283. margin-top: 10px;
  284. }
  285. </style>