Passed
Push — master ( 283033...66ce56 )
by Guangyu
07:51 queued 11s
created

admin/app/controllers.js (9 issues)

1
/**
2
 * INSPINIA - Responsive Admin Theme
3
 *
4
 * Main controller.js file
5
 * Define controllers with data used in Inspinia theme
6
 *
7
 *
8
 * Functions (controllers)
9
 *  - MainCtrl
10
 *  - dashboardFlotOne
11
 *  - dashboardFlotTwo
12
 *  - dashboardFlotFive
13
 *  - dashboardMap
14
 *  - flotChartCtrl
15
 *  - rickshawChartCtrl
16
 *  - sparklineChartCtrl
17
 *  - widgetFlotChart
18
 *  - modalDemoCtrl
19
 *  - ionSlider
20
 *  - wizardCtrl
21
 *  - CalendarCtrl
22
 *  - chartJsCtrl
23
 *  - GoogleMaps
24
 *  - ngGridCtrl
25
 *  - codeEditorCtrl
26
 *  - nestableCtrl
27
 *  - notifyCtrl
28
 *  - translateCtrl
29
 *  - imageCrop
30
 *  - diff
31
 *  - idleTimer
32
 *  - liveFavicon
33
 *  - formValidation
34
 *  - agileBoard
35
 *  - draggablePanels
36
 *  - chartistCtrl
37
 *  - metricsCtrl
38
 *  - sweetAlertCtrl
39
 *  - selectCtrl
40
 *  - toastrCtrl
41
 *  - loadingCtrl
42
 *  - datatablesCtrl
43
 *  - truncateCtrl
44
 *  - touchspinCtrl
45
 *  - tourCtrl
46
 *  - jstreeCtrl
47
 *
48
 *
49
 */
50
51
/**
52
 * MainCtrl - controller
53
 * Contains several global data used in different view
54
 *
55
 */
56
function MainCtrl($scope) {
57
    $scope.show="subfactory";
58
    /**
59
     * daterange - Used as initial model for data range picker in Advanced form view
60
     */
61
    this.daterange = {startDate: null, endDate: null};
62
63
    /**
64
     * slideInterval - Interval for bootstrap Carousel, in milliseconds:
65
     */
66
    this.slideInterval = 5000;
67
68
69
    /**
70
     * states - Data used in Advanced Form view for Chosen plugin
71
     */
72
    this.states = [
73
        'Alabama',
74
        'Alaska',
75
        'Arizona',
76
        'Arkansas',
77
        'California',
78
        'Colorado',
79
        'Connecticut',
80
        'Delaware',
81
        'Florida',
82
        'Georgia',
83
        'Hawaii',
84
        'Idaho',
85
        'Illinois',
86
        'Indiana',
87
        'Iowa',
88
        'Kansas',
89
        'Kentucky',
90
        'Louisiana',
91
        'Maine',
92
        'Maryland',
93
        'Massachusetts',
94
        'Michigan',
95
        'Minnesota',
96
        'Mississippi',
97
        'Missouri',
98
        'Montana',
99
        'Nebraska',
100
        'Nevada',
101
        'New Hampshire',
102
        'New Jersey',
103
        'New Mexico',
104
        'New York',
105
        'North Carolina',
106
        'North Dakota',
107
        'Ohio',
108
        'Oklahoma',
109
        'Oregon',
110
        'Pennsylvania',
111
        'Rhode Island',
112
        'South Carolina',
113
        'South Dakota',
114
        'Tennessee',
115
        'Texas',
116
        'Utah',
117
        'Vermont',
118
        'Virginia',
119
        'Washington',
120
        'West Virginia',
121
        'Wisconsin',
122
        'Wyoming'
123
    ];
124
125
    /**
126
     * check's - Few variables for checkbox input used in iCheck plugin. Only for demo purpose
127
     */
128
    this.checkOne = true;
129
    this.checkTwo = true;
130
    this.checkThree = true;
131
    this.checkFour = true;
132
133
    /**
134
     * knobs - Few variables for knob plugin used in Advanced Plugins view
135
     */
136
    this.knobOne = 75;
137
    this.knobTwo = 25;
138
    this.knobThree = 50;
139
140
    /**
141
     * Variables used for Ui Elements view
142
     */
143
    this.bigTotalItems = 175;
144
    this.bigCurrentPage = 1;
145
    this.maxSize = 5;
146
    this.singleModel = false;
147
    this.radioModel = 'Middle';
148
    this.checkModel = {
149
        left: false,
150
        middle: true,
151
        right: false
152
    };
153
154
    /**
155
     * groups - used for Collapse panels in Tabs and Panels view
156
     */
157
    this.groups = [
158
        {
159
            title: 'Dynamic Group Header - 1',
160
            content: 'Dynamic Group Body - 1'
161
        },
162
        {
163
            title: 'Dynamic Group Header - 2',
164
            content: 'Dynamic Group Body - 2'
165
        }
166
    ];
167
168
    /**
169
     * alerts - used for dynamic alerts in Notifications and Tooltips view
170
     */
171
    this.alerts = [
172
        { type: 'danger', msg: 'Oh snap! Change a few things up and try submitting again.' },
173
        { type: 'success', msg: 'Well done! You successfully read this important alert message.' },
174
        { type: 'info', msg: 'OK, You are done a great job man.' }
175
    ];
176
177
    /**
178
     * addAlert, closeAlert  - used to manage alerts in Notifications and Tooltips view
179
     */
180
    this.addAlert = function() {
181
        this.alerts.push({msg: 'Another alert!'});
182
    };
183
184
    this.closeAlert = function(index) {
185
        this.alerts.splice(index, 1);
186
    };
187
188
    /**
189
     * randomStacked - used for progress bar (stacked type) in Badges adn Labels view
190
     */
191
    this.randomStacked = function() {
192
        this.stacked = [];
193
        var types = ['success', 'info', 'warning', 'danger'];
194
195
        for (var i = 0, n = Math.floor((Math.random() * 4) + 1); i < n; i++) {
196
            var index = Math.floor((Math.random() * 4));
197
            this.stacked.push({
198
                value: Math.floor((Math.random() * 30) + 1),
199
                type: types[index]
200
            });
201
        }
202
    };
203
    /**
204
     * initial run for random stacked value
205
     */
206
    this.randomStacked();
207
208
    /**
209
     * General variables for Peity Charts
210
     * used in many view so this is in Main controller
211
     */
212
    this.BarChart = {
213
        data: [5, 3, 9, 6, 5, 9, 7, 3, 5, 2, 4, 7, 3, 2, 7, 9, 6, 4, 5, 7, 3, 2, 1, 0, 9, 5, 6, 8, 3, 2, 1],
214
        options: {
215
            fill: ["#1ab394", "#d7d7d7"],
216
            width: 100
217
        }
218
    };
219
220
    this.BarChart2 = {
221
        data: [5, 3, 9, 6, 5, 9, 7, 3, 5, 2],
222
        options: {
223
            fill: ["#1ab394", "#d7d7d7"]
224
        }
225
    };
226
227
    this.BarChart3 = {
228
        data: [5, 3, 2, -1, -3, -2, 2, 3, 5, 2],
229
        options: {
230
            fill: ["#1ab394", "#d7d7d7"]
231
        }
232
    };
233
234
    this.LineChart = {
235
        data: [5, 9, 7, 3, 5, 2, 5, 3, 9, 6, 5, 9, 4, 7, 3, 2, 9, 8, 7, 4, 5, 1, 2, 9, 5, 4, 7],
236
        options: {
237
            fill: '#1ab394',
238
            stroke: '#169c81',
239
            width: 64
240
        }
241
    };
242
243
    this.LineChart2 = {
244
        data: [3, 2, 9, 8, 47, 4, 5, 1, 2, 9, 5, 4, 7],
245
        options: {
246
            fill: '#1ab394',
247
            stroke: '#169c81',
248
            width: 64
249
        }
250
    };
251
252
    this.LineChart3 = {
253
        data: [5, 3, 2, -1, -3, -2, 2, 3, 5, 2],
254
        options: {
255
            fill: '#1ab394',
256
            stroke: '#169c81',
257
            width: 64
258
        }
259
    };
260
261
    this.LineChart4 = {
262
        data: [5, 3, 9, 6, 5, 9, 7, 3, 5, 2],
263
        options: {
264
            fill: '#1ab394',
265
            stroke: '#169c81',
266
            width: 64
267
        }
268
    };
269
270
    this.PieChart = {
271
        data: [1, 5],
272
        options: {
273
            fill: ["#1ab394", "#d7d7d7"]
274
        }
275
    };
276
277
    this.PieChart2 = {
278
        data: [226, 360],
279
        options: {
280
            fill: ["#1ab394", "#d7d7d7"]
281
        }
282
    };
283
    this.PieChart3 = {
284
        data: [0.52, 1.561],
285
        options: {
286
            fill: ["#1ab394", "#d7d7d7"]
287
        }
288
    };
289
    this.PieChart4 = {
290
        data: [1, 4],
291
        options: {
292
            fill: ["#1ab394", "#d7d7d7"]
293
        }
294
    };
295
    this.PieChart5 = {
296
        data: [226, 134],
297
        options: {
298
            fill: ["#1ab394", "#d7d7d7"]
299
        }
300
    };
301
    this.PieChart6 = {
302
        data: [0.52, 1.041],
303
        options: {
304
            fill: ["#1ab394", "#d7d7d7"]
305
        }
306
    };
307
};
308
309
310
/**
311
 * dashboardFlotOne - simple controller for data
312
 * for Flot chart in Dashboard view
313
 */
314
function dashboardFlotOne() {
315
316
    var data1 = [
317
        [0, 4],
318
        [1, 8],
319
        [2, 5],
320
        [3, 10],
321
        [4, 4],
322
        [5, 16],
323
        [6, 5],
324
        [7, 11],
325
        [8, 6],
326
        [9, 11],
327
        [10, 30],
328
        [11, 10],
329
        [12, 13],
330
        [13, 4],
331
        [14, 3],
332
        [15, 3],
333
        [16, 6]
334
    ];
335
    var data2 = [
336
        [0, 1],
337
        [1, 0],
338
        [2, 2],
339
        [3, 0],
340
        [4, 1],
341
        [5, 3],
342
        [6, 1],
343
        [7, 5],
344
        [8, 2],
345
        [9, 3],
346
        [10, 2],
347
        [11, 1],
348
        [12, 0],
349
        [13, 2],
350
        [14, 8],
351
        [15, 0],
352
        [16, 0]
353
    ];
354
355
    var options = {
356
        series: {
357
            lines: {
358
                show: false,
359
                fill: true
360
            },
361
            splines: {
362
                show: true,
363
                tension: 0.4,
364
                lineWidth: 1,
365
                fill: 0.4
366
            },
367
            points: {
368
                radius: 0,
369
                show: true
370
            },
371
            shadowSize: 2,
372
            grow: {stepMode:"linear",stepDirection:"up",steps:80}
373
        },
374
        grow: {stepMode:"linear",stepDirection:"up",steps:80},
375
        grid: {
376
            hoverable: true,
377
            clickable: true,
378
            tickColor: "#d5d5d5",
379
            borderWidth: 1,
380
            color: '#d5d5d5'
381
        },
382
        colors: ["#1ab394", "#1C84C6"],
383
        xaxis: {
384
        },
385
        yaxis: {
386
            ticks: 4
387
        },
388
        tooltip: false
389
    };
390
391
    /**
392
     * Definition of variables
393
     * Flot chart
394
     */
395
    this.flotData = [data1, data2];
396
    this.flotOptions = options;
397
}
398
399
/**
400
 * dashboardFlotTwo - simple controller for data
401
 * for Flot chart in Dashboard view
402
 */
403
function dashboardFlotTwo() {
404
405
    var data1 = [
406
        [gd(2012, 1, 1), 7],
407
        [gd(2012, 1, 2), 6],
408
        [gd(2012, 1, 3), 4],
409
        [gd(2012, 1, 4), 8],
410
        [gd(2012, 1, 5), 9],
411
        [gd(2012, 1, 6), 7],
412
        [gd(2012, 1, 7), 5],
413
        [gd(2012, 1, 8), 4],
414
        [gd(2012, 1, 9), 7],
415
        [gd(2012, 1, 10), 8],
416
        [gd(2012, 1, 11), 9],
417
        [gd(2012, 1, 12), 6],
418
        [gd(2012, 1, 13), 4],
419
        [gd(2012, 1, 14), 5],
420
        [gd(2012, 1, 15), 11],
421
        [gd(2012, 1, 16), 8],
422
        [gd(2012, 1, 17), 8],
423
        [gd(2012, 1, 18), 11],
424
        [gd(2012, 1, 19), 11],
425
        [gd(2012, 1, 20), 6],
426
        [gd(2012, 1, 21), 6],
427
        [gd(2012, 1, 22), 8],
428
        [gd(2012, 1, 23), 11],
429
        [gd(2012, 1, 24), 13],
430
        [gd(2012, 1, 25), 7],
431
        [gd(2012, 1, 26), 9],
432
        [gd(2012, 1, 27), 9],
433
        [gd(2012, 1, 28), 8],
434
        [gd(2012, 1, 29), 5],
435
        [gd(2012, 1, 30), 8],
436
        [gd(2012, 1, 31), 25]
437
    ];
438
439
    var data2 = [
440
        [gd(2012, 1, 1), 800],
441
        [gd(2012, 1, 2), 500],
442
        [gd(2012, 1, 3), 600],
443
        [gd(2012, 1, 4), 700],
444
        [gd(2012, 1, 5), 500],
445
        [gd(2012, 1, 6), 456],
446
        [gd(2012, 1, 7), 800],
447
        [gd(2012, 1, 8), 589],
448
        [gd(2012, 1, 9), 467],
449
        [gd(2012, 1, 10), 876],
450
        [gd(2012, 1, 11), 689],
451
        [gd(2012, 1, 12), 700],
452
        [gd(2012, 1, 13), 500],
453
        [gd(2012, 1, 14), 600],
454
        [gd(2012, 1, 15), 700],
455
        [gd(2012, 1, 16), 786],
456
        [gd(2012, 1, 17), 345],
457
        [gd(2012, 1, 18), 888],
458
        [gd(2012, 1, 19), 888],
459
        [gd(2012, 1, 20), 888],
460
        [gd(2012, 1, 21), 987],
461
        [gd(2012, 1, 22), 444],
462
        [gd(2012, 1, 23), 999],
463
        [gd(2012, 1, 24), 567],
464
        [gd(2012, 1, 25), 786],
465
        [gd(2012, 1, 26), 666],
466
        [gd(2012, 1, 27), 888],
467
        [gd(2012, 1, 28), 900],
468
        [gd(2012, 1, 29), 178],
469
        [gd(2012, 1, 30), 555],
470
        [gd(2012, 1, 31), 993]
471
    ];
472
473
474
    var dataset = [
475
        {
476
            label: "能耗",
477
            grow:{stepMode:"linear"},
478
            data: data2,
479
            color: "#1ab394",
480
            bars: {
481
                show: true,
482
                align: "center",
483
                barWidth: 24 * 60 * 60 * 600,
484
                lineWidth: 0
485
            }
486
487
        },
488
        {
489
            label: "费用",
490
            grow:{stepMode:"linear"},
491
            data: data1,
492
            yaxis: 2,
493
            color: "#1C84C6",
494
            lines: {
495
                lineWidth: 1,
496
                show: true,
497
                fill: true,
498
                fillColor: {
499
                    colors: [
500
                        {
501
                            opacity: 0.2
502
                        },
503
                        {
504
                            opacity: 0.2
505
                        }
506
                    ]
507
                }
508
            }
509
        }
510
    ];
511
512
513
    var options = {
514
        grid: {
515
            hoverable: true,
516
            clickable: true,
517
            tickColor: "#d5d5d5",
518
            borderWidth: 0,
519
            color: '#d5d5d5'
520
        },
521
        colors: ["#1ab394", "#464f88"],
522
        tooltip: true,
523
        xaxis: {
524
            mode: "time",
525
            tickSize: [3, "day"],
526
            tickLength: 0,
527
            axisLabel: "Date",
528
            axisLabelUseCanvas: true,
529
            axisLabelFontSizePixels: 12,
530
            axisLabelFontFamily: 'Arial',
531
            axisLabelPadding: 10,
532
            color: "#d5d5d5"
533
        },
534
        yaxes: [
535
            {
536
                position: "left",
537
                max: 1070,
538
                color: "#d5d5d5",
539
                axisLabelUseCanvas: true,
540
                axisLabelFontSizePixels: 12,
541
                axisLabelFontFamily: 'Arial',
542
                axisLabelPadding: 3
543
            },
544
            {
545
                position: "right",
546
                color: "#d5d5d5",
547
                axisLabelUseCanvas: true,
548
                axisLabelFontSizePixels: 12,
549
                axisLabelFontFamily: ' Arial',
550
                axisLabelPadding: 67
551
            }
552
        ],
553
        legend: {
554
            noColumns: 1,
555
            labelBoxBorderColor: "#d5d5d5",
556
            position: "nw"
557
        }
558
559
    };
560
561
    function gd(year, month, day) {
562
        return new Date(year, month - 1, day).getTime();
563
    }
564
565
    /**
566
     * Definition of variables
567
     * Flot chart
568
     */
569
    this.flotData = dataset;
570
    this.flotOptions = options;
571
}
572
573
/**
574
 * dashboardFlotFive - simple controller for data
575
 * for Flot chart in Dashboard view
576
 */
