Decision4.vue 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. <template>
  2. <div class="decision-page-4">
  3. <div class="query mg-b-8">
  4. <div class="query-items">
  5. <div class="query-item">
  6. <div class="lable">开始日期:</div>
  7. <div class="search-input">
  8. <el-date-picker v-model="value4" @change="BeginChange(value4)" type="date"
  9. value-format="YYYY-MM-DD" placeholder="选择日期" popper-class="date-select">
  10. </el-date-picker>
  11. </div>
  12. </div>
  13. <div class="query-item">
  14. <div class="lable">结束日期:</div>
  15. <div class="search-input">
  16. <el-date-picker v-model="value5" @change="EndChange(value5)" type="date"
  17. value-format="YYYY-MM-DD" placeholder="选择日期" popper-class="date-select">
  18. </el-date-picker>
  19. <div class="unit svg-icon svg-icon-gray">
  20. <svg-icon :svgid="''" />
  21. </div>
  22. </div>
  23. </div>
  24. </div>
  25. </div>
  26. <div class="mg-b-16">
  27. <div class="project-table">
  28. <Table :data="tableData"></Table>
  29. </div>
  30. </div>
  31. </div>
  32. </template>
  33. <script>
  34. import MultipleBarChart from "../../components/chart/bar/multiple-bar-chart.vue";
  35. import SvgIcon from "../../components/coms/icon/svg-icon.vue";
  36. import Panel from "../../components/coms/panel/panel.vue";
  37. import ToolbarPanel from "../../components/coms/panel/toolbar-panel.vue";
  38. import Table from "../../components/coms/table/table.vue";
  39. export default {
  40. components: {
  41. Panel,
  42. Table,
  43. SvgIcon,
  44. MultipleBarChart,
  45. ToolbarPanel
  46. },
  47. data() {
  48. return {
  49. tableData: {
  50. column: [{
  51. name: "",
  52. field: "index",
  53. is_num: false,
  54. is_light: false,
  55. },
  56. {
  57. name: "值际",
  58. field: "dutyname",
  59. is_num: false,
  60. is_light: false,
  61. },
  62. {
  63. name: "理论发电量",
  64. field: "theoreticalgeneratity",
  65. is_num: false,
  66. is_light: false,
  67. },
  68. {
  69. name: "实际发电量",
  70. field: "generatity",
  71. is_num: false,
  72. is_light: false,
  73. },
  74. {
  75. name: "故障损失",
  76. field: "faultloss",
  77. is_num: false,
  78. is_light: false,
  79. },
  80. {
  81. name: "维护损失",
  82. field: "mainloss",
  83. is_num: false,
  84. is_light: false,
  85. },
  86. {
  87. name: "性能损失",
  88. field: "performanceloss",
  89. is_num: false,
  90. is_light: false,
  91. },
  92. {
  93. name: "限电损失",
  94. field: "rationingloss",
  95. is_num: false,
  96. is_light: true,
  97. },
  98. {
  99. name: "受累损失",
  100. field: "involvesloss",
  101. is_num: false,
  102. is_light: false,
  103. }
  104. ],
  105. data: []
  106. },
  107. value4: "",
  108. value5: "",
  109. };
  110. },
  111. created() {
  112. this.value4 = this.getTime(1);
  113. this.value5 = this.getTime(2);
  114. this.AjaxCommon();
  115. },
  116. methods: {
  117. BeginChange(val) {
  118. this.value4 = val;
  119. this.AjaxCommon();
  120. },
  121. EndChange(val) {
  122. this.value5 = val;
  123. this.AjaxCommon();
  124. },
  125. getTime(val) { //时间戳处理,val=1是默认开始时间(当前月第一天),val=2是默认结束时间(今天)
  126. var date = new Date();
  127. var year = date.getFullYear(),
  128. month = date.getMonth() + 1,
  129. day = date.getDate();
  130. month >= 1 && month <= 9 ? (month = '0' + month) : '';
  131. day >= 0 && day <= 9 ? (day = '0' + day) : '';
  132. var begin = year + '-' + month + '-01';
  133. var end = year + '-' + month + '-' + day;
  134. if (val == 1) {
  135. return begin;
  136. } else if (val == 2) {
  137. return end;
  138. }
  139. },
  140. AjaxCommon() {
  141. var that = this;
  142. that.API.requestData({
  143. method: "GET",
  144. baseURL : "http://10.155.32.4:9001/",
  145. subUrl: "benchmarking/zjwxssl",
  146. data: {
  147. beginDate: that.value4,
  148. endDate: that.value5,
  149. },
  150. success(res) {
  151. var data = [];
  152. res.data.forEach((item, index) => {
  153. data.push({
  154. index: index + 1,
  155. dutyname: item.dutyname,
  156. theoreticalgeneratity: item.theoreticalgeneratity,
  157. generatity: item.generatity,
  158. faultloss: item.faultloss,
  159. mainloss: item.mainloss,
  160. performanceloss: item.performanceloss,
  161. rationingloss: item.rationingloss,
  162. involvesloss: item.involvesloss,
  163. is_light: false
  164. })
  165. })
  166. that.tableData.data = data;
  167. }
  168. });
  169. },
  170. }
  171. };
  172. </script>
  173. <style lang="less">
  174. .decision-page-4 {
  175. .com-panel {
  176. .panel-title {
  177. color: @gray-l;
  178. }
  179. .tools {
  180. display: flex;
  181. .tool-block {
  182. display: flex;
  183. align-items: center;
  184. margin-left: 0.741vh;
  185. .legend {
  186. flex: auto;
  187. width: 0.741vh;
  188. height: 0.741vh;
  189. margin-right: 0.741vh;
  190. &.long {
  191. width: 2.963vh;
  192. height: 0.37vh;
  193. }
  194. }
  195. .legend-text {
  196. color: @gray-l;
  197. font-size: @fontsize-s;
  198. }
  199. }
  200. }
  201. }
  202. .project-table {
  203. overflow: auto;
  204. height:90vh;
  205. tbody {
  206. // height: 100vh;
  207. }
  208. th,
  209. td {
  210. color: #b2bdc0;
  211. &:nth-child(1) {
  212. width: 50px;
  213. }
  214. &:nth-child(2) {
  215. width: 50px;
  216. }
  217. }
  218. }
  219. }
  220. </style>