mirror of
https://github.com/nasa/openmct.git
synced 2025-01-22 20:38:23 +00:00
4885c816dc
* Replacing all instances of the new Vue() component creation pattern * In Vue 3, components cannot be created on the fly and mounted off-DOM. The suggested fix from Vue is to use createApp, but in the context of Open MCT this means dozens of Vue apps being created and destroyed at any given moment. Instead, we have used a community hack for creating individual components. * beforeDestroy() -> beforeUnmount() * destroyed() -> unmounted() * The addition of deep: true option on Array listeners is now required to detect Array changes * Open MCT is now mounted on a child div instead of directly on document.body --------- Co-authored-by: Scott Bell <scott@traclabs.com> Co-authored-by: Andrew Henry <akhenry@gmail.com> Co-authored-by: John Hill <john.c.hill@nasa.gov>
36 lines
846 B
JavaScript
36 lines
846 B
JavaScript
import Vue from 'vue';
|
|
import HelloWorld from './HelloWorld.vue';
|
|
|
|
function SimpleVuePlugin() {
|
|
return function install(openmct) {
|
|
openmct.types.addType('hello-world', {
|
|
name: 'Hello World',
|
|
description: 'An introduction object',
|
|
creatable: true
|
|
});
|
|
openmct.objectViews.addProvider({
|
|
name: 'demo-provider',
|
|
key: 'hello-world',
|
|
cssClass: 'icon-packet',
|
|
canView: function (d) {
|
|
return d.type === 'hello-world';
|
|
},
|
|
view: function (domainObject) {
|
|
var vm;
|
|
|
|
return {
|
|
show: function (container) {
|
|
vm = new Vue(HelloWorld);
|
|
container.appendChild(vm.$mount().$el);
|
|
},
|
|
destroy: function (container) {
|
|
//vm.$destroy();
|
|
}
|
|
};
|
|
}
|
|
});
|
|
};
|
|
}
|
|
|
|
export default SimpleVuePlugin;
|