577
function dashboardFive() {
578
579
    var data1 = [
580
        [0,4],[1,8],[2,5],[3,10],[4,4],[5,16],[6,5],[7,11],[8,6],[9,11],[10,20],[11,10],[12,13],[13,4],[14,7],[15,8],[16,12]
581
    ];
582
    var data2 = [
583
        [0,0],[1,2],[2,7],[3,4],[4,11],[5,4],[6,2],[7,5],[8,11],[9,5],[10,4],[11,1],[12,5],[13,2],[14,5],[15,2],[16,0]
584
    ];
585
586
    var options = {
587
        series: {
588
            lines: {
589
                show: false,
590
                fill: true
591
            },
592
            splines: {
593
                show: true,
594
                tension: 0.4,
595
                lineWidth: 1,
596
                fill: 0.4
597
            },
598
            points: {
599
                radius: 0,
600
                show: true
601
            },
602
            shadowSize: 2
603
        },
604
        grid: {
605
            hoverable: true,
606
            clickable: true,
607
608
            borderWidth: 2,
609
            color: 'transparent'
610
        },
611
        colors: ["#1ab394", "#1C84C6"],
612
        xaxis:{
613
        },
614
        yaxis: {
615
        },
616
        tooltip: false
617
    };
618
619
    /**
620
     * Definition of variables
621
     * Flot chart
622
     */
623
    this.flotData = [data1, data2];
624
    this.flotOptions = options;
625
626
627
    var sparkline1Data = [34, 43, 43, 35, 44, 32, 44, 52];
628
    var sparkline1Options = {
629
        type: 'line',
630
        width: '100%',
631
        height: '50',
632
        lineColor: '#1ab394',
633
        fillColor: "transparent"
634
    };
635
636
    var sparkline2Data = [32, 11, 25, 37, 41, 32, 34, 42];
637
    var sparkline2Options = {
638
        type: 'line',
639
        width: '100%',
640
        height: '50',
641
        lineColor: '#1ab394',
642
        fillColor: "transparent"
643
    };
644
645
    this.sparkline1 = sparkline1Data;
646
    this.sparkline1Options = sparkline1Options;
647
    this.sparkline2 = sparkline2Data;
648
    this.sparkline2Options = sparkline2Options;
649
650
}
651
652
653
/**
654
 * dashboardMap - data for Map plugin
655
 * used in Dashboard 2 view
656
 */
657
658
function dashboardMap() {
659
    var data = {
660
        "US": 298,
661
        "SA": 200,
662
        "DE": 220,
663
        "FR": 540,
664
        "CN": 120,
665
        "AU": 760,
666
        "BR": 550,
667
        "IN": 200,
668
        "GB": 120
669
    };
670
671
    this.data = data;
672
}
673
674
/**
675
 * flotChartCtrl - Controller for data for All flot chart
676
 * used in Flot chart view
677
 */
