mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-10-24 04:39:59 +08:00
65 lines
1.4 KiB
Vue
65 lines
1.4 KiB
Vue
<template>
|
|
<div>
|
|
<MenuDropdown
|
|
:listItems="this.formattedList"
|
|
btnClasses="bg-transparent w-6 h-6 border-0 p-0 flex"
|
|
:position="'right'"
|
|
:alwaysShow="true"
|
|
:btnIcon="'sn-icon sn-icon-more-hori'"
|
|
@open="loadActions"
|
|
@dtEvent="handleEvents"
|
|
></MenuDropdown>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import MenuDropdown from '../menu_dropdown.vue';
|
|
import axios from '../../../packs/custom_axios.js';
|
|
|
|
export default {
|
|
name: 'RowMenuRenderer',
|
|
props: {
|
|
params: {
|
|
required: true,
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
actionsMenu: [],
|
|
};
|
|
},
|
|
components: {
|
|
MenuDropdown,
|
|
},
|
|
computed: {
|
|
formattedList() {
|
|
return this.actionsMenu.map((item) => {
|
|
const newItem = { text: item.label };
|
|
if (item.type === 'emit') {
|
|
newItem.emit = item.name;
|
|
}
|
|
if (item.type === 'link') {
|
|
newItem.url = item.path;
|
|
}
|
|
|
|
newItem.params = item;
|
|
|
|
return newItem;
|
|
});
|
|
},
|
|
},
|
|
methods: {
|
|
loadActions() {
|
|
if (this.actionsMenu.length > 0) return;
|
|
axios.get(this.params.data.urls.actions)
|
|
.then((response) => {
|
|
this.actionsMenu = response.data.actions;
|
|
});
|
|
},
|
|
handleEvents(event, option) {
|
|
const dt = this.params.dtComponent;
|
|
dt.$emit(event, option.params, [this.params.data]);
|
|
},
|
|
},
|
|
};
|
|
</script>
|