mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-11-04 00:02:37 +01:00 
			
		
		
		
	* add scroll to vm info * fix "un-choose" the Zone/Pod/Host and row selected when changing page sections * remove 'un-choose' selection in zone, cluster, pod, host * fix issue when selected page, hidden cpu/ram affinity groups * revert affinityGroup total count * fix error lint & disk offering selection Signed-off-by: Rohit Yadav <rohit.yadav@shapeblue.com>
		
			
				
	
	
		
			290 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			290 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
// Licensed to the Apache Software Foundation (ASF) under one
 | 
						|
// or more contributor license agreements.  See the NOTICE file
 | 
						|
// distributed with this work for additional information
 | 
						|
// regarding copyright ownership.  The ASF licenses this file
 | 
						|
// to you under the Apache License, Version 2.0 (the
 | 
						|
// "License"); you may not use this file except in compliance
 | 
						|
// with the License.  You may obtain a copy of the License at
 | 
						|
//
 | 
						|
//   http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
//
 | 
						|
// Unless required by applicable law or agreed to in writing,
 | 
						|
// software distributed under the License is distributed on an
 | 
						|
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 | 
						|
// KIND, either express or implied.  See the License for the
 | 
						|
// specific language governing permissions and limitations
 | 
						|
// under the License.
 | 
						|
 | 
						|
<template>
 | 
						|
  <div>
 | 
						|
    <a-input-search
 | 
						|
      style="width: 25vw; float: right; margin-bottom: 10px; z-index: 8"
 | 
						|
      :placeholder="$t('label.search')"
 | 
						|
      v-model="filter"
 | 
						|
      @search="handleSearch" />
 | 
						|
    <a-button type="primary" @click="showCreateForm = true" style="float: right; margin-right: 5px; z-index: 8">
 | 
						|
      {{ $t('label.add.network') }}
 | 
						|
    </a-button>
 | 
						|
    <a-table
 | 
						|
      :loading="loading"
 | 
						|
      :columns="columns"
 | 
						|
      :dataSource="networkItems"
 | 
						|
      :rowKey="record => record.id"
 | 
						|
      :pagination="false"
 | 
						|
      :rowSelection="rowSelection"
 | 
						|
      :scroll="{ y: 225 }"
 | 
						|
    >
 | 
						|
      <a-list
 | 
						|
        slot="expandedRowRender"
 | 
						|
        slot-scope="record"
 | 
						|
        :key="record.id"
 | 
						|
        :dataSource="getDetails(record)"
 | 
						|
        size="small"
 | 
						|
      >
 | 
						|
        <a-list-item slot="renderItem" slot-scope="item" :key="item.id">
 | 
						|
          <a-list-item-meta
 | 
						|
            :description="item.description"
 | 
						|
          >
 | 
						|
            <template v-slot:title>{{ item.title }}</template>
 | 
						|
          </a-list-item-meta>
 | 
						|
        </a-list-item>
 | 
						|
      </a-list>
 | 
						|
    </a-table>
 | 
						|
 | 
						|
    <div style="display: block; text-align: right;">
 | 
						|
      <a-pagination
 | 
						|
        size="small"
 | 
						|
        :current="options.page"
 | 
						|
        :pageSize="options.pageSize"
 | 
						|
        :total="rowCount"
 | 
						|
        :showTotal="total => `Total ${total} items`"
 | 
						|
        :pageSizeOptions="['10', '20', '40', '80', '100', '500']"
 | 
						|
        @change="onChangePage"
 | 
						|
        @showSizeChange="onChangePageSize"
 | 
						|
        showSizeChanger />
 | 
						|
    </div>
 | 
						|
 | 
						|
    <a-modal
 | 
						|
      :visible="showCreateForm"
 | 
						|
      :title="$t('label.add.network')"
 | 
						|
      :closable="true"
 | 
						|
      :footer="null"
 | 
						|
      @cancel="showCreateForm = false"
 | 
						|
      centered
 | 
						|
      width="auto">
 | 
						|
      <create-network
 | 
						|
        :resource="{}"
 | 
						|
        @refresh-data="handleSearch"
 | 
						|
        @close-action="showCreateForm = false"
 | 
						|
      />
 | 
						|
    </a-modal>
 | 
						|
  </div>
 | 
						|
