Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nasa/openmct.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/timelist/TimelistViewProvider.js')
-rw-r--r--src/plugins/timelist/TimelistViewProvider.js68
1 files changed, 68 insertions, 0 deletions
diff --git a/src/plugins/timelist/TimelistViewProvider.js b/src/plugins/timelist/TimelistViewProvider.js
new file mode 100644
index 000000000..ed2101ccc
--- /dev/null
+++ b/src/plugins/timelist/TimelistViewProvider.js
@@ -0,0 +1,68 @@
+/*****************************************************************************
+ * Open MCT, Copyright (c) 2014-2022, United States Government
+ * as represented by the Administrator of the National Aeronautics and Space
+ * Administration. All rights reserved.
+ *
+ * Open MCT is licensed under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ * http://www.apache.org/licenses/LICENSE-2.0.
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations
+ * under the License.
+ *
+ * Open MCT includes source code licensed under additional open source
+ * licenses. See the Open Source Licenses file (LICENSES.md) included with
+ * this source code distribution or the Licensing information page available
+ * at runtime from the About dialog for additional information.
+ *****************************************************************************/
+
+import Timelist from './Timelist.vue';
+import { TIMELIST_TYPE } from './constants';
+import Vue from 'vue';
+
+export default function TimelistViewProvider(openmct) {
+
+ return {
+ key: 'timelist.view',
+ name: 'Time List',
+ cssClass: 'icon-timelist',
+ canView(domainObject) {
+ return domainObject.type === TIMELIST_TYPE;
+ },
+
+ canEdit(domainObject) {
+ return domainObject.type === TIMELIST_TYPE;
+ },
+
+ view: function (domainObject, objectPath) {
+ let component;
+
+ return {
+ show: function (element) {
+
+ component = new Vue({
+ el: element,
+ components: {
+ Timelist
+ },
+ provide: {
+ openmct,
+ domainObject,
+ path: objectPath,
+ composition: openmct.composition.get(domainObject)
+ },
+ template: '<timelist></timelist>'
+ });
+ },
+ destroy: function () {
+ component.$destroy();
+ component = undefined;
+ }
+ };
+ }
+ };
+}