2018-09-11 17:10:59 +00:00
|
|
|
<template>
|
2022-03-21 18:40:35 +00:00
|
|
|
<div
|
|
|
|
ref="createButton"
|
|
|
|
class="c-create-button--w"
|
2021-03-29 17:49:49 +00:00
|
|
|
>
|
2019-12-04 20:39:09 +00:00
|
|
|
<button
|
|
|
|
class="c-create-button c-button--menu c-button--major icon-plus"
|
2021-03-29 17:49:49 +00:00
|
|
|
@click.prevent.stop="showCreateMenu"
|
2019-12-04 20:39:09 +00:00
|
|
|
>
|
|
|
|
<span class="c-button__label">Create</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
2018-09-11 17:10:59 +00:00
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2021-12-07 20:27:23 +00:00
|
|
|
import CreateAction from '@/plugins/formActions/CreateAction';
|
2018-10-19 22:07:30 +00:00
|
|
|
|
2019-12-04 20:39:09 +00:00
|
|
|
export default {
|
|
|
|
inject: ['openmct'],
|
|
|
|
data: function () {
|
2018-09-13 22:15:01 +00:00
|
|
|
|
2019-12-04 20:39:09 +00:00
|
|
|
return {
|
2022-06-04 16:06:07 +00:00
|
|
|
menuItems: {},
|
2019-12-04 20:39:09 +00:00
|
|
|
selectedMenuItem: {},
|
|
|
|
opened: false
|
2020-07-31 19:11:03 +00:00
|
|
|
};
|
2019-12-04 20:39:09 +00:00
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
sortedItems() {
|
2022-06-04 16:06:07 +00:00
|
|
|
let items = this.getItems();
|
|
|
|
|
|
|
|
return items.sort((a, b) => {
|
2019-12-04 20:39:09 +00:00
|
|
|
if (a.name < b.name) {
|
|
|
|
return -1;
|
|
|
|
} else if (a.name > b.name) {
|
|
|
|
return 1;
|
|
|
|
} else {
|
|
|
|
return 0;
|
2018-09-13 22:15:01 +00:00
|
|
|
}
|
|
|
|
});
|
2019-12-04 20:39:09 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
2022-06-04 16:06:07 +00:00
|
|
|
getItems() {
|
|
|
|
let keys = this.openmct.types.listKeys();
|
|
|
|
|
|
|
|
keys.forEach(key => {
|
|
|
|
if (!this.menuItems[key]) {
|
|
|
|
let typeDef = this.openmct.types.get(key).definition;
|
|
|
|
|
|
|
|
if (typeDef.creatable) {
|
|
|
|
this.menuItems[key] = {
|
|
|
|
cssClass: typeDef.cssClass,
|
|
|
|
name: typeDef.name,
|
|
|
|
description: typeDef.description,
|
|
|
|
onItemClicked: () => this.create(key)
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return Object.values(this.menuItems);
|
|
|
|
},
|
2021-03-29 17:49:49 +00:00
|
|
|
showCreateMenu() {
|
|
|
|
const elementBoundingClientRect = this.$refs.createButton.getBoundingClientRect();
|
|
|
|
const x = elementBoundingClientRect.x;
|
|
|
|
const y = elementBoundingClientRect.y + elementBoundingClientRect.height;
|
2020-07-31 19:11:03 +00:00
|
|
|
|
2021-03-29 17:49:49 +00:00
|
|
|
const menuOptions = {
|
|
|
|
menuClass: 'c-create-menu'
|
|
|
|
};
|
2020-07-31 19:11:03 +00:00
|
|
|
|
2021-03-29 17:49:49 +00:00
|
|
|
this.openmct.menus.showSuperMenu(x, y, this.sortedItems, menuOptions);
|
2019-12-04 20:39:09 +00:00
|
|
|
},
|
2021-03-29 17:49:49 +00:00
|
|
|
create(key) {
|
2023-01-31 06:01:00 +00:00
|
|
|
const createAction = new CreateAction(this.openmct, key, this.openmct.router.path[0]);
|
2020-07-31 19:11:03 +00:00
|
|
|
|
2023-01-31 06:01:00 +00:00
|
|
|
createAction.invoke();
|
2018-09-11 17:10:59 +00:00
|
|
|
}
|
|
|
|
}
|
2020-07-31 19:11:03 +00:00
|
|
|
};
|
2018-09-11 17:10:59 +00:00
|
|
|
</script>
|