678
679
function flotChartCtrl() {
680
681
    /**
682
     * Bar Chart Options
683
     */
684
    var barOptions = {
685
        series: {
686
            bars: {
687
                show: true,
688
                barWidth: 0.6,
689
                fill: true,
690
                fillColor: {
691
                    colors: [
692
                        {
693
                            opacity: 0.8
694
                        },
695
                        {
696
                            opacity: 0.8
697
                        }
698
                    ]
699
                }
700
            }
701
        },
702
        xaxis: {
703
            tickDecimals: 0
704
        },
705
        colors: ["#1ab394"],
706
        grid: {
707
            color: "#999999",
708
            hoverable: true,
709
            clickable: true,
710
            tickColor: "#D4D4D4",
711
            borderWidth: 0
712
        },
713
        legend: {
714
            show: false
715
        },
716
        tooltip: true,
717
        tooltipOpts: {
718
            content: "x: %x, y: %y"
719
        }
720
    };
721
722
    /**
723
     * Bar Chart data
724
     */
725
    var chartData = [
726
        {
727
            label: "bar",
728
            data: [
729
                [1, 34],
730
                [2, 25],
731
                [3, 19],
732
                [4, 34],
733
                [5, 32],
734
                [6, 44]
735
            ]
736
        }
737
    ];
738
739
    /**
740
     * Pie Chart Data
741
     */
742
    var pieData = [
743
        {
744
            label: "Sales 1",
745
            data: 21,
746
            color: "#d3d3d3"
747
        },
748
        {
749
            label: "Sales 2",
750
            data: 3,
751
            color: "#bababa"
752
        },
753
        {
754
            label: "Sales 3",
755
            data: 15,
756
            color: "#79d2c0"
757
        },
758
        {
759
            label: "Sales 4",
760
            data: 52,
761
            color: "#1ab394"
762
        }
763
    ];
764
765
    /**
766
     * Pie Chart Options
767
     */
768
    var pieOptions = {
769
        series: {
770
            pie: {
771
                show: true
772
            }
773
        },
774
        grid: {
775
            hoverable: true
776
        },
777
        tooltip: true,
778
        tooltipOpts: {
779
            content: "%p.0%, %s", // show percentages, rounding to 2 decimal places
780
            shifts: {
781
                x: 20,
782
                y: 0
783
            },
784
            defaultTheme: false
785
        }
786
    };
787
788
    /**
789
     * Line Chart Options
790
     */
791
    var lineOptions = {
792
        series: {
793
            lines: {
794
                show: true,
795
                lineWidth: 2,
796
                fill: true,
797
                fillColor: {
798
                    colors: [
799
                        {
800
                            opacity: 0.0
801
                        },
802
                        {
803
                            opacity: 0.0
804
                        }
805
                    ]
806
                }
807
            }
808
        },
809
        xaxis: {
810
            tickDecimals: 0
811
        },
812
        colors: ["#1ab394"],
813
        grid: {
814
            color: "#999999",
815
            hoverable: true,
816
            clickable: true,
817
            tickColor: "#D4D4D4",
818
            borderWidth: 0
819
        },
820
        legend: {
821
            show: false
822
        },
823
        tooltip: true,
824
        tooltipOpts: {
825
            content: "x: %x, y: %y"
826
        }
827
    };
828
829
    /**
830
     * Line Chart Data
831
     */
832
    var lineAreaData = [
833
        {
834
            label: "line",
835
            data: [
836
                [1, 34],
837
                [2, 22],
838
                [3, 19],
839
                [4, 12],
840
                [5, 32],
841
                [6, 54],
842
                [7, 23],
843
                [8, 57],
844
                [9, 12],
845
                [10, 24],
846
                [11, 44],
847
                [12, 64],
848
                [13, 21]
849
            ]
850
        }
851
    ];
852
853
    /**
854
     * Line Area Chart Options
855
     */
856
    var lineAreaOptions = {
857
        series: {
858
            lines: {
859
                show: true,
860
                lineWidth: 2,
861
                fill: true,
862
                fillColor: {
863
                    colors: [
864
                        {
865
                            opacity: 0.7
866
                        },
867
                        {
868
                            opacity: 0.5
869
                        }
870
                    ]
871
                }
872
            }
873
        },
874
        xaxis: {
875
            tickDecimals: 0
876
        },
877
        colors: ["#1ab394"],
878
        grid: {
879
            color: "#999999",
880
            hoverable: true,
881
            clickable: true,
882
            tickColor: "#D4D4D4",
883
            borderWidth: 0
884
        },
885
        legend: {
886
            show: false
887
        },
888
        tooltip: true,
889
        tooltipOpts: {
890
            content: "x: %x, y: %y"
891
        }
892
    };
893
894
    /**
895
     * Data for Multi line chart
896
     */
897
    var oilprices = [[1167692400000, 61.05], [1167778800000, 58.32], [1167865200000, 57.35], [1167951600000, 56.31], [1168210800000, 55.55], [1168297200000, 55.64], [1168383600000, 54.02], [1168470000000, 51.88], [1168556400000, 52.99], [1168815600000, 52.99], [1168902000000, 51.21], [1168988400000, 52.24], [1169074800000, 50.48], [1169161200000, 51.99], [1169420400000, 51.13], [1169506800000, 55.04], [1169593200000, 55.37], [1169679600000, 54.23], [1169766000000, 55.42], [1170025200000, 54.01], [1170111600000, 56.97], [1170198000000, 58.14], [1170284400000, 58.14], [1170370800000, 59.02], [1170630000000, 58.74], [1170716400000, 58.88], [1170802800000, 57.71], [1170889200000, 59.71], [1170975600000, 59.89], [1171234800000, 57.81], [1171321200000, 59.06], [1171407600000, 58.00], [1171494000000, 57.99], [1171580400000, 59.39], [1171839600000, 59.39], [1171926000000, 58.07], [1172012400000, 60.07], [1172098800000, 61.14], [1172444400000, 61.39], [1172530800000, 61.46], [1172617200000, 61.79], [1172703600000, 62.00], [1172790000000, 60.07], [1173135600000, 60.69], [1173222000000, 61.82], [1173308400000, 60.05], [1173654000000, 58.91], [1173740400000, 57.93], [1173826800000, 58.16], [1173913200000, 57.55], [1173999600000, 57.11], [1174258800000, 56.59], [1174345200000, 59.61], [1174518000000, 61.69], [1174604400000, 62.28], [1174860000000, 62.91], [1174946400000, 62.93], [1175032800000, 64.03], [1175119200000, 66.03], [1175205600000, 65.87], [1175464800000, 64.64], [1175637600000, 64.38], [1175724000000, 64.28], [1175810400000, 64.28], [1176069600000, 61.51], [1176156000000, 61.89], [1176242400000, 62.01], [1176328800000, 63.85], [1176415200000, 63.63], [1176674400000, 63.61], [1176760800000, 63.10], [1176847200000, 63.13], [1176933600000, 61.83], [1177020000000, 63.38], [1177279200000, 64.58], [1177452000000, 65.84], [1177538400000, 65.06], [1177624800000, 66.46], [1177884000000, 64.40], [1178056800000, 63.68], [1178143200000, 63.19], [1178229600000, 61.93], [1178488800000, 61.47], [1178575200000, 61.55], [1178748000000, 61.81], [1178834400000, 62.37], [1179093600000, 62.46], [1179180000000, 63.17], [1179266400000, 62.55], [1179352800000, 64.94], [1179698400000, 66.27], [1179784800000, 65.50], [1179871200000, 65.77], [1179957600000, 64.18], [1180044000000, 65.20], [1180389600000, 63.15], [1180476000000, 63.49], [1180562400000, 65.08], [1180908000000, 66.30], [1180994400000, 65.96], [1181167200000, 66.93], [1181253600000, 65.98], [1181599200000, 65.35], [1181685600000, 66.26], [1181858400000, 68.00], [1182117600000, 69.09], [1182204000000, 69.10], [1182290400000, 68.19], [1182376800000, 68.19], [1182463200000, 69.14], [1182722400000, 68.19], [1182808800000, 67.77], [1182895200000, 68.97], [1182981600000, 69.57], [1183068000000, 70.68], [1183327200000, 71.09], [1183413600000, 70.92], [1183586400000, 71.81], [1183672800000, 72.81], [1183932000000, 72.19], [1184018400000, 72.56], [1184191200000, 72.50], [1184277600000, 74.15], [1184623200000, 75.05], [1184796000000, 75.92], [1184882400000, 75.57], [1185141600000, 74.89], [1185228000000, 73.56], [1185314400000, 75.57], [1185400800000, 74.95], [1185487200000, 76.83], [1185832800000, 78.21], [1185919200000, 76.53], [1186005600000, 76.86], [1186092000000, 76.00], [1186437600000, 71.59], [1186696800000, 71.47], [1186956000000, 71.62], [1187042400000, 71.00], [1187301600000, 71.98], [1187560800000, 71.12], [1187647200000, 69.47], [1187733600000, 69.26], [1187820000000, 69.83], [1187906400000, 71.09], [1188165600000, 71.73], [1188338400000, 73.36], [1188511200000, 74.04], [1188856800000, 76.30], [1189116000000, 77.49], [1189461600000, 78.23], [1189548000000, 79.91], [1189634400000, 80.09], [1189720800000, 79.10], [1189980000000, 80.57], [1190066400000, 81.93], [1190239200000, 83.32], [1190325600000, 81.62], [1190584800000, 80.95], [1190671200000, 79.53], [1190757600000, 80.30], [1190844000000, 82.88], [1190930400000, 81.66], [1191189600000, 80.24], [1191276000000, 80.05], [1191362400000, 79.94], [1191448800000, 81.44], [1191535200000, 81.22], [1191794400000, 79.02], [1191880800000, 80.26], [1191967200000, 80.30], [1192053600000, 83.08], [1192140000000, 83.69], [1192399200000, 86.13], [1192485600000, 87.61], [1192572000000, 87.40], [1192658400000, 89.47], [1192744800000, 88.60], [1193004000000, 87.56], [1193090400000, 87.56], [1193176800000, 87.10], [1193263200000, 91.86], [1193612400000, 93.53], [1193698800000, 94.53], [1193871600000, 95.93], [1194217200000, 93.98], [1194303600000, 96.37], [1194476400000, 95.46], [1194562800000, 96.32], [1195081200000, 93.43], [1195167600000, 95.10], [1195426800000, 94.64], [1195513200000, 95.10], [1196031600000, 97.70], [1196118000000, 94.42], [1196204400000, 90.62], [1196290800000, 91.01], [1196377200000, 88.71], [1196636400000, 88.32], [1196809200000, 90.23], [1196982000000, 88.28], [1197241200000, 87.86], [1197327600000, 90.02], [1197414000000, 92.25], [1197586800000, 90.63], [1197846000000, 90.63], [1197932400000, 90.49], [1198018800000, 91.24], [1198105200000, 91.06], [1198191600000, 90.49], [1198710000000, 96.62], [1198796400000, 96.00], [1199142000000, 99.62], [1199314800000, 99.18], [1199401200000, 95.09], [1199660400000, 96.33], [1199833200000, 95.67], [1200351600000, 91.90], [1200438000000, 90.84], [1200524400000, 90.13], [1200610800000, 90.57], [1200956400000, 89.21], [1201042800000, 86.99], [1201129200000, 89.85], [1201474800000, 90.99], [1201561200000, 91.64], [1201647600000, 92.33], [1201734000000, 91.75], [1202079600000, 90.02], [1202166000000, 88.41], [1202252400000, 87.14], [1202338800000, 88.11], [1202425200000, 91.77], [1202770800000, 92.78], [1202857200000, 93.27], [1202943600000, 95.46], [1203030000000, 95.46], [1203289200000, 101.74], [1203462000000, 98.81], [1203894000000, 100.88], [1204066800000, 99.64], [1204153200000, 102.59], [1204239600000, 101.84], [1204498800000, 99.52], [1204585200000, 99.52], [1204671600000, 104.52], [1204758000000, 105.47], [1204844400000, 105.15], [1205103600000, 108.75], [1205276400000, 109.92], [1205362800000, 110.33], [1205449200000, 110.21], [1205708400000, 105.68], [1205967600000, 101.84], [1206313200000, 100.86], [1206399600000, 101.22], [1206486000000, 105.90], [1206572400000, 107.58], [1206658800000, 105.62], [1206914400000, 101.58], [1207000800000, 100.98], [1207173600000, 103.83], [1207260000000, 106.23], [1207605600000, 108.50], [1207778400000, 110.11], [1207864800000, 110.14], [1208210400000, 113.79], [1208296800000, 114.93], [1208383200000, 114.86], [1208728800000, 117.48], [1208815200000, 118.30], [1208988000000, 116.06], [1209074400000, 118.52], [1209333600000, 118.75], [1209420000000, 113.46], [1209592800000, 112.52], [1210024800000, 121.84], [1210111200000, 123.53], [1210197600000, 123.69], [1210543200000, 124.23], [1210629600000, 125.80], [1210716000000, 126.29], [1211148000000, 127.05], [1211320800000, 129.07], [1211493600000, 132.19], [1211839200000, 128.85], [1212357600000, 127.76], [1212703200000, 138.54], [1212962400000, 136.80], [1213135200000, 136.38], [1213308000000, 134.86], [1213653600000, 134.01], [1213740000000, 136.68], [1213912800000, 135.65], [1214172000000, 134.62], [1214258400000, 134.62], [1214344800000, 134.62], [1214431200000, 139.64], [1214517600000, 140.21], [1214776800000, 140.00], [1214863200000, 140.97], [1214949600000, 143.57], [1215036000000, 145.29], [1215381600000, 141.37], [1215468000000, 136.04], [1215727200000, 146.40], [1215986400000, 145.18], [1216072800000, 138.74], [1216159200000, 134.60], [1216245600000, 129.29], [1216332000000, 130.65], [1216677600000, 127.95], [1216850400000, 127.95], [1217282400000, 122.19], [1217455200000, 124.08], [1217541600000, 125.10], [1217800800000, 121.41], [1217887200000, 119.17], [1217973600000, 118.58], [1218060000000, 120.02], [1218405600000, 114.45], [1218492000000, 113.01], [1218578400000, 116.00], [1218751200000, 113.77], [1219010400000, 112.87], [1219096800000, 114.53], [1219269600000, 114.98], [1219356000000, 114.98], [1219701600000, 116.27], [1219788000000, 118.15], [1219874400000, 115.59], [1219960800000, 115.46], [1220306400000, 109.71], [1220392800000, 109.35], [1220565600000, 106.23], [1220824800000, 106.34]];
898
    var exchangerates = [[1167606000000, 0.7580], [1167692400000, 0.7580], [1167778800000, 0.75470], [1167865200000, 0.75490], [1167951600000, 0.76130], [1168038000000, 0.76550], [1168124400000, 0.76930], [1168210800000, 0.76940], [1168297200000, 0.76880], [1168383600000, 0.76780], [1168470000000, 0.77080], [1168556400000, 0.77270], [1168642800000, 0.77490], [1168729200000, 0.77410], [1168815600000, 0.77410], [1168902000000, 0.77320], [1168988400000, 0.77270], [1169074800000, 0.77370], [1169161200000, 0.77240], [1169247600000, 0.77120], [1169334000000, 0.7720], [1169420400000, 0.77210], [1169506800000, 0.77170], [1169593200000, 0.77040], [1169679600000, 0.7690], [1169766000000, 0.77110], [1169852400000, 0.7740], [1169938800000, 0.77450], [1170025200000, 0.77450], [1170111600000, 0.7740], [1170198000000, 0.77160], [1170284400000, 0.77130], [1170370800000, 0.76780], [1170457200000, 0.76880], [1170543600000, 0.77180], [1170630000000, 0.77180], [1170716400000, 0.77280], [1170802800000, 0.77290], [1170889200000, 0.76980], [1170975600000, 0.76850], [1171062000000, 0.76810], [1171148400000, 0.7690], [1171234800000, 0.7690], [1171321200000, 0.76980], [1171407600000, 0.76990], [1171494000000, 0.76510], [1171580400000, 0.76130], [1171666800000, 0.76160], [1171753200000, 0.76140], [1171839600000, 0.76140], [1171926000000, 0.76070], [1172012400000, 0.76020], [1172098800000, 0.76110], [1172185200000, 0.76220], [1172271600000, 0.76150], [1172358000000, 0.75980], [1172444400000, 0.75980], [1172530800000, 0.75920], [1172617200000, 0.75730], [1172703600000, 0.75660], [1172790000000, 0.75670], [1172876400000, 0.75910], [1172962800000, 0.75820], [1173049200000, 0.75850], [1173135600000, 0.76130], [1173222000000, 0.76310], [1173308400000, 0.76150], [1173394800000, 0.760], [1173481200000, 0.76130], [1173567600000, 0.76270], [1173654000000, 0.76270], [1173740400000, 0.76080], [1173826800000, 0.75830], [1173913200000, 0.75750], [1173999600000, 0.75620], [1174086000000, 0.7520], [1174172400000, 0.75120], [1174258800000, 0.75120], [1174345200000, 0.75170], [1174431600000, 0.7520], [1174518000000, 0.75110], [1174604400000, 0.7480], [1174690800000, 0.75090], [1174777200000, 0.75310], [1174860000000, 0.75310], [1174946400000, 0.75270], [1175032800000, 0.74980], [1175119200000, 0.74930], [1175205600000, 0.75040], [1175292000000, 0.750], [1175378400000, 0.74910], [1175464800000, 0.74910], [1175551200000, 0.74850], [1175637600000, 0.74840], [1175724000000, 0.74920], [1175810400000, 0.74710], [1175896800000, 0.74590], [1175983200000, 0.74770], [1176069600000, 0.74770], [1176156000000, 0.74830], [1176242400000, 0.74580], [1176328800000, 0.74480], [1176415200000, 0.7430], [1176501600000, 0.73990], [1176588000000, 0.73950], [1176674400000, 0.73950], [1176760800000, 0.73780], [1176847200000, 0.73820], [1176933600000, 0.73620], [1177020000000, 0.73550], [1177106400000, 0.73480], [1177192800000, 0.73610], [1177279200000, 0.73610], [1177365600000, 0.73650], [1177452000000, 0.73620], [1177538400000, 0.73310], [1177624800000, 0.73390], [1177711200000, 0.73440], [1177797600000, 0.73270], [1177884000000, 0.73270], [1177970400000, 0.73360], [1178056800000, 0.73330], [1178143200000, 0.73590], [1178229600000, 0.73590], [1178316000000, 0.73720], [1178402400000, 0.7360], [1178488800000, 0.7360], [1178575200000, 0.7350], [1178661600000, 0.73650], [1178748000000, 0.73840], [1178834400000, 0.73950], [1178920800000, 0.74130], [1179007200000, 0.73970], [1179093600000, 0.73960], [1179180000000, 0.73850], [1179266400000, 0.73780], [1179352800000, 0.73660], [1179439200000, 0.740], [1179525600000, 0.74110], [1179612000000, 0.74060], [1179698400000, 0.74050], [1179784800000, 0.74140], [1179871200000, 0.74310], [1179957600000, 0.74310], [1180044000000, 0.74380], [1180130400000, 0.74430], [1180216800000, 0.74430], [1180303200000, 0.74430], [1180389600000, 0.74340], [1180476000000, 0.74290], [1180562400000, 0.74420], [1180648800000, 0.7440], [1180735200000, 0.74390], [1180821600000, 0.74370], [1180908000000, 0.74370], [1180994400000, 0.74290], [1181080800000, 0.74030], [1181167200000, 0.73990], [1181253600000, 0.74180], [1181340000000, 0.74680], [1181426400000, 0.7480], [1181512800000, 0.7480], [1181599200000, 0.7490], [1181685600000, 0.74940], [1181772000000, 0.75220], [1181858400000, 0.75150], [1181944800000, 0.75020], [1182031200000, 0.74720], [1182117600000, 0.74720], [1182204000000, 0.74620], [1182290400000, 0.74550], [1182376800000, 0.74490], [1182463200000, 0.74670], [1182549600000, 0.74580], [1182636000000, 0.74270], [1182722400000, 0.74270], [1182808800000, 0.7430], [1182895200000, 0.74290], [1182981600000, 0.7440], [1183068000000, 0.7430], [1183154400000, 0.74220], [1183240800000, 0.73880], [1183327200000, 0.73880], [1183413600000, 0.73690], [1183500000000, 0.73450], [1183586400000, 0.73450], [1183672800000, 0.73450], [1183759200000, 0.73520], [1183845600000, 0.73410], [1183932000000, 0.73410], [1184018400000, 0.7340], [1184104800000, 0.73240], [1184191200000, 0.72720], [1184277600000, 0.72640], [1184364000000, 0.72550], [1184450400000, 0.72580], [1184536800000, 0.72580], [1184623200000, 0.72560], [1184709600000, 0.72570], [1184796000000, 0.72470], [1184882400000, 0.72430], [1184968800000, 0.72440], [1185055200000, 0.72350], [1185141600000, 0.72350], [1185228000000, 0.72350], [1185314400000, 0.72350], [1185400800000, 0.72620], [1185487200000, 0.72880], [1185573600000, 0.73010], [1185660000000, 0.73370], [1185746400000, 0.73370], [1185832800000, 0.73240], [1185919200000, 0.72970], [1186005600000, 0.73170], [1186092000000, 0.73150], [1186178400000, 0.72880], [1186264800000, 0.72630], [1186351200000, 0.72630], [1186437600000, 0.72420], [1186524000000, 0.72530], [1186610400000, 0.72640], [1186696800000, 0.7270], [1186783200000, 0.73120], [1186869600000, 0.73050], [1186956000000, 0.73050], [1187042400000, 0.73180], [1187128800000, 0.73580], [1187215200000, 0.74090], [1187301600000, 0.74540], [1187388000000, 0.74370], [1187474400000, 0.74240], [1187560800000, 0.74240], [1187647200000, 0.74150], [1187733600000, 0.74190], [1187820000000, 0.74140], [1187906400000, 0.73770], [1187992800000, 0.73550], [1188079200000, 0.73150], [1188165600000, 0.73150], [1188252000000, 0.7320], [1188338400000, 0.73320], [1188424800000, 0.73460], [1188511200000, 0.73280], [1188597600000, 0.73230], [1188684000000, 0.7340], [1188770400000, 0.7340], [1188856800000, 0.73360], [1188943200000, 0.73510], [1189029600000, 0.73460], [1189116000000, 0.73210], [1189202400000, 0.72940], [1189288800000, 0.72660], [1189375200000, 0.72660], [1189461600000, 0.72540], [1189548000000, 0.72420], [1189634400000, 0.72130], [1189720800000, 0.71970], [1189807200000, 0.72090], [1189893600000, 0.7210], [1189980000000, 0.7210], [1190066400000, 0.7210], [1190152800000, 0.72090], [1190239200000, 0.71590], [1190325600000, 0.71330], [1190412000000, 0.71050], [1190498400000, 0.70990], [1190584800000, 0.70990], [1190671200000, 0.70930], [1190757600000, 0.70930], [1190844000000, 0.70760], [1190930400000, 0.7070], [1191016800000, 0.70490], [1191103200000, 0.70120], [1191189600000, 0.70110], [1191276000000, 0.70190], [1191362400000, 0.70460], [1191448800000, 0.70630], [1191535200000, 0.70890], [1191621600000, 0.70770], [1191708000000, 0.70770], [1191794400000, 0.70770], [1191880800000, 0.70910], [1191967200000, 0.71180], [1192053600000, 0.70790], [1192140000000, 0.70530], [1192226400000, 0.7050], [1192312800000, 0.70550], [1192399200000, 0.70550], [1192485600000, 0.70450], [1192572000000, 0.70510], [1192658400000, 0.70510], [1192744800000, 0.70170], [1192831200000, 0.70], [1192917600000, 0.69950], [1193004000000, 0.69940], [1193090400000, 0.70140], [1193176800000, 0.70360], [1193263200000, 0.70210], [1193349600000, 0.70020], [1193436000000, 0.69670], [1193522400000, 0.6950], [1193612400000, 0.6950], [1193698800000, 0.69390], [1193785200000, 0.6940], [1193871600000, 0.69220], [1193958000000, 0.69190], [1194044400000, 0.69140], [1194130800000, 0.68940], [1194217200000, 0.68910], [1194303600000, 0.69040], [1194390000000, 0.6890], [1194476400000, 0.68340], [1194562800000, 0.68230], [1194649200000, 0.68070], [1194735600000, 0.68150], [1194822000000, 0.68150], [1194908400000, 0.68470], [1194994800000, 0.68590], [1195081200000, 0.68220], [1195167600000, 0.68270], [1195254000000, 0.68370], [1195340400000, 0.68230], [1195426800000, 0.68220], [1195513200000, 0.68220], [1195599600000, 0.67920], [1195686000000, 0.67460], [1195772400000, 0.67350], [1195858800000, 0.67310], [1195945200000, 0.67420], [1196031600000, 0.67440], [1196118000000, 0.67390], [1196204400000, 0.67310], [1196290800000, 0.67610], [1196377200000, 0.67610], [1196463600000, 0.67850], [1196550000000, 0.68180], [1196636400000, 0.68360], [1196722800000, 0.68230], [1196809200000, 0.68050], [1196895600000, 0.67930], [1196982000000, 0.68490], [1197068400000, 0.68330], [1197154800000, 0.68250], [1197241200000, 0.68250], [1197327600000, 0.68160], [1197414000000, 0.67990], [1197500400000, 0.68130], [1197586800000, 0.68090], [1197673200000, 0.68680], [1197759600000, 0.69330], [1197846000000, 0.69330], [1197932400000, 0.69450], [1198018800000, 0.69440], [1198105200000, 0.69460], [1198191600000, 0.69640], [1198278000000, 0.69650], [1198364400000, 0.69560], [1198450800000, 0.69560], [1198537200000, 0.6950], [1198623600000, 0.69480], [1198710000000, 0.69280], [1198796400000, 0.68870], [1198882800000, 0.68240], [1198969200000, 0.67940], [1199055600000, 0.67940], [1199142000000, 0.68030], [1199228400000, 0.68550], [1199314800000, 0.68240], [1199401200000, 0.67910], [1199487600000, 0.67830], [1199574000000, 0.67850], [1199660400000, 0.67850], [1199746800000, 0.67970], [1199833200000, 0.680], [1199919600000, 0.68030], [1200006000000, 0.68050], [1200092400000, 0.6760], [1200178800000, 0.6770], [1200265200000, 0.6770], [1200351600000, 0.67360], [1200438000000, 0.67260], [1200524400000, 0.67640], [1200610800000, 0.68210], [1200697200000, 0.68310], [1200783600000, 0.68420], [1200870000000, 0.68420], [1200956400000, 0.68870], [1201042800000, 0.69030], [1201129200000, 0.68480], [1201215600000, 0.68240], [1201302000000, 0.67880], [1201388400000, 0.68140], [1201474800000, 0.68140], [1201561200000, 0.67970], [1201647600000, 0.67690], [1201734000000, 0.67650], [1201820400000, 0.67330], [1201906800000, 0.67290], [1201993200000, 0.67580], [1202079600000, 0.67580], [1202166000000, 0.6750], [1202252400000, 0.6780], [1202338800000, 0.68330], [1202425200000, 0.68560], [1202511600000, 0.69030], [1202598000000, 0.68960], [1202684400000, 0.68960], [1202770800000, 0.68820], [1202857200000, 0.68790], [1202943600000, 0.68620], [1203030000000, 0.68520], [1203116400000, 0.68230], [1203202800000, 0.68130], [1203289200000, 0.68130], [1203375600000, 0.68220], [1203462000000, 0.68020], [1203548400000, 0.68020], [1203634800000, 0.67840], [1203721200000, 0.67480], [1203807600000, 0.67470], [1203894000000, 0.67470], [1203980400000, 0.67480], [1204066800000, 0.67330], [1204153200000, 0.6650], [1204239600000, 0.66110], [1204326000000, 0.65830], [1204412400000, 0.6590], [1204498800000, 0.6590], [1204585200000, 0.65810], [1204671600000, 0.65780], [1204758000000, 0.65740], [1204844400000, 0.65320], [1204930800000, 0.65020], [1205017200000, 0.65140], [1205103600000, 0.65140], [1205190000000, 0.65070], [1205276400000, 0.6510], [1205362800000, 0.64890], [1205449200000, 0.64240], [1205535600000, 0.64060], [1205622000000, 0.63820], [1205708400000, 0.63820], [1205794800000, 0.63410], [1205881200000, 0.63440], [1205967600000, 0.63780], [1206054000000, 0.64390], [1206140400000, 0.64780], [1206226800000, 0.64810], [1206313200000, 0.64810], [1206399600000, 0.64940], [1206486000000, 0.64380], [1206572400000, 0.63770], [1206658800000, 0.63290], [1206745200000, 0.63360], [1206831600000, 0.63330], [1206914400000, 0.63330], [1207000800000, 0.6330], [1207087200000, 0.63710], [1207173600000, 0.64030], [1207260000000, 0.63960], [1207346400000, 0.63640], [1207432800000, 0.63560], [1207519200000, 0.63560], [1207605600000, 0.63680], [1207692000000, 0.63570], [1207778400000, 0.63540], [1207864800000, 0.6320], [1207951200000, 0.63320], [1208037600000, 0.63280], [1208124000000, 0.63310], [1208210400000, 0.63420], [1208296800000, 0.63210], [1208383200000, 0.63020], [1208469600000, 0.62780], [1208556000000, 0.63080], [1208642400000, 0.63240], [1208728800000, 0.63240], [1208815200000, 0.63070], [1208901600000, 0.62770], [1208988000000, 0.62690], [1209074400000, 0.63350], [1209160800000, 0.63920], [1209247200000, 0.640], [1209333600000, 0.64010], [1209420000000, 0.63960], [1209506400000, 0.64070], [1209592800000, 0.64230], [1209679200000, 0.64290], [1209765600000, 0.64720], [1209852000000, 0.64850], [1209938400000, 0.64860], [1210024800000, 0.64670], [1210111200000, 0.64440], [1210197600000, 0.64670], [1210284000000, 0.65090], [1210370400000, 0.64780], [1210456800000, 0.64610], [1210543200000, 0.64610], [1210629600000, 0.64680], [1210716000000, 0.64490], [1210802400000, 0.6470], [1210888800000, 0.64610], [1210975200000, 0.64520], [1211061600000, 0.64220], [1211148000000, 0.64220], [1211234400000, 0.64250], [1211320800000, 0.64140], [1211407200000, 0.63660], [1211493600000, 0.63460], [1211580000000, 0.6350], [1211666400000, 0.63460], [1211752800000, 0.63460], [1211839200000, 0.63430], [1211925600000, 0.63460], [1212012000000, 0.63790], [1212098400000, 0.64160], [1212184800000, 0.64420], [1212271200000, 0.64310], [1212357600000, 0.64310], [1212444000000, 0.64350], [1212530400000, 0.6440], [1212616800000, 0.64730], [1212703200000, 0.64690], [1212789600000, 0.63860], [1212876000000, 0.63560], [1212962400000, 0.6340], [1213048800000, 0.63460], [1213135200000, 0.6430], [1213221600000, 0.64520], [1213308000000, 0.64670], [1213394400000, 0.65060], [1213480800000, 0.65040], [1213567200000, 0.65030], [1213653600000, 0.64810], [1213740000000, 0.64510], [1213826400000, 0.6450], [1213912800000, 0.64410], [1213999200000, 0.64140], [1214085600000, 0.64090], [1214172000000, 0.64090], [1214258400000, 0.64280], [1214344800000, 0.64310], [1214431200000, 0.64180], [1214517600000, 0.63710], [1214604000000, 0.63490], [1214690400000, 0.63330], [1214776800000, 0.63340], [1214863200000, 0.63380], [1214949600000, 0.63420], [1215036000000, 0.6320], [1215122400000, 0.63180], [1215208800000, 0.6370], [1215295200000, 0.63680], [1215381600000, 0.63680], [1215468000000, 0.63830], [1215554400000, 0.63710], [1215640800000, 0.63710], [1215727200000, 0.63550], [1215813600000, 0.6320], [1215900000000, 0.62770], [1215986400000, 0.62760], [1216072800000, 0.62910], [1216159200000, 0.62740], [1216245600000, 0.62930], [1216332000000, 0.63110], [1216418400000, 0.6310], [1216504800000, 0.63120], [1216591200000, 0.63120], [1216677600000, 0.63040], [1216764000000, 0.62940], [1216850400000, 0.63480], [1216936800000, 0.63780], [1217023200000, 0.63680], [1217109600000, 0.63680], [1217196000000, 0.63680], [1217282400000, 0.6360], [1217368800000, 0.6370], [1217455200000, 0.64180], [1217541600000, 0.64110], [1217628000000, 0.64350], [1217714400000, 0.64270], [1217800800000, 0.64270], [1217887200000, 0.64190], [1217973600000, 0.64460], [1218060000000, 0.64680], [1218146400000, 0.64870], [1218232800000, 0.65940], [1218319200000, 0.66660], [1218405600000, 0.66660], [1218492000000, 0.66780], [1218578400000, 0.67120], [1218664800000, 0.67050], [1218751200000, 0.67180], [1218837600000, 0.67840], [1218924000000, 0.68110], [1219010400000, 0.68110], [1219096800000, 0.67940], [1219183200000, 0.68040], [1219269600000, 0.67810], [1219356000000, 0.67560], [1219442400000, 0.67350], [1219528800000, 0.67630], [1219615200000, 0.67620], [1219701600000, 0.67770], [1219788000000, 0.68150], [1219874400000, 0.68020], [1219960800000, 0.6780], [1220047200000, 0.67960], [1220133600000, 0.68170], [1220220000000, 0.68170], [1220306400000, 0.68320], [1220392800000, 0.68770], [1220479200000, 0.69120], [1220565600000, 0.69140], [1220652000000, 0.70090], [1220738400000, 0.70120], [1220824800000, 0.7010], [1220911200000, 0.70050]];
899
900
    function euroFormatter(v, axis) {
901
        return v.toFixed(axis.tickDecimals) + "€";
902
    }
903
    var position = 'right';
904
905
    /**
906
     * multiData - data for multi line chart
907
     */
908
    var multiData = [
909
        {
910
            data: oilprices,
911
            label: "Oil price ($)"
912
        },
913
        {
914
            data: exchangerates,
915
            label: "USD/EUR exchange rate",
916
            yaxis: 2
917
        }
918
    ];
919
920
    /**
921
     * multiOptions - options for multi chart
922
     */
923
    var multiOptions = {
924
        xaxes: [
925
            {
926
                mode: 'time'
927
            }
928
        ],
929
        yaxes: [
930
            {
931
                min: 0
932
            },
933
            {
934
                // align if we are to the right
935
                alignTicksWithAxis: position == "right" ? 1 : null,
936
                position: position,
937
                tickFormatter: euroFormatter
938
            }
939
        ],
940
        legend: {
941
            position: 'sw'
942
        },
943
        colors: ["#1ab394"],
944
        grid: {
945
            color: "#999999",
946
            hoverable: true,
947
            clickable: true,
948
            tickColor: "#D4D4D4",
949
            borderWidth: 0
950
951
        },
952
        tooltip: true,
953
        tooltipOpts: {
954
            content: "%s for %x was %y",
955
            xDateFormat: "%y-%0m-%0d",
956
            onHover: function (flotItem, $tooltipEl) {
957
            }
958
        }
959
960
    };
961
962
    /**
963
     * Definition of variables
964
     * Flot chart
965
     */
966
    this.flotChartData = chartData;
967
    this.flotBarOptions = barOptions;
968
    this.flotLineOptions = lineOptions;
969
    this.flotPieData = pieData;
970
    this.flotPieOptions = pieOptions;
971
    this.flotLineAreaData = lineAreaData;
972
    this.flotLineAreaOptions = lineAreaOptions;
973
    this.flotMultiData = multiData;
974
    this.flotMultiOptions = multiOptions;
975
}
976
977
/**
978
 * rickshawChartCtrl - Controller for data for all Rickshaw chart
979
 * used in Rickshaw chart view
980
 */
