| |
| /* |
| * Copyright 2017-present Open Networking Foundation |
| |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| |
| (function () { |
| 'use strict'; |
| |
| angular.module('xos.dashboardManager') |
| .directive('dashboardForm', function(){ |
| return { |
| restrict: 'E', |
| scope: {}, |
| bindToController: true, |
| controllerAs: 'vm', |
| templateUrl: 'templates/dashboard-form.tpl.html', |
| controller: function($stateParams, $log, Dashboards){ |
| |
| this.dashboard = { |
| enabled: true |
| }; |
| |
| if($stateParams.id){ |
| Dashboards.get({id: $stateParams.id}).$promise |
| .then(dash => { |
| this.dashboard = dash; |
| }) |
| .catch(e => { |
| console.log(e); |
| }) |
| } |
| |
| this.formConfig = { |
| exclude: [ |
| 'backend_register', |
| 'controllers', |
| 'deployments', |
| 'enacted', |
| 'humanReadableName', |
| 'lazy_blocked', |
| 'no_policy', |
| 'no_sync', |
| 'policed', |
| 'write_protect', |
| 'icon', |
| 'icon_active' |
| ], |
| actions: [ |
| { |
| label: 'Save', |
| icon: 'ok', |
| cb: (item,form) => { |
| |
| if (!form.$valid){ |
| return; |
| } |
| if(item.name && item.url && item.custom_icon){ |
| var indexOfXos = item.url.indexOf('xos'); |
| if (indexOfXos>=0){ |
| var dashboard_name = item.url.slice(indexOfXos+3,item.url.length).toLowerCase(); |
| item.icon =dashboard_name.concat('-icon.png'); |
| item.icon_active =dashboard_name.concat('-icon-active.png'); |
| } |
| else{ |
| item.icon ='default-icon.png'; |
| item.icon_active ='default-icon-active.png'; |
| } |
| } |
| else{ |
| item.icon ='default-icon.png'; |
| item.icon_active ='default-icon-active.png'; |
| } |
| this.createOrUpdateDashboard(item); |
| }, |
| class: 'success' |
| }, |
| { |
| label: 'Esport to TOSCA', |
| icon: 'export', |
| cb: (item) => { |
| this.toTosca(item); |
| }, |
| class: 'primary' |
| } |
| ], |
| formName: 'dashboardForm', |
| feedback: { |
| show: false, |
| message: 'Form submitted successfully !!!', |
| type: 'success' |
| }, |
| fields: { |
| name: { |
| type: 'string', |
| validators: { |
| required: true |
| } |
| }, |
| url: { |
| type: 'string', |
| validators: { |
| required: true |
| } |
| }, |
| enabled: { |
| type: 'boolean' |
| }, |
| custom_icon: { |
| type: 'boolean' |
| } |
| } |
| }; |
| |
| this.createOrUpdateDashboard = dashboard => { |
| let p; |
| if(dashboard.id){ |
| delete dashboard.controllers; |
| delete dashboard.deployments; |
| p = dashboard.$save(); |
| } |
| else{ |
| p = Dashboards.save(dashboard).$promise; |
| } |
| |
| p.then(res => { |
| this.formConfig.feedback.show = true; |
| }) |
| .catch(e => { |
| $log.info(e); |
| this.formConfig.feedback.show = true; |
| this.formConfig.feedback.message = e; |
| this.formConfig.feedback.type='danger'; |
| }) |
| }; |
| |
| this.toTosca = dashboard => { |
| const yaml = {} |
| yaml[dashboard.name] = { |
| type: 'tosca.nodes.DashboardView', |
| properties: { |
| url: dashboard.url |
| } |
| }; |
| this.tosca = jsyaml.dump(yaml).replace(/'/g, ''); |
| |
| const yamlRequirements = { |
| requirements: [] |
| }; |
| const dashboardRequirements = {}; |
| dashboardRequirements[`${dashboard.name.toLowerCase()}_dashboard`] = { |
| node: dashboard.name, |
| relationship: 'tosca.relationships.UsesDashboard' |
| } |
| yamlRequirements.requirements.push(dashboardRequirements); |
| this.toscaRequirements = jsyaml.dump(yamlRequirements).replace(/'/g, ''); |
| }; |
| } |
| } |
| }); |
| })(); |