| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250 |
- <template>
- <div>
- <a-form
- class="mt-3"
- :form="form.fc"
- v-bind="formItemLayout"
- @submit="submit"
- hideRequiredMark>
- <a-form-item :label="$t('compute.text_297', [$t('dictionary.project')])" v-show="false">
- <domain-project
- :fc="form.fc"
- :fd="form.fd"
- :decorators="{ project: decorators.project, domain: decorators.domain }"
- @fetchDomainCallback="fetchDomainCallback"
- @fetchProjectCallback="fetchProjectCallback" />
- </a-form-item>
- <a-form-item :label="$t('compute.text_177')" class="mb-0" v-show="false">
- <cloudregion-zone
- :zone-params="zoneParams"
- :cloudregion-params="cloudregionParams"
- :decorator="decorators.cloudregionZone"
- filterBrandResource="compute_engine" />
- </a-form-item>
- <a-form-item :label="$t('compute.text_294')">
- <a-input-number v-decorator="decorators.count" @blur="countBlur" :min="1" :max="100" />
- </a-form-item>
- <a-form-item :label="$t('compute.text_1058')" class="mb-0">
- <cpu-radio :decorator="decorators.vcpu" :options="form.fi.cpuMem.cpus || []" @change="cpuChange" />
- </a-form-item>
- <a-form-item :label="$t('compute.text_369')" class="mb-0">
- <mem-radio :decorator="decorators.vmem" :options="form.fi.cpuMem.mems_mb || []" />
- </a-form-item>
- <a-form-item :label="$t('compute.text_109')" v-if="showSku">
- <sku
- v-decorator="decorators.sku"
- :type="type"
- :sku-params="skuParam"
- :hypervisor="form.fd.hypervisor" />
- </a-form-item>
- <a-form-item :label="$t('compute.text_49')" class="mb-0">
- <system-disk
- :decorator="decorators.systemDisk"
- :type="type"
- :form="form"
- :hypervisor="form.fd.hypervisor"
- :sku="form.fd.sku"
- :capability-data="form.fi.capability"
- :image="form.fi.imageMsg"
- :sizeDisabled="disabledSysDiskSize" />
- </a-form-item>
- <a-form-item :label="$t('compute.text_50')">
- <data-disk
- v-if="form.fd.hypervisor"
- :decorator="decorators.dataDisk"
- :type="type"
- :form="form"
- :hypervisor="form.fd.hypervisor"
- :sku="form.fd.sku"
- :defaultType="form.fd.systemDiskType"
- :capability-data="form.fi.capability"
- :simplify="true"
- ref="dataDiskRef" />
- </a-form-item>
- <bottom-bar
- ref="bottomBarRef"
- :loading="submiting"
- :form="form"
- :type="type"
- :dataDiskSizes="dataDiskSizes"
- :isOpenWorkflow="isOpenWorkflow"
- :errors.sync="errors"
- :isServertemplate="isServertemplate"
- :hasMeterService="hasMeterService"
- @getOriginPrice="getOriginPrice" />
- </a-form>
- </div>
- </template>
- <script>
- import _ from 'lodash'
- import * as R from 'ramda'
- import mixin from './mixin'
- import { resolveValueChangeField } from '@/utils/common/ant'
- import { HYPERVISORS_MAP } from '@/constants'
- export default {
- name: 'VMPrivateCreate',
- components: {},
- mixins: [mixin],
- computed: {
- cloudregionParams () {
- return {
- cloud_env: 'private',
- usable: true,
- show_emulated: true,
- ...this.scopeParams,
- }
- },
- zoneParams () {
- return {
- usable: true,
- show_emulated: true,
- order_by: 'created_at',
- order: 'asc',
- ...this.scopeParams,
- }
- },
- cacheImageParams () {
- const params = {}
- if (R.is(Object, this.form.fd.sku)) {
- if (this.cloudregionZoneParams.cloudregion) {
- params.cloudregion_id = this.cloudregionZoneParams.cloudregion
- }
- }
- if (!params.cloudregion_id) return {}
- return params
- },
- showSku () {
- if (this.form.fd.vcpu && this.form.fd.vmem) {
- return true
- }
- return false
- },
- skuParam () {
- return {
- limit: 0,
- public_cloud: false,
- postpaid_status: 'available',
- cpu_core_count: this.form.fd.vcpu || this.decorators.vcpu[1].initialValue,
- memory_size_mb: this.form.fd.vmem,
- usable: true,
- enabled: true,
- provider: 'OneCloud',
- ...this.scopeParams,
- }
- },
- policyHostParams () {
- const zone = _.get(this.form.fd, 'zone.key')
- if (zone) {
- return {
- enabled: 1,
- usable: true,
- zone,
- hypervisor: this.form.fd.hypervisor,
- }
- }
- return {}
- },
- networkParam () {
- const params = {
- filter: 'server_type.notin(ipmi, pxe)',
- usable: true,
- zone: _.get(this.form, 'fd.zone.key'),
- ...this.scopeParams,
- }
- return params
- },
- instanceSpecParmas () {
- if (this.form.fd.hypervisor === HYPERVISORS_MAP.hcso.hypervisor || this.form.fd.hypervisor === HYPERVISORS_MAP.hcs.hypervisor) {
- const params = {
- usable: true,
- enabled: true,
- provider: HYPERVISORS_MAP.hcso.provider,
- }
- if (this.form.fd.hypervisor === HYPERVISORS_MAP.hcs.hypervisor) {
- params.provider = HYPERVISORS_MAP.hcs.provider
- }
- if (this.cloudregionZoneParams.cloudregion) {
- params.cloudregion_id = this.cloudregionZoneParams.cloudregion
- }
- return params
- } else {
- return {
- usable: true,
- enabled: true,
- 'provider.0': HYPERVISORS_MAP.kvm.provider,
- 'provider.1': _.get(HYPERVISORS_MAP, `[${this.form.fd.hypervisor}].provider`),
- }
- }
- },
- cloudproviderParamsExtra () {
- const params = {
- cloud_env: 'private',
- ...this.scopeParams,
- }
- if (this.form.fd.hypervisor && this.form.fd.hypervisor) {
- params.provider = HYPERVISORS_MAP[this.form.fd.hypervisor].provider
- }
- return params
- },
- disabledSysDiskSize () {
- if (this.form.fd.systemDiskType) {
- return this.form.fd.systemDiskType.key === 'nova'
- }
- return false
- },
- },
- methods: {
- onValuesChange (vm, changedFields) {
- this.$nextTick(() => {
- const formValue = this.form.fc.getFieldsValue()
- const newField = resolveValueChangeField(changedFields)
- this._setNewFieldToFd(newField, formValue)
- const keys = Object.keys(newField)
- if (keys.includes('zone')) {
- this.fetchCapability()
- }
- })
- },
- fetchCapability () {
- const params = {
- show_emulated: true,
- resource_type: 'shared',
- ...this.scopeParams,
- }
- let id = this.cloudregionZoneParams.cloudregion
- let resource = 'cloudregions'
- if (this.cloudregionZoneParams.zone) {
- id = this.cloudregionZoneParams.zone
- resource = 'zones'
- }
- const capabilityParams = { id, spec: 'capability', params }
- if (!id) return
- if (R.equals(this.capabilityParams, capabilityParams)) return // 和已有的参数一样则不发请求
- this.capabilityParams = capabilityParams
- new this.$Manager(resource).getSpecific(this.capabilityParams)
- .then(({ data }) => {
- this.form.fi.capability = {
- ...data,
- hypervisors: data.hypervisors.filter(val => val !== 'baremetal'),
- }
- this.form.fc.getFieldDecorator('hypervisor', { preserve: true })
- this.form.fc.setFieldsValue({
- hypervisor: this.form.fi.capability.hypervisors[0], // 赋值默认第一个平台
- })
- this.$nextTick(this.fetchInstanceSpecs)
- })
- },
- fetchInstanceSpecs () {
- this.serverskusM.get({ id: 'instance-specs', params: this.instanceSpecParmas })
- .then(({ data }) => {
- this.form.fi.cpuMem = data
- const vcpuDecorator = this.decorators.vcpu
- const vcpuInit = vcpuDecorator[1].initialValue
- this.cpuChange(vcpuInit)
- })
- },
- },
- }
- </script>
|