981
function rickshawChartCtrl() {
982
983
    /**
984
     * Data for simple chart
985
     */
986
    var simpleChartSeries = [
987
        {
988
            color: '#1ab394',
989
            data: [
990
                { x: 0, y: 40 },
991
                { x: 1, y: 49 },
992
                { x: 2, y: 38 },
993
                { x: 3, y: 30 },
994
                { x: 4, y: 32 }
995
            ]
996
        }
997
    ];
998
    /**
999
     * Options for simple chart
1000
     */
1001
    var simpleChartOptions = {
1002
        renderer: 'area'
1003
    };
1004
1005
    /**
1006
     * Data for Multi Area chart
1007
     */
1008
    var multiAreaChartSeries = [
1009
        {
1010
            data: [
1011
                { x: 0, y: 40 },
1012
                { x: 1, y: 49 },
1013
                { x: 2, y: 38 },
1014
                { x: 3, y: 20 },
1015
                { x: 4, y: 16 }
1016
            ],
1017
            color: '#1ab394',
1018
            stroke: '#17997f'
1019
        },
1020
        {
1021
            data: [
1022
                { x: 0, y: 22 },
1023
                { x: 1, y: 25 },
1024
                { x: 2, y: 38 },
1025
                { x: 3, y: 44 },
1026
                { x: 4, y: 46 }
1027
            ],
1028
            color: '#eeeeee',
1029
            stroke: '#d7d7d7'
1030
        }
1031
    ];
1032
1033
    /**
1034
     * Options for Multi chart
1035
     */
1036
    var multiAreaChartOptions = {
1037
        renderer: 'area',
1038
        stroke: true
1039
    };
1040
1041
    /**
1042
     * Options for one line chart
1043
     */
1044
    var oneLineChartOptions = {
1045
        renderer: 'line'
1046
    };
1047
1048
    /**
1049
     * Data for one line chart
1050
     */
1051
    var oneLineChartSeries = [
1052
        {
1053
            data: [
1054
                { x: 0, y: 40 },
1055
                { x: 1, y: 49 },
1056
                { x: 2, y: 38 },
1057
                { x: 3, y: 30 },
1058
                { x: 4, y: 32 }
1059
            ],
1060
            color: '#1ab394'
1061
        }
1062
    ];
1063
1064
    /**
1065
     * Options for Multi line chart
1066
     */
1067
    var multiLineChartOptions = {
1068
        renderer: 'line'
1069
    };
1070
1071
    /**
1072
     * Data for Multi line chart
1073
     */
1074
    var multiLineChartSeries = [
1075
        {
1076
            data: [
1077
                { x: 0, y: 40 },
1078
                { x: 1, y: 49 },
1079
                { x: 2, y: 38 },
1080
                { x: 3, y: 30 },
1081
                { x: 4, y: 32 }
1082
            ],
1083
            color: '#1ab394'
1084
        },
1085
        {
1086
            data: [
1087
                { x: 0, y: 20 },
1088
                { x: 1, y: 24 },
1089
                { x: 2, y: 19 },
1090
                { x: 3, y: 15 },
1091
                { x: 4, y: 16 }
1092
            ],
1093
            color: '#d7d7d7'
1094
        }
1095
    ];
1096
1097
    /**
1098
     * Options for Bars chart
1099
     */
1100
    var barsChartOptions = {
1101
        renderer: 'bar'
1102
    };
1103
1104
    /**
1105
     * Data for Bars chart
1106
     */
1107
    var barsChartSeries = [
1108
        {
1109
            data: [
1110
                { x: 0, y: 40 },
1111
                { x: 1, y: 49 },
1112
                { x: 2, y: 38 },
1113
                { x: 3, y: 30 },
1114
                { x: 4, y: 32 }
1115
            ],
1116
            color: '#1ab394'
1117
        }
1118
    ];
1119
1120
    /**
1121
     * Options for Stacked chart
1122
     */
1123
    var stackedChartOptions = {
1124
        renderer: 'bar'
1125
    };
1126
1127
    /**
1128
     * Data for Stacked chart
1129
     */
1130
    var stackedChartSeries = [
1131
        {
1132
            data: [
1133
                { x: 0, y: 40 },
1134
                { x: 1, y: 49 },
1135
                { x: 2, y: 38 },
1136
                { x: 3, y: 30 },
1137
                { x: 4, y: 32 }
1138
            ],
1139
            color: '#1ab394'
1140
        },
1141
        {
1142
            data: [
1143
                { x: 0, y: 20 },
1144
                { x: 1, y: 24 },
1145
                { x: 2, y: 19 },
1146
                { x: 3, y: 15 },
1147
                { x: 4, y: 16 }
1148
            ],
1149
            color: '#d7d7d7'
1150
        }
1151
    ];
1152
1153
    /**
1154
     * Options for Scatterplot chart
1155
     */
1156
    var scatterplotChartOptions = {
1157
        renderer: 'scatterplot',
1158
        stroke: true,
1159
        padding: { top: 0.05, left: 0.05, right: 0.05 }
1160
    }
1161
1162
    /**
1163
     * Data for Scatterplot chart
1164
     */
1165
    var scatterplotChartSeries = [
1166
        {
1167
            data: [
1168
                { x: 0, y: 15 },
1169
                { x: 1, y: 18 },
1170
                { x: 2, y: 10 },
1171
                { x: 3, y: 12 },
1172
                { x: 4, y: 15 },
1173
                { x: 5, y: 24 },
1174
                { x: 6, y: 28 },
1175
                { x: 7, y: 31 },
1176
                { x: 8, y: 22 },
1177
                { x: 9, y: 18 },
1178
                { x: 10, y: 16 }
1179
            ],
1180
            color: '#1ab394'
1181
        }
1182
    ]
1183
1184
    /**
1185
     * Definition all variables
1186
     * Rickshaw chart
1187
     */
1188
    this.simpleSeries = simpleChartSeries;
1189
    this.simpleOptions = simpleChartOptions;
1190
    this.multiAreaOptions = multiAreaChartOptions;
1191
    this.multiAreaSeries = multiAreaChartSeries;
1192
    this.oneLineOptions = oneLineChartOptions;
1193
    this.oneLineSeries = oneLineChartSeries;
1194
    this.multiLineOptions = multiLineChartOptions;
1195
    this.multiLineSeries = multiLineChartSeries;
1196
    this.barsOptions = barsChartOptions;
1197
    this.barsSeries = barsChartSeries;
1198
    this.stackedOptions = stackedChartOptions;
1199
    this.stackedSeries = stackedChartSeries;
1200
    this.scatterplotOptions = scatterplotChartOptions;
1201
    this.scatterplotSeries = scatterplotChartSeries;
1202
1203
}
1204
1205
/**
1206
 * sparklineChartCtrl - Controller for data for all Sparkline chart
1207
 * used in Sparkline chart view
1208
 */
1209
function sparklineChartCtrl() {
1210
1211
    /**
1212
     * Inline chart
1213
     */
1214
    var inlineData = [34, 43, 43, 35, 44, 32, 44, 52, 25];
1215
    var inlineOptions = {
1216
        type: 'line',
1217
        lineColor: '#17997f',
1218
        fillColor: '#1ab394'
1219
    };
1220
1221
    /**
1222
     * Bar chart
1223
     */
1224
    var barSmallData = [5, 6, 7, 2, 0, -4, -2, 4];
1225
    var barSmallOptions = {
1226
        type: 'bar',
1227
        barColor: '#1ab394',
1228
        negBarColor: '#c6c6c6'
1229
    };
1230
1231
    /**
1232
     * Pie chart
1233
     */
1234
    var smallPieData = [1, 1, 2];
1235
    var smallPieOptions = {
1236
        type: 'pie',
1237
        sliceColors: ['#1ab394', '#b3b3b3', '#e4f0fb']
1238
    };
1239
1240
    /**
1241
     * Long line chart
1242
     */
1243
    var longLineData = [34, 43, 43, 35, 44, 32, 15, 22, 46, 33, 86, 54, 73, 53, 12, 53, 23, 65, 23, 63, 53, 42, 34, 56, 76, 15, 54, 23, 44];
1244
    var longLineOptions = {
1245
        type: 'line',
1246
        lineColor: '#17997f',
1247
        fillColor: '#ffffff'
1248
    };
1249
1250
    /**
1251
     * Tristate chart
1252
     */
1253
    var tristateData = [1, 1, 0, 1, -1, -1, 1, -1, 0, 0, 1, 1];
1254
    var tristateOptions = {
1255
        type: 'tristate',
1256
        posBarColor: '#1ab394',
1257
        negBarColor: '#bfbfbf'
1258
    };
1259
1260
    /**
1261
     * Discrate chart
1262
     */
1263
    var discreteData = [4, 6, 7, 7, 4, 3, 2, 1, 4, 4, 5, 6, 3, 4, 5, 8, 7, 6, 9, 3, 2, 4, 1, 5, 6, 4, 3, 7, ];
1264
    var discreteOptions = {
1265
        type: 'discrete',
1266
        lineColor: '#1ab394'
1267
    };
1268
1269
    /**
1270
     * Pie chart
1271
     */
1272
    var pieCustomData = [52, 12, 44];
1273
    var pieCustomOptions = {
1274
        type: 'pie',
1275
        height: '150px',
1276
        sliceColors: ['#1ab394', '#b3b3b3', '#e4f0fb']
1277
    };
1278
1279
    /**
1280
     * Bar chart
1281
     */
1282
    var barCustomData = [5, 6, 7, 2, 0, 4, 2, 4, 5, 7, 2, 4, 12, 14, 4, 2, 14, 12, 7];
1283
    var barCustomOptions = {
1284
        type: 'bar',
1285
        barWidth: 8,
1286
        height: '150px',
1287
        barColor: '#1ab394',
1288
        negBarColor: '#c6c6c6'
1289
    };
1290
1291
    /**
1292
     * Line chart
1293
     */
1294
    var lineCustomData = [34, 43, 43, 35, 44, 32, 15, 22, 46, 33, 86, 54, 73, 53, 12, 53, 23, 65, 23, 63, 53, 42, 34, 56, 76, 15, 54, 23, 44];
1295
    var lineCustomOptions = {
1296
        type: 'line',
1297
        lineWidth: 1,
1298
        height: '150px',
1299
        lineColor: '#17997f',
1300
        fillColor: '#ffffff'
1301
    };
1302
1303
1304
    /**
1305
     * Definition of variables
1306
     * Flot chart
1307
     */
1308
    this.inlineData = inlineData;
1309
    this.inlineOptions = inlineOptions;
1310
    this.barSmallData = barSmallData;
1311
    this.barSmallOptions = barSmallOptions;
1312
    this.pieSmallData = smallPieData;
1313
    this.pieSmallOptions = smallPieOptions;
1314
    this.discreteData = discreteData;
1315
    this.discreteOptions = discreteOptions;
1316
    this.longLineData = longLineData;
1317
    this.longLineOptions = longLineOptions;
1318
    this.tristateData = tristateData;
1319
    this.tristateOptions = tristateOptions;
1320
    this.pieCustomData = pieCustomData;
1321
    this.pieCustomOptions = pieCustomOptions;
1322
    this.barCustomData = barCustomData;
1323
    this.barCustomOptions = barCustomOptions;
1324
    this.lineCustomData = lineCustomData;
1325
    this.lineCustomOptions = lineCustomOptions;
1326
}
1327
1328
1329
/**
1330
 * widgetFlotChart - Data for Flot chart
1331
 * used in Widget view
1332
 */
