summaryrefslogtreecommitdiffstats
path: root/afm-client/app/Frontend/widgets/ActionButtons/AppliButton.js
blob: a10030cbf4d333b96cfff8a2e770ec619c24e52f (plain)
1
2
3
4
5
6
7
8

@media only all and (prefers-color-scheme: dark) {
.highlight .hll { background-color: #49483e }
.highlight .c { color: #75715e } /* Comment */
.highlight .err { color: #960050; background-color: #1e0010 } /* Error */
.highlight .k { color: #66d9ef } /* Keyword */
.highlight .l { color: #ae81ff } /* Literal */
.highlight .n { color: #f8f8f2 } /* Name */
.highlight .o { color: #f92672 } /* Operator */
.highlight .p { color: #f8f8f2 } /* Punctuation */
.highlight .ch { color: #75715e } /* Comment.Hashbang */
.highlight .cm { color: #75715e } /* Comment.Multiline */
.highlight .cp { color: #75715e } /* Comment.Preproc */
.highlight .cpf { color: #75715e } /* Comment.PreprocFile */
.highlight .c1 { color: #75715e } /* Comment.Single */
.highlight .cs { color: #75715e } /* Comment.Special */
.highlight .gd { color: #f92672 } /* Generic.Deleted */
.highlight .ge { font-style: italic } /* Generic.Emph */
.highlight .gi { color: #a6e22e } /* Generic.Inserted */
.highlight .gs { font-weight: bold } /* Generic.Strong */
.highlight .gu { color: #75715e } /* Generic.Subheading */
.highlight .kc { color: #66d9ef } /* Keyword.Constant */
.highlight .kd { color: #66d9ef } /* Keyword.Declaration */
.highlight .kn { color: #f92672 } /* Keyword.Namespace */
.highlight .kp { color: #66d9ef } /* Keyword.Pseudo */
.highlight .kr { color: #66d9ef } /* Keyword.Reserved */
.highlight .kt { color: #66d9ef } /* Keyword.Type */
.highlight .ld { color: #e6db74 } /* Literal.Date */
.highlight .m { color: #ae81ff } /* Literal.Number */
.highlight .s { color: #e6db74 } /* Literal.String */
.highlight .na { color: #a6e22e } /* Name.Attribute */
.highlight .nb { color: #f8f8f2 } /* Name.Builtin */
.highlight .nc { color: #a6e22e } /* Name.Class */
.highlight .no { color: #66d9ef } /* Name.Constant */
.highlight .nd { color: #a6e22e } /* Name.Decorator */
.highlight .ni { color: #f8f8f2 } /* Name.Entity */
.highlight .ne { color: #a6e22e } /* Name.Exception */
.highlight .nf { color: #a6e22e } /* Name.Function */
.highlight .nl { color: #f8f8f2 } /* Name.Label */
.highlight .nn { color: #f8f8f2 } /* Name.Namespace */
.highlight .nx { color: #a6e22e } /* Name.Other */
.highlight .py { color: #f8f8f2 } /* Name.Property */
.highlight .nt { color: #f92672 } /* Name.Tag */
.highlight .nv { color: #f8f8f2 } /* Name.Variable */
.highlight .ow { color: #f92672 } /* Operator.Word */
.highlight .w { color: #f8f8f2 } /* Text.Whitespace */
.highlight .mb { color: #ae81ff } /* Literal.Number.Bin */
.highlight .mf { color: #ae81ff } /* Literal.Number.Float */
.highlight .mh { color: #ae81ff } /* Literal.Number.Hex */
.highlight .mi { color: #ae81ff } /* Literal.Number.Integer */
.highlight .mo { color: #ae81ff } /* Literal.Number.Oct */
.highlight .sa { color: #e6db74 } /* Literal.String.Affix */
.highlight .sb { color: #e6db74 } /* Literal.String.Backtick */
.highlight .sc { color: #e6db74 } /* Literal.String.Char */
.highlight .dl { color: #e6db74 } /* Literal.String.Delimiter */
.highlight .sd { color: #e6db74 } /* Literal.String.Doc */
.highlight .s2 { color: #e6db74 } /* Literal.String.Double */
.highlight .se { color: #ae81ff } /* Literal.String.Escape */
.highlight .sh { color: #e6db74 } /* Literal.String.Heredoc */
.highlight .si { color: #e6db74 } /* Literal.String.Interpol */
.highlight .sx { color: #e6db74 } /* Literal.String.Other */
.highlight .sr { color: #e6db74 } /* Literal.String.Regex */
.highlight .s1 { color: #e6db74 } /* Literal.String.Single */
.highlight .ss { color: #e6db74 } /* Literal.String.Symbol */
.highlight .bp { color: #f8f8f2 } /* Name.Builtin.Pseudo */
.highlight .fm { color: #a6e22e } /* Name.Function.Magic */
.highlight .vc { color: #f8f8f2 } /* Name.Variable.Class */
.highlight .vg { color: #f8f8f2 } /* Name.Variable.Global */
.highlight .vi { color: #f8f8f2 } /* Name.Variable.Instance */
.highlight .vm { color: #f8f8f2 } /* Name.Variable.Magic */
.highlight .il { color: #ae81ff } /* Literal.Number.Integer.Long */
}
@media (prefers-color-scheme: light) {
.highlight .hll { background-color: #ffffcc }
.highlight .c { color: #888888 } /* Comment */
.highlight .err { color: #a61717; background-color: #e3d2d2 } /* Error */
.highlight .k { color: #008800; font-weight: bold } /* Keyword */
.highlight .ch { color: #888888 } /* Comment.Hashbang */
.highlight .cm { color: #888888 } /* Comment.Multiline */
.highlight .cp { color: #cc0000; font-weight: bold } /* Comment.Preproc */
.highlight .cpf { color: #888888 } /* Comment.PreprocFile */
.highlight .c1 { color: #888888 } /* Comment.Single */
.highlight .cs { color: #cc0000; font-weight: bold; background-color: #fff0f0 } /* Comment.Special */
.highlight .gd { color: #000000; background-color: #ffdddd } /* Generic.Deleted */
.highlight .ge { font-style: italic } /* Generic.Emph */
.highlight .gr { color: #aa0000 } /* Generic.Error */
.highlight .gh { color: #333333 } /* Generic.Heading */
.highlight .gi { color: #000000; background-color: #ddffdd } /* Generic.Inserted */
.highlight .go { color: #888888 } /* Generic.Output */
.highlight .gp { color: #555555 } /* Generic.Prompt */
.highlight .gs { font-weight: bold } /* Generic.Strong */
.highlight .gu { color: #666666 } /* Generic.Subheading */
.highlight .gt { color: #aa0000 } /* Generic.Traceback */
.highlight .kc { color: #008800; font-weight: bold } /* Keyword.Constant */
.highlight .kd { color: #008800; font-weight: bold } /* Keyword.Declaration */
.highlight .kn { color: #008800; font-weight: bold } /* Keyword.Namespace */
.highlight .kp { color: #008800 } /* Keyword.Pseudo */
.highlight .kr { color: #008800; font-weight: bold } /* Keyword.Reserved */
.highlight .kt { color: #888888; font-weight: bold } /* Keyword.Type */
.highlight .m { color: #0000DD; font-weight: bold } /* Literal.Number */
.highlight .s { color: #dd2200; background-color: #fff0f0 } /* Literal.String */
.highlight .na { color: #336699 } /* Name.Attribute */
.highlight .nb { color: #003388 } /* Name.Builtin */
.highlight .nc { color: #bb0066; font-weight: bold } /* Name.Class */
.highlight .no { color: #003366; font-weight: bold } /* Name.Constant */
.highlight .nd { color: #555555 } /* Name.Decorator */
.highlight .ne { color: #bb0066; font-weight: bold } /* Name.Exception */
.highlight .nf { color: #0066bb; font-weight: bold } /* Name.Function */
.highlight .nl { color: #336699; font-style: italic } /* Name.Label */
.highlight .nn { color: #bb0066; font-weight: bold } /* Name.
/* 
 * Copyright (C) 2015 "IoT.bzh"
 * Author "Fulup Ar Foll"
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 * 
 * Bugs: Input with Callback SHOULD BE get 'required' class
 */

(function () {
    'use strict';

    var tmplAppli = '<div  ng-click="clicked()">' +
            '<img ng-src="{{icon}}">' +
            '<span>{{label}}</span>' +
            '</div>';
    
    var tmplModal = 
            '<b class="close-button" ng-click="close()">×</b>' +
            '<img ng-src="{{icon}}">' +
            '<span class="modal-text">Application <b>{{label}}</b></span>' +
            '<ul class="vertical icon-left primary menu-bar appli-menu-start">' +
            '<li class=start-{{runstatus}}><a ng-click=action("start")><i class="fi-check"> Start</i></a></li>' +
            '<li class=stop-{{runstatus}}><a ng-click=action("stop")><i class="fi-x"> Stop</i></a></li>' +
            '<li><a ng-click=action("info")><i class="fi-info"> Info</i></a></li>' +
            '<li class=start-{{runstatus}}><a ng-click=action("uninstall")><i class="fi-x"> Uninstall</i></a></li>' +
            '</ul>' +
            '';
    
    var tmplDetail = 
            '<b class="close-button" ng-click="close()">×</b>' +
            '<img ng-src="{{icon}}">' +
            '<span class="modal-text">Application <b>{{label}}</b></span>' +
            '<ul class="vertical icon-left appli-menu-info">' +
            '<li><i class="fi-paperclip"> Name : {{detail.name}} </i></li>' +
            '<li><i class="fi-info"> Description {{detail.description}}</i></li>' +
            '<li><i class="fi-torso"> Author : {{detail.author}}</i></li>' +
            '</ul>' +
            '';

    angular.module('AppliButton', [])
            .directive('appliButton', function (AppConfig, AppCall, ModalFactory, Notification, $timeout, $window, $location, urlquery) {

                function mymethods(scope, elem, attrs) {
                    scope.runstatus = "stop";
                    scope.runmode   = urlquery.runmode || "auto";
                    scope.clicked = function () {

                        var notifyError = function(action, jresp) {
                            Notification.error ({message: "Fail /api/afm-main" + action + "=" + scope.label + " RunID="+ scope.appID, delay: 5000});
                            elem.addClass ("fail");
                            elem.removeClass ("success");
                            scope.callback (scope.appID, action, jresp);
                        };
                        
                        var notifySuccess = function (action, jresp) {
                            elem.removeClass ("fail");
                            scope.runID = jresp.response.runid;
                            scope.callback (scope.appID, action, jresp);
                        };
                        
                        var closeModApp = function() {
                            scope.modApp.deactivate();
                            $timeout (function() {scope.modApp.destroy();}, 1000);
                        };
                        
                        var closeModInfo = function() {
                            scope.modInfo.deactivate();
                            $timeout (function() {scope.modInfo.destroy();}, 1000);
                        };
                        
                        var actionModal = function(action) {
                            console.log ("Modal Action=%s", action);
                            switch (action) {
                                
                                case "start":
                                    if (scope.runstatus !== "stop") return;
                                    AppCall.get ("afm-main", "start", {id: scope.appID, mode: scope.runmode}, function(jresp, errcode) {
                                        if (errcode !== 200 || jresp.jtype !== "afb-reply") {
                                            notifyError ("start", jresp);
                                            return;
                                        }
                                        scope.runstatus="start";
                                        notifySuccess (action, jresp);
					if(response.data.response.uri)
                                            scope.winapp= $window.open(response.data.response.uri.replace("%h", $location.host()));                                            
                                    });
                                    break;
                                    
                                case "stop":
                                    if (scope.runstatus !== "start") return;
                                    
                                    AppCall.get ("afm-main", "terminate", {runid: scope.runID}, function(jresp, errcode) {
                                        if (errcode !== 200 || jresp.jtype !== "afb-reply") {
                                            notifyError ("stop", jresp);
                                            return;
                                        }
                                        scope.runstatus="stop";
                                        
                                        // if a remote window app was open let's close it
                                        if (scope.winapp) {
                                           console.log ("Closing Application Window label=%s id=%s", scope.label, scope.appID);
                                           scope.winapp.close();
                                           scope.winapp=false;
                                        }
                                        notifySuccess (action, jresp);
                                    });
                                    break;
                                        
                                case "info":
                                    AppCall.get ("afm-main", "detail", {id: scope.appID}, function(jresp, errcode) {
                                        if (errcode !== 200 || jresp.jtype !== "afb-reply") {
                                            notifyError ("detail", jresp);
                                            return;
                                        }
                                                                               
                                        // reference http://foundation.zurb.com/apps/docs/#!/angular-modules
                                        var config = {
                                            animationIn: 'slideInFromTop',
                                            contentScope: {
                                                close   : closeModInfo,
                                                icon    : scope.icon,
                                                label   : scope.appID,
                                                detail  : response.data.response
                                            }, template : tmplDetail
                                        }; 
                                        // Popup Modal to render application data
                                        scope.modInfo = new ModalFactory(config);
                                        scope.modInfo.activate ();

                                    });
                                    break;

                                case "uninstall":
                                    if (scope.runstatus !== "stop") return;
                                    AppCall.get ("afm-main", "uninstall", {id: scope.appID}, function(jresp, errcode) {
                                        if (errcode !== 200 || jresp.jtype !== "afb-reply") {
                                            notifyError ("uninstall", jresp);
                                            return;
                                        }
                                        
                                        notifySuccess (action, jresp);
                                    });
                                    break;

                                default:
                                    console.log ("ActionModal unknown action=[%s]", action);
                                    break;
                            }
                            
                            closeModApp();
                        };
            
                        // reference http://foundation.zurb.com/apps/docs/#!/angular-modules
                        var config = {
                            animationIn: 'slideInFromTop',
                            contentScope: {
                                action   : actionModal,
                                runstatus: scope.runstatus,
                                close    : closeModApp,
                                icon     : scope.icon,
                                label    : scope.label
                            }, template  : tmplModal
                        }; 
                        // Popup Modal to render application data
                        scope.modApp = new ModalFactory(config);
                        scope.modApp.activate ();
                    };

                    // extract application information from AppID+Store
                    if (attrs.handle && scope.store [attrs.handle].name) {
                        scope.icon  = AppConfig.paths.icons + attrs.handle; //scope.store [attrs.handle].name.toLowerCase() + '-ico.png';
                        scope.label = scope.store [attrs.handle].name;
                        scope.appID= attrs.handle;
                    } else {
                         scope.icon  = AppConfig.paths.icons + 'w3c-ico.png';
                         scope.label = attrs.handle;
                    }
                                
                    // add label as class
                    elem.addClass (scope.label.toLowerCase());
                    
                    // note: clicked in imported and when template is clicked
                    // it will call clicked method passed in param.
                }
                
                return {
                    restrict: 'E',
                    template: tmplAppli,
                    link: mymethods,
                    scope: {callback: '=', store: '='}
                };
            });
})();