aboutsummaryrefslogtreecommitdiff
path: root/js/document/views/base.js
blob: 897591953a1b3ec7dd3bde9a29bdaf65febeaeeb (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
/* <copyright>
This file contains proprietary software owned by Motorola Mobility, Inc.<br/>
No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/>
(c) Copyright 2011 Motorola Mobility, Inc.  All Rights Reserved.
</copyright> */

////////////////////////////////////////////////////////////////////////
//
var Montage = 	require("montage/core/core").Montage,
	Component = require("montage/ui/component").Component,
	UrlParser = require("js/document/helpers/url-parser").UrlParser;
////////////////////////////////////////////////////////////////////////
//	
exports.BaseDocumentView = Montage.create(Component, {
	////////////////////////////////////////////////////////////////////
	//
	hasTemplate: {
        value: false
    },
    ////////////////////////////////////////////////////////////////////
	//
	urlParser: {
        value: UrlParser
    },
	////////////////////////////////////////////////////////////////////
	//
	_iframe: {
        value: null
    },
    ////////////////////////////////////////////////////////////////////
	//TODO: This should be renamed to better illustrate it's a container (iframe for design, div for code view)
	iframe: {
		get: function() {return this._iframe;},
        set: function(value) {this._iframe= value;}
    },
   	////////////////////////////////////////////////////////////////////
	//
	show: {
        value: function (callback) {
        	if (this.iframe) {
        		this.iframe.style.display = 'block';
                this.iframe.style.opacity = 1;
                this.toggleWebGlAnimation(true);
        	} else {
        		console.log('Error: View has no iframe to show!');
        	}
        	//
        	if (callback) callback();
        }
    },
    ////////////////////////////////////////////////////////////////////
	//
	hide: {
        value: function (callback) {
        	if (this.iframe) {
        		this.iframe.style.display = 'none';
                this.iframe.style.opacity = 0;
                this.pauseVideos();
                this.toggleWebGlAnimation(false);
        	} else {
        		console.log('Error: View has no iframe to hide!');
        	}
        	//
        	if (callback) callback();
        }
    }
	////////////////////////////////////////////////////////////////////
	////////////////////////////////////////////////////////////////////
});
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////