1333
function widgetFlotChart() {
1334
1335
1336
    /**
1337
     * Flot chart data and options
1338
     */
1339
    var d1 = [[1262304000000, 6], [1264982400000, 3057], [1267401600000, 20434], [1270080000000, 31982], [1272672000000, 26602], [1275350400000, 27826], [1277942400000, 24302], [1280620800000, 24237], [1283299200000, 21004], [1285891200000, 12144], [1288569600000, 10577], [1291161600000, 10295]];
1340
    var d2 = [[1262304000000, 5], [1264982400000, 200], [1267401600000, 1605], [1270080000000, 6129], [1272672000000, 11643], [1275350400000, 19055], [1277942400000, 30062], [1280620800000, 39197], [1283299200000, 37000], [1285891200000, 27000], [1288569600000, 21000], [1291161600000, 17000]];
1341
1342
    var flotChartData1 = [
1343
        { label: "Data 1", data: d1, color: '#17a084'},
1344
        { label: "Data 2", data: d2, color: '#127e68' }
1345
    ];
1346
1347
    var flotChartOptions1 = {
1348
        xaxis: {
1349
            tickDecimals: 0
1350
        },
1351
        series: {
1352
            lines: {
1353
                show: true,
1354
                fill: true,
1355
                fillColor: {
1356
                    colors: [{
1357
                        opacity: 1
1358
                    }, {
1359
                        opacity: 1
1360
                    }]
1361
                }
1362
            },
1363
            points: {
1364
                width: 0.1,
1365
                show: false
1366
            }
1367
        },
1368
        grid: {
1369
            show: false,
1370
            borderWidth: 0
1371
        },
1372
        legend: {
1373
            show: false
1374
        }
1375
    };
1376
1377
    var flotChartData2 = [
1378
        { label: "Data 1", data: d1, color: '#19a0a1'}
1379
    ];
1380
1381
    var flotChartOptions2 = {
1382
        xaxis: {
1383
            tickDecimals: 0
1384
        },
1385
        series: {
1386
            lines: {
1387
                show: true,
1388
                fill: true,
1389
                fillColor: {
1390
                    colors: [{
1391
                        opacity: 1
1392
                    }, {
1393
                        opacity: 1
1394
                    }]
1395
                }
1396
            },
1397
            points: {
1398
                width: 0.1,
1399
                show: false
1400
            }
1401
        },
1402
        grid: {
1403
            show: false,
1404
            borderWidth: 0
1405
        },
1406
        legend: {
1407
            show: false
1408
        }
1409
    };
1410
1411
    var flotChartData3 = [
1412
        { label: "Data 1", data: d1, color: '#fbbe7b'},
1413
        { label: "Data 2", data: d2, color: '#f8ac59' }
1414
    ];
1415
1416
    var flotChartOptions3 = {
1417
        xaxis: {
1418
            tickDecimals: 0
1419
        },
1420
        series: {
1421
            lines: {
1422
                show: true,
1423
                fill: true,
1424
                fillColor: {
1425
                    colors: [{
1426
                        opacity: 1
1427
                    }, {
1428
                        opacity: 1
1429
                    }]
1430
                }
1431
            },
1432
            points: {
1433
                width: 0.1,
1434
                show: false
1435
            }
1436
        },
1437
        grid: {
1438
            show: false,
1439
            borderWidth: 0
1440
        },
1441
        legend: {
1442
            show: false
1443
        }
1444
    };
1445
1446
    /**
1447
     * Definition of variables
1448
     * Flot chart
1449
     */
1450
1451
    this.flotChartData1 = flotChartData1;
1452
    this.flotChartOptions1 = flotChartOptions1;
1453
    this.flotChartData2 = flotChartData2;
1454
    this.flotChartOptions2 = flotChartOptions2;
1455
    this.flotChartData3 = flotChartData3;
1456
    this.flotChartOptions3 = flotChartOptions3;
1457
1458
1459
}
1460
1461
/**
1462
 * modalDemoCtrl - Controller used to run modal view
1463
 * used in Basic form view
1464
 */
1465
function modalDemoCtrl($scope, $uibModal) {
1466
1467
    $scope.open = function () {
1468
1469
        var modalInstance = $uibModal.open({
0 ignored issues
show
The variable modalInstance seems to be never used. Consider removing it.
Loading history...
1470
            templateUrl: 'views/modal_example.html',
1471
            controller: ModalInstanceCtrl
1472
        });
1473
    };
1474
1475
    $scope.open1 = function () {
1476
        var modalInstance = $uibModal.open({
0 ignored issues
show
The variable modalInstance seems to be never used. Consider removing it.
Loading history...
1477
            templateUrl: 'views/modal_example1.html',
1478
            controller: ModalInstanceCtrl
1479
        });
1480
    };
1481
1482
    $scope.open2 = function () {
1483
        var modalInstance = $uibModal.open({
0 ignored issues
show
The variable modalInstance seems to be never used. Consider removing it.
Loading history...
1484
            templateUrl: 'views/modal_example2.html',
1485
            controller: ModalInstanceCtrl,
1486
            windowClass: "animated fadeIn"
1487
        });
1488
    };
1489
1490
    $scope.open3 = function (size) {
1491
        var modalInstance = $uibModal.open({
0 ignored issues
show
The variable modalInstance seems to be never used. Consider removing it.
Loading history...
1492
            templateUrl: 'views/modal_example3.html',
1493
            size: size,
1494
            controller: ModalInstanceCtrl
1495
        });
1496
    };
1497
1498
    $scope.open4 = function () {
1499
        var modalInstance = $uibModal.open({
0 ignored issues
show
The variable modalInstance seems to be never used. Consider removing it.
Loading history...
1500
            templateUrl: 'views/modal_example2.html',
1501
            controller: ModalInstanceCtrl,
1502
            windowClass: "animated flipInY"
1503
        });
1504
    };
1505
};
1506
1507
function ModalInstanceCtrl ($scope, $uibModalInstance) {
1508
1509
    $scope.ok = function () {
1510
        $uibModalInstance.close();
1511
    };
1512
1513
    $scope.cancel = function () {
1514
        $uibModalInstance.dismiss('cancel');
1515
    };
1516
1517
1518
    $scope.states = [
1519
        'Alabama',
1520
        'Alaska',
1521
        'Arizona',
1522
        'Arkansas',
1523
        'California',
1524
        'Colorado',
1525
        'Connecticut',
1526
        'Delaware',
1527
        'Florida',
1528
        'Georgia',
1529
        'Hawaii',
1530
        'Idaho',
1531
        'Illinois',
1532
        'Indiana',
1533
        'Iowa',
1534
        'Kansas',
1535
        'Kentucky',
1536
        'Louisiana',
1537
        'Maine',
1538
        'Maryland',
1539
        'Massachusetts',
1540
        'Michigan',
1541
        'Minnesota',
1542
        'Mississippi',
1543
        'Missouri',
1544
        'Montana',
1545
        'Nebraska',
1546
        'Nevada',
1547
        'New Hampshire',
1548
        'New Jersey',
1549
        'New Mexico',
1550
        'New York',
1551
        'North Carolina',
1552
        'North Dakota',
1553
        'Ohio',
1554
        'Oklahoma',
1555
        'Oregon',
1556
        'Pennsylvania',
1557
        'Rhode Island',
1558
        'South Carolina',
1559
        'South Dakota',
1560
        'Tennessee',
1561
        'Texas',
1562
        'Utah',
1563
        'Vermont',
1564
        'Virginia',
1565
        'Washington',
1566
        'West Virginia',
1567
        'Wisconsin',
1568
        'Wyoming'
1569
    ];
1570
1571
};
1572
1573
/**
1574
 * ionSlider - Controller for data for Ion Slider plugin
1575
 * used in Advanced plugin view
1576
 */
1577
function ionSlider() {
1578
    this.ionSliderOptions1 = {
1579
        min: 0,
1580
        max: 5000,
1581
        type: 'double',
1582
        prefix: "$",
1583
        maxPostfix: "+",
1584
        prettify: false,
1585
        hasGrid: true
1586
    };
1587
    this.ionSliderOptions2 = {
1588
        min: 0,
1589
        max: 10,
1590
        type: 'single',
1591
        step: 0.1,
1592
        postfix: " carats",
1593
        prettify: false,
1594
        hasGrid: true
1595
    };
1596
    this.ionSliderOptions3 = {
1597
        min: -50,
1598
        max: 50,
1599
        from: 0,
1600
        postfix: "°",
1601
        prettify: false,
1602
        hasGrid: true
1603
    };
1604
    this.ionSliderOptions4 = {
1605
        values: [
1606
            "January", "February", "March",
1607
            "April", "May", "June",
1608
            "July", "August", "September",
1609
            "October", "November", "December"
1610
        ],
1611
        type: 'single',
1612
        hasGrid: true
1613
    };
1614
    this.ionSliderOptions5 = {
1615
        min: 10000,
1616
        max: 100000,
1617
        step: 100,
1618
        postfix: " km",
1619
        from: 55000,
1620
        hideMinMax: true,
1621
        hideFromTo: false
1622
    };
1623
}
1624
1625
/**
1626
 * wizardCtrl - Controller for wizard functions
1627
 * used in Wizard view
1628
 */
1629
function wizardCtrl($scope, $rootScope) {
1630
    // All data will be store in this object
1631
    $scope.formData = {};
1632
1633
    // After process wizard
1634
    $scope.processForm = function() {
1635
        alert('Wizard completed');
0 ignored issues
show
Debugging Code Best Practice introduced by
The alert UI element is often considered obtrusive and is generally only used as a temporary measure. Consider replacing it with another UI element.
Loading history...
1636
    };
1637
1638
}
1639
1640
1641
/**
1642
 * CalendarCtrl - Controller for Calendar
1643
 * Store data events for calendar
1644
 */
1645
function CalendarCtrl($scope) {
1646
1647
    var date = new Date();
1648
    var d = date.getDate();
1649
    var m = date.getMonth();
1650
    var y = date.getFullYear();
1651
1652
    // Events
1653
    $scope.events = [
1654
        {title: 'All Day Event',start: new Date(y, m, 1)},
1655
        {title: 'Long Event',start: new Date(y, m, d - 5),end: new Date(y, m, d - 2)},
1656
        {id: 999,title: 'Repeating Event',start: new Date(y, m, d - 3, 16, 0),allDay: false},
1657
        {id: 999,title: 'Repeating Event',start: new Date(y, m, d + 4, 16, 0),allDay: false},
1658
        {title: 'Birthday Party',start: new Date(y, m, d + 1, 19, 0),end: new Date(y, m, d + 1, 22, 30),allDay: false},
1659
        {title: 'Click for Google',start: new Date(y, m, 28),end: new Date(y, m, 29),url: 'http://google.com/'}
1660
    ];
1661
1662
1663
    /* message on eventClick */
1664
    $scope.alertOnEventClick = function( event, allDay, jsEvent, view ){
1665
        $scope.alertMessage = (event.title + ': Clicked ');
1666
    };
1667
    /* message on Drop */
1668
    $scope.alertOnDrop = function(event, dayDelta, minuteDelta, allDay, revertFunc, jsEvent, ui, view){
1669
        $scope.alertMessage = (event.title +': Droped to make dayDelta ' + dayDelta);
1670
    };
1671
    /* message on Resize */
1672
    $scope.alertOnResize = function(event, dayDelta, minuteDelta, revertFunc, jsEvent, ui, view ){
1673
        $scope.alertMessage = (event.title +': Resized to make dayDelta ' + minuteDelta);
1674
    };
1675
1676
    /* config object */
1677
    $scope.uiConfig = {
1678
        calendar:{
1679
            height: 450,
1680
            editable: true,
1681
            header: {
1682
                left: 'prev,next',
1683
                center: 'title',
1684
                right: 'month,agendaWeek,agendaDay'
1685
            },
1686
            eventClick: $scope.alertOnEventClick,
1687
            eventDrop: $scope.alertOnDrop,
1688
            eventResize: $scope.alertOnResize
1689
        }
1690
    };
1691
1692
    /* Event sources array */
1693
    $scope.eventSources = [$scope.events];
1694
}
1695
1696
/**
1697
 * chartJsCtrl - Controller for data for ChartJs plugin
1698
 * used in Chart.js view
1699
 */
