co-datalets-creator-controllet.html 4.07 KB
<script src="../shared_js/perfect-scrollbar/js/min/perfect-scrollbar.jquery.min.js"></script>
<link rel="stylesheet" href="../shared_js/perfect-scrollbar/css/perfect-scrollbar.min.css">

<script src="../../locales/controllet_ln.js"></script>

<link rel="import" href="../../bower_components/polymer/polymer.html">

<link rel="import" href="../page-slider-controllet/page-slider-controllet.html">

<link rel="import" href="../select-data-controllet/select-data-controllet.html" />
<link rel="import" href="../select-visualization-controllet/select-visualization-controllet.html" />

<dom-module id="co-datalets-creator-controllet">

    <template>

        <page-slider-controllet id="slider">

            <neon-animatable>

                <select-data-controllet id="select_data"></select-data-controllet>

            </neon-animatable>

            <neon-animatable>

                <select-visualization-controllet id="select_visualization" deep-url={{deepUrl}} datalets-list-url={{dataletsListUrl}}></select-visualization-controllet>

            </neon-animatable>

        </page-slider-controllet>

    </template>

    <script>

        Polymer({

            is : 'co-datalets-creator-controllet',

            listeners : {
                'page-slider-controllet_selected' : '_updateSlider',
                'select-fields-controllet_selected-fields' : '_allowThirdStep',
                'filters-controllet_filters': '_allowThirdStep'
            },

            properties : {

                dataUrl : {
                    type  : String,
                    value : undefined
                },

                data : {
                    type : Array,
                    value : []
                },

                deepUrl : {
                    type : String,
                    value : undefined
                },

                dataletsListUrl : {
                    type : String ,
                    value : undefined
                },

                localization : {
                    type : String,
                    value : "en"
                }

            },

            ready : function(){
                ln["localization"] = this.localization;

                this.$.select_data.data = this.data;
                this.$.select_data.dataUrl = this.dataUrl;
                this.$.select_data.init();
                this.$.select_visualization.dataUrl = this.dataUrl;
                this.$.select_visualization.init();
            },

            _updateSlider : function(e){
                switch (e.detail.selected) {
                    case 0:
                        this.$.slider.setTitle(ln["slide2Title_" + this.localization], ln["slide2Subtitle_" + this.localization]);

                        this.$.slider.chevronLeft("invisible");
                        this.$.slider.chevronRight(false);

                        if(this.$.slider.getPrevSelected() == 1)
                            this.$.slider.chevronRight(true);
                        break;
                    case 1:
                        this.$.slider.setTitle(ln["slide3Title_" + this.localization], ln["slide3Subtitle_" + this.localization]);

                        this.$.slider.chevronLeft(true);
                        this.$.slider.chevronRight("invisible");
                }
            },

            _allowThirdStep : function(){
                this.$.slider.chevronRight(false);
                var fields = this.$.select_data.getSelectedFields();
                var filters = this.$.select_data.getFilters();
                var data = this.$.select_data.getData();
                if(fields.length > 0) {
                    this.$.select_visualization.init();
                    this.$.select_visualization.setFields(fields);
                    this.$.select_visualization.setFilters(filters);
                    this.$.select_visualization.setData(data);
                    this.$.slider.chevronRight(true);
                }
            }

        });

    </script>

</dom-module>