aboutsummaryrefslogtreecommitdiff
path: root/js/panels/presets/content.reel/content.js
blob: eba150c36e4cfd04d95a7a5e3a08be33f3081eb4 (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
/* <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;

exports.content = Montage.create(Component, {
    hasTemplate: {
        value: true
    },
    contentPanel : {
        value: null
    },
    activeTabIndex: {
        value: null,
        serializable: true
    },
    templateDidLoad : {
        value: function() {
            var storedTabIndex = this.application.localStorage.getItem("presetsTabIndex");
            if(storedTabIndex) {
                this.activeTabIndex = storedTabIndex;
            }
        }
    },
    prepareForDraw : {
        value: function() {
            this.activeTab = this.tabs[this.activeTabIndex];
            this.tabBar.addEventListener('click', this, false);
        }
    },
    handleClick : {
        value: function(e) {
            var tabObject = this.tabs.filter(function(item) {
                return item.tab === e._event.target;
            });

            if(tabObject[0]) {
                this.activeTab = tabObject[0];
            }

        }
    },
    _activeTab : {
        value: null,
        enumerable: false
    },
    activeTab : {
        get: function() {
            return this._activeTab;
        },
        set: function(tabObject) {
            this.contentPanel = tabObject.key;
            this.application.localStorage.setItem("presetsTabIndex", this.tabs.indexOf(tabObject));
            this._tabToDeactivate = this._activeTab;
            this._activeTab = tabObject;

            this.needsDraw = this._needsTabSwitch = true;
        },
        serializable: true
    },
    tabBar: {
        value: null,
        serializable: true
    },
    tabs:{
        value: null,
        serializable: true
    },
    _tabToDeactivate : {
        value: null,
        enumarable: false
    },
    _needsTabSwitch : {
        value: null,
        enumerable: false
    },
    draw : {
        value: function() {
            if(this._needsTabSwitch) {
                if(this._tabToDeactivate) {
                    this._tabToDeactivate.tab.classList.remove('active-tab');
                }

                this._activeTab.tab.classList.add('active-tab');
            }
        }
    }
});