Guest User

controllers.js

a guest
Feb 8th, 2017
565
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  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.  *  - datamapsCtrl
  48.  *  - pdfCtrl
  49.  *
  50.  *
  51.  */
  52.  
  53. /**
  54.  * MainCtrl - controller
  55.  * Contains several global data used in different view
  56.  *
  57.  */
  58. function MainCtrl($http) {
  59.  
  60.     /**
  61.      * countries - Used as duallistbox in form advanced view
  62.      */
  63.  
  64.     this.countries = [
  65.         { name: 'Amsterdam' },
  66.         { name: 'Washington' },
  67.         { name: 'Sydney' },
  68.         { name: 'Cairo' },
  69.         { name: 'Beijing' }];
  70.  
  71.     this.getLocation = function(val) {
  72.         return $http.get('//maps.googleapis.com/maps/api/geocode/json', {
  73.             params: {
  74.                 address: val,
  75.                 sensor: false
  76.             }
  77.         }).then(function(response){
  78.             return response.data.results.map(function(item){
  79.                 return item.formatted_address;
  80.             });
  81.         });
  82.     };
  83.  
  84.     /**
  85.      * daterange - Used as initial model for data range picker in Advanced form view
  86.      */
  87.     this.daterange = {startDate: null, endDate: null};
  88.  
  89.     /**
  90.      * slideInterval - Interval for bootstrap Carousel, in milliseconds:
  91.      */
  92.     this.slideInterval = 5000;
  93.  
  94.     /**
  95.      * tags - Used as advanced forms view in input tag control
  96.      */
  97.  
  98.     this.tags = [
  99.         { text: 'Amsterdam' },
  100.         { text: 'Washington' },
  101.         { text: 'Sydney' },
  102.         { text: 'Cairo' },
  103.         { text: 'Beijing' }
  104.     ];
  105.  
  106.     /**
  107.      * states - Data used in Advanced Form view for Chosen plugin
  108.      */
  109.     this.states = [
  110.         'Alabama',
  111.         'Alaska',
  112.         'Arizona',
  113.         'Arkansas',
  114.         'California',
  115.         'Colorado',
  116.         'Connecticut',
  117.         'Delaware',
  118.         'Florida',
  119.         'Georgia',
  120.         'Hawaii',
  121.         'Idaho',
  122.         'Illinois',
  123.         'Indiana',
  124.         'Iowa',
  125.         'Kansas',
  126.         'Kentucky',
  127.         'Louisiana',
  128.         'Maine',
  129.         'Maryland',
  130.         'Massachusetts',
  131.         'Michigan',
  132.         'Minnesota',
  133.         'Mississippi',
  134.         'Missouri',
  135.         'Montana',
  136.         'Nebraska',
  137.         'Nevada',
  138.         'New Hampshire',
  139.         'New Jersey',
  140.         'New Mexico',
  141.         'New York',
  142.         'North Carolina',
  143.         'North Dakota',
  144.         'Ohio',
  145.         'Oklahoma',
  146.         'Oregon',
  147.         'Pennsylvania',
  148.         'Rhode Island',
  149.         'South Carolina',
  150.         'South Dakota',
  151.         'Tennessee',
  152.         'Texas',
  153.         'Utah',
  154.         'Vermont',
  155.         'Virginia',
  156.         'Washington',
  157.         'West Virginia',
  158.         'Wisconsin',
  159.         'Wyoming'
  160.     ];
  161.  
  162.     /**
  163.      * check's - Few variables for checkbox input used in iCheck plugin. Only for demo purpose
  164.      */
  165.     this.checkOne = true;
  166.     this.checkTwo = true;
  167.     this.checkThree = true;
  168.     this.checkFour = true;
  169.  
  170.     /**
  171.      * knobs - Few variables for knob plugin used in Advanced Plugins view
  172.      */
  173.     this.knobOne = 75;
  174.     this.knobTwo = 25;
  175.     this.knobThree = 50;
  176.  
  177.     /**
  178.      * Variables used for Ui Elements view
  179.      */
  180.     this.bigTotalItems = 175;
  181.     this.bigCurrentPage = 1;
  182.     this.maxSize = 5;
  183.     this.singleModel = false;
  184.     this.radioModel = 'Middle';
  185.     this.checkModel = {
  186.         left: false,
  187.         middle: true,
  188.         right: false
  189.     };
  190.  
  191.     /**
  192.      * groups - used for Collapse panels in Tabs and Panels view
  193.      */
  194.     this.groups = [
  195.         {
  196.             title: 'Dynamic Group Header - 1',
  197.             content: 'Dynamic Group Body - 1'
  198.         },
  199.         {
  200.             title: 'Dynamic Group Header - 2',
  201.             content: 'Dynamic Group Body - 2'
  202.         }
  203.     ];
  204.  
  205.     /**
  206.      * alerts - used for dynamic alerts in Notifications and Tooltips view
  207.      */
  208.     this.alerts = [
  209.         { type: 'danger', msg: 'Oh snap! Change a few things up and try submitting again.' },
  210.         { type: 'success', msg: 'Well done! You successfully read this important alert message.' },
  211.         { type: 'info', msg: 'OK, You are done a great job man.' }
  212.     ];
  213.  
  214.     /**
  215.      * addAlert, closeAlert  - used to manage alerts in Notifications and Tooltips view
  216.      */
  217.     this.addAlert = function() {
  218.         this.alerts.push({msg: 'Another alert!'});
  219.     };
  220.  
  221.     this.closeAlert = function(index) {
  222.         this.alerts.splice(index, 1);
  223.     };
  224.  
  225.     /**
  226.      * randomStacked - used for progress bar (stacked type) in Badges adn Labels view
  227.      */
  228.     this.randomStacked = function() {
  229.         this.stacked = [];
  230.         var types = ['success', 'info', 'warning', 'danger'];
  231.  
  232.         for (var i = 0, n = Math.floor((Math.random() * 4) + 1); i < n; i++) {
  233.             var index = Math.floor((Math.random() * 4));
  234.             this.stacked.push({
  235.                 value: Math.floor((Math.random() * 30) + 1),
  236.                 type: types[index]
  237.             });
  238.         }
  239.     };
  240.     /**
  241.      * initial run for random stacked value
  242.      */
  243.     this.randomStacked();
  244.  
  245.     /**
  246.      * summernoteText - used for Summernote plugin
  247.      */
  248.     this.summernoteText = ['<h3>Hello Jonathan! </h3>',
  249.     '<p>dummy text of the printing and typesetting industry. <strong>Lorem Ipsum has been the dustrys</strong> 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 five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more',
  250.         'recently with</p>'].join('');
  251.  
  252.     /**
  253.      * General variables for Peity Charts
  254.      * used in many view so this is in Main controller
  255.      */
  256.     this.BarChart = {
  257.         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],
  258.         options: {
  259.             fill: ["#1ab394", "#d7d7d7"],
  260.             width: 100
  261.         }
  262.     };
  263.  
  264.     this.BarChart2 = {
  265.         data: [5, 3, 9, 6, 5, 9, 7, 3, 5, 2],
  266.         options: {
  267.             fill: ["#1ab394", "#d7d7d7"]
  268.         }
  269.     };
  270.  
  271.     this.BarChart3 = {
  272.         data: [5, 3, 2, -1, -3, -2, 2, 3, 5, 2],
  273.         options: {
  274.             fill: ["#1ab394", "#d7d7d7"]
  275.         }
  276.     };
  277.  
  278.     this.LineChart = {
  279.         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],
  280.         options: {
  281.             fill: '#1ab394',
  282.             stroke: '#169c81',
  283.             width: 64
  284.         }
  285.     };
  286.  
  287.     this.LineChart2 = {
  288.         data: [3, 2, 9, 8, 47, 4, 5, 1, 2, 9, 5, 4, 7],
  289.         options: {
  290.             fill: '#1ab394',
  291.             stroke: '#169c81',
  292.             width: 64
  293.         }
  294.     };
  295.  
  296.     this.LineChart3 = {
  297.         data: [5, 3, 2, -1, -3, -2, 2, 3, 5, 2],
  298.         options: {
  299.             fill: '#1ab394',
  300.             stroke: '#169c81',
  301.             width: 64
  302.         }
  303.     };
  304.  
  305.     this.LineChart4 = {
  306.         data: [5, 3, 9, 6, 5, 9, 7, 3, 5, 2],
  307.         options: {
  308.             fill: '#1ab394',
  309.             stroke: '#169c81',
  310.             width: 64
  311.         }
  312.     };
  313.  
  314.     this.PieChart = {
  315.         data: [1, 5],
  316.         options: {
  317.             fill: ["#1ab394", "#d7d7d7"]
  318.         }
  319.     };
  320.  
  321.     this.PieChart2 = {
  322.         data: [226, 360],
  323.         options: {
  324.             fill: ["#1ab394", "#d7d7d7"]
  325.         }
  326.     };
  327.     this.PieChart3 = {
  328.         data: [0.52, 1.561],
  329.         options: {
  330.             fill: ["#1ab394", "#d7d7d7"]
  331.         }
  332.     };
  333.     this.PieChart4 = {
  334.         data: [1, 4],
  335.         options: {
  336.             fill: ["#1ab394", "#d7d7d7"]
  337.         }
  338.     };
  339.     this.PieChart5 = {
  340.         data: [226, 134],
  341.         options: {
  342.             fill: ["#1ab394", "#d7d7d7"]
  343.         }
  344.     };
  345.     this.PieChart6 = {
  346.         data: [0.52, 1.041],
  347.         options: {
  348.             fill: ["#1ab394", "#d7d7d7"]
  349.         }
  350.     };
  351. };
  352.  
  353.  
  354. /**
  355.  * dashboardFlotOne - simple controller for data
  356.  * for Flot chart in Dashboard view
  357.  */
  358. function dashboardFlotOne() {
  359.  
  360.     var data1 = [
  361.         [0, 4],
  362.         [1, 8],
  363.         [2, 5],
  364.         [3, 10],
  365.         [4, 4],
  366.         [5, 16],
  367.         [6, 5],
  368.         [7, 11],
  369.         [8, 6],
  370.         [9, 11],
  371.         [10, 30],
  372.         [11, 10],
  373.         [12, 13],
  374.         [13, 4],
  375.         [14, 3],
  376.         [15, 3],
  377.         [16, 6]
  378.     ];
  379.     var data2 = [
  380.         [0, 1],
  381.         [1, 0],
  382.         [2, 2],
  383.         [3, 0],
  384.         [4, 1],
  385.         [5, 3],
  386.         [6, 1],
  387.         [7, 5],
  388.         [8, 2],
  389.         [9, 3],
  390.         [10, 2],
  391.         [11, 1],
  392.         [12, 0],
  393.         [13, 2],
  394.         [14, 8],
  395.         [15, 0],
  396.         [16, 0]
  397.     ];
  398.  
  399.     var options = {
  400.         series: {
  401.             lines: {
  402.                 show: false,
  403.                 fill: true
  404.             },
  405.             splines: {
  406.                 show: true,
  407.                 tension: 0.4,
  408.                 lineWidth: 1,
  409.                 fill: 0.4
  410.             },
  411.             points: {
  412.                 radius: 0,
  413.                 show: true
  414.             },
  415.             shadowSize: 2,
  416.             grow: {stepMode:"linear",stepDirection:"up",steps:80}
  417.         },
  418.         grow: {stepMode:"linear",stepDirection:"up",steps:80},
  419.         grid: {
  420.             hoverable: true,
  421.             clickable: true,
  422.             tickColor: "#d5d5d5",
  423.             borderWidth: 1,
  424.             color: '#d5d5d5'
  425.         },
  426.         colors: ["#1ab394", "#1C84C6"],
  427.         xaxis: {
  428.         },
  429.         yaxis: {
  430.             ticks: 4
  431.         },
  432.         tooltip: false
  433.     };
  434.  
  435.     /**
  436.      * Definition of variables
  437.      * Flot chart
  438.      */
  439.     this.flotData = [data1, data2];
  440.     this.flotOptions = options;
  441. }
  442.  
  443. /**
  444.  * dashboardFlotTwo - simple controller for data
  445.  * for Flot chart in Dashboard view
  446.  */
  447. function dashboardFlotTwo() {
  448.  
  449.     var data1 = [
  450.         [gd(2012, 1, 1), 7],
  451.         [gd(2012, 1, 2), 6],
  452.         [gd(2012, 1, 3), 4],
  453.         [gd(2012, 1, 4), 8],
  454.         [gd(2012, 1, 5), 9],
  455.         [gd(2012, 1, 6), 7],
  456.         [gd(2012, 1, 7), 5],
  457.         [gd(2012, 1, 8), 4],
  458.         [gd(2012, 1, 9), 7],
  459.         [gd(2012, 1, 10), 8],
  460.         [gd(2012, 1, 11), 9],
  461.         [gd(2012, 1, 12), 6],
  462.         [gd(2012, 1, 13), 4],
  463.         [gd(2012, 1, 14), 5],
  464.         [gd(2012, 1, 15), 11],
  465.         [gd(2012, 1, 16), 8],
  466.         [gd(2012, 1, 17), 8],
  467.         [gd(2012, 1, 18), 11],
  468.         [gd(2012, 1, 19), 11],
  469.         [gd(2012, 1, 20), 6],
  470.         [gd(2012, 1, 21), 6],
  471.         [gd(2012, 1, 22), 8],
  472.         [gd(2012, 1, 23), 11],
  473.         [gd(2012, 1, 24), 13],
  474.         [gd(2012, 1, 25), 7],
  475.         [gd(2012, 1, 26), 9],
  476.         [gd(2012, 1, 27), 9],
  477.         [gd(2012, 1, 28), 8],
  478.         [gd(2012, 1, 29), 5],
  479.         [gd(2012, 1, 30), 8],
  480.         [gd(2012, 1, 31), 25]
  481.     ];
  482.  
  483.     var data2 = [
  484.         [gd(2012, 1, 1), 800],
  485.         [gd(2012, 1, 2), 500],
  486.         [gd(2012, 1, 3), 600],
  487.         [gd(2012, 1, 4), 700],
  488.         [gd(2012, 1, 5), 500],
  489.         [gd(2012, 1, 6), 456],
  490.         [gd(2012, 1, 7), 800],
  491.         [gd(2012, 1, 8), 589],
  492.         [gd(2012, 1, 9), 467],
  493.         [gd(2012, 1, 10), 876],
  494.         [gd(2012, 1, 11), 689],
  495.         [gd(2012, 1, 12), 700],
  496.         [gd(2012, 1, 13), 500],
  497.         [gd(2012, 1, 14), 600],
  498.         [gd(2012, 1, 15), 700],
  499.         [gd(2012, 1, 16), 786],
  500.         [gd(2012, 1, 17), 345],
  501.         [gd(2012, 1, 18), 888],
  502.         [gd(2012, 1, 19), 888],
  503.         [gd(2012, 1, 20), 888],
  504.         [gd(2012, 1, 21), 987],
  505.         [gd(2012, 1, 22), 444],
  506.         [gd(2012, 1, 23), 999],
  507.         [gd(2012, 1, 24), 567],
  508.         [gd(2012, 1, 25), 786],
  509.         [gd(2012, 1, 26), 666],
  510.         [gd(2012, 1, 27), 888],
  511.         [gd(2012, 1, 28), 900],
  512.         [gd(2012, 1, 29), 178],
  513.         [gd(2012, 1, 30), 555],
  514.         [gd(2012, 1, 31), 993]
  515.     ];
  516.  
  517.  
  518.     var dataset = [
  519.         {
  520.             label: "Number of orders",
  521.             grow:{stepMode:"linear"},
  522.             data: data2,
  523.             color: "#1ab394",
  524.             bars: {
  525.                 show: true,
  526.                 align: "center",
  527.                 barWidth: 24 * 60 * 60 * 600,
  528.                 lineWidth: 0
  529.             }
  530.  
  531.         },
  532.         {
  533.             label: "Payments",
  534.             grow:{stepMode:"linear"},
  535.             data: data1,
  536.             yaxis: 2,
  537.             color: "#1C84C6",
  538.             lines: {
  539.                 lineWidth: 1,
  540.                 show: true,
  541.                 fill: true,
  542.                 fillColor: {
  543.                     colors: [
  544.                         {
  545.                             opacity: 0.2
  546.                         },
  547.                         {
  548.                             opacity: 0.2
  549.                         }
  550.                     ]
  551.                 }
  552.             }
  553.         }
  554.     ];
  555.  
  556.  
  557.     var options = {
  558.         grid: {
  559.             hoverable: true,
  560.             clickable: true,
  561.             tickColor: "#d5d5d5",
  562.             borderWidth: 0,
  563.             color: '#d5d5d5'
  564.         },
  565.         colors: ["#1ab394", "#464f88"],
  566.         tooltip: true,
  567.         xaxis: {
  568.             mode: "time",
  569.             tickSize: [3, "day"],
  570.             tickLength: 0,
  571.             axisLabel: "Date",
  572.             axisLabelUseCanvas: true,
  573.             axisLabelFontSizePixels: 12,
  574.             axisLabelFontFamily: 'Arial',
  575.             axisLabelPadding: 10,
  576.             color: "#d5d5d5"
  577.         },
  578.         yaxes: [
  579.             {
  580.                 position: "left",
  581.                 max: 1070,
  582.                 color: "#d5d5d5",
  583.                 axisLabelUseCanvas: true,
  584.                 axisLabelFontSizePixels: 12,
  585.                 axisLabelFontFamily: 'Arial',
  586.                 axisLabelPadding: 3
  587.             },
  588.             {
  589.                 position: "right",
  590.                 color: "#d5d5d5",
  591.                 axisLabelUseCanvas: true,
  592.                 axisLabelFontSizePixels: 12,
  593.                 axisLabelFontFamily: ' Arial',
  594.                 axisLabelPadding: 67
  595.             }
  596.         ],
  597.         legend: {
  598.             noColumns: 1,
  599.             labelBoxBorderColor: "#d5d5d5",
  600.             position: "nw"
  601.         }
  602.  
  603.     };
  604.  
  605.     function gd(year, month, day) {
  606.         return new Date(year, month - 1, day).getTime();
  607.     }
  608.  
  609.     /**
  610.      * Definition of variables
  611.      * Flot chart
  612.      */
  613.     this.flotData = dataset;
  614.     this.flotOptions = options;
  615. }
  616.  
  617. /**
  618.  * dashboardFlotFive - simple controller for data
  619.  * for Flot chart in Dashboard view
  620.  */
  621. function dashboardFive() {
  622.  
  623.     var data1 = [
  624.         [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]
  625.     ];
  626.     var data2 = [
  627.         [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]
  628.     ];
  629.  
  630.     var options = {
  631.         series: {
  632.             lines: {
  633.                 show: false,
  634.                 fill: true
  635.             },
  636.             splines: {
  637.                 show: true,
  638.                 tension: 0.4,
  639.                 lineWidth: 1,
  640.                 fill: 0.4
  641.             },
  642.             points: {
  643.                 radius: 0,
  644.                 show: true
  645.             },
  646.             shadowSize: 2
  647.         },
  648.         grid: {
  649.             hoverable: true,
  650.             clickable: true,
  651.  
  652.             borderWidth: 2,
  653.             color: 'transparent'
  654.         },
  655.         colors: ["#1ab394", "#1C84C6"],
  656.         xaxis:{
  657.         },
  658.         yaxis: {
  659.         },
  660.         tooltip: false
  661.     };
  662.  
  663.     /**
  664.      * Definition of variables
  665.      * Flot chart
  666.      */
  667.     this.flotData = [data1, data2];
  668.     this.flotOptions = options;
  669.  
  670.  
  671.     var sparkline1Data = [34, 43, 43, 35, 44, 32, 44, 52];
  672.     var sparkline1Options = {
  673.         type: 'line',
  674.         width: '100%',
  675.         height: '50',
  676.         lineColor: '#1ab394',
  677.         fillColor: "transparent"
  678.     };
  679.  
  680.     var sparkline2Data = [32, 11, 25, 37, 41, 32, 34, 42];
  681.     var sparkline2Options = {
  682.         type: 'line',
  683.         width: '100%',
  684.         height: '50',
  685.         lineColor: '#1ab394',
  686.         fillColor: "transparent"
  687.     };
  688.  
  689.     this.sparkline1 = sparkline1Data;
  690.     this.sparkline1Options = sparkline1Options;
  691.     this.sparkline2 = sparkline2Data;
  692.     this.sparkline2Options = sparkline2Options;
  693.  
  694. }
  695.  
  696.  
  697. /**
  698.  * dashboardMap - data for Map plugin
  699.  * used in Dashboard 2 view
  700.  */
  701.  
  702. function dashboardMap() {
  703.     var data = {
  704.         "US": 298,
  705.         "SA": 200,
  706.         "DE": 220,
  707.         "FR": 540,
  708.         "CN": 120,
  709.         "AU": 760,
  710.         "BR": 550,
  711.         "IN": 200,
  712.         "GB": 120
  713.     };
  714.  
  715.     this.data = data;
  716. }
  717.  
  718. /**
  719.  * flotChartCtrl - Controller for data for All flot chart
  720.  * used in Flot chart view
  721.  */
  722.  
  723. function flotChartCtrl() {
  724.  
  725.     /**
  726.      * Bar Chart Options
  727.      */
  728.     var barOptions = {
  729.         series: {
  730.             bars: {
  731.                 show: true,
  732.                 barWidth: 0.6,
  733.                 fill: true,
  734.                 fillColor: {
  735.                     colors: [
  736.                         {
  737.                             opacity: 0.8
  738.                         },
  739.                         {
  740.                             opacity: 0.8
  741.                         }
  742.                     ]
  743.                 }
  744.             }
  745.         },
  746.         xaxis: {
  747.             tickDecimals: 0
  748.         },
  749.         colors: ["#1ab394"],
  750.         grid: {
  751.             color: "#999999",
  752.             hoverable: true,
  753.             clickable: true,
  754.             tickColor: "#D4D4D4",
  755.             borderWidth: 0
  756.         },
  757.         legend: {
  758.             show: false
  759.         },
  760.         tooltip: true,
  761.         tooltipOpts: {
  762.             content: "x: %x, y: %y"
  763.         }
  764.     };
  765.  
  766.     /**
  767.      * Bar Chart data
  768.      */
  769.     var chartData = [
  770.         {
  771.             label: "bar",
  772.             data: [
  773.                 [1, 34],
  774.                 [2, 25],
  775.                 [3, 19],
  776.                 [4, 34],
  777.                 [5, 32],
  778.                 [6, 44]
  779.             ]
  780.         }
  781.     ];
  782.  
  783.     /**
  784.      * Pie Chart Data
  785.      */
  786.     var pieData = [
  787.         {
  788.             label: "Sales 1",
  789.             data: 21,
  790.             color: "#d3d3d3"
  791.         },
  792.         {
  793.             label: "Sales 2",
  794.             data: 3,
  795.             color: "#bababa"
  796.         },
  797.         {
  798.             label: "Sales 3",
  799.             data: 15,
  800.             color: "#79d2c0"
  801.         },
  802.         {
  803.             label: "Sales 4",
  804.             data: 52,
  805.             color: "#1ab394"
  806.         }
  807.     ];
  808.  
  809.     /**
  810.      * Pie Chart Options
  811.      */
  812.     var pieOptions = {
  813.         series: {
  814.             pie: {
  815.                 show: true
  816.             }
  817.         },
  818.         grid: {
  819.             hoverable: true
  820.         },
  821.         tooltip: true,
  822.         tooltipOpts: {
  823.             content: "%p.0%, %s", // show percentages, rounding to 2 decimal places
  824.             shifts: {
  825.                 x: 20,
  826.                 y: 0
  827.             },
  828.             defaultTheme: false
  829.         }
  830.     };
  831.  
  832.     /**
  833.      * Line Chart Options
  834.      */
  835.     var lineOptions = {
  836.         series: {
  837.             lines: {
  838.                 show: true,
  839.                 lineWidth: 2,
  840.                 fill: true,
  841.                 fillColor: {
  842.                     colors: [
  843.                         {
  844.                             opacity: 0.0
  845.                         },
  846.                         {
  847.                             opacity: 0.0
  848.                         }
  849.                     ]
  850.                 }
  851.             }
  852.         },
  853.         xaxis: {
  854.             tickDecimals: 0
  855.         },
  856.         colors: ["#1ab394"],
  857.         grid: {
  858.             color: "#999999",
  859.             hoverable: true,
  860.             clickable: true,
  861.             tickColor: "#D4D4D4",
  862.             borderWidth: 0
  863.         },
  864.         legend: {
  865.             show: false
  866.         },
  867.         tooltip: true,
  868.         tooltipOpts: {
  869.             content: "x: %x, y: %y"
  870.         }
  871.     };
  872.  
  873.     /**
  874.      * Line Chart Data
  875.      */
  876.     var lineAreaData = [
  877.         {
  878.             label: "line",
  879.             data: [
  880.                 [1, 34],
  881.                 [2, 22],
  882.                 [3, 19],
  883.                 [4, 12],
  884.                 [5, 32],
  885.                 [6, 54],
  886.                 [7, 23],
  887.                 [8, 57],
  888.                 [9, 12],
  889.                 [10, 24],
  890.                 [11, 44],
  891.                 [12, 64],
  892.                 [13, 21]
  893.             ]
  894.         }
  895.     ];
  896.  
  897.     /**
  898.      * Line Area Chart Options
  899.      */
  900.     var lineAreaOptions = {
  901.         series: {
  902.             lines: {
  903.                 show: true,
  904.                 lineWidth: 2,
  905.                 fill: true,
  906.                 fillColor: {
  907.                     colors: [
  908.                         {
  909.                             opacity: 0.7
  910.                         },
  911.                         {
  912.                             opacity: 0.5
  913.                         }
  914.                     ]
  915.                 }
  916.             }
  917.         },
  918.         xaxis: {
  919.             tickDecimals: 0
  920.         },
  921.         colors: ["#1ab394"],
  922.         grid: {
  923.             color: "#999999",
  924.             hoverable: true,
  925.             clickable: true,
  926.             tickColor: "#D4D4D4",
  927.             borderWidth: 0
  928.         },
  929.         legend: {
  930.             show: false
  931.         },
  932.         tooltip: true,
  933.         tooltipOpts: {
  934.             content: "x: %x, y: %y"
  935.         }
  936.     };
  937.  
  938.     /**
  939.      * Data for Multi line chart
  940.      */"€";
  941.     }
  942.     var position = 'right';
  943.  
  944.     /**
  945.      * multiData - data for multi line chart
  946.      */
  947.     var multiData = [
  948.         {
  949.             data: oilprices,
  950.             label: "Oil price ($)"
  951.         },
  952.         {
  953.             data: exchangerates,
  954.             label: "USD/EUR exchange rate",
  955.             yaxis: 2
  956.         }
  957.     ];
  958.  
  959.     /**
  960.      * multiOptions - options for multi chart
  961.      */
  962.     var multiOptions = {
  963.         xaxes: [
  964.             {
  965.                 mode: 'time'
  966.             }
  967.         ],
  968.         yaxes: [
  969.             {
  970.                 min: 0
  971.             },
  972.             {
  973.                 // align if we are to the right
  974.                 alignTicksWithAxis: position == "right" ? 1 : null,
  975.                 position: position,
  976.                 tickFormatter: euroFormatter
  977.             }
  978.         ],
  979.         legend: {
  980.             position: 'sw'
  981.         },
  982.         colors: ["#1ab394"],
  983.         grid: {
  984.             color: "#999999",
  985.             hoverable: true,
  986.             clickable: true,
  987.             tickColor: "#D4D4D4",
  988.             borderWidth: 0
  989.  
  990.         },
  991.         tooltip: true,
  992.         tooltipOpts: {
  993.             content: "%s for %x was %y",
  994.             xDateFormat: "%y-%0m-%0d",
  995.             onHover: function (flotItem, $tooltipEl) {
  996.             }
  997.         }
  998.  
  999.     };
  1000.  
  1001.     /**
  1002.      * Definition of variables
  1003.      * Flot chart
  1004.      */
  1005.     this.flotChartData = chartData;
  1006.     this.flotBarOptions = barOptions;
  1007.     this.flotLineOptions = lineOptions;
  1008.     this.flotPieData = pieData;
  1009.     this.flotPieOptions = pieOptions;
  1010.     this.flotLineAreaData = lineAreaData;
  1011.     this.flotLineAreaOptions = lineAreaOptions;
  1012.     this.flotMultiData = multiData;
  1013.     this.flotMultiOptions = multiOptions;
  1014. }
  1015.  
  1016. /**
  1017.  * rickshawChartCtrl - Controller for data for all Rickshaw chart
  1018.  * used in Rickshaw chart view
  1019.  */
  1020. function rickshawChartCtrl() {
  1021.  
  1022.     /**
  1023.      * Data for simple chart
  1024.      */
  1025.     var simpleChartSeries = [
  1026.         {
  1027.             color: '#1ab394',
  1028.             data: [
  1029.                 { x: 0, y: 40 },
  1030.                 { x: 1, y: 49 },
  1031.                 { x: 2, y: 38 },
  1032.                 { x: 3, y: 30 },
  1033.                 { x: 4, y: 32 }
  1034.             ]
  1035.         }
  1036.     ];
  1037.     /**
  1038.      * Options for simple chart
  1039.      */
  1040.     var simpleChartOptions = {
  1041.         renderer: 'area'
  1042.     };
  1043.  
  1044.     /**
  1045.      * Data for Multi Area chart
  1046.      */
  1047.     var multiAreaChartSeries = [
  1048.         {
  1049.             data: [
  1050.                 { x: 0, y: 40 },
  1051.                 { x: 1, y: 49 },
  1052.                 { x: 2, y: 38 },
  1053.                 { x: 3, y: 20 },
  1054.                 { x: 4, y: 16 }
  1055.             ],
  1056.             color: '#1ab394',
  1057.             stroke: '#17997f'
  1058.         },
  1059.         {
  1060.             data: [
  1061.                 { x: 0, y: 22 },
  1062.                 { x: 1, y: 25 },
  1063.                 { x: 2, y: 38 },
  1064.                 { x: 3, y: 44 },
  1065.                 { x: 4, y: 46 }
  1066.             ],
  1067.             color: '#eeeeee',
  1068.             stroke: '#d7d7d7'
  1069.         }
  1070.     ];
  1071.  
  1072.     /**
  1073.      * Options for Multi chart
  1074.      */
  1075.     var multiAreaChartOptions = {
  1076.         renderer: 'area',
  1077.         stroke: true
  1078.     };
  1079.  
  1080.     /**
  1081.      * Options for one line chart
  1082.      */
  1083.     var oneLineChartOptions = {
  1084.         renderer: 'line'
  1085.     };
  1086.  
  1087.     /**
  1088.      * Data for one line chart
  1089.      */
  1090.     var oneLineChartSeries = [
  1091.         {
  1092.             data: [
  1093.                 { x: 0, y: 40 },
  1094.                 { x: 1, y: 49 },
  1095.                 { x: 2, y: 38 },
  1096.                 { x: 3, y: 30 },
  1097.                 { x: 4, y: 32 }
  1098.             ],
  1099.             color: '#1ab394'
  1100.         }
  1101.     ];
  1102.  
  1103.     /**
  1104.      * Options for Multi line chart
  1105.      */
  1106.     var multiLineChartOptions = {
  1107.         renderer: 'line'
  1108.     };
  1109.  
  1110.     /**
  1111.      * Data for Multi line chart
  1112.      */
  1113.     var multiLineChartSeries = [
  1114.         {
  1115.             data: [
  1116.                 { x: 0, y: 40 },
  1117.                 { x: 1, y: 49 },
  1118.                 { x: 2, y: 38 },
  1119.                 { x: 3, y: 30 },
  1120.                 { x: 4, y: 32 }
  1121.             ],
  1122.             color: '#1ab394'
  1123.         },
  1124.         {
  1125.             data: [
  1126.                 { x: 0, y: 20 },
  1127.                 { x: 1, y: 24 },
  1128.                 { x: 2, y: 19 },
  1129.                 { x: 3, y: 15 },
  1130.                 { x: 4, y: 16 }
  1131.             ],
  1132.             color: '#d7d7d7'
  1133.         }
  1134.     ];
  1135.  
  1136.     /**
  1137.      * Options for Bars chart
  1138.      */
  1139.     var barsChartOptions = {
  1140.         renderer: 'bar'
  1141.     };
  1142.  
  1143.     /**
  1144.      * Data for Bars chart
  1145.      */
  1146.     var barsChartSeries = [
  1147.         {
  1148.             data: [
  1149.                 { x: 0, y: 40 },
  1150.                 { x: 1, y: 49 },
  1151.                 { x: 2, y: 38 },
  1152.                 { x: 3, y: 30 },
  1153.                 { x: 4, y: 32 }
  1154.             ],
  1155.             color: '#1ab394'
  1156.         }
  1157.     ];
  1158.  
  1159.     /**
  1160.      * Options for Stacked chart
  1161.      */
  1162.     var stackedChartOptions = {
  1163.         renderer: 'bar'
  1164.     };
  1165.  
  1166.     /**
  1167.      * Data for Stacked chart
  1168.      */
  1169.     var stackedChartSeries = [
  1170.         {
  1171.             data: [
  1172.                 { x: 0, y: 40 },
  1173.                 { x: 1, y: 49 },
  1174.                 { x: 2, y: 38 },
  1175.                 { x: 3, y: 30 },
  1176.                 { x: 4, y: 32 }
  1177.             ],
  1178.             color: '#1ab394'
  1179.         },
  1180.         {
  1181.             data: [
  1182.                 { x: 0, y: 20 },
  1183.                 { x: 1, y: 24 },
  1184.                 { x: 2, y: 19 },
  1185.                 { x: 3, y: 15 },
  1186.                 { x: 4, y: 16 }
  1187.             ],
  1188.             color: '#d7d7d7'
  1189.         }
  1190.     ];
  1191.  
  1192.     /**
  1193.      * Options for Scatterplot chart
  1194.      */
  1195.     var scatterplotChartOptions = {
  1196.         renderer: 'scatterplot',
  1197.         stroke: true,
  1198.         padding: { top: 0.05, left: 0.05, right: 0.05 }
  1199.     }
  1200.  
  1201.     /**
  1202.      * Data for Scatterplot chart
  1203.      */
  1204.     var scatterplotChartSeries = [
  1205.         {
  1206.             data: [
  1207.                 { x: 0, y: 15 },
  1208.                 { x: 1, y: 18 },
  1209.                 { x: 2, y: 10 },
  1210.                 { x: 3, y: 12 },
  1211.                 { x: 4, y: 15 },
  1212.                 { x: 5, y: 24 },
  1213.                 { x: 6, y: 28 },
  1214.                 { x: 7, y: 31 },
  1215.                 { x: 8, y: 22 },
  1216.                 { x: 9, y: 18 },
  1217.                 { x: 10, y: 16 }
  1218.             ],
  1219.             color: '#1ab394'
  1220.         }
  1221.     ]
  1222.  
  1223.     /**
  1224.      * Definition all variables
  1225.      * Rickshaw chart
  1226.      */
  1227.     this.simpleSeries = simpleChartSeries;
  1228.     this.simpleOptions = simpleChartOptions;
  1229.     this.multiAreaOptions = multiAreaChartOptions;
  1230.     this.multiAreaSeries = multiAreaChartSeries;
  1231.     this.oneLineOptions = oneLineChartOptions;
  1232.     this.oneLineSeries = oneLineChartSeries;
  1233.     this.multiLineOptions = multiLineChartOptions;
  1234.     this.multiLineSeries = multiLineChartSeries;
  1235.     this.barsOptions = barsChartOptions;
  1236.     this.barsSeries = barsChartSeries;
  1237.     this.stackedOptions = stackedChartOptions;
  1238.     this.stackedSeries = stackedChartSeries;
  1239.     this.scatterplotOptions = scatterplotChartOptions;
  1240.     this.scatterplotSeries = scatterplotChartSeries;
  1241.  
  1242. }
  1243.  
  1244. /**
  1245.  * sparklineChartCtrl - Controller for data for all Sparkline chart
  1246.  * used in Sparkline chart view
  1247.  */
  1248. function sparklineChartCtrl() {
  1249.  
  1250.     /**
  1251.      * Inline chart
  1252.      */
  1253.     var inlineData = [34, 43, 43, 35, 44, 32, 44, 52, 25];
  1254.     var inlineOptions = {
  1255.         type: 'line',
  1256.         lineColor: '#17997f',
  1257.         fillColor: '#1ab394'
  1258.     };
  1259.  
  1260.     /**
  1261.      * Bar chart
  1262.      */
  1263.     var barSmallData = [5, 6, 7, 2, 0, -4, -2, 4];
  1264.     var barSmallOptions = {
  1265.         type: 'bar',
  1266.         barColor: '#1ab394',
  1267.         negBarColor: '#c6c6c6'
  1268.     };
  1269.  
  1270.     /**
  1271.      * Pie chart
  1272.      */
  1273.     var smallPieData = [1, 1, 2];
  1274.     var smallPieOptions = {
  1275.         type: 'pie',
  1276.         sliceColors: ['#1ab394', '#b3b3b3', '#e4f0fb']
  1277.     };
  1278.  
  1279.     /**
  1280.      * Long line chart
  1281.      */
  1282.     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];
  1283.     var longLineOptions = {
  1284.         type: 'line',
  1285.         lineColor: '#17997f',
  1286.         fillColor: '#ffffff'
  1287.     };
  1288.  
  1289.     /**
  1290.      * Tristate chart
  1291.      */
  1292.     var tristateData = [1, 1, 0, 1, -1, -1, 1, -1, 0, 0, 1, 1];
  1293.     var tristateOptions = {
  1294.         type: 'tristate',
  1295.         posBarColor: '#1ab394',
  1296.         negBarColor: '#bfbfbf'
  1297.     };
  1298.  
  1299.     /**
  1300.      * Discrate chart
  1301.      */
  1302.     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, ];
  1303.     var discreteOptions = {
  1304.         type: 'discrete',
  1305.         lineColor: '#1ab394'
  1306.     };
  1307.  
  1308.     /**
  1309.      * Pie chart
  1310.      */
  1311.     var pieCustomData = [52, 12, 44];
  1312.     var pieCustomOptions = {
  1313.         type: 'pie',
  1314.         height: '150px',
  1315.         sliceColors: ['#1ab394', '#b3b3b3', '#e4f0fb']
  1316.     };
  1317.  
  1318.     /**
  1319.      * Bar chart
  1320.      */
  1321.     var barCustomData = [5, 6, 7, 2, 0, 4, 2, 4, 5, 7, 2, 4, 12, 14, 4, 2, 14, 12, 7];
  1322.     var barCustomOptions = {
  1323.         type: 'bar',
  1324.         barWidth: 8,
  1325.         height: '150px',
  1326.         barColor: '#1ab394',
  1327.         negBarColor: '#c6c6c6'
  1328.     };
  1329.  
  1330.     /**
  1331.      * Line chart
  1332.      */
  1333.     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];
  1334.     var lineCustomOptions = {
  1335.         type: 'line',
  1336.         lineWidth: 1,
  1337.         height: '150px',
  1338.         lineColor: '#17997f',
  1339.         fillColor: '#ffffff'
  1340.     };
  1341.  
  1342.  
  1343.     /**
  1344.      * Definition of variables
  1345.      * Flot chart
  1346.      */
  1347.     this.inlineData = inlineData;
  1348.     this.inlineOptions = inlineOptions;
  1349.     this.barSmallData = barSmallData;
  1350.     this.barSmallOptions = barSmallOptions;
  1351.     this.pieSmallData = smallPieData;
  1352.     this.pieSmallOptions = smallPieOptions;
  1353.     this.discreteData = discreteData;
  1354.     this.discreteOptions = discreteOptions;
  1355.     this.longLineData = longLineData;
  1356.     this.longLineOptions = longLineOptions;
  1357.     this.tristateData = tristateData;
  1358.     this.tristateOptions = tristateOptions;
  1359.     this.pieCustomData = pieCustomData;
  1360.     this.pieCustomOptions = pieCustomOptions;
  1361.     this.barCustomData = barCustomData;
  1362.     this.barCustomOptions = barCustomOptions;
  1363.     this.lineCustomData = lineCustomData;
  1364.     this.lineCustomOptions = lineCustomOptions;
  1365. }
  1366.  
  1367.  
  1368. /**
  1369.  * widgetFlotChart - Data for Flot chart
  1370.  * used in Widget view
  1371.  */
  1372. function widgetFlotChart() {
  1373.  
  1374.  
  1375.     /**
  1376.      * Flot chart data and options
  1377.      */
  1378.     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]];
  1379.     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]];
  1380.  
  1381.     var flotChartData1 = [
  1382.         { label: "Data 1", data: d1, color: '#17a084'},
  1383.         { label: "Data 2", data: d2, color: '#127e68' }
  1384.     ];
  1385.  
  1386.     var flotChartOptions1 = {
  1387.         xaxis: {
  1388.             tickDecimals: 0
  1389.         },
  1390.         series: {
  1391.             lines: {
  1392.                 show: true,
  1393.                 fill: true,
  1394.                 fillColor: {
  1395.                     colors: [{
  1396.                         opacity: 1
  1397.                     }, {
  1398.                         opacity: 1
  1399.                     }]
  1400.                 }
  1401.             },
  1402.             points: {
  1403.                 width: 0.1,
  1404.                 show: false
  1405.             }
  1406.         },
  1407.         grid: {
  1408.             show: false,
  1409.             borderWidth: 0
  1410.         },
  1411.         legend: {
  1412.             show: false
  1413.         }
  1414.     };
  1415.  
  1416.     var flotChartData2 = [
  1417.         { label: "Data 1", data: d1, color: '#19a0a1'}
  1418.     ];
  1419.  
  1420.     var flotChartOptions2 = {
  1421.         xaxis: {
  1422.             tickDecimals: 0
  1423.         },
  1424.         series: {
  1425.             lines: {
  1426.                 show: true,
  1427.                 fill: true,
  1428.                 fillColor: {
  1429.                     colors: [{
  1430.                         opacity: 1
  1431.                     }, {
  1432.                         opacity: 1
  1433.                     }]
  1434.                 }
  1435.             },
  1436.             points: {
  1437.                 width: 0.1,
  1438.                 show: false
  1439.             }
  1440.         },
  1441.         grid: {
  1442.             show: false,
  1443.             borderWidth: 0
  1444.         },
  1445.         legend: {
  1446.             show: false
  1447.         }
  1448.     };
  1449.  
  1450.     var flotChartData3 = [
  1451.         { label: "Data 1", data: d1, color: '#fbbe7b'},
  1452.         { label: "Data 2", data: d2, color: '#f8ac59' }
  1453.     ];
  1454.  
  1455.     var flotChartOptions3 = {
  1456.         xaxis: {
  1457.             tickDecimals: 0
  1458.         },
  1459.         series: {
  1460.             lines: {
  1461.                 show: true,
  1462.                 fill: true,
  1463.                 fillColor: {
  1464.                     colors: [{
  1465.                         opacity: 1
  1466.                     }, {
  1467.                         opacity: 1
  1468.                     }]
  1469.                 }
  1470.             },
  1471.             points: {
  1472.                 width: 0.1,
  1473.                 show: false
  1474.             }
  1475.         },
  1476.         grid: {
  1477.             show: false,
  1478.             borderWidth: 0
  1479.         },
  1480.         legend: {
  1481.             show: false
  1482.         }
  1483.     };
  1484.  
  1485.     /**
  1486.      * Definition of variables
  1487.      * Flot chart
  1488.      */
  1489.  
  1490.     this.flotChartData1 = flotChartData1;
  1491.     this.flotChartOptions1 = flotChartOptions1;
  1492.     this.flotChartData2 = flotChartData2;
  1493.     this.flotChartOptions2 = flotChartOptions2;
  1494.     this.flotChartData3 = flotChartData3;
  1495.     this.flotChartOptions3 = flotChartOptions3;
  1496.  
  1497.  
  1498. }
  1499.  
  1500. /**
  1501.  * modalDemoCtrl - Controller used to run modal view
  1502.  * used in Basic form view
  1503.  */
  1504. function modalDemoCtrl($scope, $uibModal) {
  1505.  
  1506.     $scope.open = function () {
  1507.  
  1508.         var modalInstance = $uibModal.open({
  1509.             templateUrl: 'views/modal_example.html',
  1510.             controller: ModalInstanceCtrl
  1511.         });
  1512.     };
  1513.  
  1514.     $scope.open1 = function () {
  1515.         var modalInstance = $uibModal.open({
  1516.             templateUrl: 'views/modal_example1.html',
  1517.             controller: ModalInstanceCtrl
  1518.         });
  1519.     };
  1520.  
  1521.     $scope.open2 = function () {
  1522.         var modalInstance = $uibModal.open({
  1523.             templateUrl: 'views/modal_example2.html',
  1524.             controller: ModalInstanceCtrl,
  1525.             windowClass: "animated fadeIn"
  1526.         });
  1527.     };
  1528.  
  1529.     $scope.open3 = function (size) {
  1530.         var modalInstance = $uibModal.open({
  1531.             templateUrl: 'views/modal_example3.html',
  1532.             size: size,
  1533.             controller: ModalInstanceCtrl
  1534.         });
  1535.     };
  1536.  
  1537.     $scope.open4 = function () {
  1538.         var modalInstance = $uibModal.open({
  1539.             templateUrl: 'views/modal_example2.html',
  1540.             controller: ModalInstanceCtrl,
  1541.             windowClass: "animated flipInY"
  1542.         });
  1543.     };
  1544. };
  1545.  
  1546. function ModalInstanceCtrl ($scope, $uibModalInstance) {
  1547.  
  1548.     $scope.ok = function () {
  1549.         $uibModalInstance.close();
  1550.     };
  1551.  
  1552.     $scope.cancel = function () {
  1553.         $uibModalInstance.dismiss('cancel');
  1554.     };
  1555.  
  1556.  
  1557.     $scope.states = [
  1558.         'Alabama',
  1559.         'Alaska',
  1560.         'Arizona',
  1561.         'Arkansas',
  1562.         'California',
  1563.         'Colorado',
  1564.         'Connecticut',
  1565.         'Delaware',
  1566.         'Florida',
  1567.         'Georgia',
  1568.         'Hawaii',
  1569.         'Idaho',
  1570.         'Illinois',
  1571.         'Indiana',
  1572.         'Iowa',
  1573.         'Kansas',
  1574.         'Kentucky',
  1575.         'Louisiana',
  1576.         'Maine',
  1577.         'Maryland',
  1578.         'Massachusetts',
  1579.         'Michigan',
  1580.         'Minnesota',
  1581.         'Mississippi',
  1582.         'Missouri',
  1583.         'Montana',
  1584.         'Nebraska',
  1585.         'Nevada',
  1586.         'New Hampshire',
  1587.         'New Jersey',
  1588.         'New Mexico',
  1589.         'New York',
  1590.         'North Carolina',
  1591.         'North Dakota',
  1592.         'Ohio',
  1593.         'Oklahoma',
  1594.         'Oregon',
  1595.         'Pennsylvania',
  1596.         'Rhode Island',
  1597.         'South Carolina',
  1598.         'South Dakota',
  1599.         'Tennessee',
  1600.         'Texas',
  1601.         'Utah',
  1602.         'Vermont',
  1603.         'Virginia',
  1604.         'Washington',
  1605.         'West Virginia',
  1606.         'Wisconsin',
  1607.         'Wyoming'
  1608.     ];
  1609.  
  1610. };
  1611.  
  1612. /**
  1613.  * ionSlider - Controller for data for Ion Slider plugin
  1614.  * used in Advanced plugin view
  1615.  */
  1616. function ionSlider() {
  1617.     this.ionSliderOptions1 = {
  1618.         min: 0,
  1619.         max: 5000,
  1620.         type: 'double',
  1621.         prefix: "$",
  1622.         maxPostfix: "+",
  1623.         prettify: false,
  1624.         hasGrid: true
  1625.     };
  1626.     this.ionSliderOptions2 = {
  1627.         min: 0,
  1628.         max: 10,
  1629.         type: 'single',
  1630.         step: 0.1,
  1631.         postfix: " carats",
  1632.         prettify: false,
  1633.         hasGrid: true
  1634.     };
  1635.     this.ionSliderOptions3 = {
  1636.         min: -50,
  1637.         max: 50,
  1638.         from: 0,
  1639.         postfix: "°",
  1640.         prettify: false,
  1641.         hasGrid: true
  1642.     };
  1643.     this.ionSliderOptions4 = {
  1644.         values: [
  1645.             "January", "February", "March",
  1646.             "April", "May", "June",
  1647.             "July", "August", "September",
  1648.             "October", "November", "December"
  1649.         ],
  1650.         type: 'single',
  1651.         hasGrid: true
  1652.     };
  1653.     this.ionSliderOptions5 = {
  1654.         min: 10000,
  1655.         max: 100000,
  1656.         step: 100,
  1657.         postfix: " km",
  1658.         from: 55000,
  1659.         hideMinMax: true,
  1660.         hideFromTo: false
  1661.     };
  1662. }
  1663.  
  1664. /**
  1665.  * wizardCtrl - Controller for wizard functions
  1666.  * used in Wizard view
  1667.  */
  1668. function wizardCtrl($scope, $rootScope) {
  1669.     // All data will be store in this object
  1670.     $scope.formData = {};
  1671.  
  1672.     // After process wizard
  1673.     $scope.processForm = function() {
  1674.         alert('Wizard completed');
  1675.     };
  1676.  
  1677. }
  1678.  
  1679.  
  1680. /**
  1681.  * CalendarCtrl - Controller for Calendar
  1682.  * Store data events for calendar
  1683.  */
  1684. function CalendarCtrl($scope) {
  1685.  
  1686.     var date = new Date();
  1687.     var d = date.getDate();
  1688.     var m = date.getMonth();
  1689.     var y = date.getFullYear();
  1690.  
  1691.     // Events
  1692.     $scope.events = [
  1693.         {title: 'All Day Event',start: new Date(y, m, 1)},
  1694.         {title: 'Long Event',start: new Date(y, m, d - 5),end: new Date(y, m, d - 2)},
  1695.         {id: 999,title: 'Repeating Event',start: new Date(y, m, d - 3, 16, 0),allDay: false},
  1696.         {id: 999,title: 'Repeating Event',start: new Date(y, m, d + 4, 16, 0),allDay: false},
  1697.         {title: 'Birthday Party',start: new Date(y, m, d + 1, 19, 0),end: new Date(y, m, d + 1, 22, 30),allDay: false},
  1698.         {title: 'Click for Google',start: new Date(y, m, 28),end: new Date(y, m, 29),url: 'http://google.com/'}
  1699.     ];
  1700.  
  1701.  
  1702.     /* message on eventClick */
  1703.     $scope.alertOnEventClick = function( event, allDay, jsEvent, view ){
  1704.         $scope.alertMessage = (event.title + ': Clicked ');
  1705.     };
  1706.     /* message on Drop */
  1707.     $scope.alertOnDrop = function(event, dayDelta, minuteDelta, allDay, revertFunc, jsEvent, ui, view){
  1708.         $scope.alertMessage = (event.title +': Droped to make dayDelta ' + dayDelta);
  1709.     };
  1710.     /* message on Resize */
  1711.     $scope.alertOnResize = function(event, dayDelta, minuteDelta, revertFunc, jsEvent, ui, view ){
  1712.         $scope.alertMessage = (event.title +': Resized to make dayDelta ' + minuteDelta);
  1713.     };
  1714.  
  1715.     /* config object */
  1716.     $scope.uiConfig = {
  1717.         calendar:{
  1718.             height: 450,
  1719.             editable: true,
  1720.             header: {
  1721.                 left: 'prev,next',
  1722.                 center: 'title',
  1723.                 right: 'month,agendaWeek,agendaDay'
  1724.             },
  1725.             eventClick: $scope.alertOnEventClick,
  1726.             eventDrop: $scope.alertOnDrop,
  1727.             eventResize: $scope.alertOnResize
  1728.         }
  1729.     };
  1730.  
  1731.     /* Event sources array */
  1732.     $scope.eventSources = [$scope.events];
  1733. }
  1734.  
  1735. /**
  1736.  * chartJsCtrl - Controller for data for ChartJs plugin
  1737.  * used in Chart.js view
  1738.  */
  1739. function chartJsCtrl() {
  1740.  
  1741.     /**
  1742.      * Data for Polar chart
  1743.      */
  1744.     this.polarData = [
  1745.         {
  1746.             value: 300,
  1747.             color:"#a3e1d4",
  1748.             highlight: "#1ab394",
  1749.             label: "App"
  1750.         },
  1751.         {
  1752.             value: 140,
  1753.             color: "#dedede",
  1754.             highlight: "#1ab394",
  1755.             label: "Software"
  1756.         },
  1757.         {
  1758.             value: 200,
  1759.             color: "#A4CEE8",
  1760.             highlight: "#1ab394",
  1761.             label: "Laptop"
  1762.         }
  1763.     ];
  1764.  
  1765.     /**
  1766.      * Options for Polar chart
  1767.      */
  1768.     this.polarOptions = {
  1769.         scaleShowLabelBackdrop : true,
  1770.         scaleBackdropColor : "rgba(255,255,255,0.75)",
  1771.         scaleBeginAtZero : true,
  1772.         scaleBackdropPaddingY : 1,
  1773.         scaleBackdropPaddingX : 1,
  1774.         scaleShowLine : true,
  1775.         segmentShowStroke : true,
  1776.         segmentStrokeColor : "#fff",
  1777.         segmentStrokeWidth : 2,
  1778.         animationSteps : 100,
  1779.         animationEasing : "easeOutBounce",
  1780.         animateRotate : true,
  1781.         animateScale : false
  1782.     };
  1783.  
  1784.     /**
  1785.      * Data for Doughnut chart
  1786.      */
  1787.     this.doughnutData = [
  1788.         {
  1789.             value: 300,
  1790.             color:"#a3e1d4",
  1791.             highlight: "#1ab394",
  1792.             label: "App"
  1793.         },
  1794.         {
  1795.             value: 50,
  1796.             color: "#dedede",
  1797.             highlight: "#1ab394",
  1798.             label: "Software"
  1799.         },
  1800.         {
  1801.             value: 100,
  1802.             color: "#A4CEE8",
  1803.             highlight: "#1ab394",
  1804.             label: "Laptop"
  1805.         }
  1806.     ];
  1807.  
  1808.     /**
  1809.      * Options for Doughnut chart
  1810.      */
  1811.     this.doughnutOptions = {
  1812.         segmentShowStroke : true,
  1813.         segmentStrokeColor : "#fff",
  1814.         segmentStrokeWidth : 2,
  1815.         percentageInnerCutout : 45, // This is 0 for Pie charts
  1816.         animationSteps : 100,
  1817.         animationEasing : "easeOutBounce",
  1818.         animateRotate : true,
  1819.         animateScale : false
  1820.     };
  1821.  
  1822.     /**
  1823.      * Data for Line chart
  1824.      */
  1825.     this.lineData = {
  1826.         labels: ["January", "February", "March", "April", "May", "June", "July"],
  1827.         datasets: [
  1828.             {
  1829.                 label: "Example dataset",
  1830.                 fillColor: "rgba(220,220,220,0.5)",
  1831.                 strokeColor: "rgba(220,220,220,1)",
  1832.                 pointColor: "rgba(220,220,220,1)",
  1833.                 pointStrokeColor: "#fff",
  1834.                 pointHighlightFill: "#fff",
  1835.                 pointHighlightStroke: "rgba(220,220,220,1)",
  1836.                 data: [65, 59, 80, 81, 56, 55, 40]
  1837.             },
  1838.             {
  1839.                 label: "Example dataset",
  1840.                 fillColor: "rgba(26,179,148,0.5)",
  1841.                 strokeColor: "rgba(26,179,148,0.7)",
  1842.                 pointColor: "rgba(26,179,148,1)",
  1843.                 pointStrokeColor: "#fff",
  1844.                 pointHighlightFill: "#fff",
  1845.                 pointHighlightStroke: "rgba(26,179,148,1)",
  1846.                 data: [28, 48, 40, 19, 86, 27, 90]
  1847.             }
  1848.         ]
  1849.     };
  1850.  
  1851.     this.lineDataDashboard4 = {
  1852.         labels: ["January", "February", "March", "April", "May", "June", "July"],
  1853.         datasets: [
  1854.             {
  1855.                 label: "Example dataset",
  1856.                 fillColor: "rgba(220,220,220,0.5)",
  1857.                 strokeColor: "rgba(220,220,220,1)",
  1858.                 pointColor: "rgba(220,220,220,1)",
  1859.                 pointStrokeColor: "#fff",
  1860.                 pointHighlightFill: "#fff",
  1861.                 pointHighlightStroke: "rgba(220,220,220,1)",
  1862.                 data: [65, 59, 40, 51, 36, 25, 40]
  1863.             },
  1864.             {
  1865.                 label: "Example dataset",
  1866.                 fillColor: "rgba(26,179,148,0.5)",
  1867.                 strokeColor: "rgba(26,179,148,0.7)",
  1868.                 pointColor: "rgba(26,179,148,1)",
  1869.                 pointStrokeColor: "#fff",
  1870.                 pointHighlightFill: "#fff",
  1871.                 pointHighlightStroke: "rgba(26,179,148,1)",
  1872.                 data: [48, 48, 60, 39, 56, 37, 30]
  1873.             }
  1874.         ]
  1875.     };
  1876.  
  1877.     /**
  1878.      * Options for Line chart
  1879.      */
  1880.     this.lineOptions = {
  1881.         scaleShowGridLines : true,
  1882.         scaleGridLineColor : "rgba(0,0,0,.05)",
  1883.         scaleGridLineWidth : 1,
  1884.         bezierCurve : true,
  1885.         bezierCurveTension : 0.4,
  1886.         pointDot : true,
  1887.         pointDotRadius : 4,
  1888.         pointDotStrokeWidth : 1,
  1889.         pointHitDetectionRadius : 20,
  1890.         datasetStroke : true,
  1891.         datasetStrokeWidth : 2,
  1892.         datasetFill : true
  1893.     };
  1894.  
  1895.     /**
  1896.      * Options for Bar chart
  1897.      */
  1898.     this.barOptions = {
  1899.         scaleBeginAtZero : true,
  1900.         scaleShowGridLines : true,
  1901.         scaleGridLineColor : "rgba(0,0,0,.05)",
  1902.         scaleGridLineWidth : 1,
  1903.         barShowStroke : true,
  1904.         barStrokeWidth : 2,
  1905.         barValueSpacing : 5,
  1906.         barDatasetSpacing : 1
  1907. };
  1908.  
  1909.     /**
  1910.      * Data for Bar chart
  1911.      */
  1912.     this.barData = {
  1913.         labels: ["January", "February", "March", "April", "May", "June", "July"],
  1914.         datasets: [
  1915.             {
  1916.                 label: "My First dataset",
  1917.                 fillColor: "rgba(220,220,220,0.5)",
  1918.                 strokeColor: "rgba(220,220,220,0.8)",
  1919.                 highlightFill: "rgba(220,220,220,0.75)",
  1920.                 highlightStroke: "rgba(220,220,220,1)",
  1921.                 data: [65, 59, 80, 81, 56, 55, 40]
  1922.             },
  1923.             {
  1924.                 label: "My Second dataset",
  1925.                 fillColor: "rgba(26,179,148,0.5)",
  1926.                 strokeColor: "rgba(26,179,148,0.8)",
  1927.                 highlightFill: "rgba(26,179,148,0.75)",
  1928.                 highlightStroke: "rgba(26,179,148,1)",
  1929.                 data: [28, 48, 40, 19, 86, 27, 90]
  1930.             }
  1931.         ]
  1932.     };
  1933.  
  1934.     /**
  1935.      * Data for Radar chart
  1936.      */
  1937.     this.radarData = {
  1938.         labels: ["Eating", "Drinking", "Sleeping", "Designing", "Coding", "Cycling", "Running"],
  1939.         datasets: [
  1940.             {
  1941.                 label: "My First dataset",
  1942.                 fillColor: "rgba(220,220,220,0.2)",
  1943.                 strokeColor: "rgba(220,220,220,1)",
  1944.                 pointColor: "rgba(220,220,220,1)",
  1945.                 pointStrokeColor: "#fff",
  1946.                 pointHighlightFill: "#fff",
  1947.                 pointHighlightStroke: "rgba(220,220,220,1)",
  1948.                 data: [65, 59, 90, 81, 56, 55, 40]
  1949.             },
  1950.             {
  1951.                 label: "My Second dataset",
  1952.                 fillColor: "rgba(26,179,148,0.2)",
  1953.                 strokeColor: "rgba(26,179,148,1)",
  1954.                 pointColor: "rgba(26,179,148,1)",
  1955.                 pointStrokeColor: "#fff",
  1956.                 pointHighlightFill: "#fff",
  1957.                 pointHighlightStroke: "rgba(151,187,205,1)",
  1958.                 data: [28, 48, 40, 19, 96, 27, 100]
  1959.             }
  1960.         ]
  1961.     };
  1962.  
  1963.     /**
  1964.      * Options for Radar chart
  1965.      */
  1966.     this.radarOptions = {
  1967.         scaleShowLine : true,
  1968.         angleShowLineOut : true,
  1969.         scaleShowLabels : false,
  1970.         scaleBeginAtZero : true,
  1971.         angleLineColor : "rgba(0,0,0,.1)",
  1972.         angleLineWidth : 1,
  1973.         pointLabelFontFamily : "'Arial'",
  1974.         pointLabelFontStyle : "normal",
  1975.         pointLabelFontSize : 10,
  1976.         pointLabelFontColor : "#666",
  1977.         pointDot : true,
  1978.         pointDotRadius : 3,
  1979.         pointDotStrokeWidth : 1,
  1980.         pointHitDetectionRadius : 20,
  1981.         datasetStroke : true,
  1982.         datasetStrokeWidth : 2,
  1983.         datasetFill : true
  1984.     };
  1985.  
  1986.  
  1987. };
  1988.  
  1989. /**
  1990.  * GoogleMaps - Controller for data google maps
  1991.  */
  1992. function GoogleMaps($scope) {
  1993.     $scope.mapOptions = {
  1994.         zoom: 11,
  1995.         center: new google.maps.LatLng(40.6700, -73.9400),
  1996.         // Style for Google Maps
  1997.         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"}]}],
  1998.         mapTypeId: google.maps.MapTypeId.ROADMAP
  1999.     };
  2000.     $scope.mapOptions2 = {
  2001.         zoom: 11,
  2002.         center: new google.maps.LatLng(40.6700, -73.9400),
  2003.         // Style for Google Maps
  2004.         styles: [{"featureType":"all","elementType":"all","stylers":[{"invert_lightness":true},{"saturation":10},{"lightness":30},{"gamma":0.5},{"hue":"#435158"}]}],
  2005.         mapTypeId: google.maps.MapTypeId.ROADMAP
  2006.     };
  2007.     $scope.mapOptions3 = {
  2008.         center: new google.maps.LatLng(36.964645, -122.01523),
  2009.         zoom: 18,
  2010.         // Style for Google Maps
  2011.         MapTypeId: google.maps.MapTypeId.SATELLITE,
  2012.         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}]}],
  2013.         mapTypeId: google.maps.MapTypeId.SATELLITE
  2014.     };
  2015.     $scope.mapOptions4 = {
  2016.         zoom: 11,
  2017.         center: new google.maps.LatLng(40.6700, -73.9400),
  2018.         // Style for Google Maps
  2019.         styles: [{"stylers":[{"hue":"#18a689"},{"visibility":"on"},{"invert_lightness":true},{"saturation":40},{"lightness":10}]}],
  2020.         mapTypeId: google.maps.MapTypeId.ROADMAP
  2021.     };
  2022. }
  2023.  
  2024. /**
  2025.  * nestableCtrl - Controller for nestable list
  2026.  */
  2027. function nestableCtrl($scope) {
  2028.     $scope.remove = function(scope) {
  2029.         scope.remove();
  2030.     };
  2031.     $scope.toggle = function(scope) {
  2032.         scope.toggle();
  2033.     };
  2034.     $scope.moveLastToTheBeginning = function () {
  2035.         var a = $scope.data.pop();
  2036.         $scope.data.splice(0,0, a);
  2037.     };
  2038.     $scope.newSubItem = function(scope) {
  2039.         var nodeData = scope.$modelValue;
  2040.         nodeData.nodes.push({
  2041.             id: nodeData.id * 10 + nodeData.nodes.length,
  2042.             title: nodeData.title + '.' + (nodeData.nodes.length + 1),
  2043.             nodes: []
  2044.         });
  2045.     };
  2046.     $scope.collapseAll = function() {
  2047.         $scope.$broadcast('collapseAll');
  2048.     };
  2049.     $scope.expandAll = function() {
  2050.         $scope.$broadcast('expandAll');
  2051.     };
  2052.     $scope.data = [{
  2053.         "id": 1,
  2054.         "title": "node1",
  2055.         "nodes": [
  2056.             {
  2057.                 "id": 11,
  2058.                 "title": "node1.1",
  2059.                 "nodes": [
  2060.                     {
  2061.                         "id": 111,
  2062.                         "title": "node1.1.1",
  2063.                         "nodes": []
  2064.                     }
  2065.                 ]
  2066.             },
  2067.             {
  2068.                 "id": 12,
  2069.                 "title": "node1.2",
  2070.                 "nodes": []
  2071.             }
  2072.         ]
  2073.     }, {
  2074.         "id": 2,
  2075.         "title": "node2",
  2076.         "nodes": [
  2077.             {
  2078.                 "id": 21,
  2079.                 "title": "node2.1",
  2080.                 "nodes": []
  2081.             },
  2082.             {
  2083.                 "id": 22,
  2084.                 "title": "node2.2",
  2085.                 "nodes": []
  2086.             }
  2087.         ]
  2088.     }, {
  2089.         "id": 3,
  2090.         "title": "node3",
  2091.         "nodes": [
  2092.             {
  2093.                 "id": 31,
  2094.                 "title": "node3.1",
  2095.                 "nodes": []
  2096.             }
  2097.         ]
  2098.     }];
  2099. }
  2100.  
  2101. /**
  2102.  * codeEditorCtrl - Controller for code editor - Code Mirror
  2103.  */
  2104. function codeEditorCtrl($scope) {
  2105.     $scope.editorOptions = {
  2106.         lineNumbers: true,
  2107.         matchBrackets: true,
  2108.         styleActiveLine: true,
  2109.         theme:"ambiance"
  2110.     };
  2111.  
  2112.     $scope.editorOptions2 = {
  2113.         lineNumbers: true,
  2114.         matchBrackets: true,
  2115.         styleActiveLine: true
  2116.     };
  2117.  
  2118. }
  2119.  
  2120. /**
  2121.  * ngGridCtrl - Controller for code ngGrid
  2122.  */
  2123. function ngGridCtrl($scope) {
  2124.     $scope.ngData = [
  2125.         {Name: "Moroni", Age: 50, Position: 'PR Menager', Status: 'active', Date: '12.12.2014'},
  2126.         {Name: "Teancum", Age: 43, Position: 'CEO/CFO', Status: 'deactive', Date: '10.10.2014'},
  2127.         {Name: "Jacob", Age: 27, Position: 'UI Designer', Status: 'active', Date: '09.11.2013'},
  2128.         {Name: "Nephi", Age: 29, Position: 'Java programmer', Status: 'deactive', Date: '22.10.2014'},
  2129.         {Name: "Joseph", Age: 22, Position: 'Marketing manager', Status: 'active', Date: '24.08.2013'},
  2130.         {Name: "Monica", Age: 43, Position: 'President', Status: 'active', Date: '11.12.2014'},
  2131.         {Name: "Arnold", Age: 12, Position: 'CEO', Status: 'active', Date: '07.10.2013'},
  2132.         {Name: "Mark", Age: 54, Position: 'Analyst', Status: 'deactive', Date: '03.03.2014'},
  2133.         {Name: "Amelia", Age: 33, Position: 'Sales manager', Status: 'deactive', Date: '26.09.2013'},
  2134.         {Name: "Jesica", Age: 41, Position: 'Ruby programmer', Status: 'active', Date: '22.12.2013'},
  2135.         {Name: "John", Age: 48, Position: 'Marketing manager', Status: 'deactive', Date: '09.10.2014'},
  2136.         {Name: "Berg", Age: 19, Position: 'UI/UX Designer', Status: 'active', Date: '12.11.2013'}
  2137.     ];
  2138.  
  2139.     $scope.ngOptions = { data: 'ngData' };
  2140.     $scope.ngOptions2 = {
  2141.         data: 'ngData',
  2142.         showGroupPanel: true,
  2143.         jqueryUIDraggable: true
  2144.     };
  2145. }
  2146.  
  2147.  
  2148. /**
  2149.  * notifyCtrl - Controller angular notify
  2150.  */
  2151. function notifyCtrl($scope, notify) {
  2152.     $scope.msg = 'Hello! This is a sample message!';
  2153.     $scope.demo = function () {
  2154.         notify({
  2155.             message: $scope.msg,
  2156.             classes: $scope.classes,
  2157.             templateUrl: $scope.template
  2158.         });
  2159.     };
  2160.     $scope.closeAll = function () {
  2161.         notify.closeAll();
  2162.     };
  2163.  
  2164.     $scope.inspiniaTemplate = 'views/common/notify.html';
  2165.     $scope.inspiniaDemo1 = function(){
  2166.         notify({ message: 'Info - This is a Inspinia info notification', classes: 'alert-info', templateUrl: $scope.inspiniaTemplate});
  2167.     }
  2168.     $scope.inspiniaDemo2 = function(){
  2169.         notify({ message: 'Success - This is a Inspinia success notification', classes: 'alert-success', templateUrl: $scope.inspiniaTemplate});
  2170.     }
  2171.     $scope.inspiniaDemo3 = function(){
  2172.         notify({ message: 'Warning - This is a Inspinia warning notification', classes: 'alert-warning', templateUrl: $scope.inspiniaTemplate});
  2173.     }
  2174.     $scope.inspiniaDemo4 = function(){
  2175.         notify({ message: 'Danger - This is a Inspinia danger notification', classes: 'alert-danger', templateUrl: $scope.inspiniaTemplate});
  2176.     }
  2177. }
  2178.  
  2179. /**
  2180.  * translateCtrl - Controller for translate
  2181.  */
  2182. function translateCtrl($translate, $scope) {
  2183.     $scope.changeLanguage = function (langKey) {
  2184.         $translate.use(langKey);
  2185.         $scope.language = langKey;
  2186.     };
  2187. }
  2188.  
  2189. /**
  2190.  * imageCrop - Controller for image crop functionality
  2191.  */
  2192. function imageCrop($scope) {
  2193.  
  2194.     $scope.dupa = "dasdasdas";
  2195.  
  2196.     $scope.myImage='';
  2197.     $scope.myCroppedImage='';
  2198.  
  2199.     var handleFileSelect=function(evt) {
  2200.         var file=evt.currentTarget.files[0];
  2201.         var reader = new FileReader();
  2202.         reader.onload = function (evt) {
  2203.             $scope.$apply(function($scope){
  2204.                 $scope.myImage=evt.target.result;
  2205.             });
  2206.         };
  2207.         reader.readAsDataURL(file);
  2208.     };
  2209.     angular.element(document.querySelector('#fileInput')).on('change',handleFileSelect);
  2210. }
  2211.  
  2212.  
  2213. /**
  2214.  * diff - Controller for diff function
  2215.  */
  2216. function diff($scope) {
  2217.     $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.';
  2218.     $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.';
  2219.  
  2220.     $scope.oldText1 = 'Lorem Ipsum is simply printing and typesetting industry. Lorem Ipsum has been the industry\'s standard dummy text eve';
  2221.     $scope.newText1 = 'Ting dummy text of the printing and has been the industry\'s typesetting. Lorem Ipsum has been the industry\'s';
  2222. }
  2223.  
  2224. /**
  2225.  * idleTimer - Controller for Idle Timer
  2226.  */
  2227. function idleTimer($scope, Idle, notify) {
  2228.  
  2229.     // Custm alter
  2230.     $scope.customAlert = false;
  2231.  
  2232.     // Start watching idle
  2233.     Idle.watch();
  2234.  
  2235.     // Config notify behavior
  2236.     notify.config({
  2237.        duration: '5000'
  2238.     });
  2239.  
  2240.     // function you want to fire when the user goes idle
  2241.     $scope.$on('IdleStart', function () {
  2242.         notify({
  2243.             message: 'Idle time - You can call any function after idle timeout.',
  2244.             classes: 'alert-warning',
  2245.             templateUrl: 'views/common/notify.html'
  2246.         });
  2247.         $scope.customAlert = true;
  2248.  
  2249.     });
  2250.  
  2251.     // function you want to fire when the user becomes active again
  2252.     $scope.$on('IdleEnd', function () {
  2253.         notify({
  2254.             message: 'You are back, Great that you decided to move a mouse.',
  2255.             classes: 'alert-success',
  2256.             templateUrl: 'views/common/notify.html'
  2257.         });
  2258.         $scope.customAlert = false;
  2259.     });
  2260.  
  2261. }
  2262.  
  2263.  
  2264. /**
  2265.  * liveFavicon - Controller for live favicon
  2266.  */
  2267. function liveFavicon($scope){
  2268.  
  2269.     $scope.example1 = function(){
  2270.         Tinycon.setBubble(1);
  2271.         Tinycon.setOptions({
  2272.             background: '#f03d25'
  2273.         });
  2274.     }
  2275.  
  2276.     $scope.example2 = function(){
  2277.         Tinycon.setBubble(1000);
  2278.         Tinycon.setOptions({
  2279.             background: '#f03d25'
  2280.         });
  2281.     }
  2282.  
  2283.     $scope.example3 = function(){
  2284.         Tinycon.setBubble('In');
  2285.         Tinycon.setOptions({
  2286.             background: '#f03d25'
  2287.         });
  2288.     }
  2289.  
  2290.     $scope.example4 = function(){
  2291.         Tinycon.setOptions({
  2292.             background: '#e0913b'
  2293.         });
  2294.         Tinycon.setBubble(8);
  2295.     }
  2296.  
  2297. }
  2298.  
  2299. /**
  2300.  * formValidation - Controller for validation example
  2301.  */
  2302. function formValidation($scope) {
  2303.  
  2304.     $scope.signupForm = function() {
  2305.         if ($scope.signup_form.$valid) {
  2306.             // Submit as normal
  2307.         } else {
  2308.             $scope.signup_form.submitted = true;
  2309.         }
  2310.     }
  2311.  
  2312.     $scope.signupForm2 = function() {
  2313.         if ($scope.signup_form.$valid) {
  2314.             // Submit as normal
  2315.         }
  2316.     }
  2317.  
  2318. };
  2319.  
  2320. /**
  2321.  * agileBoard - Controller for agile Board view
  2322.  */
  2323. function agileBoard($scope) {
  2324.  
  2325.  
  2326.     $scope.todoList = [
  2327.         {
  2328.             content: 'Simply dummy text of the printing and typesetting industry.',
  2329.             date: '12.10.2015',
  2330.             statusClass: 'warning',
  2331.             tagName: 'Mark'
  2332.         },
  2333.         {
  2334.             content: 'Many desktop publishing packages and web page editors now use Lorem Ipsum as their default.',
  2335.             date: '05.04.2015',
  2336.             statusClass: 'success',
  2337.             tagName: 'Tag'
  2338.         },
  2339.         {
  2340.             content: 'Sometimes by accident, sometimes on purpose (injected humour and the like).',
  2341.             date: '16.11.2015',
  2342.             statusClass: 'info',
  2343.             tagName: 'Mark'
  2344.         },
  2345.         {
  2346.             content: 'All the Lorem Ipsum generators',
  2347.             date: '06.10.2015',
  2348.             statusClass: 'danger',
  2349.             tagName: 'Tag'
  2350.         },
  2351.         {
  2352.             content: 'Which looks reasonable. The generated Lorem Ipsum is therefore always free from repetition, injected humour, or non-characteristic words etc.',
  2353.             date: '09.12.2015',
  2354.             statusClass: 'warning',
  2355.             tagName: 'Mark'
  2356.         },
  2357.         {
  2358.             content: 'Packages and web page editors now use Lorem Ipsum as',
  2359.             date: '08.04.2015',
  2360.             statusClass: 'warning',
  2361.             tagName: 'Mark'
  2362.         },
  2363.         {
  2364.             content: 'Many desktop publishing packages and web page editors now use Lorem Ipsum as their default.',
  2365.             date: '05.04.2015',
  2366.             statusClass: 'success',
  2367.             tagName: 'Tag'
  2368.         },
  2369.         {
  2370.             content: 'Sometimes by accident, sometimes on purpose (injected humour and the like).',
  2371.             date: '16.11.2015',
  2372.             statusClass: 'info',
  2373.             tagName: 'Tag'
  2374.         }
  2375.     ];
  2376.     $scope.inProgressList = [
  2377.         {
  2378.             content: 'Quisque venenatis ante in porta suscipit.',
  2379.             date: '12.10.2015',
  2380.             statusClass: 'success',
  2381.             tagName: 'Mark'
  2382.         },
  2383.         {
  2384.             content: ' Phasellus sit amet tortor sed enim mollis accumsan in consequat orci.',
  2385.             date: '05.04.2015',
  2386.             statusClass: 'success',
  2387.             tagName: 'Tag'
  2388.         },
  2389.         {
  2390.             content: 'Nunc sed arcu at ligula faucibus tempus ac id felis. Vestibulum et nulla quis turpis sagittis fringilla.',
  2391.             date: '16.11.2015',
  2392.             statusClass: 'warning',
  2393.             tagName: 'Mark'
  2394.         },
  2395.         {
  2396.             content: 'Ut porttitor augue non sapien mollis accumsan. Nulla non elit eget lacus elementum viverra.',
  2397.             date: '09.12.2015',
  2398.             statusClass: 'warning',
  2399.             tagName: 'Tag'
  2400.         },
  2401.         {
  2402.             content: 'Packages and web page editors now use Lorem Ipsum as',
  2403.             date: '08.04.2015',
  2404.             statusClass: 'info',
  2405.             tagName: 'Tag'
  2406.         },
  2407.         {
  2408.             content: 'Quisque lacinia tellus et odio ornare maximus.',
  2409.             date: '05.04.2015',
  2410.             statusClass: 'success',
  2411.             tagName: 'Mark'
  2412.         },
  2413.         {
  2414.             content: 'Enim mollis accumsan in consequat orci.',
  2415.             date: '11.04.2015',
  2416.             statusClass: 'danger',
  2417.             tagName: 'Tag'
  2418.         }
  2419.     ];
  2420.     $scope.completedList = [
  2421.         {
  2422.             content: 'Sometimes by accident, sometimes on purpose (injected humour and the like).',
  2423.             date: '16.11.2015',
  2424.             statusClass: 'info',
  2425.             tagName: 'Mark'
  2426.         },
  2427.         {
  2428.             content: 'Ut porttitor augue non sapien mollis accumsan. Nulla non elit eget lacus elementum viverra.',
  2429.             date: '09.12.2015',
  2430.             statusClass: 'warning',
  2431.             tagName: 'Tag'
  2432.         },
  2433.         {
  2434.             content: 'Which looks reasonable. The generated Lorem Ipsum is therefore always free from repetition, injected humour, or non-characteristic words etc.',
  2435.             date: '09.12.2015',
  2436.             statusClass: 'warning',
  2437.             tagName: 'Tag'
  2438.         },
  2439.         {
  2440.             content: 'Packages and web page editors now use Lorem Ipsum as',
  2441.             date: '08.04.2015',
  2442.             statusClass: 'warning',
  2443.             tagName: 'Tag'
  2444.         },
  2445.         {
  2446.             content: 'Many desktop publishing packages and web page editors now use Lorem Ipsum as their default.',
  2447.             date: '05.04.2015',
  2448.             statusClass: 'success',
  2449.             tagName: 'Mark'
  2450.         },
  2451.         {
  2452.             content: 'Sometimes by accident, sometimes on purpose (injected humour and the like).',
  2453.             date: '16.11.2015',
  2454.             statusClass: 'info',
  2455.             tagName: 'Tag'
  2456.         },
  2457.         {
  2458.             content: 'Simply dummy text of the printing and typesetting industry.',
  2459.             date: '12.10.2015',
  2460.             statusClass: 'warning',
  2461.             tagName: 'Mark'
  2462.         },
  2463.         {
  2464.             content: 'Many desktop publishing packages and web page editors now use Lorem Ipsum as their default.',
  2465.             date: '05.04.2015',
  2466.             statusClass: 'success',
  2467.             tagName: 'Mark'
  2468.         }
  2469.     ];
  2470.  
  2471.     $scope.sortableOptions = {
  2472.         connectWith: ".connectList"
  2473.     };
  2474.  
  2475. }
  2476.  
  2477. /**
  2478.  * draggablePanels - Controller for draggable panels example
  2479.  */
  2480. function draggablePanels($scope) {
  2481.  
  2482.     $scope.sortableOptions = {
  2483.         connectWith: ".connectPanels",
  2484.         handler: ".ibox-title"
  2485.     };
  2486.  
  2487. }
  2488.  
  2489. /**
  2490.  * chartistCtrl - Controller for Chartist library
  2491.  */
  2492. function chartistCtrl() {
  2493.  
  2494.     this.lineData = {
  2495.         labels: ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday'],
  2496.         series: [
  2497.             [12, 9, 7, 8, 5],
  2498.             [2, 1, 3.5, 7, 3],
  2499.             [1, 3, 4, 5, 6]
  2500.         ]
  2501.     }
  2502.  
  2503.     this.lineOptions = {
  2504.         fullWidth: true,
  2505.         chartPadding: {
  2506.             right: 40
  2507.         }
  2508.     }
  2509.  
  2510.     var times = function (n) {
  2511.         return Array.apply(null, new Array(n));
  2512.     };
  2513.  
  2514.     var prepareData = times(26).map(Math.random).reduce(function (data, rnd, index) {
  2515.         data.labels.push(index + 1);
  2516.         data.series.forEach(function (series) {
  2517.             series.push(Math.random() * 100)
  2518.         });
  2519.  
  2520.         return data;
  2521.     }, {
  2522.         labels: [],
  2523.         series: times(4).map(function () {
  2524.             return new Array()
  2525.         })
  2526.     });
  2527.  
  2528.     this.scatterData = prepareData;
  2529.  
  2530.     this.scatterOptions = {
  2531.         showLine: false,
  2532.         axisX: {
  2533.             labelInterpolationFnc: function (value, index) {
  2534.                 return index % 13 === 0 ? 'W' + value : null;
  2535.             }
  2536.         }
  2537.     }
  2538.  
  2539.     this.stackedData = {
  2540.         labels: ['Q1', 'Q2', 'Q3', 'Q4'],
  2541.         series: [
  2542.             [800000, 1200000, 1400000, 1300000],
  2543.             [200000, 400000, 500000, 300000],
  2544.             [100000, 200000, 400000, 600000]
  2545.         ]
  2546.     }
  2547.     this.stackedOptions = {
  2548.         stackBars: true,
  2549.         axisY: {
  2550.             labelInterpolationFnc: function (value) {
  2551.                 return (value / 1000) + 'k';
  2552.             }
  2553.         }
  2554.     }
  2555.  
  2556.     this.horizontalData = {
  2557.         labels: ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday'],
  2558.         series: [
  2559.             [5, 4, 3, 7, 5, 10, 3],
  2560.             [3, 2, 9, 5, 4, 6, 4]
  2561.         ]
  2562.     }
  2563.  
  2564.     this.horizontalOptions = {
  2565.         seriesBarDistance: 10,
  2566.         reverseData: true,
  2567.         horizontalBars: true,
  2568.         axisY: {
  2569.             offset: 70
  2570.         }
  2571.     }
  2572.  
  2573.     var prepareData = {
  2574.         series: [5, 3, 4]
  2575.     }
  2576.  
  2577.     this.pieData = prepareData
  2578.  
  2579.     var sum = function (a, b) {
  2580.         return a + b
  2581.     };
  2582.  
  2583.     this.pieOptions = {
  2584.         labelInterpolationFnc: function (value) {
  2585.             return Math.round(value / prepareData.series.reduce(sum) * 100) + '%';
  2586.         }
  2587.     }
  2588.  
  2589.     this.gaugeData = {
  2590.         series: [20, 10, 30, 40]
  2591.     }
  2592.  
  2593.     this.gaugeOptions = {
  2594.         donut: true,
  2595.         donutWidth: 60,
  2596.         startAngle: 270,
  2597.         total: 200,
  2598.         showLabel: false
  2599.     }
  2600.  
  2601. }
  2602.  
  2603. /**
  2604.  * metricsCtrl - Controller for data for all Sparkline chart
  2605.  * used in Metrics view
  2606.  */
  2607. function metricsCtrl() {
  2608.  
  2609.  
  2610.     this.demo1Data = [34, 43, 43, 35, 44, 32, 44, 52];
  2611.     this.demo1Options = {
  2612.         type: 'line',
  2613.         width: '100%',
  2614.         height: '60',
  2615.         lineColor: '#1ab394',
  2616.         fillColor: "#ffffff"
  2617.     };
  2618.  
  2619.     this.demo2Data = [24, 43, 43, 55, 44, 62, 44, 72];
  2620.     this.demo2Options = {
  2621.         type: 'line',
  2622.         width: '100%',
  2623.         height: '60',
  2624.         lineColor: '#1ab394',
  2625.         fillColor: "#ffffff"
  2626.     };
  2627.  
  2628.     this.demo3Data = [74, 43, 23, 55, 54, 32, 24, 12];
  2629.     this.demo3Options = {
  2630.         type: 'line',
  2631.         width: '100%',
  2632.         height: '60',
  2633.         lineColor: '#ed5565',
  2634.         fillColor: "#ffffff"
  2635.     };
  2636.  
  2637.     this.demo4Data = [24, 43, 33, 55, 64, 72, 44, 22];
  2638.     this.demo4Options = {
  2639.         type: 'line',
  2640.         width: '100%',
  2641.         height: '60',
  2642.         lineColor: '#ed5565',
  2643.         fillColor: "#ffffff"
  2644.     };
  2645.  
  2646.     this.demo5Data = [1, 4];
  2647.     this.demo5Options = {
  2648.         type: 'pie',
  2649.         height: '140',
  2650.         sliceColors: ['#1ab394', '#F5F5F5']
  2651.     };
  2652.  
  2653.     this.demo6Data = [5, 3];
  2654.     this.demo6Options = {
  2655.         type: 'pie',
  2656.         height: '140',
  2657.         sliceColors: ['#1ab394', '#F5F5F5']
  2658.     };
  2659.  
  2660.     this.demo7Data = [2, 2];
  2661.     this.demo7Options = {
  2662.         type: 'pie',
  2663.         height: '140',
  2664.         sliceColors: ['#ed5565', '#F5F5F5']
  2665.     };
  2666.  
  2667.     this.demo8Data = [2, 3];
  2668.     this.demo8Options = {
  2669.         type: 'pie',
  2670.         height: '140',
  2671.         sliceColors: ['#ed5565', '#F5F5F5']
  2672.     };
  2673.  
  2674. }
  2675.  
  2676.  
  2677.  
  2678. /**
  2679.  * sweetAlertCtrl - Function for Sweet alerts
  2680.  */
  2681. function sweetAlertCtrl($scope, SweetAlert) {
  2682.  
  2683.  
  2684.     $scope.demo1 = function () {
  2685.         SweetAlert.swal({
  2686.             title: "Welcome in Alerts",
  2687.             text: "Lorem Ipsum is simply dummy text of the printing and typesetting industry."
  2688.         });
  2689.     }
  2690.  
  2691.     $scope.demo2 = function () {
  2692.         SweetAlert.swal({
  2693.             title: "Good job!",
  2694.             text: "You clicked the button!",
  2695.             type: "success"
  2696.         });
  2697.     }
  2698.  
  2699.     $scope.demo3 = function () {
  2700.         SweetAlert.swal({
  2701.                 title: "Are you sure?",
  2702.                 text: "Your will not be able to recover this imaginary file!",
  2703.                 type: "warning",
  2704.                 showCancelButton: true,
  2705.                 confirmButtonColor: "#DD6B55",
  2706.                 confirmButtonText: "Yes, delete it!",
  2707.                 closeOnConfirm: false,
  2708.                 closeOnCancel: false
  2709.             },
  2710.             function () {
  2711.                 SweetAlert.swal("Ok!");
  2712.             });
  2713.     }
  2714.  
  2715.     $scope.demo4 = function () {
  2716.         SweetAlert.swal({
  2717.                 title: "Are you sure?",
  2718.                 text: "Your will not be able to recover this imaginary file!",
  2719.                 type: "warning",
  2720.                 showCancelButton: true,
  2721.                 confirmButtonColor: "#DD6B55",
  2722.                 confirmButtonText: "Yes, delete it!",
  2723.                 cancelButtonText: "No, cancel plx!",
  2724.                 closeOnConfirm: false,
  2725.                 closeOnCancel: false },
  2726.             function (isConfirm) {
  2727.                 if (isConfirm) {
  2728.                     SweetAlert.swal("Deleted!", "Your imaginary file has been deleted.", "success");
  2729.                 } else {
  2730.                     SweetAlert.swal("Cancelled", "Your imaginary file is safe :)", "error");
  2731.                 }
  2732.             });
  2733.     }
  2734.  
  2735. }
  2736.  
  2737. function selectCtrl($scope) {
  2738.  
  2739.     $scope.person = {};
  2740.     $scope.people = [
  2741.         { name: 'Adam',      email: 'adam@email.com',      age: 12, country: 'United States' },
  2742.         { name: 'Amalie',    email: 'amalie@email.com',    age: 12, country: 'Argentina' },
  2743.         { name: 'Estefanía', email: 'estefania@email.com', age: 21, country: 'Argentina' },
  2744.         { name: 'Adrian',    email: 'adrian@email.com',    age: 21, country: 'Ecuador' },
  2745.         { name: 'Wladimir',  email: 'wladimir@email.com',  age: 30, country: 'Ecuador' },
  2746.         { name: 'Samantha',  email: 'samantha@email.com',  age: 30, country: 'United States' },
  2747.         { name: 'Nicole',    email: 'nicole@email.com',    age: 43, country: 'Colombia' },
  2748.         { name: 'Natasha',   email: 'natasha@email.com',   age: 54, country: 'Ecuador' },
  2749.         { name: 'Michael',   email: 'michael@email.com',   age: 15, country: 'Colombia' },
  2750.         { name: 'Nicolás',   email: 'nicolas@email.com',    age: 43, country: 'Colombia' }
  2751.     ];
  2752.  
  2753.     $scope.option = {};
  2754.     $scope.options = [
  2755.         { number: '1',      text: 'Option 1' },
  2756.         { number: '2',      text: 'Option 2' },
  2757.         { number: '3',      text: 'Option 3' },
  2758.         { number: '4',      text: 'Option 4' },
  2759.         { number: '5',      text: 'Option 5' },
  2760.         { number: '6',      text: 'Option 6' }
  2761.     ];
  2762.  
  2763.     $scope.availableColors = ['Red','Green','Blue','Yellow','Magenta','Maroon','Umbra','Turquoise'];
  2764.  
  2765.     $scope.multipleDemo = {};
  2766.     $scope.multipleDemo.colors = ['Blue','Red'];
  2767.  
  2768. }
  2769.  
  2770.  
  2771.  
  2772. function toastrCtrl($scope, toaster){
  2773.  
  2774.     $scope.demo1 = function(){
  2775.         toaster.success({ body:"Hi, welcome to Inspinia. This is example of Toastr notification box."});
  2776.     };
  2777.  
  2778.     $scope.demo2 = function(){
  2779.         toaster.warning({ title: "Title example", body:"This is example of Toastr notification box."});
  2780.     };
  2781.  
  2782.     $scope.demo3 = function(){
  2783.         toaster.pop({
  2784.             type: 'info',
  2785.             title: 'Title example',
  2786.             body: 'This is example of Toastr notification box.',
  2787.             showCloseButton: true
  2788.  
  2789.         });
  2790.     };
  2791.  
  2792.     $scope.demo4 = function(){
  2793.         toaster.pop({
  2794.             type: 'error',
  2795.             title: 'Title example',
  2796.             body: 'This is example of Toastr notification box.',
  2797.             showCloseButton: true,
  2798.             timeout: 600
  2799.         });
  2800.     };
  2801.  
  2802. }
  2803.  
  2804. function loadingCtrl($scope, $timeout){
  2805.  
  2806.  
  2807.     $scope.runLoading = function() {
  2808.         // start loading
  2809.         $scope.loading = true;
  2810.  
  2811.         $timeout(function(){
  2812.             // Simulate some service
  2813.             $scope.loading = false;
  2814.         },2000)
  2815.     };
  2816.  
  2817.  
  2818.     // Demo purpose actions
  2819.     $scope.runLoading1 = function () {
  2820.         // start loading
  2821.         $scope.loading1 = true;
  2822.  
  2823.         $timeout(function () {
  2824.             // Simulate some service
  2825.             $scope.loading1 = false;
  2826.         }, 2000)
  2827.     };
  2828.     $scope.runLoading2 = function () {
  2829.         // start loading
  2830.         $scope.loading2 = true;
  2831.  
  2832.         $timeout(function () {
  2833.             // Simulate some service
  2834.             $scope.loading2 = false;
  2835.         }, 2000)
  2836.     };
  2837.     $scope.runLoading3 = function () {
  2838.         // start loading
  2839.         $scope.loading3 = true;
  2840.  
  2841.         $timeout(function () {
  2842.             // Simulate some service
  2843.             $scope.loading3 = false;
  2844.         }, 2000)
  2845.     };
  2846.     $scope.runLoading4 = function () {
  2847.         // start loading
  2848.         $scope.loading4 = true;
  2849.  
  2850.         $timeout(function () {
  2851.             // Simulate some service
  2852.             $scope.loading4 = false;
  2853.         }, 2000)
  2854.     };
  2855.     $scope.runLoading5 = function () {
  2856.         // start loading
  2857.         $scope.loading5 = true;
  2858.  
  2859.         $timeout(function () {
  2860.             // Simulate some service
  2861.             $scope.loading5 = false;
  2862.         }, 2000)
  2863.     };
  2864.     $scope.runLoading6 = function () {
  2865.         // start loading
  2866.         $scope.loading6 = true;
  2867.  
  2868.         $timeout(function () {
  2869.             // Simulate some service
  2870.             $scope.loading6 = false;
  2871.         }, 2000)
  2872.     };
  2873.     $scope.runLoading7 = function () {
  2874.         // start loading
  2875.         $scope.loading7 = true;
  2876.  
  2877.         $timeout(function () {
  2878.             // Simulate some service
  2879.             $scope.loading7 = false;
  2880.         }, 2000)
  2881.     };
  2882.     $scope.runLoading8 = function () {
  2883.         // start loading
  2884.         $scope.loading8 = true;
  2885.  
  2886.         $timeout(function () {
  2887.             // Simulate some service
  2888.             $scope.loading8 = false;
  2889.         }, 2000)
  2890.     };
  2891.     $scope.runLoading9 = function () {
  2892.         // start loading
  2893.         $scope.loading9 = true;
  2894.  
  2895.         $timeout(function () {
  2896.             // Simulate some service
  2897.             $scope.loading9 = false;
  2898.         }, 2000)
  2899.     };
  2900.     $scope.runLoading10 = function () {
  2901.         // start loading
  2902.         $scope.loading10 = true;
  2903.  
  2904.         $timeout(function () {
  2905.             // Simulate some service
  2906.             $scope.loading10 = false;
  2907.         }, 2000)
  2908.     };
  2909.     $scope.runLoading11 = function () {
  2910.         // start loading
  2911.         $timeout(function() {
  2912.             $scope.loading11 = 0.1;
  2913.         }, 500);
  2914.         $timeout(function() {
  2915.             $scope.loading11 += 0.2;
  2916.         }, 1000);
  2917.         $timeout(function() {
  2918.             $scope.loading11 += 0.3;
  2919.         }, 1500);
  2920.         $timeout(function() {
  2921.             $scope.loading11 = false;
  2922.         }, 2000);
  2923.  
  2924.     };
  2925.     $scope.runLoading12 = function () {
  2926.         // start loading
  2927.         $timeout(function() {
  2928.             $scope.loading12 = 0.1;
  2929.         }, 500);
  2930.         $timeout(function() {
  2931.             $scope.loading12 += 0.2;
  2932.         }, 1000);
  2933.         $timeout(function() {
  2934.             $scope.loading12 += 0.3;
  2935.         }, 1500);
  2936.         $timeout(function() {
  2937.             $scope.loading12 = false;
  2938.         }, 2000);
  2939.  
  2940.     };
  2941.  
  2942.     $scope.runLoadingDemo = function() {
  2943.         // start loading
  2944.         $scope.loadingDemo = true;
  2945.  
  2946.         $timeout(function(){
  2947.             // Simulate some service
  2948.             $scope.loadingDemo = false;
  2949.         },2000)
  2950.     };
  2951.  
  2952.  
  2953. }
  2954.  
  2955.  
  2956. function datatablesCtrl($scope,DTOptionsBuilder){
  2957.  
  2958.     $scope.dtOptions = DTOptionsBuilder.newOptions()
  2959.         .withDOM('<"html5buttons"B>lTfgitp')
  2960.         .withButtons([
  2961.             {extend: 'copy'},
  2962.             {extend: 'csv'},
  2963.             {extend: 'excel', title: 'ExampleFile'},
  2964.             {extend: 'pdf', title: 'ExampleFile'},
  2965.  
  2966.             {extend: 'print',
  2967.                 customize: function (win){
  2968.                     $(win.document.body).addClass('white-bg');
  2969.                     $(win.document.body).css('font-size', '10px');
  2970.  
  2971.                     $(win.document.body).find('table')
  2972.                         .addClass('compact')
  2973.                         .css('font-size', 'inherit');
  2974.                 }
  2975.             }
  2976.         ]);
  2977.  
  2978.     /**
  2979.      * persons - Data used in Tables view for Data Tables plugin
  2980.      */
  2981.     $scope.persons = [
  2982.         {
  2983.             id: '1',
  2984.             firstName: 'Monica',
  2985.             lastName: 'Smith'
  2986.         },
  2987.         {
  2988.             id: '2',
  2989.             firstName: 'Sandra',
  2990.             lastName: 'Jackson'
  2991.         },
  2992.         {
  2993.             id: '3',
  2994.             firstName: 'John',
  2995.             lastName: 'Underwood'
  2996.         },
  2997.         {
  2998.             id: '4',
  2999.             firstName: 'Chris',
  3000.             lastName: 'Johnatan'
  3001.         },
  3002.         {
  3003.             id: '5',
  3004.             firstName: 'Kim',
  3005.             lastName: 'Rosowski'
  3006.         }
  3007.     ];
  3008.  
  3009. }
  3010.  
  3011. function truncateCtrl($scope){
  3012.  
  3013.     $scope.truncateOptions = {
  3014.         watch: 'window'
  3015.     };
  3016.  
  3017.     $scope.truncateOptions2 = {
  3018.         watch: 'window',
  3019.         ellipsis: ' ///...'
  3020.     };
  3021.  
  3022.     $scope.truncateOptions3 = {
  3023.         watch: 'window',
  3024.         wrap: 'letter'
  3025.     }
  3026.  
  3027. }
  3028.  
  3029. function touchspinCtrl($scope) {
  3030.  
  3031.     $scope.inputteresxcs = 55;
  3032.     $scope.spinOption1 = {
  3033.         min: 0,
  3034.         max: 100,
  3035.         step: 0.1,
  3036.         decimals: 2,
  3037.         boostat: 5,
  3038.         maxboostedstep: 10,
  3039.     };
  3040.  
  3041.     $scope.spinOption2 = {
  3042.         verticalbuttons: true
  3043.     }
  3044.  
  3045.     $scope.spinOption3 = {
  3046.         postfix: '%'
  3047.     }
  3048.  
  3049.     $scope.spinOption4 = {
  3050.         postfix: "a button",
  3051.         postfix_extraclass: "btn btn-default"
  3052.     }
  3053.  
  3054. }
  3055.  
  3056. function tourCtrl($scope){
  3057.  
  3058.     $scope.preparebody = function(tour){
  3059.         $('body').addClass('tour-open')
  3060.     };
  3061.  
  3062.     $scope.clearbody = function(tour){
  3063.         $('body').removeClass('tour-close')
  3064.     }
  3065.  
  3066. }
  3067.  
  3068. function jstreeCtrl($scope) {
  3069.  
  3070.     $scope.treeConfig = {
  3071.         'plugins' : [ 'types', 'dnd' ],
  3072.         'types' : {
  3073.             'default' : {
  3074.                 'icon' : 'fa fa-folder'
  3075.             },
  3076.             'html' : {
  3077.                 'icon' : 'fa fa-file-code-o'
  3078.             },
  3079.             'svg' : {
  3080.                 'icon' : 'fa fa-file-picture-o'
  3081.             },
  3082.             'css' : {
  3083.                 'icon' : 'fa fa-file-code-o'
  3084.             },
  3085.             'img' : {
  3086.                 'icon' : 'fa fa-file-image-o'
  3087.             },
  3088.             'js' : {
  3089.                 'icon' : 'fa fa-file-text-o'
  3090.             }
  3091.  
  3092.         }
  3093.     };
  3094.  
  3095.     $scope.treeData = [
  3096.         {
  3097.             "id": "ajson1",
  3098.             "parent": "#",
  3099.             "text": "Admin theme",
  3100.             "state": {
  3101.                 "opened": true
  3102.             },
  3103.             "__uiNodeId": 1
  3104.         }, {
  3105.             "id": "ajson2",
  3106.             "parent": "ajson1",
  3107.             "text": "css",
  3108.             "state": {
  3109.                 "opened": true
  3110.             },
  3111.             "__uiNodeId": 2
  3112.         }, {
  3113.             "id": "ajson3",
  3114.             "parent": "ajson2",
  3115.             "text": "animate.css",
  3116.             "state": {
  3117.                 "opened": true
  3118.             },
  3119.             "type": "css",
  3120.             "__uiNodeId": 3
  3121.         },
  3122.         {
  3123.             "id": "ajson4",
  3124.             "parent": "ajson2",
  3125.             "text": "bootstrap.css",
  3126.             "state": {
  3127.                 "opened": true
  3128.             },
  3129.             "type": "css",
  3130.             "__uiNodeId": 4
  3131.         },
  3132.         {
  3133.             "id": "ajson5",
  3134.             "parent": "ajson2",
  3135.             "text": "style.css",
  3136.             "state": {
  3137.                 "opened": true
  3138.             },
  3139.             "type": "css",
  3140.             "__uiNodeId": 5
  3141.         },
  3142.         {
  3143.             "id": "ajson6",
  3144.             "parent": "ajson1",
  3145.             "text": "fonts",
  3146.             "state": {
  3147.                 "opened": false
  3148.             },
  3149.             "__uiNodeId": 6
  3150.         },
  3151.         {
  3152.             "id": "ajson9",
  3153.             "parent": "ajson6",
  3154.             "text": "glyphicons-halflings-regular.eot",
  3155.             "state": {
  3156.                 "opened": true
  3157.             },
  3158.             "type":"img",
  3159.             "__uiNodeId": 9
  3160.         },
  3161.         {
  3162.             "id": "ajson10",
  3163.             "parent": "ajson6",
  3164.             "text": "glyphicons-halflings-regular.svg",
  3165.             "state": {
  3166.                 "opened": true
  3167.             },
  3168.             "type":"svg",
  3169.             "__uiNodeId": 10
  3170.         },
  3171.         {
  3172.             "id": "ajson11",
  3173.             "parent": "ajson6",
  3174.             "text": "glyphicons-halflings-regular.ttf",
  3175.             "state": {
  3176.                 "opened": true
  3177.             },
  3178.             "type":"img",
  3179.             "__uiNodeId": 11
  3180.         },
  3181.         {
  3182.             "id": "ajson12",
  3183.             "parent": "ajson6",
  3184.             "text": "glyphicons-halflings-regular.woff",
  3185.             "state": {
  3186.                 "opened": true
  3187.             },
  3188.             "type":"img",
  3189.             "__uiNodeId": 12
  3190.         },
  3191.         {
  3192.             "id": "ajson7",
  3193.             "parent": "ajson1",
  3194.             "text": "img",
  3195.             "state": {
  3196.                 "opened": true
  3197.             },
  3198.             "__uiNodeId": 7
  3199.         },
  3200.         {
  3201.             "id": "ajson13",
  3202.             "parent": "ajson7",
  3203.             "text": "profile_small.jpg",
  3204.             "state": {
  3205.                 "opened": true
  3206.             },
  3207.             "type": "img",
  3208.             "__uiNodeId": 13
  3209.         },
  3210.         {
  3211.             "id": "ajson14",
  3212.             "parent": "ajson7",
  3213.             "text": "angular_logo.png",
  3214.             "state": {
  3215.                 "opened": true
  3216.             },
  3217.             "type": "img",
  3218.             "__uiNodeId": 14
  3219.         },
  3220.         {
  3221.             "id": "ajson15",
  3222.             "parent": "ajson7",
  3223.             "text": "html_logo.png",
  3224.             "state": {
  3225.                 "opened": true
  3226.             },
  3227.             "li_attr": {"class": "text-navy"},
  3228.             "type": "img",
  3229.             "__uiNodeId": 15
  3230.         },
  3231.         {
  3232.             "id": "ajson16",
  3233.             "parent": "ajson7",
  3234.             "text": "mvc_logo.png",
  3235.             "state": {
  3236.                 "opened": true
  3237.             },
  3238.             "li_attr": {"class": "text-navy"},
  3239.             "type": "img",
  3240.             "__uiNodeId": 16
  3241.         },
  3242.         {
  3243.             "id": "ajson8",
  3244.             "parent": "ajson1",
  3245.             "text": "js",
  3246.             "state": {
  3247.                 "opened": true
  3248.             },
  3249.             "__uiNodeId": 8
  3250.         },
  3251.         {
  3252.             "id": "ajson17",
  3253.             "parent": "ajson8",
  3254.             "text": "inspinia.js",
  3255.             "state": {
  3256.                 "opened": true
  3257.             },
  3258.             "type":"js",
  3259.             "__uiNodeId": 17
  3260.         },
  3261.         {
  3262.             "id": "ajson18",
  3263.             "parent": "ajson8",
  3264.             "text": "bootstrap.js",
  3265.             "state": {
  3266.                 "opened": true
  3267.             },
  3268.             "type":"js",
  3269.             "__uiNodeId": 18
  3270.         },
  3271.         {
  3272.             "id": "ajson19",
  3273.             "parent": "ajson8",
  3274.             "text": "jquery-2.1.1.js",
  3275.             "state": {
  3276.                 "opened": true
  3277.             },
  3278.             "type":"js",
  3279.             "__uiNodeId": 19
  3280.         },
  3281.         {
  3282.             "id": "ajson20",
  3283.             "parent": "ajson8",
  3284.             "text": "jquery-ui.custom.min.js",
  3285.             "state": {
  3286.                 "opened": true
  3287.             },
  3288.             "type":"js",
  3289.             "__uiNodeId":20
  3290.         },
  3291.         {
  3292.             "id": "ajson21",
  3293.             "parent": "ajson1",
  3294.             "text": "affix.html",
  3295.             "type":"html",
  3296.             "__uiNodeId":21
  3297.         },
  3298.         {
  3299.             "id": "ajson22",
  3300.             "parent": "ajson1",
  3301.             "text": "dashboard.html",
  3302.             "type":"html",
  3303.             "__uiNodeId":22
  3304.         },
  3305.         {
  3306.             "id": "ajson23",
  3307.             "parent": "ajson1",
  3308.             "text": "buttons.html",
  3309.             "type":"html",
  3310.             "__uiNodeId":23
  3311.         },
  3312.         {
  3313.             "id": "ajson24",
  3314.             "parent": "ajson1",
  3315.             "text": "calendar.html",
  3316.             "type":"html",
  3317.             "__uiNodeId":24
  3318.         },
  3319.         {
  3320.             "id": "ajson25",
  3321.             "parent": "ajson1",
  3322.             "text": "contacts.html",
  3323.             "type":"html",
  3324.             "__uiNodeId":25
  3325.         },
  3326.         {
  3327.             "id": "ajson26",
  3328.             "parent": "ajson1",
  3329.             "text": "css_animation.html",
  3330.             "type":"html",
  3331.             "__uiNodeId":26
  3332.         },
  3333.         {
  3334.             "id": "ajson27",
  3335.             "parent": "ajson1",
  3336.             "text": "flot_chart.html",
  3337.             "type":"html",
  3338.             "__uiNodeId":27
  3339.         },
  3340.         {
  3341.             "id": "ajson28",
  3342.             "parent": "ajson1",
  3343.             "text": "google_maps.html",
  3344.             "type":"html",
  3345.             "__uiNodeId":28
  3346.         },
  3347.         {
  3348.             "id": "ajson29",
  3349.             "parent": "ajson1",
  3350.             "text": "icons.html",
  3351.             "type":"html",
  3352.             "__uiNodeId":29
  3353.         },
  3354.         {
  3355.             "id": "ajson30",
  3356.             "parent": "ajson1",
  3357.             "text": "invoice.html",
  3358.             "type":"html",
  3359.             "__uiNodeId":30
  3360.         },
  3361.         {
  3362.             "id": "ajson31",
  3363.             "parent": "ajson1",
  3364.             "text": "login.html",
  3365.             "type":"html",
  3366.             "__uiNodeId":31
  3367.         }
  3368.     ]
  3369.  
  3370. }
  3371.  
  3372. function datamapsCtrl($scope) {
  3373.  
  3374.     $scope.mapObject1 = {
  3375.         scope: 'world',
  3376.         responsive: true,
  3377.         fills: {
  3378.             defaultFill: "#DBDAD6"
  3379.         },
  3380.         geographyConfig: {
  3381.             highlightFillColor: '#1C977A',
  3382.             highlightBorderWidth: 0,
  3383.         },
  3384.     }
  3385.  
  3386.     $scope.mapObject2 = {
  3387.         scope: 'world',
  3388.         responsive: true,
  3389.         fills: {
  3390.             defaultFill: "#DBDAD6",
  3391.             active: "#2BA587"
  3392.         },
  3393.         geographyConfig: {
  3394.             highlightFillColor: '#1C977A',
  3395.             highlightBorderWidth: 0,
  3396.         },
  3397.         data: {
  3398.             USA: { fillKey: "active" },
  3399.             RUS: { fillKey: "active" },
  3400.             DEU: { fillKey: "active" },
  3401.             BRA: { fillKey: "active" }
  3402.         }
  3403.     }
  3404.  
  3405.     $scope.mapObject3 = {
  3406.         responsive: true,
  3407.         scope: 'usa',
  3408.         fills: {
  3409.             defaultFill: "#DBDAD6",
  3410.             active: "#2BA587"
  3411.         },
  3412.         geographyConfig: {
  3413.             highlightFillColor: '#1C977A',
  3414.             highlightBorderWidth: 0
  3415.         },
  3416.         data: {
  3417.             NE: { fillKey: "active" },
  3418.             CA: { fillKey: "active" },
  3419.             NY: { fillKey: "active" },
  3420.         }
  3421.     }
  3422.  
  3423.     $scope.mapObject4 = {
  3424.         scope: 'world',
  3425.         responsive: true,
  3426.         fills: {
  3427.             defaultFill: "#F2F2F0",
  3428.             active: "#DBDAD6",
  3429.             usa: "#269479"
  3430.         },
  3431.         geographyConfig: {
  3432.             highlightFillColor: '#1C977A',
  3433.             highlightBorderWidth: 0
  3434.         },
  3435.         data: {
  3436.             USA: {fillKey: "usa"},
  3437.             RUS: {fillKey: "active"},
  3438.             DEU: {fillKey: "active"},
  3439.             POL: {fillKey: "active"},
  3440.             JAP: {fillKey: "active"},
  3441.             AUS: {fillKey: "active"},
  3442.             BRA: {fillKey: "active"}
  3443.         }
  3444.     };
  3445.  
  3446.     $scope.mapPlugins = {
  3447.         arc: {}
  3448.     };
  3449.  
  3450.     $scope.mapPluginData = {
  3451.         arc: [
  3452.             { origin: 'USA', destination: 'RUS'},
  3453.             { origin: 'USA', destination: 'DEU'},
  3454.             { origin: 'USA', destination: 'POL'},
  3455.             { origin: 'USA', destination: 'JAP'},
  3456.             { origin: 'USA', destination: 'AUS'},
  3457.             { origin: 'USA', destination: 'BRA'}
  3458.         ]
  3459.     }
  3460.  
  3461.  
  3462.  
  3463. }
  3464.  
  3465. function pdfCtrl($scope) {
  3466.     $scope.pdfUrl = './pdf/example.pdf';
  3467.     $scope.httpHeaders = { Authorization: 'Bearer some-aleatory-token' };
  3468. }
  3469.  
  3470. /**
  3471.  *
  3472.  * Pass all functions into module
  3473.  */
  3474. angular
  3475.     .module('inspinia')
  3476.     .controller('MainCtrl', MainCtrl)
  3477.     .controller('dashboardFlotOne', dashboardFlotOne)
  3478.     .controller('dashboardFlotTwo', dashboardFlotTwo)
  3479.     .controller('dashboardFive', dashboardFive)
  3480.     .controller('dashboardMap', dashboardMap)
  3481.     .controller('flotChartCtrl', flotChartCtrl)
  3482.     .controller('rickshawChartCtrl', rickshawChartCtrl)
  3483.     .controller('sparklineChartCtrl', sparklineChartCtrl)
  3484.     .controller('widgetFlotChart', widgetFlotChart)
  3485.     .controller('modalDemoCtrl', modalDemoCtrl)
  3486.     .controller('ionSlider', ionSlider)
  3487.     .controller('wizardCtrl', wizardCtrl)
  3488.     .controller('CalendarCtrl', CalendarCtrl)
  3489.     .controller('chartJsCtrl', chartJsCtrl)
  3490.     .controller('GoogleMaps', GoogleMaps)
  3491.     .controller('ngGridCtrl', ngGridCtrl)
  3492.     .controller('codeEditorCtrl', codeEditorCtrl)
  3493.     .controller('nestableCtrl', nestableCtrl)
  3494.     .controller('notifyCtrl', notifyCtrl)
  3495.     .controller('translateCtrl', translateCtrl)
  3496.     .controller('imageCrop', imageCrop)
  3497.     .controller('diff', diff)
  3498.     .controller('idleTimer', idleTimer)
  3499.     .controller('liveFavicon', liveFavicon)
  3500.     .controller('formValidation', formValidation)
  3501.     .controller('agileBoard', agileBoard)
  3502.     .controller('draggablePanels', draggablePanels)
  3503.     .controller('chartistCtrl', chartistCtrl)
  3504.     .controller('metricsCtrl', metricsCtrl)
  3505.     .controller('sweetAlertCtrl', sweetAlertCtrl)
  3506.     .controller('selectCtrl', selectCtrl)
  3507.     .controller('toastrCtrl', toastrCtrl)
  3508.     .controller('loadingCtrl', loadingCtrl)
  3509.     .controller('datatablesCtrl', datatablesCtrl)
  3510.     .controller('truncateCtrl', truncateCtrl)
  3511.     .controller('touchspinCtrl', touchspinCtrl)
  3512.     .controller('tourCtrl', tourCtrl)
  3513.     .controller('jstreeCtrl', jstreeCtrl)
  3514.     .controller('datamapsCtrl', datamapsCtrl)
  3515.     .controller('pdfCtrl', pdfCtrl);
Add Comment
Please, Sign In to add comment