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

viewLargeAction.js « viewLargeAction « plugins « src - github.com/nasa/openmct.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 9d5891fff153a5a3d44d0776383d74da89bf3fd1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*****************************************************************************
 * 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 Preview from '@/ui/preview/Preview.vue';

import Vue from 'vue';

export default class ViewLargeAction {
    constructor(openmct) {
        this.openmct = openmct;

        this.cssClass = 'icon-items-expand';
        this.description = 'View Large';
        this.group = 'windowing';
        this.key = 'large.view';
        this.name = 'Large View';
        this.priority = 1;
        this.showInStatusBar = true;
    }

    invoke(objectPath, view) {
        performance.mark('viewlarge.start');
        const childElement = view?.parentElement?.firstChild;
        if (!childElement) {
            const message = "ViewLargeAction: missing element";
            this.openmct.notifications.error(message);
            throw new Error(message);
        }

        this._expand(objectPath, view);
    }

    appliesTo(objectPath, view) {
        const childElement = view?.parentElement?.firstChild;

        return childElement && !childElement.classList.contains('js-main-container')
            && !this.openmct.router.isNavigatedObject(objectPath);
    }

    _expand(objectPath, view) {
        const element = this._getPreview(objectPath, view);

        this.overlay = this.openmct.overlays.overlay({
            element,
            size: 'large',
            autoHide: false,
            onDestroy: () => {
                this.preview.$destroy();
                this.preview = undefined;
                delete this.preview;
            }
        });
    }

    _getPreview(objectPath, view) {
        this.preview = new Vue({
            components: {
                Preview
            },
            provide: {
                openmct: this.openmct,
                objectPath
            },
            data() {
                return {
                    view
                };
            },
            template: '<Preview :existing-view="view"></Preview>'
        });

        return this.preview.$mount().$el;
    }
}