primevue-mirror/components/lib/organizationchart/OrganizationChart.vue

79 lines
2.3 KiB
Vue
Raw Permalink Normal View History

2022-09-06 12:03:37 +00:00
<template>
2024-02-11 23:48:09 +00:00
<div :class="cx('root')" v-bind="ptmi('root')">
2023-05-10 08:07:14 +00:00
<OrganizationChartNode
:node="value"
:templates="$slots"
@node-toggle="onNodeToggle"
:collapsedKeys="d_collapsedKeys"
:collapsible="collapsible"
@node-click="onNodeClick"
:selectionMode="selectionMode"
:selectionKeys="selectionKeys"
:pt="pt"
:unstyled="unstyled"
2023-05-10 08:07:14 +00:00
/>
2022-09-06 12:03:37 +00:00
</div>
</template>
<script>
import BaseOrganizationChart from './BaseOrganizationChart.vue';
2022-09-06 12:03:37 +00:00
import OrganizationChartNode from './OrganizationChartNode.vue';
export default {
name: 'OrganizationChart',
extends: BaseOrganizationChart,
2024-02-11 23:48:09 +00:00
inheritAttrs: false,
2022-09-06 12:03:37 +00:00
emits: ['node-unselect', 'node-select', 'update:selectionKeys', 'node-expand', 'node-collapse', 'update:collapsedKeys'],
data() {
return {
d_collapsedKeys: this.collapsedKeys || {}
2022-09-14 11:26:01 +00:00
};
2022-09-06 12:03:37 +00:00
},
watch: {
collapsedKeys(newValue) {
this.d_collapsedKeys = newValue;
}
},
methods: {
onNodeClick(node) {
const key = node.key;
if (this.selectionMode) {
2022-09-14 11:26:01 +00:00
let _selectionKeys = this.selectionKeys ? { ...this.selectionKeys } : {};
2022-09-06 12:03:37 +00:00
if (_selectionKeys[key]) {
delete _selectionKeys[key];
this.$emit('node-unselect', node);
2022-09-14 11:26:01 +00:00
} else {
2022-09-06 12:03:37 +00:00
if (this.selectionMode === 'single') {
_selectionKeys = {};
}
_selectionKeys[key] = true;
this.$emit('node-select', node);
}
this.$emit('update:selectionKeys', _selectionKeys);
}
},
onNodeToggle(node) {
const key = node.key;
if (this.d_collapsedKeys[key]) {
delete this.d_collapsedKeys[key];
this.$emit('node-expand', node);
2022-09-14 11:26:01 +00:00
} else {
2022-09-06 12:03:37 +00:00
this.d_collapsedKeys[key] = true;
this.$emit('node-collapse', node);
}
2022-09-14 11:26:01 +00:00
this.d_collapsedKeys = { ...this.d_collapsedKeys };
2022-09-06 12:03:37 +00:00
this.$emit('update:collapsedKeys', this.d_collapsedKeys);
}
},
components: {
2022-09-14 11:26:01 +00:00
OrganizationChartNode: OrganizationChartNode
2022-09-06 12:03:37 +00:00
}
2022-09-14 11:26:01 +00:00
};
2022-09-06 12:03:37 +00:00
</script>