1700
function chartJsCtrl() {
1701
1702
    /**
1703
     * Data for Polar chart
1704
     */
1705
    this.polarData = [
1706
        {
1707
            value: 300,
1708
            color:"#a3e1d4",
1709
            highlight: "#1ab394",
1710
            label: "App"
1711
        },
1712
        {
1713
            value: 140,
1714
            color: "#dedede",
1715
            highlight: "#1ab394",
1716
            label: "Software"
1717
        },
1718
        {
1719
            value: 200,
1720
            color: "#A4CEE8",
1721
            highlight: "#1ab394",
1722
            label: "Laptop"
1723
        }
1724
    ];
1725
1726
    /**
1727
     * Options for Polar chart
1728
     */
1729
    this.polarOptions = {
1730
        scaleShowLabelBackdrop : true,
1731
        scaleBackdropColor : "rgba(255,255,255,0.75)",
1732
        scaleBeginAtZero : true,
1733
        scaleBackdropPaddingY : 1,
1734
        scaleBackdropPaddingX : 1,
1735
        scaleShowLine : true,
1736
        segmentShowStroke : true,
1737
        segmentStrokeColor : "#fff",
1738
        segmentStrokeWidth : 2,
1739
        animationSteps : 100,
1740
        animationEasing : "easeOutBounce",
1741
        animateRotate : true,
1742
        animateScale : false
1743
    };
1744
1745
    /**
1746
     * Data for Doughnut chart
1747
     */
1748
    this.doughnutData = [
1749
        {
1750
            value: 300,
1751
            color:"#a3e1d4",
1752
            highlight: "#1ab394",
1753
            label: "App"
1754
        },
1755
        {
1756
            value: 50,
1757
            color: "#dedede",
1758
            highlight: "#1ab394",
1759
            label: "Software"
1760
        },
1761
        {
1762
            value: 100,
1763
            color: "#A4CEE8",
1764
            highlight: "#1ab394",
1765
            label: "Laptop"
1766
        }
1767
    ];
1768
1769
    /**
1770
     * Options for Doughnut chart
1771
     */
1772
    this.doughnutOptions = {
1773
        segmentShowStroke : true,
1774
        segmentStrokeColor : "#fff",
1775
        segmentStrokeWidth : 2,
1776
        percentageInnerCutout : 45, // This is 0 for Pie charts
1777
        animationSteps : 100,
1778
        animationEasing : "easeOutBounce",
1779
        animateRotate : true,
1780
        animateScale : false
1781
    };
1782
1783
    /**
1784
     * Data for Line chart
1785
     */
1786
    this.lineData = {
1787
        labels: ["January", "February", "March", "April", "May", "June", "July"],
1788
        datasets: [
1789
            {
1790
                label: "Example dataset",
1791
                fillColor: "rgba(220,220,220,0.5)",
1792
                strokeColor: "rgba(220,220,220,1)",
1793
                pointColor: "rgba(220,220,220,1)",
1794
                pointStrokeColor: "#fff",
1795
                pointHighlightFill: "#fff",
1796
                pointHighlightStroke: "rgba(220,220,220,1)",
1797
                data: [65, 59, 80, 81, 56, 55, 40]
1798
            },
1799
            {
1800
                label: "Example dataset",
1801
                fillColor: "rgba(26,179,148,0.5)",
1802
                strokeColor: "rgba(26,179,148,0.7)",
1803
                pointColor: "rgba(26,179,148,1)",
1804
                pointStrokeColor: "#fff",
1805
                pointHighlightFill: "#fff",
1806
                pointHighlightStroke: "rgba(26,179,148,1)",
1807
                data: [28, 48, 40, 19, 86, 27, 90]
1808
            }
1809
        ]
1810
    };
1811
1812
    this.lineDataDashboard4 = {
1813
        labels: ["January", "February", "March", "April", "May", "June", "July"],
1814
        datasets: [
1815
            {
1816
                label: "Example dataset",
1817
                fillColor: "rgba(220,220,220,0.5)",
1818
                strokeColor: "rgba(220,220,220,1)",
1819
                pointColor: "rgba(220,220,220,1)",
1820
                pointStrokeColor: "#fff",
1821
                pointHighlightFill: "#fff",
1822
                pointHighlightStroke: "rgba(220,220,220,1)",
1823
                data: [65, 59, 40, 51, 36, 25, 40]
1824
            },
1825
            {
1826
                label: "Example dataset",
1827
                fillColor: "rgba(26,179,148,0.5)",
1828
                strokeColor: "rgba(26,179,148,0.7)",
1829
                pointColor: "rgba(26,179,148,1)",
1830
                pointStrokeColor: "#fff",
1831
                pointHighlightFill: "#fff",
1832
                pointHighlightStroke: "rgba(26,179,148,1)",
1833
                data: [48, 48, 60, 39, 56, 37, 30]
1834
            }
1835
        ]
1836
    };
1837
1838
    /**
1839
     * Options for Line chart
1840
     */
1841
    this.lineOptions = {
1842
        scaleShowGridLines : true,
1843
        scaleGridLineColor : "rgba(0,0,0,.05)",
1844
        scaleGridLineWidth : 1,
1845
        bezierCurve : true,
1846
        bezierCurveTension : 0.4,
1847
        pointDot : true,
1848
        pointDotRadius : 4,
1849
        pointDotStrokeWidth : 1,
1850
        pointHitDetectionRadius : 20,
1851
        datasetStroke : true,
1852
        datasetStrokeWidth : 2,
1853
        datasetFill : true
1854
    };
1855
1856
    /**
1857
     * Options for Bar chart
1858
     */
1859
    this.barOptions = {
1860
        scaleBeginAtZero : true,
1861
        scaleShowGridLines : true,
1862
        scaleGridLineColor : "rgba(0,0,0,.05)",
1863
        scaleGridLineWidth : 1,
1864
        barShowStroke : true,
1865
        barStrokeWidth : 2,
1866
        barValueSpacing : 5,
1867
        barDatasetSpacing : 1
1868
};
1869
1870
    /**
1871
     * Data for Bar chart
1872
     */
1873
    this.barData = {
1874
        labels: ["January", "February", "March", "April", "May", "June", "July"],
1875
        datasets: [
1876
            {
1877
                label: "My First dataset",
1878
                fillColor: "rgba(220,220,220,0.5)",
1879
                strokeColor: "rgba(220,220,220,0.8)",
1880
                highlightFill: "rgba(220,220,220,0.75)",
1881
                highlightStroke: "rgba(220,220,220,1)",
1882
                data: [65, 59, 80, 81, 56, 55, 40]
1883
            },
1884
            {
1885
                label: "My Second dataset",
1886
                fillColor: "rgba(26,179,148,0.5)",
1887
                strokeColor: "rgba(26,179,148,0.8)",
1888
                highlightFill: "rgba(26,179,148,0.75)",
1889
                highlightStroke: "rgba(26,179,148,1)",
1890
                data: [28, 48, 40, 19, 86, 27, 90]
1891
            }
1892
        ]
1893
    };
1894
1895
    /**
1896
     * Data for Radar chart
1897
     */
1898
    this.radarData = {
1899
        labels: ["Eating", "Drinking", "Sleeping", "Designing", "Coding", "Cycling", "Running"],
1900
        datasets: [
1901
            {
1902
                label: "My First dataset",
1903
                fillColor: "rgba(220,220,220,0.2)",
1904
                strokeColor: "rgba(220,220,220,1)",
1905
                pointColor: "rgba(220,220,220,1)",
1906
                pointStrokeColor: "#fff",
1907
                pointHighlightFill: "#fff",
1908
                pointHighlightStroke: "rgba(220,220,220,1)",
1909
                data: [65, 59, 90, 81, 56, 55, 40]
1910
            },
1911
            {
1912
                label: "My Second dataset",
1913
                fillColor: "rgba(26,179,148,0.2)",
1914
                strokeColor: "rgba(26,179,148,1)",
1915
                pointColor: "rgba(26,179,148,1)",
1916
                pointStrokeColor: "#fff",
1917
                pointHighlightFill: "#fff",
1918
                pointHighlightStroke: "rgba(151,187,205,1)",
1919
                data: [28, 48, 40, 19, 96, 27, 100]
1920
            }
1921
        ]
1922
    };
1923
1924
    /**
1925
     * Options for Radar chart
1926
     */
1927
    this.radarOptions = {
1928
        scaleShowLine : true,
1929
        angleShowLineOut : true,
1930
        scaleShowLabels : false,
1931
        scaleBeginAtZero : true,
1932
        angleLineColor : "rgba(0,0,0,.1)",
1933
        angleLineWidth : 1,
1934
        pointLabelFontFamily : "'Arial'",
1935
        pointLabelFontStyle : "normal",
1936
        pointLabelFontSize : 10,
1937
        pointLabelFontColor : "#666",
1938
        pointDot : true,
1939
        pointDotRadius : 3,
1940
        pointDotStrokeWidth : 1,
1941
        pointHitDetectionRadius : 20,
1942
        datasetStroke : true,
1943
        datasetStrokeWidth : 2,
1944
        datasetFill : true
1945
    };
1946
1947
1948
};
1949
1950
/**
1951
 * GoogleMaps - Controller for data google maps
1952
 */
1953
function GoogleMaps($scope) {
1954
    $scope.mapOptions = {
1955
        zoom: 11,
1956
        center: new google.maps.LatLng(40.6700, -73.9400),
1957
        // Style for Google Maps
1958
        styles: [{"featureType":"water","stylers":[{"saturation":43},{"lightness":-11},{"hue":"#0088ff"}]},{"featureType":"road","elementType":"geometry.fill","stylers":[{"hue":"#ff0000"},{"saturation":-100},{"lightness":99}]},{"featureType":"road","elementType":"geometry.stroke","stylers":[{"color":"#808080"},{"lightness":54}]},{"featureType":"landscape.man_made","elementType":"geometry.fill","stylers":[{"color":"#ece2d9"}]},{"featureType":"poi.park","elementType":"geometry.fill","stylers":[{"color":"#ccdca1"}]},{"featureType":"road","elementType":"labels.text.fill","stylers":[{"color":"#767676"}]},{"featureType":"road","elementType":"labels.text.stroke","stylers":[{"color":"#ffffff"}]},{"featureType":"poi","stylers":[{"visibility":"off"}]},{"featureType":"landscape.natural","elementType":"geometry.fill","stylers":[{"visibility":"on"},{"color":"#b8cb93"}]},{"featureType":"poi.park","stylers":[{"visibility":"on"}]},{"featureType":"poi.sports_complex","stylers":[{"visibility":"on"}]},{"featureType":"poi.medical","stylers":[{"visibility":"on"}]},{"featureType":"poi.business","stylers":[{"visibility":"simplified"}]}],
1959
        mapTypeId: google.maps.MapTypeId.ROADMAP
1960
    };
1961
    $scope.mapOptions2 = {
1962
        zoom: 11,
1963
        center: new google.maps.LatLng(40.6700, -73.9400),
1964
        // Style for Google Maps
1965
        styles: [{"featureType":"all","elementType":"all","stylers":[{"invert_lightness":true},{"saturation":10},{"lightness":30},{"gamma":0.5},{"hue":"#435158"}]}],
1966
        mapTypeId: google.maps.MapTypeId.ROADMAP
1967
    };
1968
    $scope.mapOptions3 = {
1969
        center: new google.maps.LatLng(36.964645, -122.01523),
1970
        zoom: 18,
1971
        // Style for Google Maps
1972
        MapTypeId: google.maps.MapTypeId.SATELLITE,
1973
        styles: [{"featureType":"road","elementType":"geometry","stylers":[{"visibility":"off"}]},{"featureType":"poi","elementType":"geometry","stylers":[{"visibility":"off"}]},{"featureType":"landscape","elementType":"geometry","stylers":[{"color":"#fffffa"}]},{"featureType":"water","stylers":[{"lightness":50}]},{"featureType":"road","elementType":"labels","stylers":[{"visibility":"off"}]},{"featureType":"transit","stylers":[{"visibility":"off"}]},{"featureType":"administrative","elementType":"geometry","stylers":[{"lightness":40}]}],
1974
        mapTypeId: google.maps.MapTypeId.SATELLITE
1975
    };
1976
    $scope.mapOptions4 = {
1977
        zoom: 11,
1978
        center: new google.maps.LatLng(40.6700, -73.9400),
1979
        // Style for Google Maps
1980
        styles: [{"stylers":[{"hue":"#18a689"},{"visibility":"on"},{"invert_lightness":true},{"saturation":40},{"lightness":10}]}],
1981
        mapTypeId: google.maps.MapTypeId.ROADMAP
1982
    };
1983
}
1984
1985
/**
1986
 * nestableCtrl - Controller for nestable list
1987
 */
1988
function nestableCtrl($scope) {
1989
    $scope.remove = function(scope) {
1990
        scope.remove();
1991
    };
1992
    $scope.toggle = function(scope) {
1993
        scope.toggle();
1994
    };
1995
    $scope.moveLastToTheBeginning = function () {
1996
        var a = $scope.data.pop();
1997
        $scope.data.splice(0,0, a);
1998
    };
1999
    $scope.newSubItem = function(scope) {
2000
        var nodeData = scope.$modelValue;
2001
        nodeData.nodes.push({
2002
            id: nodeData.id * 10 + nodeData.nodes.length,
2003
            title: nodeData.title + '.' + (nodeData.nodes.length + 1),
2004
            nodes: []
2005
        });
2006
    };
2007
    $scope.collapseAll = function() {
2008
        $scope.$broadcast('collapseAll');
2009
    };
2010
    $scope.expandAll = function() {
2011
        $scope.$broadcast('expandAll');
2012
    };
2013
    $scope.data = [{
2014
        "id": 1,
2015
        "title": "node1",
2016
        "nodes": [
2017
            {
2018
                "id": 11,
2019
                "title": "node1.1",
2020
                "nodes": [
2021
                    {
2022
                        "id": 111,
2023
                        "title": "node1.1.1",
2024
                        "nodes": []
2025
                    }
2026
                ]
2027
            },
2028
            {
2029
                "id": 12,
2030
                "title": "node1.2",
2031
                "nodes": []
2032
            }
2033
        ]
2034
    }, {
2035
        "id": 2,
2036
        "title": "node2",
2037
        "nodes": [
2038
            {
2039
                "id": 21,
2040
                "title": "node2.1",
2041
                "nodes": []
2042
            },
2043
            {
2044
                "id": 22,
2045
                "title": "node2.2",
2046
                "nodes": []
2047
            }
2048
        ]
2049
    }, {
2050
        "id": 3,
2051
        "title": "node3",
2052
        "nodes": [
2053
            {
2054
                "id": 31,
2055
                "title": "node3.1",
2056
                "nodes": []
2057
            }
2058
        ]
2059
    }];
2060
}
2061
2062
/**
2063
 * codeEditorCtrl - Controller for code editor - Code Mirror
2064
 */
2065
function codeEditorCtrl($scope) {
2066
    $scope.editorOptions = {
2067
        lineNumbers: true,
2068
        matchBrackets: true,
2069
        styleActiveLine: true,
2070
        theme:"ambiance"
2071
    };
2072
2073
    $scope.editorOptions2 = {
2074
        lineNumbers: true,
2075
        matchBrackets: true,
2076
        styleActiveLine: true
2077
    };
2078
2079
}
2080
2081
/**
2082
 * ngGridCtrl - Controller for code ngGrid
2083
 */
2084
function ngGridCtrl($scope) {
2085
    $scope.ngData = [
2086
        {Name: "Moroni", Age: 50, Position: 'PR Menager', Status: 'active', Date: '12.12.2014'},
2087
        {Name: "Teancum", Age: 43, Position: 'CEO/CFO', Status: 'deactive', Date: '10.10.2014'},
2088
        {Name: "Jacob", Age: 27, Position: 'UI Designer', Status: 'active', Date: '09.11.2013'},
2089
        {Name: "Nephi", Age: 29, Position: 'Java programmer', Status: 'deactive', Date: '22.10.2014'},
2090
        {Name: "Joseph", Age: 22, Position: 'Marketing manager', Status: 'active', Date: '24.08.2013'},
2091
        {Name: "Monica", Age: 43, Position: 'President', Status: 'active', Date: '11.12.2014'},
2092
        {Name: "Arnold", Age: 12, Position: 'CEO', Status: 'active', Date: '07.10.2013'},
2093
        {Name: "Mark", Age: 54, Position: 'Analyst', Status: 'deactive', Date: '03.03.2014'},
2094
        {Name: "Amelia", Age: 33, Position: 'Sales manager', Status: 'deactive', Date: '26.09.2013'},
2095
        {Name: "Jesica", Age: 41, Position: 'Ruby programmer', Status: 'active', Date: '22.12.2013'},
2096
        {Name: "John", Age: 48, Position: 'Marketing manager', Status: 'deactive', Date: '09.10.2014'},
2097
        {Name: "Berg", Age: 19, Position: 'UI/UX Designer', Status: 'active', Date: '12.11.2013'}
2098
    ];
2099
2100
    $scope.ngOptions = { data: 'ngData' };
2101
    $scope.ngOptions2 = {
2102
        data: 'ngData',
2103
        showGroupPanel: true,
2104
        jqueryUIDraggable: true
2105
    };
2106
}
2107
2108
2109
/**
2110
 * notifyCtrl - Controller angular notify
2111
 */
2112
function notifyCtrl($scope, notify) {
2113
    $scope.msg = 'Hello! This is a sample message!';
2114
    $scope.demo = function () {
2115
        notify({
2116
            message: $scope.msg,
2117
            classes: $scope.classes,
2118
            templateUrl: $scope.template
2119
        });
2120
    };
2121
    $scope.closeAll = function () {
2122
        notify.closeAll();
2123
    };
2124
2125
    $scope.inspiniaTemplate = 'views/demo/set_factory.html';
2126
    $scope.inspiniaDemo1 = function(){
2127
        notify({ message: 'Info - This is a Inspinia info notification', classes: 'alert-info', templateUrl: $scope.inspiniaTemplate});
2128
    }
2129
    $scope.inspiniaDemo2 = function(){
2130
        notify({ message: 'Success - This is a Inspinia success notification', classes: 'alert-success', templateUrl: $scope.inspiniaTemplate});
2131
    }
2132
    $scope.inspiniaDemo3 = function(){
2133
        notify({ message: 'Warning - This is a Inspinia warning notification', classes: 'alert-warning', templateUrl: $scope.inspiniaTemplate});
2134
    }
2135
    $scope.inspiniaDemo4 = function(){
2136
        notify({ message: 'Danger - This is a Inspinia danger notification', classes: 'alert-danger', templateUrl: $scope.inspiniaTemplate});
2137
    }
2138
}
2139
2140
/**
2141
 * translateCtrl - Controller for translate
2142
 */
2143
function translateCtrl($translate, $scope) {
2144
    $scope.changeLanguage = function (langKey) {
2145
        $translate.use(langKey);
2146
        $scope.language = langKey;
2147
    };
2148
}
2149
2150
/**
2151
 * imageCrop - Controller for image crop functionality
2152
 */
2153
function imageCrop($scope) {
2154
2155
    $scope.dupa = "dasdasdas";
2156
2157
    $scope.myImage='';
2158
    $scope.myCroppedImage='';
2159
2160
    var handleFileSelect=function(evt) {
2161
        var file=evt.currentTarget.files[0];
2162
        var reader = new FileReader();
2163
        reader.onload = function (evt) {
2164
            $scope.$apply(function($scope){
2165
                $scope.myImage=evt.target.result;
2166
            });
2167
        };
2168
        reader.readAsDataURL(file);
2169
    };
2170
    angular.element(document.querySelector('#fileInput')).on('change',handleFileSelect);
2171
}
2172
2173
2174
/**
2175
 * diff - Controller for diff function
2176
 */
