rightHeader3.vue 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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="headerType flex-basis-50% flex flex-items-center flex-grow-1 costume-header_right">
  30. <div class="flex-grow-1">
  31. {{ selectedDeviceSlot }}
  32. </div>
  33. </div>
  34. </template>
  35. </div>
  36. </template>
  37. <script lang="ts" setup>
  38. import { ref, watch } from 'vue';
  39. import { Config } from '../../../../../deviceManager/configurationTable/types';
  40. import { useInitModule } from '../../../hooks/useInit';
  41. import { MenuItem, Menu, Dropdown } from 'ant-design-vue';
  42. import { SwapOutlined, CaretUpOutlined, CaretDownOutlined } from '@ant-design/icons-vue';
  43. const props = defineProps<{
  44. moduleData: Config['moduleData'];
  45. deviceType: Config['deviceType'];
  46. data: any;
  47. }>();
  48. const emit = defineEmits(['select']);
  49. const visible = ref(false);
  50. const headerConfig = props.moduleData.header;
  51. const { selectedDeviceID, selectedDevice, selectedDeviceSlot, selectedDeviceLabel, options, init } = useInitModule(
  52. props.deviceType,
  53. props.moduleData
  54. );
  55. function selectHandler({ key }) {
  56. selectedDeviceID.value = key;
  57. emit('select', selectedDevice.value);
  58. }
  59. watch(
  60. () => props.data,
  61. (d) => {
  62. init(d);
  63. emit('select', selectedDevice.value);
  64. },
  65. {
  66. immediate: true,
  67. }
  68. );
  69. </script>
  70. <style scoped>
  71. @import '/@/design/theme.less';
  72. .costume-header {
  73. width: 100%;
  74. height: 30px;
  75. margin-bottom: 10px;
  76. background: url('@/assets/images/vent/homeNew/Right-bottom.png') no-repeat;
  77. background-size: 100% 100%;
  78. }
  79. .costume-header_left {
  80. margin-left: 20px;
  81. }
  82. .costume-header_right {
  83. }
  84. </style>