leftHeader1.vue 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <!-- eslint-disable vue/multi-word-component-names -->
  2. <template>
  3. <!-- Header部分 -->
  4. <div v-if="headerConfig.show" class="w-100% flex costume-header">
  5. <!-- 选择下拉框,自动填充剩余空间,这种实现是因为 Select 不支持 suffix -->
  6. <Dropdown
  7. v-if="headerConfig.selector.show"
  8. class="flex-grow-1 costume-header_left"
  9. :trigger="['click']"
  10. :bordered="false"
  11. @open-change="visible = $event"
  12. >
  13. <div class="flex-basis-100% flex flex-items-center" @click.prevent>
  14. <div class="headerType w-100px flex-grow-1 overflow-hidden whitespace-nowrap text-ellipsis">
  15. {{ selectedDeviceLabel }}
  16. </div>
  17. <CaretUpOutlined class="w-30px" v-if="visible" />
  18. <CaretDownOutlined class="w-30px" v-else />
  19. </div>
  20. <template #overlay>
  21. <Menu :selected-keys="[selectedDeviceID]" @click="selectHandler">
  22. <MenuItem v-for="item in options" :key="item.value" :title="item.label">
  23. {{ item.label }}
  24. </MenuItem>
  25. </Menu>
  26. </template>
  27. </Dropdown>
  28. <template v-if="headerConfig.slot.show">
  29. <div class="divider"> </div>
  30. <div class="headerType flex-basis-80% flex flex-items-center flex-grow-1 costume-header_right">
  31. <div class="flex-grow-1">
  32. {{ selectedDeviceSlot }}
  33. </div>
  34. </div>
  35. </template>
  36. </div>
  37. </template>
  38. <script lang="ts" setup>
  39. import { ref, watch } from 'vue';
  40. import { Config } from '../../../../../deviceManager/configurationTable/types';
  41. import { useInitModule } from '../../../hooks/useInit';
  42. import { MenuItem, Menu, Dropdown } from 'ant-design-vue';
  43. import { SwapOutlined, CaretUpOutlined, CaretDownOutlined } from '@ant-design/icons-vue';
  44. const props = defineProps<{
  45. moduleData: Config['moduleData'];
  46. deviceType: Config['deviceType'];
  47. data: any;
  48. }>();
  49. const emit = defineEmits(['select']);
  50. const visible = ref(false);
  51. const headerConfig = props.moduleData.header;
  52. const { selectedDeviceID, selectedDevice, selectedDeviceSlot, selectedDeviceLabel, options, init } = useInitModule(
  53. props.deviceType,
  54. props.moduleData
  55. );
  56. function selectHandler({ key }) {
  57. selectedDeviceID.value = key;
  58. emit('select', selectedDevice.value);
  59. }
  60. watch(
  61. () => props.data,
  62. (d) => {
  63. init(d);
  64. emit('select', selectedDevice.value);
  65. },
  66. {
  67. immediate: true,
  68. }
  69. );
  70. </script>
  71. <style scoped>
  72. @import '/@/design/theme.less';
  73. .costume-header {
  74. height: 30px;
  75. margin-bottom: 10px;
  76. width: 111%;
  77. background: url('@/assets/images/vent/homeNew/Left-top.png') no-repeat;
  78. background-size: 100% 100%;
  79. }
  80. .costume-header_left {
  81. }
  82. .costume-header_right {
  83. }
  84. .divider {
  85. width: 40px;
  86. background: url('@/assets/images/vent/homeNew/left-divider.png') no-repeat;
  87. background-size: 100% 100%;
  88. }
  89. </style>