2177
function diff($scope) {
2178
    $scope.oldText = 'Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry\'s standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only centuries, but also the leap into electronic typesetting.';
2179
    $scope.newText = 'Lorem Ipsum is simply typesetting dummy text of the printing and has been the industry\'s typesetting. Lorem Ipsum has been the industry\'s standard dummy text ever the 1500s, when an printer took a galley of type and simply it to make a type. It has survived not only five centuries, but survived not also the leap into electronic typesetting.';
2180
2181
    $scope.oldText1 = 'Lorem Ipsum is simply printing and typesetting industry. Lorem Ipsum has been the industry\'s standard dummy text eve';
2182
    $scope.newText1 = 'Ting dummy text of the printing and has been the industry\'s typesetting. Lorem Ipsum has been the industry\'s';
2183
}
2184
2185
/**
2186
 * idleTimer - Controller for Idle Timer
2187
 */
2188
function idleTimer($scope, Idle, notify) {
2189
2190
    // Custm alter
2191
    $scope.customAlert = false;
2192
2193
    // Start watching idle
2194
    Idle.watch();
2195
2196
    // Config notify behavior
2197
    notify.config({
2198
       duration: '5000'
2199
    });
2200
2201
    // function you want to fire when the user goes idle
2202
    $scope.$on('IdleStart', function () {
2203
        notify({
2204
            message: 'Idle time - You can call any function after idle timeout.',
2205
            classes: 'alert-warning',
2206
            templateUrl: 'views/common/notify.html'
2207
        });
2208
        $scope.customAlert = true;
2209
2210
    });
2211
2212
    // function you want to fire when the user becomes active again
2213
    $scope.$on('IdleEnd', function () {
2214
        notify({
2215
            message: 'You are back, Great that you decided to move a mouse.',
2216
            classes: 'alert-success',
2217
            templateUrl: 'views/common/notify.html'
2218
        });
2219
        $scope.customAlert = false;
2220
    });
2221
2222
}
2223
2224
2225
/**
2226
 * liveFavicon - Controller for live favicon
2227
 */
2228
function liveFavicon($scope){
2229
2230
    $scope.example1 = function(){
2231
        Tinycon.setBubble(1);
2232
        Tinycon.setOptions({
2233
            background: '#f03d25'
2234
        });
2235
    }
2236
2237
    $scope.example2 = function(){
2238
        Tinycon.setBubble(1000);
2239
        Tinycon.setOptions({
2240
            background: '#f03d25'
2241
        });
2242
    }
2243
2244
    $scope.example3 = function(){
2245
        Tinycon.setBubble('In');
2246
        Tinycon.setOptions({
2247
            background: '#f03d25'
2248
        });
2249
    }
2250
2251
    $scope.example4 = function(){
2252
        Tinycon.setOptions({
2253
            background: '#e0913b'
2254
        });
2255
        Tinycon.setBubble(8);
2256
    }
2257
2258
}
2259
2260
/**
2261
 * formValidation - Controller for validation example
2262
 */
2263
function formValidation($scope) {
2264
2265
    $scope.signupForm = function() {
2266
        if ($scope.signup_form.$valid) {
0 ignored issues
show
Comprehensibility Documentation Best Practice introduced by
This code block is empty. Consider removing it or adding a comment to explain.
Loading history...
2267
            // Submit as normal
2268
        } else {
2269
            $scope.signup_form.submitted = true;
2270
        }
2271
    }
2272
2273
    $scope.signupForm2 = function() {
2274
        if ($scope.signup_form.$valid) {
0 ignored issues
show
Comprehensibility Documentation Best Practice introduced by
This code block is empty. Consider removing it or adding a comment to explain.
Loading history...
2275
            // Submit as normal
2276
        }
2277
    }
2278
2279
};
2280
2281
/**
2282
 * agileBoard - Controller for agile Board view
2283
 */
2284
function agileBoard($scope) {
2285
2286
2287
    $scope.todoList = [
2288
        {
2289
            content: 'Simply dummy text of the printing and typesetting industry.',
2290
            date: '12.10.2015',
2291
            statusClass: 'warning',
2292
            tagName: 'Mark'
2293
        },
2294
        {
2295
            content: 'Many desktop publishing packages and web page editors now use Lorem Ipsum as their default.',
2296
            date: '05.04.2015',
2297
            statusClass: 'success',
2298
            tagName: 'Tag'
2299
        },
2300
        {
2301
            content: 'Sometimes by accident, sometimes on purpose (injected humour and the like).',
2302
            date: '16.11.2015',
2303
            statusClass: 'info',
2304
            tagName: 'Mark'
2305
        },
2306
        {
2307
            content: 'All the Lorem Ipsum generators',
2308
            date: '06.10.2015',
2309
            statusClass: 'danger',
2310
            tagName: 'Tag'
2311
        },
2312
        {
2313
            content: 'Which looks reasonable. The generated Lorem Ipsum is therefore always free from repetition, injected humour, or non-characteristic words etc.',
2314
            date: '09.12.2015',
2315
            statusClass: 'warning',
2316
            tagName: 'Mark'
2317
        },
2318
        {
2319
            content: 'Packages and web page editors now use Lorem Ipsum as',
2320
            date: '08.04.2015',
2321
            statusClass: 'warning',
2322
            tagName: 'Mark'
2323
        },
2324
        {
2325
            content: 'Many desktop publishing packages and web page editors now use Lorem Ipsum as their default.',
2326
            date: '05.04.2015',
2327
            statusClass: 'success',
2328
            tagName: 'Tag'
2329
        },
2330
        {
2331
            content: 'Sometimes by accident, sometimes on purpose (injected humour and the like).',
2332
            date: '16.11.2015',
2333
            statusClass: 'info',
2334
            tagName: 'Tag'
2335
        }
2336
    ];
2337
    $scope.inProgressList = [
2338
        {
2339
            content: 'Quisque venenatis ante in porta suscipit.',
2340
            date: '12.10.2015',
2341
            statusClass: 'success',
2342
            tagName: 'Mark'
2343
        },
2344
        {
2345
            content: ' Phasellus sit amet tortor sed enim mollis accumsan in consequat orci.',
2346
            date: '05.04.2015',
2347
            statusClass: 'success',
2348
            tagName: 'Tag'
2349
        },
2350
        {
2351
            content: 'Nunc sed arcu at ligula faucibus tempus ac id felis. Vestibulum et nulla quis turpis sagittis fringilla.',
2352
            date: '16.11.2015',
2353
            statusClass: 'warning',
2354
            tagName: 'Mark'
2355
        },
2356
        {
2357
            content: 'Ut porttitor augue non sapien mollis accumsan. Nulla non elit eget lacus elementum viverra.',
2358
            date: '09.12.2015',
2359
            statusClass: 'warning',
2360
            tagName: 'Tag'
2361
        },
2362
        {
2363
            content: 'Packages and web page editors now use Lorem Ipsum as',
2364
            date: '08.04.2015',
2365
            statusClass: 'info',
2366
            tagName: 'Tag'
2367
        },
2368
        {
2369
            content: 'Quisque lacinia tellus et odio ornare maximus.',
2370
            date: '05.04.2015',
2371
            statusClass: 'success',
2372
            tagName: 'Mark'
2373
        },
2374
        {
2375
            content: 'Enim mollis accumsan in consequat orci.',
2376
            date: '11.04.2015',
2377
            statusClass: 'danger',
2378
            tagName: 'Tag'
2379
        }
2380
    ];
2381
    $scope.completedList = [
2382
        {
2383
            content: 'Sometimes by accident, sometimes on purpose (injected humour and the like).',
2384
            date: '16.11.2015',
2385
            statusClass: 'info',
2386
            tagName: 'Mark'
2387
        },
2388
        {
2389
            content: 'Ut porttitor augue non sapien mollis accumsan. Nulla non elit eget lacus elementum viverra.',
2390
            date: '09.12.2015',
2391
            statusClass: 'warning',
2392
            tagName: 'Tag'
2393
        },
2394
        {
2395
            content: 'Which looks reasonable. The generated Lorem Ipsum is therefore always free from repetition, injected humour, or non-characteristic words etc.',
2396
            date: '09.12.2015',
2397
            statusClass: 'warning',
2398
            tagName: 'Tag'
2399
        },
2400
        {
2401
            content: 'Packages and web page editors now use Lorem Ipsum as',
2402
            date: '08.04.2015',
2403
            statusClass: 'warning',
2404
            tagName: 'Tag'
2405
        },
2406
        {
2407
            content: 'Many desktop publishing packages and web page editors now use Lorem Ipsum as their default.',
2408
            date: '05.04.2015',
2409
            statusClass: 'success',
2410
            tagName: 'Mark'
2411
        },
2412
        {
2413
            content: 'Sometimes by accident, sometimes on purpose (injected humour and the like).',
2414
            date: '16.11.2015',
2415
            statusClass: 'info',
2416
            tagName: 'Tag'
2417
        },
2418
        {
2419
            content: 'Simply dummy text of the printing and typesetting industry.',
2420
            date: '12.10.2015',
2421
            statusClass: 'warning',
2422
            tagName: 'Mark'
2423
        },
2424
        {
2425
            content: 'Many desktop publishing packages and web page editors now use Lorem Ipsum as their default.',
2426
            date: '05.04.2015',
2427
            statusClass: 'success',
2428
            tagName: 'Mark'
2429
        }
2430
    ];
2431
2432
    $scope.sortableOptions = {
2433
        connectWith: ".connectList"
2434
    };
2435
2436
}
2437
2438
/**
2439
 * draggablePanels - Controller for draggable panels example
2440
 */
2441
function draggablePanels($scope) {
2442
2443
    $scope.sortableOptions = {
2444
        connectWith: ".connectPanels",
2445
        handler: ".ibox-title"
2446
    };
2447
2448
}
2449
2450
/**
2451
 * chartistCtrl - Controller for Chartist library
2452
 */
2453
function chartistCtrl() {
2454
2455
    this.lineData = {
2456
        labels: ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday'],
2457
        series: [
2458
            [12, 9, 7, 8, 5],
2459
            [2, 1, 3.5, 7, 3],
2460
            [1, 3, 4, 5, 6]
2461
        ]
2462
    }
2463
2464
    this.lineOptions = {
2465
        fullWidth: true,
2466
        chartPadding: {
2467
            right: 40
2468
        }
2469
    }
2470
2471
    var times = function (n) {
2472
        return Array.apply(null, new Array(n));
2473
    };
2474
2475
    var prepareData = times(26).map(Math.random).reduce(function (data, rnd, index) {
2476
        data.labels.push(index + 1);
2477
        data.series.forEach(function (series) {
2478
            series.push(Math.random() * 100)
2479
        });
2480
2481
        return data;
2482
    }, {
2483
        labels: [],
2484
        series: times(4).map(function () {
2485
            return new Array()
0 ignored issues
show
Coding Style Best Practice introduced by
Using the Array constructor is generally discouraged. Consider using an array literal instead.
Loading history...
2486
        })
2487
    });
2488
2489
    this.scatterData = prepareData;
2490
2491
    this.scatterOptions = {
2492
        showLine: false,
2493
        axisX: {
2494
            labelInterpolationFnc: function (value, index) {
2495
                return index % 13 === 0 ? 'W' + value : null;
2496
            }
2497
        }
2498
    }
2499
2500
    this.stackedData = {
2501
        labels: ['Q1', 'Q2', 'Q3', 'Q4'],
2502
        series: [
2503
            [800000, 1200000, 1400000, 1300000],
2504
            [200000, 400000, 500000, 300000],
2505
            [100000, 200000, 400000, 600000]
2506
        ]
2507
    }
2508
    this.stackedOptions = {
2509
        stackBars: true,
2510
        axisY: {
2511
            labelInterpolationFnc: function (value) {
2512
                return (value / 1000) + 'k';
2513
            }
2514
        }
2515
    }
2516
2517
    this.horizontalData = {
2518
        labels: ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday'],
2519
        series: [
2520
            [5, 4, 3, 7, 5, 10, 3],
2521
            [3, 2, 9, 5, 4, 6, 4]
2522
        ]
2523
    }
2524
2525
    this.horizontalOptions = {
2526
        seriesBarDistance: 10,
2527
        reverseData: true,
2528
        horizontalBars: true,
2529
        axisY: {
2530
            offset: 70
2531
        }
2532
    }
2533
2534
    var prepareData = {
2535
        series: [5, 3, 4]
2536
    }
2537
2538
    this.pieData = prepareData
2539
2540
    var sum = function (a, b) {
2541
        return a + b
2542
    };
2543
2544
    this.pieOptions = {
2545
        labelInterpolationFnc: function (value) {
2546
            return Math.round(value / prepareData.series.reduce(sum) * 100) + '%';
2547
        }
2548
    }
2549
2550
    this.gaugeData = {
2551
        labels: ['Monday', 'Tuesday'],
2552
        series: [20, 10, 30, 40]
2553
    }
2554
2555
    this.gaugeOptions = {
2556
        donut: true,
2557
        donutWidth: 60,
2558
        startAngle: 270,
2559
        total: 200,
2560
        showLabel: true
2561
2562
    }
2563
2564
}
2565
2566
/**
2567
 * metricsCtrl - Controller for data for all Sparkline chart
2568
 * used in Metrics view
2569
 */
2570
function metricsCtrl() {
2571
2572
2573
    this.demo1Data = [34, 43, 43, 35, 44, 32, 44, 52];
2574
    this.demo1Options = {
2575
        type: 'line',
2576
        width: '100%',
2577
        height: '60',
2578
        lineColor: '#1ab394',
2579
        fillColor: "#ffffff"
2580
    };
2581
2582
    this.demo2Data = [24, 43, 43, 55, 44, 62, 44, 72];
2583
    this.demo2Options = {
2584
        type: 'line',
2585
        width: '100%',
2586
        height: '60',
2587
        lineColor: '#1ab394',
2588
        fillColor: "#ffffff"
2589
    };
2590
2591
    this.demo3Data = [74, 43, 23, 55, 54, 32, 24, 12];
2592
    this.demo3Options = {
2593
        type: 'line',
2594
        width: '100%',
2595
        height: '60',
2596
        lineColor: '#ed5565',
2597
        fillColor: "#ffffff"
2598
    };
2599
2600
    this.demo4Data = [24, 43, 33, 55, 64, 72, 44, 22];
2601
    this.demo4Options = {
2602
        type: 'line',
2603
        width: '100%',
2604
        height: '60',
2605
        lineColor: '#ed5565',
2606
        fillColor: "#ffffff"
2607
    };
2608
2609
    this.demo5Data = [1, 4];
2610
    this.demo5Options = {
2611
        type: 'pie',
2612
        height: '140',
2613
        sliceColors: ['#1ab394', '#F5F5F5']
2614
    };
2615
2616
    this.demo6Data = [5, 3];
2617
    this.demo6Options = {
2618
        type: 'pie',
2619
        height: '140',
2620
        sliceColors: ['#1ab394', '#F5F5F5']
2621
    };
2622
2623
    this.demo7Data = [2, 2];
2624
    this.demo7Options = {
2625
        type: 'pie',
2626
        height: '140',
2627
        sliceColors: ['#ed5565', '#F5F5F5']
2628
    };
2629
2630
    this.demo8Data = [2, 3];
2631
    this.demo8Options = {
2632
        type: 'pie',
2633
        height: '140',
2634
        sliceColors: ['#ed5565', '#F5F5F5']
2635
    };
2636
2637
}
2638
2639
2640
2641
/**
2642
 * sweetAlertCtrl - Function for Sweet alerts
2643
 */
