pm_main.js 36 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138
  1. /**
  2. * 项目管理相关js
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/8/22
  6. * @version
  7. */
  8. let Tree = null;
  9. let movetoZTree = null;
  10. let copytoZTree = null;
  11. let engineering = [];
  12. let feeRateData = [];
  13. let isSaving = false;
  14. let projectProperty = [];
  15. let projectType = {
  16. folder: 'Folder',
  17. tender: 'Tender',
  18. project: 'Project',
  19. engineering: 'Engineering'
  20. };
  21. let ProjTreeSetting = {
  22. tree: {
  23. id: 'ID',
  24. pid: 'ParentID',
  25. nid: 'NextSiblingID',
  26. btnColumn: 1,
  27. nullId: -1
  28. },
  29. columns: [
  30. {
  31. head: '',
  32. data: '',
  33. width: '40',
  34. event: {}
  35. },
  36. {
  37. head: '工程列表',
  38. data: 'name',
  39. width: '78%',
  40. event: {
  41. getText: function (html, node, text) {
  42. let className = '';
  43. let aClassName = '';
  44. switch (node.data.projType) {
  45. case projectType.folder:
  46. className = "fa fa-folder-open-o";
  47. break;
  48. case projectType.tender:
  49. className = "fa fa-sticky-note-o";
  50. break;
  51. case projectType.project:
  52. className = "fa fa-cubes";
  53. aClassName = "open-sidebar";
  54. break;
  55. case projectType.engineering:
  56. className = "fa fa-cube";
  57. aClassName = "open-sidebar";
  58. break;
  59. }
  60. let icon = '<i class ="tree-icon '+ className +'"></i>';
  61. html.push((node && node.data && node.data.projType === projectType.folder) ? '&nbsp;' : '');
  62. html.push('<a ');
  63. if (aClassName !== '') {
  64. html.push('class="'+ aClassName +'" ');
  65. }
  66. if (node && node.data) {
  67. //html.push('href="/main?project=', node.id(), '"');
  68. html.push('href="javacript:void(0);"');
  69. }
  70. html.push('>', icon, '&nbsp;', text, '<a>');
  71. },
  72. getIcon: function (html, node) {
  73. if (node.data.projType === projectType.tender) {
  74. html.push('<span class="poj-icon">└</span>');
  75. }
  76. },
  77. tdBindEvent: function (td, node) {
  78. if (node.data.projType === projectType.tender) {
  79. $('a:eq(1)', td).bind('click', function () {
  80. BeforeOpenProject(node.id(), {'fullFolder': GetFullFolder(node.parent)}, function () {
  81. window.location.href = '/main?project=' + node.id();
  82. });
  83. return false;
  84. });
  85. }
  86. }
  87. }
  88. },
  89. {
  90. head: '最近使用',
  91. data: 'lastDateTime',
  92. width: '10%',
  93. event: {
  94. getText: function (html, node, text) {
  95. if (node.data.projType === projectType.tender) {
  96. html.push(text ? new Date(text).Format('yyyy-MM-dd') : '');
  97. }
  98. }
  99. }
  100. },
  101. {
  102. head: '创建日期',
  103. data: 'createDateTime',
  104. width: '10%',
  105. event: {
  106. getText: function (html, node, text) {
  107. if (node.data.projType === projectType.tender) {
  108. html.push(text ? new Date(text).Format('yyyy-MM-dd') : '');
  109. }
  110. }
  111. }
  112. }
  113. ],
  114. viewEvent: {
  115. beforeSelect: function (node) {
  116. if (node && node.row) {
  117. $('td:eq(0)', node.row).children().remove();
  118. }
  119. },
  120. onSelectNode: function (node) {
  121. $(".tools-btn > a").not(".disabled").addClass("disabled");
  122. switch(node.data.projType) {
  123. case projectType.project:
  124. $("#add-engineering-btn").removeClass("disabled");
  125. $("#add-project-btn").removeClass("disabled");
  126. break;
  127. case projectType.folder:
  128. $("#add-folder-btn").removeClass("disabled");
  129. $("#add-project-btn").removeClass("disabled");
  130. break;
  131. case projectType.engineering:
  132. $("#add-tender-btn").removeClass("disabled");
  133. $("#add-engineering-btn").removeClass("disabled");
  134. break;
  135. case projectType.tender:
  136. $("#add-tender-btn").removeClass("disabled");
  137. $("#move-to-btn").removeClass("disabled");
  138. $("#copy-to-btn").removeClass("disabled");
  139. $("#share-btn").removeClass("disabled");
  140. $("#cooperate-btn").removeClass("disabled");
  141. break;
  142. }
  143. $("#del-btn").removeClass("disabled");
  144. $("#rename-btn").removeClass("disabled");
  145. $('td:eq(0)', node.row).append($('<i class="fa fa-sort" data-toggle="tooltip" data-placement="top" title="长安拖动"></i>'));
  146. }
  147. }
  148. };
  149. $(document).ready(function() {
  150. init();
  151. // 侧滑数据
  152. $(".poj-list").on('click', ".open-sidebar", function() {
  153. setDataToSideBar();
  154. $(".slide-sidebar").animate({width:"800"}).addClass("open");
  155. });
  156. // 新增建设项目点击
  157. $('#add-project-btn').click(function () {
  158. let selectedItem = Tree.selected();
  159. try {
  160. let selectedType = selectedItem !== null && selectedItem.data !== undefined ?
  161. selectedItem.data.projType : projectType.folder;
  162. if (selectedType !== projectType.folder && selectedType !== projectType.project) {
  163. throw '建设项目只能添加到最外层或文件夹中';
  164. }
  165. $('#add-project-dialog').modal('show');
  166. } catch (error) {
  167. alert(error);
  168. }
  169. });
  170. // 新增建设项目操作
  171. $('#addProjOk').click(function () {
  172. AddProject();
  173. });
  174. // 选择计价方式
  175. $("input[name='valuation_type']").click(function() {
  176. let type = $(this).val();
  177. let targetData = type === 'bill' ? JSON.parse(billValuation) : JSON.parse(rationValuation);
  178. let html = '<option value="">请选择计划规则</option>';
  179. for(let valuation of targetData) {
  180. if (valuation === null) {
  181. continue;
  182. }
  183. html += '<option value="'+ valuation._id +'">'+ valuation.name +'</option>';
  184. }
  185. $("#valuation").html(html);
  186. });
  187. // 新增单项项目点击
  188. $("#add-engineering-btn").click(function() {
  189. let selectedItem = Tree.selected();
  190. try {
  191. if (selectedItem === null) {
  192. throw '请选择要添加到的项目工程';
  193. }
  194. let selectedType = selectedItem.data !== undefined ? selectedItem.data.projType : '';
  195. if (selectedType !== projectType.project && selectedType !== projectType.engineering) {
  196. throw '单项项目只能添加到建设项目中';
  197. }
  198. $("#add-engineering-dialog").modal("show");
  199. } catch (error) {
  200. alert(error);
  201. }
  202. });
  203. // 新增单项工程操作
  204. $("#add-engineering-confirm").click(function() {
  205. AddEngineering();
  206. });
  207. // 新增单位工程点击
  208. $("#add-tender-btn").click(function() {
  209. let selectedItem = Tree.selected();
  210. try {
  211. if (selectedItem === null) {
  212. throw '请选择要添加到的单项工程';
  213. }
  214. let selectedType = selectedItem.data !== undefined ? selectedItem.data.projType : '';
  215. if (selectedType !== projectType.engineering && selectedType !== projectType.tender) {
  216. throw '单项项目只能添加到单项工程中';
  217. }
  218. $("#add-tender-dialog").modal("show");
  219. } catch (error) {
  220. alert(error);
  221. }
  222. });
  223. // 新增单位工程弹层改变
  224. $('#add-tender-dialog').on('show.bs.modal', function() {
  225. // 当前选中的建设项目
  226. let selectedItem = Tree.selected();
  227. let projectInfo = null;
  228. if (selectedItem.data.projType === projectType.tender) {
  229. projectInfo = selectedItem !== null && selectedItem.parent !== undefined && selectedItem.parent.parent !== undefined ?
  230. selectedItem.parent.parent : null;
  231. } else {
  232. projectInfo = selectedItem !== null && selectedItem.parent !== undefined ? selectedItem.parent : null;
  233. }
  234. if (projectInfo !== null) {
  235. let parentID = projectInfo.data.ID;
  236. // 获取当前的数据属性
  237. getProperty(projectInfo.data);
  238. }
  239. // 获取单价文件数据
  240. getUnitFile(projectInfo.data.ID);
  241. });
  242. // 新增单位工程
  243. $("#add-tender-confirm").click(function() {
  244. AddTender();
  245. });
  246. // 新增文件夹按钮点击
  247. $("#add-folder-btn").click(function() {
  248. let selectedItem = Tree.selected();
  249. try {
  250. let selectedType = selectedItem !== null && selectedItem.data !== undefined ?
  251. selectedItem.data.projType : projectType.folder;
  252. if (selectedType !== projectType.folder) {
  253. throw '文件夹只能添加在最外层或者添加在文件夹中';
  254. }
  255. $("#add-folder-dialog").modal("show");
  256. } catch (error) {
  257. alert(error);
  258. }
  259. });
  260. // 新增文件夹操作
  261. $("#add-folder-confirm").click(function() {
  262. AddFolder();
  263. });
  264. // 删除按钮点击
  265. $('#del-btn').click(function() {
  266. if (Tree && Tree.selected()) {
  267. $('#del').modal('show');
  268. }
  269. });
  270. // 删除时文字替换
  271. $('#del').on('show.bs.modal', function() {
  272. let hasTenderChild = function (children) {
  273. for (let i = 0; i < children.length; i++) {
  274. if (children[i].children.length === 0) {
  275. if (children[i].data.projType === 'Tender') {
  276. return true;
  277. }
  278. } else if (hasTenderChild(children[i].children)) {
  279. return true;
  280. }
  281. }
  282. return false;
  283. };
  284. // 显示内容
  285. let tenderHintElement = $('#tenderHint');
  286. let folderHintElement = $('#folderHint');
  287. if (Tree.selected().children.length === 0) {
  288. tenderHintElement.show();
  289. tenderHintElement.text('删除 "' + Tree.selected().data.name +'" ?');
  290. folderHintElement.hide();
  291. } else {
  292. tenderHintElement.hide();
  293. folderHintElement.show();
  294. folderHintElement.text('删除 "'+ Tree.selected().data.name +'" 以及它包含的子项?');
  295. }
  296. // 显示是否可以找回
  297. if (hasTenderChild([Tree.selected()])) {
  298. $('#restoreHint').show();
  299. } else {
  300. $('#restoreHint').hide();
  301. }
  302. });
  303. // 删除操作
  304. $('#delete-confirm').click(function () {
  305. let updateData = null;
  306. let dialog = $('#del');
  307. if (Tree) {
  308. updateData = GetDeleteUpdateData(Tree.selected());
  309. UpdateProjectData(updateData, function () {
  310. dialog.modal('hide');
  311. Tree.removeNode(Tree.selected());
  312. });
  313. }
  314. });
  315. // 重命名按钮点击
  316. $('#rename-btn').click(function() {
  317. if (!Tree) {
  318. return false;
  319. }
  320. if (!Tree.selected()) {
  321. alert('请选择需要重命名的数据');
  322. return false;
  323. }
  324. $('#rename-dialog').modal('show');
  325. });
  326. // 重命名操作
  327. $("#rename-confirm").click(function() {
  328. let select = Tree.selected();
  329. let newName = $('#rename-name').val();
  330. let dialog = $('#rename-dialog');
  331. if (newName === '') {
  332. alert('请输入重命名的名称');
  333. return false;
  334. }
  335. if (newName === select.data.name) {
  336. dialog.modal('hide');
  337. return false;
  338. }
  339. RenameProject(select.id(), newName, select.data.ParentID, function () {
  340. dialog.modal('hide');
  341. select.data.name = newName;
  342. Tree.refreshNodesDom([select]);
  343. });
  344. });
  345. // 移动到按钮点击
  346. $('#move-to-btn').click(function () {
  347. if (Tree && Tree.selected()) {
  348. $('#move-to-dialog').modal('show');
  349. }
  350. });
  351. // 移动到窗口内容重组
  352. $('#move-to-dialog').on('show.bs.modal', function () {
  353. movetoZTree = ConvertTreeToZtree(Tree, $('#treeDemo'), Tree.selected());
  354. });
  355. // 移动到操作
  356. $('#move-to-confirm').click(function () {
  357. console.log(111);
  358. let updateData = null;
  359. let dialog = $('#move-to-dialog');
  360. let target = GetTargetTreeNode($.fn.zTree.getZTreeObj('treeDemo'));
  361. let cur = Tree.selected();
  362. if (!target) {
  363. dialog.modal('hide');
  364. return false;
  365. }
  366. if (target.data.projType !== projectType.engineering) {
  367. alert("请移动到单项工程中!");
  368. return false;
  369. }
  370. // 判断同级是否有同名
  371. if (target.children.length > 0) {
  372. for (let tmp in target.children) {
  373. if (tmp === 0) {
  374. continue;
  375. }
  376. if (target.children[tmp].data.name === cur.data.name) {
  377. alert("对应单项工程中存在同名数据!");
  378. return false;
  379. }
  380. }
  381. }
  382. let parent = target;
  383. let next = target.firstChild();
  384. if (parent !== cur.parent || (next !== cur && next !== cur.nextSibling)){
  385. let typeInfo = {
  386. updateType: 'update',
  387. projectType: null
  388. };
  389. updateData = GetUpdateData(parent, next, '', null, Tree.selected().id(), typeInfo);
  390. UpdateProjectData(updateData, function (data) {
  391. dialog.modal('hide');
  392. Tree.move(Tree.selected(), parent, next);
  393. });
  394. } else {
  395. dialog.modal('hide');
  396. }
  397. });
  398. // 复制到按钮点击
  399. $('#copy-to-btn').click(function () {
  400. let selectedItem = Tree.selected();
  401. try {
  402. let selectedType = selectedItem !== null && selectedItem.data !== undefined ?
  403. selectedItem.data.projType : '';
  404. if (selectedType !== projectType.tender) {
  405. throw '请选择单位工程进行复制';
  406. }
  407. } catch (error) {
  408. alert(error);
  409. return false;
  410. }
  411. $('#copy-to-dialog').modal('show');
  412. });
  413. // 复制到弹层替换
  414. $('#copy-to-dialog').on('show.bs.modal', function () {
  415. copytoZTree = ConvertTreeToZtree(Tree, $('#treeDemo2'), null);
  416. });
  417. // 复制到操作
  418. $("#copy-to-confirm").click(function() {
  419. let dialog = $('#copy-to-dialog');
  420. let target = GetTargetTreeNode($.fn.zTree.getZTreeObj('treeDemo2'));
  421. let parent = null;
  422. let next = null;
  423. let pre = null;
  424. let cur = Tree.selected();
  425. if (!target) {
  426. return false;
  427. }
  428. if (target.data.projType !== projectType.engineering) {
  429. alert("请移动到单项工程中!");
  430. return false;
  431. }
  432. if (target.data.projType !== projectType.tender && target.children.length !== 0 &&
  433. target.firstChild().data.projType !== projectType.tender) {
  434. dialog.modal('hide');
  435. }
  436. // 判断同级是否有同名
  437. if (target.children.length > 0) {
  438. for (let tmp in target.children) {
  439. if (tmp === 0) {
  440. continue;
  441. }
  442. if (target.children[tmp].data.name === cur.data.name) {
  443. alert("对应单项工程中存在同名数据!");
  444. return false;
  445. }
  446. }
  447. }
  448. if (target.data.projType === projectType.tender) {
  449. parent = target.parent;
  450. next = target.nextSibling;
  451. } else {
  452. parent = target;
  453. next = target.firstChild();
  454. }
  455. if (parent !== cur.parent || (next !== cur && next !== cur.nextSibling)){
  456. CommonAjax.post('/pm/api/getNewProjectID', {count: 1, user_id: userID}, function (IDs) {
  457. let typeInfo = {
  458. updateType: 'copy',
  459. projType: cur.data.projectType
  460. };
  461. let updateData = GetUpdateData(parent, next, cur.data.name, cur.data.property, IDs.lowID, typeInfo);
  462. updateData['srcProjectId'] = cur.id();
  463. pre = GetNeedUpdatePreNode(parent, next);
  464. if (pre) {
  465. updateData = {};
  466. updateData['updateType'] = 'update';
  467. updateData['updateData'] = {};
  468. updateData['updateData'][Tree.setting.tree.id] = pre.id();
  469. updateData['updateData'][Tree.setting.tree.nid] = node.tree.maxNodeId() + 1;
  470. }
  471. Tree.maxNodeId(IDs.lowID - 1);
  472. CommonAjax.post('/pm/api/copyProjects', {updateData: updateData, user_id: userID}, function (data) {
  473. dialog.modal('hide');
  474. data.forEach(function (nodeData) {
  475. if (nodeData.updateType === 'copy') {
  476. Tree.addNodeData(nodeData.updateData, parent, next);
  477. }
  478. });
  479. }, function () {
  480. dialog.modal('hide');
  481. });
  482. });
  483. }
  484. });
  485. // 选择工程专业后动态更改费率文件等数据
  486. $("#tender-engineering").change(function() {
  487. if (projectProperty.engineeringList === undefined || projectProperty.engineeringList.length <= 0) {
  488. return false;
  489. }
  490. let selectedEngineering = $(this).val();
  491. selectedEngineering = parseInt(selectedEngineering);
  492. let currentLib = {};
  493. for(let engineering of projectProperty.engineeringList) {
  494. if (engineering.engineering === selectedEngineering) {
  495. currentLib = engineering.lib;
  496. }
  497. }
  498. if (Object.keys(currentLib).length <= 0) {
  499. return false;
  500. }
  501. // 输出数据到页面
  502. let feeHtml = '<option>请选择费率文件</option>';
  503. if (currentLib.fee_lib !== undefined && currentLib.fee_lib.length > 0) {
  504. for (let fee of currentLib.fee_lib) {
  505. feeHtml += '<option value="'+ fee.id +'">'+ fee.name +'</option>';
  506. }
  507. }
  508. $("#tender-fee-rate").html(feeHtml);
  509. $(this).parent().siblings('.hidden-area').slideDown('fast');
  510. });
  511. });
  512. /**
  513. * 初始化数据
  514. *
  515. * @return {void}
  516. */
  517. function init() {
  518. let table = $('#ProjTree');
  519. $('thead', table).remove();
  520. $('tbody', table).remove();
  521. GetAllProjectData(function (data) {
  522. Tree = $.fn.treeTable.init(table, ProjTreeSetting, data);
  523. });
  524. // 显示默认两个可选菜单
  525. $(".tools-btn > a").not(".disabled").addClass("disabled");
  526. $("#add-folder-btn").removeClass("disabled");
  527. $("#add-project-btn").removeClass("disabled");
  528. engineering = engineeringList !== null && engineeringList !== undefined ? JSON.parse(engineeringList) : [];
  529. }
  530. /**
  531. * 新增建设项目
  532. *
  533. * @return {boolean}
  534. */
  535. function AddProject() {
  536. let name = $('#project-name').val();
  537. if (name === '') {
  538. alert('请填写工程');
  539. return false;
  540. }
  541. let valuation = $("#valuation").val();
  542. if (valuation === '') {
  543. alert("请选择计价规则");
  544. return false;
  545. }
  546. let valuationName = $("#valuation").children("option:selected").text();
  547. let valuationType = $("input[name='valuation_type']:checked").val();
  548. let engineeringList = [];
  549. let valuationData = valuationType === 'bill' ? JSON.parse(billValuation) : JSON.parse(rationValuation);
  550. for(let tmp of valuationData) {
  551. if (tmp._id === valuation) {
  552. engineeringList = tmp.engineering_list;
  553. break;
  554. }
  555. }
  556. let projectInfo = {
  557. valuation: valuation,
  558. valuationType: valuationType,
  559. valuationName: valuationName,
  560. engineeringList: engineeringList
  561. };
  562. let callback = function() {
  563. $("#add-project-dialog").modal("hide");
  564. $("#project-name").val('');
  565. $("input[name='valuation_type']").removeAttr('checked');
  566. $("#valuation").children("option").not(":eq(0)").remove();
  567. };
  568. let selectedItem = Tree.selected();
  569. // 如果选择的是建设项目则新增同级数据
  570. if (selectedItem !== null && selectedItem.data.projType === projectType.project) {
  571. AddSiblingsItem(name, projectInfo, projectType.project, callback);
  572. } else {
  573. AddChildrenItem(name, projectInfo, projectType.project, callback);
  574. }
  575. }
  576. /**
  577. * 新增子元素
  578. *
  579. * @param {String} name
  580. * @param {String} type
  581. * @param {function} callback
  582. * @return {void}
  583. */
  584. function AddChildrenItem(name, property, type, callback) {
  585. let parent = Tree.selected() ? Tree.selected() : Tree._root;
  586. let next = Tree.selected() ? Tree.selected().firstChild() : Tree.firstNode();
  587. GetNewProjectId(function(IDs) {
  588. let typeInfo = {
  589. updateType: 'new',
  590. projectType: type
  591. };
  592. let updateData = GetUpdateData(parent, next, name, property, IDs.lowID, typeInfo);
  593. Tree.maxNodeId(IDs.lowID - 1);
  594. UpdateProjectData(updateData, function(datas){
  595. datas.forEach(function (data) {
  596. if (data.updateType === 'new') {
  597. Tree.addNodeData(data.updateData, parent, next);
  598. }
  599. });
  600. callback();
  601. });
  602. });
  603. }
  604. /**
  605. * 新增同级元素
  606. *
  607. * @param {String} name
  608. * @param {String} type
  609. * @param {function} callback
  610. * @return {void}
  611. */
  612. function AddSiblingsItem(name, property, type, callback) {
  613. let selected = Tree.selected();
  614. let parent = selected ? selected.parent : Tree._root;
  615. let next = selected ? selected.nextSibling : Tree.firstNode();
  616. GetNewProjectId(function(IDs) {
  617. let typeInfo = {
  618. updateType: 'new',
  619. projectType: type
  620. };
  621. let updateData = GetUpdateData(parent, next, name, property, IDs.lowID, typeInfo);
  622. Tree.maxNodeId(IDs.lowID - 1);
  623. UpdateProjectData(updateData, function(datas){
  624. datas.forEach(function (data) {
  625. if (data.updateType === 'new') {
  626. Tree.addNodeData(data.updateData, parent, next);
  627. }
  628. });
  629. callback();
  630. });
  631. });
  632. }
  633. /**
  634. * 新增单项工程
  635. *
  636. * @return {boolean}
  637. */
  638. function AddEngineering() {
  639. let name = $('#engineering-name').val();
  640. if (name === '') {
  641. alert('请填写单项工程名称');
  642. return false;
  643. }
  644. let callback = function() {
  645. $("#add-engineering-dialog").modal("hide");
  646. $("#engineering-name").val('');
  647. };
  648. let selectedItem = Tree.selected();
  649. // 如果选择的是单项工程则新增同级数据
  650. if (selectedItem !== null && selectedItem.data.projType === projectType.engineering) {
  651. AddSiblingsItem(name, null, projectType.engineering, callback);
  652. } else {
  653. AddChildrenItem(name, null, projectType.engineering, callback);
  654. }
  655. }
  656. /**
  657. * 新增单位工程
  658. *
  659. * @return {boolean}
  660. */
  661. function AddTender() {
  662. try {
  663. let name = $('#tender-name').val();
  664. if (name === '') {
  665. throw '请填写单位工程名称';
  666. }
  667. let engineering = $("#tender-engineering").val();
  668. if (engineering === '') {
  669. throw '请选择工程专业';
  670. }
  671. let unitPriceFile = $("#unit-price").val();
  672. let feeFile = $("#tender-fee-rate").val();
  673. if (feeFile === '') {
  674. throw '请选择费率文件';
  675. }
  676. let valuation = $("#tender-valuation").val();
  677. let valuationName = $("#tender-valuation").children("option:selected").text();
  678. let valuationType = $("input[name='tender_valuation_type']:checked").val();
  679. let engineering_id = undefined;
  680. let valuationData = valuationType === 'bill' ? JSON.parse(billValuation) : JSON.parse(rationValuation);
  681. let engineeringList = [];
  682. for(let tmp of valuationData) {
  683. if (tmp._id === valuation) {
  684. engineeringList = tmp.engineering_list;
  685. break;
  686. }
  687. }
  688. for(let tmp of engineeringList) {
  689. if (tmp.engineering == engineering) {
  690. engineering_id = tmp.engineering_id;
  691. break;
  692. }
  693. }
  694. let engineeringName = $('#tender-engineering').children("option:selected").text();
  695. let callback = function() {
  696. $("#add-tender-dialog").modal("hide");
  697. $('#tender-name').val('');
  698. $("#tender-fee-rate").children("option").removeAttr("selected");
  699. $("#tender-engineering").children("option").removeAttr("selected");
  700. $(".hidden-area").hide();
  701. };
  702. let selectedItem = Tree.selected();
  703. let tenderInfo = {
  704. valuation: valuation,
  705. valuationType: valuationType,
  706. valuationName: valuationName,
  707. engineering: engineering,
  708. engineering_id: engineering_id,
  709. engineeringName: engineeringName,
  710. unitPriceFile: unitPriceFile,
  711. feeFile: feeFile
  712. };
  713. // 如果选择的是单项工程则新增同级数据
  714. if (selectedItem !== null && selectedItem.data.projType === projectType.tender) {
  715. AddSiblingsItem(name, tenderInfo, projectType.tender, callback);
  716. } else {
  717. AddChildrenItem(name, tenderInfo, projectType.tender, callback);
  718. }
  719. } catch (error) {
  720. alert(error);
  721. }
  722. }
  723. /**
  724. * 新增文件夹
  725. *
  726. * @return {boolean}
  727. */
  728. function AddFolder() {
  729. let name = $('#folder-name').val();
  730. if (name === '') {
  731. alert('请填写文件夹名称');
  732. return false;
  733. }
  734. let selectedItem = Tree.selected();
  735. let callback = function() {
  736. $("#add-folder-dialog").modal("hide");
  737. $("#folder-name").val('');
  738. };
  739. if (selectedItem !== null) {
  740. // 判断是否超过3层
  741. if (selectedItem.parent !== null && selectedItem.parent.parent !== null &&
  742. selectedItem.parent.parent.parent !== null) {
  743. alert("文件夹不能超过3层");
  744. return false;
  745. }
  746. AddChildrenItem(name, null, projectType.folder, callback);
  747. } else {
  748. AddSiblingsItem(name, null, projectType.folder, callback);
  749. }
  750. }
  751. /**
  752. * 组织更新数据
  753. *
  754. * @param {Object} parent
  755. * @param {Object} next
  756. * @param {String} name
  757. * @param {Object} type
  758. * @return {Object}
  759. */
  760. function GetUpdateData(parent, next, name, property, newId, type) {
  761. let data = [];
  762. let updateData = {};
  763. updateData['updateType'] = type.updateType === undefined ? 'new' : type.updateType;
  764. updateData['updateData'] = {};
  765. if (newId !== '') {
  766. updateData['updateData'][Tree.setting.tree.id] = newId;
  767. }
  768. updateData['updateData'][Tree.setting.tree.pid] = parent ? parent.id() : -1;
  769. updateData['updateData'][Tree.setting.tree.nid] = next ? next.id() : -1;
  770. if (name !== '') {
  771. updateData['updateData']['name'] = name;
  772. }
  773. if (property !== undefined) {
  774. updateData['updateData']['property'] = property;
  775. }
  776. if (type !== null && type.projectType !== null) {
  777. updateData['updateData']['projType'] = type.projectType !== undefined ? type.projectType : 'Tender';
  778. }
  779. data.push(updateData);
  780. return data;
  781. }
  782. /**
  783. * 获取删除数据
  784. *
  785. * @return {Object} node
  786. * @return {Object}
  787. */
  788. function GetDeleteUpdateData(node) {
  789. let datas = [], updateData,
  790. pre = node.preSibling(),
  791. deleteNodeData = function (node) {
  792. var data = {};
  793. data['updateType'] = 'delete';
  794. data['updateData'] = {};
  795. data['updateData'][Tree.setting.tree.id] = node.id();
  796. if (node.data.projType === 'Tender') {
  797. data['updateData']['FullFolder'] = GetFullFolder(node.parent);
  798. }
  799. return data;
  800. },
  801. addDeleteChildren = function (children) {
  802. children.forEach(function(child){
  803. datas.push(deleteNodeData(child));
  804. addDeleteChildren(child.children);
  805. });
  806. };
  807. if (pre && pre.id() !== -1) {
  808. updateData = {};
  809. updateData['updateType'] = 'update';
  810. updateData['updateData'] = {};
  811. updateData['updateData'][Tree.setting.tree.id] = pre.id();
  812. updateData['updateData'][Tree.setting.tree.nid] = node ? node.nid() : -1;
  813. datas.push(updateData);
  814. }
  815. datas.push(deleteNodeData(node));
  816. addDeleteChildren(node.children);
  817. return datas;
  818. };
  819. /**
  820. * 获取父级所有名称
  821. *
  822. * @return {Array}
  823. */
  824. function GetFullFolder (node) {
  825. let fullFolder = [];
  826. let cur = node;
  827. while (cur && cur.data) {
  828. fullFolder.unshift(cur.data.name);
  829. cur = cur.parent;
  830. }
  831. return fullFolder;
  832. }
  833. /**
  834. * 获取需要更新的前节点
  835. *
  836. * @param {Object} parent
  837. * @param {Object} next
  838. * @return {Object}
  839. */
  840. function GetNeedUpdatePreNode(parent, next) {
  841. if (next) {
  842. return next.preSibling();
  843. } else if (parent) {
  844. return parent.firstChild();
  845. } else {
  846. return null;
  847. }
  848. }
  849. /**
  850. * 获取最新id
  851. *
  852. * @param {function} callback
  853. * @return {void}
  854. */
  855. function GetNewProjectId(callback) {
  856. CommonAjax.post('/pm/api/getNewProjectID', {count: 1}, function(data) {
  857. callback(data);
  858. });
  859. }
  860. /**
  861. * 重命名项目
  862. *
  863. * @param {Number} projectId
  864. * @param {String} newName
  865. * @param {Number} parentID
  866. * @param {function} callback
  867. * @return {void}
  868. */
  869. function RenameProject(projectId, newName, parentID, callback) {
  870. $.ajax({
  871. type: "POST",
  872. url: '/pm/api/renameProject',
  873. data: {'data': JSON.stringify({"user_id": userID, "id": projectId, "newName": newName, "parentID": parentID})},
  874. dataType: 'json',
  875. cache: false,
  876. timeout: 5000,
  877. success: function(result){
  878. if (result.error === 0) {
  879. callback();
  880. } else {
  881. alert('error' + result.message);
  882. }
  883. },
  884. error: function(iqXHR, textStatus, errorThrown){
  885. alert('error ' + textStatus + " " + errorThrown)
  886. }
  887. });
  888. }
  889. /**
  890. * 转换当前树结构为zTree结构
  891. *
  892. * @param {Object} Tree
  893. * @param {Object} zTreeObj
  894. * @param {Object} filterNode
  895. * @return {Mixed}
  896. */
  897. function ConvertTreeToZtree(Tree, zTreeObj, filterNode) {
  898. let setting = {
  899. data: {
  900. simpleData: {
  901. enable:true,
  902. idKey: "id",
  903. pIdKey: "pId",
  904. rootPId: "-1"
  905. }
  906. }};
  907. let zTreeData = [],
  908. exportNodesData = function (nodes) {
  909. nodes.forEach(function (node) {
  910. if (node !== filterNode) {
  911. var data = {};
  912. data['id'] = node.data[Tree.setting.tree.id];
  913. data['pId'] = node.pid();
  914. data['name'] = node.data['name'];
  915. data['isParent'] = node.data.projType === 'Folder';//(node.data.projType === 'Folder' && node.children.length === 0);
  916. data['open'] = node.data.projType === 'Folder';//node.children.length !== 0;
  917. zTreeData.push(data);
  918. exportNodesData(node.children);
  919. }
  920. })
  921. };
  922. exportNodesData(Tree._root.children);
  923. return $.fn.zTree.init(zTreeObj, setting, zTreeData);
  924. }
  925. /**
  926. * 获取指定zTree节点
  927. *
  928. * @param {Object} zTreeObj
  929. * @return {object}
  930. */
  931. function GetTargetTreeNode(zTreeObj) {
  932. if (!zTreeObj || !Tree) {
  933. return null;
  934. }
  935. let ztree_selected = zTreeObj.getSelectedNodes().length === 0 ? null : zTreeObj.getSelectedNodes()[0];
  936. return ztree_selected ? Tree.findNode(ztree_selected.id) : null;
  937. }
  938. /**
  939. * 根据指定id获取对应的工程专业
  940. *
  941. * @param {Array} engineeringList
  942. * @return {String}
  943. */
  944. function getEngineeringHtml(engineeringList) {
  945. let result = '<option>请选择对应的工程专业</option>';
  946. if (engineeringList.length <= 0) {
  947. return result;
  948. }
  949. let engineeringObject = {};
  950. for(let tmp of engineering) {
  951. engineeringObject[tmp.value] = tmp.name;
  952. }
  953. for(let tmp of engineeringList) {
  954. if (engineeringObject[tmp.engineering] !== undefined) {
  955. result += '<option value="'+ tmp.engineering +'">'+ engineeringObject[tmp.engineering] +'</option>';
  956. }
  957. }
  958. return result;
  959. }
  960. /**
  961. * 远程获取项目属性数据
  962. *
  963. * @param {Object} projectInfo
  964. * @return {void}
  965. */
  966. function getProperty(projectInfo) {
  967. if (projectInfo.property === undefined) {
  968. return;
  969. }
  970. projectProperty = projectInfo.property;
  971. // 写入专业工程相关
  972. let engineeringHtml = getEngineeringHtml(projectProperty.engineeringList);
  973. $("#tender-engineering").html(engineeringHtml);
  974. // 填入计价规则
  975. let valuationHtml = '<option value="'+ projectProperty.valuation +'">'+ projectProperty.valuationName +'</option>';
  976. $("#tender-valuation").html(valuationHtml);
  977. // 选中计价方式
  978. $("input[name='tender_valuation_type']").attr('disabled', 'disabled').removeAttr('checked', 'checked');
  979. $("input[name='tender_valuation_type'][value='"+ projectProperty.valuationType +"']")
  980. .attr("checked", "checked").removeAttr('disabled', 'disabled');
  981. }
  982. /**
  983. * 获取单价文件
  984. *
  985. * @param {Number} parentID
  986. * @return {void}
  987. */
  988. function getUnitFile(parentID) {
  989. parentID = parseInt(parentID);
  990. if (isNaN(parentID) && parentID <= 0) {
  991. return;
  992. }
  993. $.ajax({
  994. url: '/pm/api/getUnitFile',
  995. type: 'post',
  996. data: {'data': JSON.stringify({"user_id": userID, "parentID": parentID})},
  997. dataType: 'json',
  998. error: function() {
  999. alert('数据传输错误!');
  1000. },
  1001. beforeSend: function() {
  1002. },
  1003. success: function(response) {
  1004. if (response.error === 1) {
  1005. alert('获取失败!');
  1006. } else {
  1007. if (response.data.length <= 0) {
  1008. return false;
  1009. }
  1010. let unitFileHtml = '';
  1011. for(let tmp of response.data) {
  1012. unitFileHtml += '<option value="'+ tmp.id +'">'+ tmp.name +'</option>';
  1013. }
  1014. $("#unit-price").children("option").first().after(unitFileHtml);
  1015. }
  1016. }
  1017. });
  1018. }
  1019. /**
  1020. * 加载数据到侧边栏
  1021. *
  1022. * @return {void}
  1023. */
  1024. function setDataToSideBar() {
  1025. // 获取当前点击的数据
  1026. let selectedItem = Tree.selected();
  1027. let name = selectedItem.data.name;
  1028. let target = selectedItem.data.projType === projectType.project ? '#summary-project' : '#summary-engineering';
  1029. $(".side-content .p-3").hide();
  1030. $(target).show();
  1031. $(target + '-name').html(name);
  1032. if (selectedItem.children.length <= 0) {
  1033. return;
  1034. }
  1035. // 建设项目相关
  1036. let counter = 1;
  1037. let html = '';
  1038. for(let tmp of selectedItem.children) {
  1039. html += '<tr>' +
  1040. '<td>'+ counter +'</td>' +
  1041. '<td>'+ counter +'</td>' +
  1042. '<td>'+ tmp.data.name +'</td>' +
  1043. '<td></td>' +
  1044. '<td></td>' +
  1045. '<td></td>' +
  1046. '<td></td>' +
  1047. '</tr>';
  1048. }
  1049. html += '<tr>' +
  1050. '<td>'+ (counter + 1) +'</td>' +
  1051. '<td> </td>' +
  1052. '<td>合计</td>' +
  1053. '<td></td>' +
  1054. '<td></td>' +
  1055. '<td></td>' +
  1056. '<td></td>' +
  1057. '</tr>';
  1058. $(target + '-table tbody').html(html);
  1059. }