project_info.js 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /**
  2. * Created by Mai on 2017/6/21.
  3. */
  4. var projectInfoObj = {
  5. // 头部同时编辑的用户头像
  6. handleAvatarList: function (users) {
  7. const opener = projectObj.project.projectInfo.opener;
  8. if (opener) {
  9. users = users.filter(user => user._id !== opener._id);
  10. }
  11. const avatarListHtml = users.reduce((acc, user) => {
  12. const avatarSpan = SHARE_TO.getAvatarHTML(user.mobile, user.real_name);
  13. const li =
  14. `<li data-toggle="tooltip" data-placement="bottom" title="${user.real_name}" data-original-title="${user.real_name}">
  15. ${avatarSpan}
  16. </li>`
  17. return acc += li;
  18. }, '');
  19. $('#avatar-list').html(avatarListHtml);
  20. $('#avatar-list [data-toggle="tooltip"]').tooltip();
  21. },
  22. getReceiveInfo: function (projectReadOnly, projectCooperate, owner) {
  23. if (!projectReadOnly && !projectCooperate) {
  24. return '';
  25. }
  26. const action = projectCooperate ? '可编辑' : '只能查看';
  27. const ownerName = owner && owner.real_name || '';
  28. const dropdownMenu = allowCopy?`
  29. <div class="dropdown-menu" style="left:auto;">
  30. <a class="dropdown-item btn-sm" href="#copyShare" data-toggle="modal">拷贝工程</a>
  31. </div>`:"";
  32. return `
  33. <span class="pl-2" data-toggle="tooltip" data-placement="left" title="" data-original-title="来自 ${ownerName} 的分享">
  34. <a href="javascript:void(0);" ${allowCopy?'data-toggle="dropdown"':''} class="btn btn-xs btn-primary default-cursor ${allowCopy?'dropdown-toggle':''} " ><i class="fa fa-share-alt"></i> ${action}</a>
  35. ${dropdownMenu}
  36. </span> `;
  37. },
  38. getShareButton: function (projectReadOnly, projectCooperate, shareTip) {
  39. if (projectReadOnly || projectCooperate) {
  40. return '';
  41. }
  42. return `
  43. <span id="share-tip" class="ml-2" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="${shareTip}">
  44. <a id="init-share" href="javascript:;" class="btn btn-xs btn-primary"><i class="fa fa-share-alt"></i> 分享</a>
  45. </span>`;
  46. },
  47. getFullPathHtml: function (proj) {
  48. let fullPath = [], i, pm = '<span class="text-truncate"><a href="/pm">项目管理</a></span>', angleRight = '<span class="text-truncate"><i class="fa fa-angle-right fa-fw"></i></span>';
  49. if (proj) {
  50. let pathArr = proj.fullPath;
  51. let engName = pathArr[pathArr.length - 2] || '',
  52. projectName = pathArr[pathArr.length - 3] || '',
  53. folderName = pathArr[pathArr.length - 4] || '';
  54. const receiveInfo = this.getReceiveInfo(projectReadOnly, projectCooperate, proj.owner);
  55. const shareButton = this.getShareButton(projectReadOnly, projectCooperate, proj.shareTip);
  56. let newHtml = ` <span data-toggle="tooltip" data-placement="bottom" data-original-title="${folderName}"><i class="fa fa-folder-open-o"></i>...</span>
  57. <span class="text-muted px-1">\</span>
  58. <span data-toggle="tooltip" data-placement="bottom" data-original-title="${projectName}"><i class="fa fa-cubes"></i>...</span>
  59. <span class="text-muted px-1">\</span>
  60. <span data-toggle="tooltip" data-placement="bottom" data-original-title="${engName}"><i class="fa fa-cube"></i>...</span>
  61. <span class="text-muted px-1">\</span>
  62. <span><i class="fa fa-sticky-note-o"></i></span>
  63. <span class="text-truncate" data-toggle="tooltip" data-placement="bottom" data-original-title="${proj.name}">&nbsp;${proj.name}</span>
  64. ${receiveInfo}${shareButton}
  65. <span>
  66. <ul class="avatar-list mb-0" id="avatar-list">
  67. </ul>
  68. </span>
  69. `;
  70. fullPath.push(newHtml);
  71. fullPath.push(`<input id="rootProjectName" value="${projectName}" type="hidden">`);
  72. }
  73. return fullPath.join('');
  74. },
  75. showProjectInfo: function (data) {
  76. if (data) {
  77. $('#tzCharacterText').prop('readonly', projectObj.project.projectInfo.property.lockBills);
  78. // 清单子界面的模块:清单指引、清单精灵
  79. for (let billsGuidanceLib of data.engineeringInfo.billsGuidance_lib) {
  80. BillsSub.switchModule(billsGuidanceLib.type);
  81. }
  82. //init decimal
  83. setDecimal(decimalObj, data.property.decimal);
  84. billsQuanDecimal.datas = data.property.billsQuantityDecimal || [billsDecimalView.angleDecimal];
  85. basicInfoView.orgDatas = data.property.basicInformation ? basicInfoView.toViewDatas(data.property.basicInformation) : [];
  86. projFeatureView.orgDatas = data.property.projectFeature ? projFeatureView.toViewDatas(data.property.projectFeature) : [];
  87. $('#fullpath').html(this.getFullPathHtml(data));
  88. // 分享给
  89. $('#init-share').click(() => {
  90. SHARE_TO.initModal(SHARE_TO.Mode.PROJECT, projectObj.project.ID());
  91. $('#share-tip').tooltip('hide');
  92. });
  93. SHARE_TO.handleEventListener();
  94. $("[data-toggle='tooltip']").tooltip();
  95. }
  96. }
  97. };