mirror of https://github.com/veops/cmdb.git
Merge branch 'master' of https://github.com/pycook/cmdb
This commit is contained in:
commit
5da5d32b54
|
@ -122,3 +122,19 @@ export function deleteCITypeAttributesById (CITypeId, data) {
|
||||||
data: data
|
data: data
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function transferCITypeAttrIndex (CITypeId, data) {
|
||||||
|
return axios({
|
||||||
|
url: `/v0.1/ci_types/${CITypeId}/attributes/transfer`,
|
||||||
|
method: 'POST',
|
||||||
|
data: data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
export function transferCITypeGroupIndex (CITypeId, data) {
|
||||||
|
return axios({
|
||||||
|
url: `/v0.1/ci_types/${CITypeId}/attribute_groups/transfer`,
|
||||||
|
method: 'POST',
|
||||||
|
data: data
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
|
@ -86,8 +86,7 @@
|
||||||
v-model="CITypeGroup.attributes"
|
v-model="CITypeGroup.attributes"
|
||||||
group="properties"
|
group="properties"
|
||||||
@start="drag=true"
|
@start="drag=true"
|
||||||
@end="handleEnd"
|
@change="(e)=>{handleChange(e, CITypeGroup.id)}"
|
||||||
@change="handleChange"
|
|
||||||
:filter="'.filter-empty'"
|
:filter="'.filter-empty'"
|
||||||
:animation="100"
|
:animation="100"
|
||||||
tag="div"
|
tag="div"
|
||||||
|
@ -164,8 +163,7 @@
|
||||||
v-model="otherGroupAttributes"
|
v-model="otherGroupAttributes"
|
||||||
group="properties"
|
group="properties"
|
||||||
@start="drag=true"
|
@start="drag=true"
|
||||||
@end="handleEnd"
|
@change="(e)=>{handleChange(e, -1)}"
|
||||||
@change="handleChange"
|
|
||||||
:animation="0"
|
:animation="0"
|
||||||
style="min-height: 2rem; width: 100%; display: flex; flex-flow: wrap">
|
style="min-height: 2rem; width: 100%; display: flex; flex-flow: wrap">
|
||||||
|
|
||||||
|
@ -251,14 +249,14 @@
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
/* eslint-disable */
|
||||||
import {
|
import {
|
||||||
deleteCITypeGroupById,
|
deleteCITypeGroupById,
|
||||||
getCITypeGroupById,
|
getCITypeGroupById,
|
||||||
createCITypeGroupById,
|
createCITypeGroupById,
|
||||||
updateCITypeGroupById
|
updateCITypeGroupById
|
||||||
} from '@/api/cmdb/CIType'
|
} from '@/api/cmdb/CIType'
|
||||||
import { getCITypeAttributesById, updateCITypeAttributesById } from '@/api/cmdb/CITypeAttr'
|
import { getCITypeAttributesById, updateCITypeAttributesById, transferCITypeAttrIndex, transferCITypeGroupIndex } from '@/api/cmdb/CITypeAttr'
|
||||||
import draggable from 'vuedraggable'
|
import draggable from 'vuedraggable'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
|
@ -272,6 +270,7 @@ export default {
|
||||||
CITypeId: this.$route.params.CITypeId,
|
CITypeId: this.$route.params.CITypeId,
|
||||||
CITypeName: this.$route.params.CITypeName,
|
CITypeName: this.$route.params.CITypeName,
|
||||||
CITypeGroups: [],
|
CITypeGroups: [],
|
||||||
|
addRemoveGroupFlag: {},
|
||||||
attributes: [],
|
attributes: [],
|
||||||
otherGroupAttributes: [],
|
otherGroupAttributes: [],
|
||||||
addGroupBtnVisible: true,
|
addGroupBtnVisible: true,
|
||||||
|
@ -312,7 +311,7 @@ export default {
|
||||||
group.editable = false
|
group.editable = false
|
||||||
group.originOrder = group.order
|
group.originOrder = group.order
|
||||||
group.originName = group.name
|
group.originName = group.name
|
||||||
group.attributes = group.attributes.sort((a, b) => a.order - b.order)
|
// group.attributes = group.attributes.sort((a, b) => a.order - b.order)
|
||||||
})
|
})
|
||||||
|
|
||||||
this.otherGroupAttributes = this.attributes.filter(x => !inGroupAttrKeys.includes(x.id)).sort((a, b) => a.order - b.order)
|
this.otherGroupAttributes = this.attributes.filter(x => !inGroupAttrKeys.includes(x.id)).sort((a, b) => a.order - b.order)
|
||||||
|
@ -322,7 +321,7 @@ export default {
|
||||||
attribute.originOrder = attribute.order
|
attribute.originOrder = attribute.order
|
||||||
})
|
})
|
||||||
|
|
||||||
console.log('setOtherGroupAttributes', this.CITypeGroups, this.otherGroupAttributes)
|
// console.log('setOtherGroupAttributes', this.CITypeGroups, this.otherGroupAttributes)
|
||||||
},
|
},
|
||||||
getCITypeGroupData () {
|
getCITypeGroupData () {
|
||||||
const promises = [
|
const promises = [
|
||||||
|
@ -387,13 +386,18 @@ export default {
|
||||||
},
|
},
|
||||||
|
|
||||||
handleMoveGroup (beforeIndex, afterIndex) {
|
handleMoveGroup (beforeIndex, afterIndex) {
|
||||||
|
const fromGroupId = this.CITypeGroups[beforeIndex].id
|
||||||
|
const toGroupId = this.CITypeGroups[afterIndex].id
|
||||||
|
transferCITypeGroupIndex(this.CITypeId, { from: fromGroupId, to: toGroupId }).then(res => {
|
||||||
|
this.$message.success('操作成功')
|
||||||
const beforeGroup = this.CITypeGroups[beforeIndex]
|
const beforeGroup = this.CITypeGroups[beforeIndex]
|
||||||
this.CITypeGroups[beforeIndex] = this.CITypeGroups[afterIndex]
|
this.CITypeGroups[beforeIndex] = this.CITypeGroups[afterIndex]
|
||||||
|
|
||||||
this.$set(this.CITypeGroups, beforeIndex, this.CITypeGroups[afterIndex])
|
this.$set(this.CITypeGroups, beforeIndex, this.CITypeGroups[afterIndex])
|
||||||
this.$set(this.CITypeGroups, afterIndex, beforeGroup)
|
this.$set(this.CITypeGroups, afterIndex, beforeGroup)
|
||||||
|
}).catch(err => {
|
||||||
this.updatePropertyIndex()
|
this.$httpError(err, '移动出错')
|
||||||
|
})
|
||||||
},
|
},
|
||||||
handleAddExistGroupAttr (index) {
|
handleAddExistGroupAttr (index) {
|
||||||
const group = this.CITypeGroups[index]
|
const group = this.CITypeGroups[index]
|
||||||
|
@ -456,24 +460,50 @@ export default {
|
||||||
})
|
})
|
||||||
.catch(err => this.requestFailed(err))
|
.catch(err => this.requestFailed(err))
|
||||||
},
|
},
|
||||||
handleChange (e) {
|
handleChange (e, group) {
|
||||||
console.log(e)
|
if (e.hasOwnProperty('moved') && e.moved.oldIndex !== e.moved.newIndex) {
|
||||||
if (e.hasOwnProperty('moved')) {
|
if (group === -1) {
|
||||||
this.shouldUpdatePropertyIndex = e.moved.newIndex !== e.moved.oldIndex
|
this.$message.error('更多属性不能进行排序, 如需排序需添加入其他分组中!')
|
||||||
} else {
|
} else {
|
||||||
this.shouldUpdatePropertyIndex = true
|
transferCITypeAttrIndex(this.CITypeId,
|
||||||
|
{
|
||||||
|
from: { attr_id: e.moved.element.id, group_id: group > -1 ? group : null },
|
||||||
|
to: { order: e.moved.newIndex, group_id: group > -1 ? group : null }
|
||||||
|
}).then(res => this.$message.success('保存成功')).catch(err => {
|
||||||
|
this.$httpError(err)
|
||||||
|
this.abortDraggable()
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.hasOwnProperty('added')) {
|
||||||
|
this.addRemoveGroupFlag = { to: { group_id: group > -1 ? group : null, order: e.added.newIndex }, inited: true }
|
||||||
|
}
|
||||||
|
|
||||||
|
if (e.hasOwnProperty('removed')) {
|
||||||
|
this.$nextTick(() => {
|
||||||
|
transferCITypeAttrIndex(this.CITypeId,
|
||||||
|
{
|
||||||
|
from: { attr_id: e.removed.element.id, group_id: group > -1 ? group : null },
|
||||||
|
to: { group_id: this.addRemoveGroupFlag.to.group_id, order: this.addRemoveGroupFlag.to.order }
|
||||||
|
}).then(res => this.$message.success('保存成功')).catch(err => {
|
||||||
|
this.$httpError(err)
|
||||||
|
this.abortDraggable()
|
||||||
|
}).finally(() => {
|
||||||
|
this.addRemoveGroupFlag = {}
|
||||||
|
})
|
||||||
|
})
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
handleEnd (e) {
|
abortDraggable () {
|
||||||
if (this.shouldUpdatePropertyIndex) {
|
this.$nextTick(() => {
|
||||||
this.updatePropertyIndex()
|
this.$router.push({name: 'ci_type'})
|
||||||
this.shouldUpdatePropertyIndex = false
|
})
|
||||||
}
|
|
||||||
},
|
},
|
||||||
updatePropertyIndex () {
|
updatePropertyIndex () {
|
||||||
const attributes = []
|
const attributes = [] // 全部属性
|
||||||
let attributeOrder = 0
|
let attributeOrder = 0 // 属性组
|
||||||
let groupOrder = 0
|
let groupOrder = 0 // 组排序
|
||||||
const promises = [
|
const promises = [
|
||||||
|
|
||||||
]
|
]
|
||||||
|
|
Loading…
Reference in New Issue