</template>
 | 
						|
 | 
						|
<script>
 | 
						|
import _ from 'lodash'
 | 
						|
import { api } from '@/api'
 | 
						|
import store from '@/store'
 | 
						|
import CreateNetwork from '@/views/network/CreateNetwork'
 | 
						|
 | 
						|
export default {
 | 
						|
  name: 'NetworkSelection',
 | 
						|
  components: {
 | 
						|
    CreateNetwork
 | 
						|
  },
 | 
						|
  props: {
 | 
						|
    items: {
 | 
						|
      type: Array,
 | 
						|
      default: () => []
 | 
						|
    },
 | 
						|
    rowCount: {
 | 
						|
      type: Number,
 | 
						|
      default: () => 0
 | 
						|
    },
 | 
						|
    value: {
 | 
						|
      type: Array,
 | 
						|
      default: () => []
 | 
						|
    },
 | 
						|
    loading: {
 | 
						|
      type: Boolean,
 | 
						|
      default: false
 | 
						|
    },
 | 
						|
    zoneId: {
 | 
						|
      type: String,
 | 
						|
      default: () => ''
 | 
						|
    },
 | 
						|
    preFillContent: {
 | 
						|
      type: Object,
 | 
						|
      default: () => {}
 | 
						|
    }
 | 
						|
  },
 | 
						|
  data () {
 | 
						|
    return {
 | 
						|
      filter: '',
 | 
						|
      selectedRowKeys: [],
 | 
						|
      vpcs: [],
 | 
						|
      filteredInfo: null,
 | 
						|
      networkOffering: {
 | 
						|
        loading: false,
 | 
						|
        opts: []
 | 
						|
      },
 | 
						|
      showCreateForm: false,
 | 
						|
      oldZoneId: null,
 | 
						|
      options: {
 | 
						|
        page: 1,
 | 
						|
        pageSize: 10,
 | 
						|
        keyword: null
 | 
						|
      }
 | 
						|
    }
 | 
						|
  },
 | 
						|
  computed: {
 | 
						|
    columns () {
 | 
						|
      let vpcFilter = []
 | 
						|
      if (this.vpcs) {
 | 
						|
        vpcFilter = this.vpcs.map((vpc) => {
 | 
						|
          return {
 | 
						|
            text: vpc.displaytext,
 | 
						|
            value: vpc.id
 | 
						|
          }
 | 
						|
        })
 | 
						|
      }
 | 
						|
      return [
 | 
						|
        {
 | 
						|
          dataIndex: 'name',
 | 
						|
          title: this.$t('label.networks'),
 | 
						|
          width: '40%'
 | 
						|
        },
 | 
						|
        {
 | 
						|
          dataIndex: 'type',
 | 
						|
          title: this.$t('label.guestiptype'),
 | 
						|
          width: '30%'
 | 
						|
        },
 | 
						|
        {
 | 
						|
          dataIndex: 'vpcName',
 | 
						|
          title: this.$t('label.vpc'),
 | 
						|
          width: '30%',
 | 
						|
          filters: vpcFilter,
 | 
						|
          filteredValue: _.get(this.filteredInfo, 'id'),
 | 
						|
          onFilter: (value, record) => {
 | 
						|
            return record.vpcid === value
 | 
						|
          }
 | 
						|
        }
 | 
						|
      ]
 | 
						|
    },
 | 
						|
    rowSelection () {
 | 
						|
      return {
 | 
						|
        type: 'checkbox',
 | 
						|
        selectedRowKeys: this.selectedRowKeys,
 | 
						|
        onChange: (rows) => {
 | 
						|
          this.$emit('select-network-item', rows)
 | 
						|
        }
 | 
						|
      }
 | 
						|
    },
 | 
						|
    networkItems () {
 | 
						|
      return this.items.map((network) => {
 | 
						|
        const vpc = _.find(this.vpcs, { id: network.vpcid })
 | 
						|
        return {
 | 
						|
          ...network,
 | 
						|
          ...{
 | 
						|
            vpcName: _.get(vpc, 'displaytext')
 | 
						|
          }
 | 
						|
        }
 | 
						|
      })
 | 
						|
    }
 | 
						|
  },
 | 
						|
  watch: {
 | 
						|
    value (newValue, oldValue) {
 | 
						|
      if (newValue && !_.isEqual(newValue, oldValue)) {
 | 
						|
        this.selectedRowKeys = newValue
 | 
						|
      }
 | 
						|
    },
 | 
						|
    loading () {
 | 
						|
      if (!this.loading) {
 | 
						|
        if (this.preFillContent.networkids) {
 | 
						|
          this.selectedRowKeys = this.preFillContent.networkids
 | 
						|
          this.$emit('select-network-item', this.preFillContent.networkids)
 | 
						|
        } else {
 | 
						|
          if (this.items && this.items.length > 0) {
 | 
						|
            if (this.oldZoneId === this.zoneId) {
 | 
						|
              return
 | 
						|
            }
 | 
						|
            this.oldZoneId = this.zoneId
 | 
						|
            this.selectedRowKeys = [this.items[0].id]
 | 
						|
            this.$emit('select-network-item', this.selectedRowKeys)
 | 
						|
          } else {
 | 
						|
            this.selectedRowKeys = []
 | 
						|
            this.$emit('select-network-item', [])
 | 
						|
          }
 | 
						|
        }
 | 
						|
      }
 | 
						|
    }
 | 
						|
  },
 | 
						|
  beforeCreate () {
 | 
						|
    this.form = this.$form.createForm(this)
 | 
						|
  },
 | 
						|
  created () {
 | 
						|
    api('listVPCs', {
 | 
						|
      projectid: store.getters.project.id
 | 
						|
    }).then((response) => {
 | 
						|
      this.vpcs = _.get(response, 'listvpcsresponse.vpc')
 | 
						|
    })
 | 
						|
  },
 | 
						|
  inject: ['vmFetchNetworks'],
 | 
						|
  methods: {
 | 
						|
    getDetails (network) {
 | 
						|
      return [
 | 
						|
        {
 | 
						|
          title: this.$t('label.description'),
 | 
						|
          description: network.displaytext
 | 
						|
        },
 | 
						|
        {
 | 
						|
          title: this.$t('label.networkofferingid'),
 | 
						|
          description: network.networkofferingdisplaytext
 | 
						|
        }
 | 
						|
      ]
 | 
						|
    },
 | 
						|
    handleSearch (value) {
 | 
						|
      this.filter = value
 | 
						|
      this.options.page = 1
 | 
						|
      this.options.pageSize = 10
 | 
						|
      this.options.keyword = this.filter
 | 
						|
      this.$emit('handle-search-filter', this.options)
 | 
						|
    },
 | 
						|
    onChangePage (page, pageSize) {
 | 
						|
      this.options.page = page
 | 
						|
      this.options.pageSize = pageSize
 | 
						|
      this.$emit('handle-search-filter', this.options)
 | 
						|
    },
 | 
						|
    onChangePageSize (page, pageSize) {
 | 
						|
      this.options.page = page
 | 
						|
      this.options.pageSize = pageSize
 | 
						|
      this.$emit('handle-search-filter', this.options)
 | 
						|
    },
 | 
						|
    listNetworkOfferings () {
 | 
						|
      return new Promise((resolve, reject) => {
 | 
						|
        const args = {}
 | 
						|
        args.forvpc = false
 | 
						|
        args.zoneid = this.zoneId
 | 
						|
        args.guestiptype = 'Isolated'
 | 
						|
        args.supportedServices = 'SourceNat'
 | 
						|
        args.specifyvlan = false
 | 
						|
        args.state = 'Enabled'
 | 
						|
 | 
						|
        api('listNetworkOfferings', args).then(json => {
 | 
						|
          const listNetworkOfferings = json.listnetworkofferingsresponse.networkoffering || []
 | 
						|
          resolve(listNetworkOfferings)
 | 
						|
        }).catch(error => {
 | 
						|
          resolve(error)
 | 
						|
        })
 | 
						|
      })
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 | 
						|
</script>
 | 
						|
 | 
						|
<style lang="less" scoped>
 | 
						|
  .ant-table-wrapper {
 | 
						|
    margin: 2rem 0;
 | 
						|
  }
 | 
						|
</style>
 |