2644
function sweetAlertCtrl($scope, SweetAlert) {
2645
2646
2647
    $scope.demo1 = function () {
2648
        SweetAlert.swal({
2649
            title: "Welcome in Alerts",
2650
            text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry."
2651
        });
2652
    }
2653
2654
    $scope.demo2 = function () {
2655
        SweetAlert.swal({
2656
            title: "Good job!",
2657
            text: "You clicked the button!",
2658
            type: "success"
2659
        });
2660
    }
2661
2662
    $scope.demo3 = function () {
2663
        SweetAlert.swal({
2664
                title: "Are you sure?",
2665
                text: "Your will not be able to recover this imaginary file!",
2666
                type: "warning",
2667
                showCancelButton: true,
2668
                confirmButtonColor: "#DD6B55",
2669
                confirmButtonText: "Yes, delete it!",
2670
                closeOnConfirm: false,
2671
                closeOnCancel: false
2672
            },
2673
            function () {
2674
                SweetAlert.swal("Ok!");
2675
            });
2676
    }
2677
2678
    $scope.demo4 = function () {
2679
        SweetAlert.swal({
2680
                title: "Are you sure?",
2681
                text: "Your will not be able to recover this imaginary file!",
2682
                type: "warning",
2683
                showCancelButton: true,
2684
                confirmButtonColor: "#DD6B55",
2685
                confirmButtonText: "Yes, delete it!",
2686
                cancelButtonText: "No, cancel plx!",
2687
                closeOnConfirm: false,
2688
                closeOnCancel: false },
2689
            function (isConfirm) {
2690
                if (isConfirm) {
2691
                    SweetAlert.swal("Deleted!", "Your imaginary file has been deleted.", "success");
2692
                } else {
2693
                    SweetAlert.swal("Cancelled", "Your imaginary file is safe :)", "error");
2694
                }
2695
            });
2696
    }
2697
2698
}
2699
2700
function selectCtrl($scope) {
2701
2702
    $scope.person = {};
2703
    $scope.people = [
2704
        { name: 'Adam',      email: '[email protected]',      age: 12, country: 'United States' },
2705
        { name: 'Amalie',    email: '[email protected]',    age: 12, country: 'Argentina' },
2706
        { name: 'Estefanía', email: '[email protected]', age: 21, country: 'Argentina' },
2707
        { name: 'Adrian',    email: '[email protected]',    age: 21, country: 'Ecuador' },
2708
        { name: 'Wladimir',  email: '[email protected]',  age: 30, country: 'Ecuador' },
2709
        { name: 'Samantha',  email: '[email protected]',  age: 30, country: 'United States' },
2710
        { name: 'Nicole',    email: '[email protected]',    age: 43, country: 'Colombia' },
2711
        { name: 'Natasha',   email: '[email protected]',   age: 54, country: 'Ecuador' },
2712
        { name: 'Michael',   email: '[email protected]',   age: 15, country: 'Colombia' },
2713
        { name: 'Nicolás',   email: '[email protected]',    age: 43, country: 'Colombia' }
2714
    ];
2715
2716
    $scope.option = {};
2717
    $scope.options = [
2718
        { number: '1',      text: 'Option 1' },
2719
        { number: '2',      text: 'Option 2' },
2720
        { number: '3',      text: 'Option 3' },
2721
        { number: '4',      text: 'Option 4' },
2722
        { number: '5',      text: 'Option 5' },
2723
        { number: '6',      text: 'Option 6' }
2724
    ];
2725
2726
    $scope.availableColors = ['Red','Green','Blue','Yellow','Magenta','Maroon','Umbra','Turquoise'];
2727
2728
    $scope.multipleDemo = {};
2729
    $scope.multipleDemo.colors = ['Blue','Red'];
2730
2731
}
2732
2733
2734
2735
function toastrCtrl($scope, toaster){
2736
2737
    $scope.demo1 = function(){
2738
        toaster.success({ body:"Hi, welcome to Inspinia. This is example of Toastr notification box."});
2739
    };
2740
2741
    $scope.demo2 = function(){
2742
        toaster.warning({ title: "Title example", body:"This is example of Toastr notification box."});
2743
    };
2744
2745
    $scope.demo3 = function(){
2746
        toaster.pop({
2747
            type: 'info',
2748
            title: 'Title example',
2749
            body: 'This is example of Toastr notification box.',
2750
            showCloseButton: true
2751
2752
        });
2753
    };
2754
2755
    $scope.demo4 = function(){
2756
        toaster.pop({
2757
            type: 'error',
2758
            title: 'Title example',
2759
            body: 'This is example of Toastr notification box.',
2760
            showCloseButton: true,
2761
            timeout: 600
2762
        });
2763
    };
2764
2765
}
2766
2767
function loadingCtrl($scope, $timeout){
2768
2769
2770
    $scope.runLoading = function() {
2771
        // start loading
2772
        $scope.loading = true;
2773
2774
        $timeout(function(){
2775
            // Simulate some service
2776
            $scope.loading = false;
2777
        },2000)
2778
    };
2779
2780
2781
    // Demo purpose actions
2782
    $scope.runLoading1 = function () {
2783
        // start loading
2784
        $scope.loading1 = true;
2785
2786
        $timeout(function () {
2787
            // Simulate some service
2788
            $scope.loading1 = false;
2789
        }, 2000)
2790
    };
2791
    $scope.runLoading2 = function () {
2792
        // start loading
2793
        $scope.loading2 = true;
2794
2795
        $timeout(function () {
2796
            // Simulate some service
2797
            $scope.loading2 = false;
2798
        }, 2000)
2799
    };
2800
    $scope.runLoading3 = function () {
2801
        // start loading
2802
        $scope.loading3 = true;
2803
2804
        $timeout(function () {
2805
            // Simulate some service
2806
            $scope.loading3 = false;
2807
        }, 2000)
2808
    };
2809
    $scope.runLoading4 = function () {
2810
        // start loading
2811
        $scope.loading4 = true;
2812
2813
        $timeout(function () {
2814
            // Simulate some service
2815
            $scope.loading4 = false;
2816
        }, 2000)
2817
    };
2818
    $scope.runLoading5 = function () {
2819
        // start loading
2820
        $scope.loading5 = true;
2821
2822
        $timeout(function () {
2823
            // Simulate some service
2824
            $scope.loading5 = false;
2825
        }, 2000)
2826
    };
2827
    $scope.runLoading6 = function () {
2828
        // start loading
2829
        $scope.loading6 = true;
2830
2831
        $timeout(function () {
2832
            // Simulate some service
2833
            $scope.loading6 = false;
2834
        }, 2000)
2835
    };
2836
    $scope.runLoading7 = function () {
2837
        // start loading
2838
        $scope.loading7 = true;
2839
2840
        $timeout(function () {
2841
            // Simulate some service
2842
            $scope.loading7 = false;
2843
        }, 2000)
2844
    };
2845
    $scope.runLoading8 = function () {
2846
        // start loading
2847
        $scope.loading8 = true;
2848
2849
        $timeout(function () {
2850
            // Simulate some service
2851
            $scope.loading8 = false;
2852
        }, 2000)
2853
    };
2854
    $scope.runLoading9 = function () {
2855
        // start loading
2856
        $scope.loading9 = true;
2857
2858
        $timeout(function () {
2859
            // Simulate some service
2860
            $scope.loading9 = false;
2861
        }, 2000)
2862
    };
2863
    $scope.runLoading10 = function () {
2864
        // start loading
2865
        $scope.loading10 = true;
2866
2867
        $timeout(function () {
2868
            // Simulate some service
2869
            $scope.loading10 = false;
2870
        }, 2000)
2871
    };
2872
    $scope.runLoading11 = function () {
2873
        // start loading
2874
        $timeout(function() {
2875
            $scope.loading11 = 0.1;
2876
        }, 500);
2877
        $timeout(function() {
2878
            $scope.loading11 += 0.2;
2879
        }, 1000);
2880
        $timeout(function() {
2881
            $scope.loading11 += 0.3;
2882
        }, 1500);
2883
        $timeout(function() {
2884
            $scope.loading11 = false;
2885
        }, 2000);
2886
2887
    };
2888
    $scope.runLoading12 = function () {
2889
        // start loading
2890
        $timeout(function() {
2891
            $scope.loading12 = 0.1;
2892
        }, 500);
2893
        $timeout(function() {
2894
            $scope.loading12 += 0.2;
2895
        }, 1000);
2896
        $timeout(function() {
2897
            $scope.loading12 += 0.3;
2898
        }, 1500);
2899
        $timeout(function() {
2900
            $scope.loading12 = false;
2901
        }, 2000);
2902
2903
    };
2904
2905
    $scope.runLoadingDemo = function() {
2906
        // start loading
2907
        $scope.loadingDemo = true;
2908
2909
        $timeout(function(){
2910
            // Simulate some service
2911
            $scope.loadingDemo = false;
2912
        },2000)
2913
    };
2914
2915
2916
}
2917
2918
2919
function datatablesCtrl($scope,DTOptionsBuilder){
2920
2921
    $scope.dtOptions = DTOptionsBuilder.newOptions()
2922
        .withDOM('<"html5buttons"B>lTfgitp')
2923
        .withButtons([
2924
            {extend: 'copy'},
2925
            {extend: 'csv'},
2926
            {extend: 'excel', title: 'ExampleFile'},
2927
            {extend: 'pdf', title: 'ExampleFile'},
2928
2929
            {extend: 'print',
2930
                customize: function (win){
2931
                    $(win.document.body).addClass('white-bg');
2932
                    $(win.document.body).css('font-size', '10px');
2933
2934
                    $(win.document.body).find('table')
2935
                        .addClass('compact')
2936
                        .css('font-size', 'inherit');
2937
                }
2938
            }
2939
        ]);
2940
2941
    /**
2942
     * persons - Data used in Tables view for Data Tables plugin
2943
     */
2944
    $scope.persons = [
2945
        {
2946
            id: '分厂一',
2947
            firstName: '4525421',
2948
            lastName: '25%'
2949
        },
2950
        {
2951
            id: '分厂二',
2952
            firstName: '15425451',
2953
            lastName: '40%'
2954
        },
2955
        {
2956
            id: '分厂三',
2957
            firstName: '12547854',
2958
            lastName: '7%'
2959
        },
2960
        {
2961
            id: '分厂四',
2962
            firstName: '1262254',
2963
            lastName: '8%'
2964
        },
2965
        {
2966
            id: '分厂五',
2967
            firstName: '3225854',
2968
            lastName: '30%'
2969
        }
2970
    ];
2971
2972
}
2973
2974
function truncateCtrl($scope){
2975
2976
    $scope.truncateOptions = {
2977
        watch: 'window'
2978
    };
2979
2980
    $scope.truncateOptions2 = {
2981
        watch: 'window',
2982
        ellipsis: ' ///...'
2983
    };
2984
2985
    $scope.truncateOptions3 = {
2986
        watch: 'window',
2987
        wrap: 'letter'
2988
    }
2989
2990
}
2991
2992
function touchspinCtrl($scope) {
2993
2994
    $scope.inputteresxcs = 55;
2995
    $scope.spinOption1 = {
2996
        min: 0,
2997
        max: 100,
2998
        step: 0.1,
2999
        decimals: 2,
3000
        boostat: 5,
3001
        maxboostedstep: 10,
3002
    };
3003
3004
    $scope.spinOption2 = {
3005
        verticalbuttons: true
3006
    }
3007
3008
    $scope.spinOption3 = {
3009
        postfix: '%'
3010
    }
3011
3012
    $scope.spinOption4 = {
3013
        postfix: "a button",
3014
        postfix_extraclass: "btn btn-default"
3015
    }
3016
3017
}
3018
3019
function tourCtrl($scope){
3020
3021
    $scope.preparebody = function(tour){
3022
        $('body').addClass('tour-open')
3023
    };
3024
3025
    $scope.clearbody = function(tour){
3026
        $('body').removeClass('tour-close')
3027
    }
3028
3029
}
3030
3031
function jstreeCtrl($scope) {
3032
3033
    $scope.treeConfig = {
3034
        'plugins' : [ 'types', 'dnd' ],
3035
        'types' : {
3036
            'default' : {
3037
                'icon' : 'fa fa-folder'
3038
            },
3039
            'html' : {
3040
                'icon' : 'fa fa-file-code-o'
3041
            },
3042
            'svg' : {
3043
                'icon' : 'fa fa-file-picture-o'
3044
            },
3045
            'css' : {
3046
                'icon' : 'fa fa-file-code-o'
3047
            },
3048
            'img' : {
3049
                'icon' : 'fa fa-file-image-o'
3050
            },
3051
            'js' : {
3052
                'icon' : 'fa fa-file-text-o'
3053
            }
3054
3055
        }
3056
    };
3057
3058
    $scope.treeData = [
3059
        {
3060
            "id": "ajson1",
3061
            "parent": "#",
3062
            "text": "XXX集团",
3063
            "state": {
3064
                "opened": true
3065
            },
3066
            "__uiNodeId": 1
3067
        }, {
3068
            "id": "ajson2",
3069
            "parent": "ajson1",
3070
            "text": "XXX分厂",
3071
            "state": {
3072
                "opened": true
3073
            },
3074
            "__uiNodeId": 2
3075
        }, {
3076
            "id": "ajson3",
3077
            "parent": "ajson2",
3078
            "text": "第一车间",
3079
            "state": {
3080
                "opened": true
3081
            },
3082
            "__uiNodeId": 3
3083
        },
3084
        {
3085
            "id": "ajson4",
3086
            "parent": "ajson2",
3087
            "text": "第二车间",
3088
            "state": {
3089
                "opened": true
3090
            },
3091
            "__uiNodeId": 4
3092
        },
3093
        {
3094
            "id": "ajson5",
3095
            "parent": "ajson2",
3096
            "text": "第三车间",
3097
            "state": {
3098
                "opened": true
3099
            },
3100
            "__uiNodeId": 5
3101
        },
3102
        {
3103
            "id": "ajson6",
3104
            "parent": "ajson3",
3105
            "text": "第一生产线",
3106
            "state": {
3107
                "opened": false
3108
            },
3109
            "__uiNodeId": 6
3110
        },
3111
        {
3112
            "id": "ajson9",
3113
            "parent": "ajson6",
3114
            "text": "班组1",
3115
            "state": {
3116
                "opened": true
3117
            },
3118
            "type":"img",
3119
            "__uiNodeId": 9
3120
        },
3121
        {
3122
            "id": "ajson10",
3123
            "parent": "ajson6",
3124
            "text": "班组2",
3125
            "state": {
3126
                "opened": true
3127
            },
3128
            "type":"svg",
3129
            "__uiNodeId": 10
3130
        },
3131
        {
3132
            "id": "ajson11",
3133
            "parent": "ajson12",
3134
            "text": "班组1",
3135
            "state": {
3136
                "opened": true
3137
            },
3138
            "type":"img",
3139
            "__uiNodeId": 11
3140
        },
3141
3142
        {
3143
            "id": "ajson13",
3144
            "parent": "ajson4",
3145
            "text": "第二生产线",
3146
            "state": {
3147
                "opened": true
3148
            },
3149
            "__uiNodeId": 11
3150
        },
3151
        {
3152
            "id": "ajson12",
3153
            "parent": "ajson4",
3154
            "text": "第一生产线",
3155
            "state": {
3156
                "opened": true
3157
            },
3158
            "__uiNodeId": 11
3159
        }
3160
3161
    ]
3162
3163
}
3164
3165
/**
3166
 *
3167
 * Pass all functions into module
3168
 */
3169
app
3170
    .controller('MainCtrl', MainCtrl)
3171
    .controller('dashboardFlotOne', dashboardFlotOne)
3172
    .controller('dashboardFlotTwo', dashboardFlotTwo)
3173
    .controller('dashboardFive', dashboardFive)
3174
    .controller('dashboardMap', dashboardMap)
3175
    .controller('flotChartCtrl', flotChartCtrl)
3176
    .controller('rickshawChartCtrl', rickshawChartCtrl)
3177
    .controller('sparklineChartCtrl', sparklineChartCtrl)
3178
    .controller('widgetFlotChart', widgetFlotChart)
3179
    .controller('modalDemoCtrl', modalDemoCtrl)
3180
    .controller('ionSlider', ionSlider)
3181
    .controller('wizardCtrl', wizardCtrl)
3182
    .controller('CalendarCtrl', CalendarCtrl)
3183
    .controller('chartJsCtrl', chartJsCtrl)
3184
    .controller('GoogleMaps', GoogleMaps)
3185
    .controller('ngGridCtrl', ngGridCtrl)
3186
    .controller('codeEditorCtrl', codeEditorCtrl)
3187
    .controller('nestableCtrl', nestableCtrl)
3188
    .controller('notifyCtrl', notifyCtrl)
3189
    .controller('translateCtrl', translateCtrl)
3190
    .controller('imageCrop', imageCrop)
3191
    .controller('diff', diff)
3192
    .controller('idleTimer', idleTimer)
3193
    .controller('liveFavicon', liveFavicon)
3194
    .controller('formValidation', formValidation)
3195
    .controller('agileBoard', agileBoard)
3196
    .controller('draggablePanels', draggablePanels)
3197
    .controller('chartistCtrl', chartistCtrl)
3198
    .controller('metricsCtrl', metricsCtrl)
3199
    .controller('sweetAlertCtrl', sweetAlertCtrl)
3200
    .controller('selectCtrl', selectCtrl)
3201
    .controller('toastrCtrl', toastrCtrl)
3202
    .controller('loadingCtrl', loadingCtrl)
3203
    .controller('datatablesCtrl', datatablesCtrl)
3204
    .controller('truncateCtrl', truncateCtrl)
3205
    .controller('touchspinCtrl', touchspinCtrl)
3206
    .controller('tourCtrl', tourCtrl)
3207
    .controller('jstreeCtrl', jstreeCtrl);
3208
3209