summaryrefslogtreecommitdiffstats
path: root/cvp/3rd_party/static/testapi-ui/shared
diff options
context:
space:
mode:
authorgrakiss <grakiss.wanglei@huawei.com>2017-09-28 03:47:54 -0400
committergrakiss <grakiss.wanglei@huawei.com>2017-09-28 05:15:01 -0400
commit0cf6b232ac9cf128ee9183a27c08f4f74ab2e2e6 (patch)
tree7be233b8f8f65fa968c7b93f1d1e75b691952ed9 /cvp/3rd_party/static/testapi-ui/shared
parent63c2e2aa4b8d86349a767f611123ceafc19fa6d6 (diff)
add api&web services for cvp
JIRA: DOVETAIL-512 add api&web services for cvp Change-Id: I9ef9525e980fe61dc3108035ef9a3ff8783b2697 Signed-off-by: grakiss <grakiss.wanglei@huawei.com>
Diffstat (limited to 'cvp/3rd_party/static/testapi-ui/shared')
-rw-r--r--cvp/3rd_party/static/testapi-ui/shared/alerts/alertModal.html8
-rw-r--r--cvp/3rd_party/static/testapi-ui/shared/alerts/alertModalFactory.js74
-rw-r--r--cvp/3rd_party/static/testapi-ui/shared/alerts/confirmModal.html13
-rw-r--r--cvp/3rd_party/static/testapi-ui/shared/alerts/confirmModalFactory.js67
-rw-r--r--cvp/3rd_party/static/testapi-ui/shared/filters.js100
-rw-r--r--cvp/3rd_party/static/testapi-ui/shared/footer/footer.html3
-rw-r--r--cvp/3rd_party/static/testapi-ui/shared/header/header.html59
-rw-r--r--cvp/3rd_party/static/testapi-ui/shared/header/headerController.js63
8 files changed, 387 insertions, 0 deletions
diff --git a/cvp/3rd_party/static/testapi-ui/shared/alerts/alertModal.html b/cvp/3rd_party/static/testapi-ui/shared/alerts/alertModal.html
new file mode 100644
index 00000000..59fd5001
--- /dev/null
+++ b/cvp/3rd_party/static/testapi-ui/shared/alerts/alertModal.html
@@ -0,0 +1,8 @@
+<div class="modal-body" style="padding:0px">
+ <div class="alert alert-{{alert.data.mode}}" style="margin-bottom:0px">
+ <button type="button" class="close" data-ng-click="alert.close()" >
+ <span class="glyphicon glyphicon-remove-circle"></span>
+ </button>
+ <strong>{{alert.data.title}}</strong> {{alert.data.text}}
+ </div>
+</div>
diff --git a/cvp/3rd_party/static/testapi-ui/shared/alerts/alertModalFactory.js b/cvp/3rd_party/static/testapi-ui/shared/alerts/alertModalFactory.js
new file mode 100644
index 00000000..929f5433
--- /dev/null
+++ b/cvp/3rd_party/static/testapi-ui/shared/alerts/alertModalFactory.js
@@ -0,0 +1,74 @@
+/*
+ * 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('testapiApp')
+ .factory('raiseAlert', raiseAlert);
+
+ raiseAlert.$inject = ['$uibModal'];
+
+ /**
+ * This allows alert pop-ups to be raised. Just inject it as a dependency
+ * in the calling controller.
+ */
+ function raiseAlert($uibModal) {
+ return function(mode, title, text) {
+ $uibModal.open({
+ templateUrl: 'testapi-ui/shared/alerts/alertModal.html',
+ controller: 'RaiseAlertModalController as alert',
+ backdrop: true,
+ keyboard: true,
+ backdropClick: true,
+ size: 'md',
+ resolve: {
+ data: function () {
+ return {
+ mode: mode,
+ title: title,
+ text: text
+ };
+ }
+ }
+ });
+ };
+ }
+
+ angular
+ .module('testapiApp')
+ .controller('RaiseAlertModalController', RaiseAlertModalController);
+
+ RaiseAlertModalController.$inject = ['$uibModalInstance', 'data'];
+
+ /**
+ * This is the controller for the alert pop-up.
+ */
+ function RaiseAlertModalController($uibModalInstance, data) {
+ var ctrl = this;
+
+ ctrl.close = close;
+ ctrl.data = data;
+
+ /**
+ * This method will close the alert modal. The modal will close
+ * when the user clicks the close button or clicks outside of the
+ * modal.
+ */
+ function close() {
+ $uibModalInstance.close();
+ }
+ }
+})();
diff --git a/cvp/3rd_party/static/testapi-ui/shared/alerts/confirmModal.html b/cvp/3rd_party/static/testapi-ui/shared/alerts/confirmModal.html
new file mode 100644
index 00000000..82478a51
--- /dev/null
+++ b/cvp/3rd_party/static/testapi-ui/shared/alerts/confirmModal.html
@@ -0,0 +1,13 @@
+<div class="modal-header"><h3 class="modal-title">Confirm</h3></div>
+<div class="modal-body">
+ <div class="form-group">
+ <label for="confirmText">{{confirmModal.data.text}}:</label>
+ <textarea type="text" class="form-control"
+ rows="5" ng-model="confirmModal.inputText" id="confirmText">
+ </textarea>
+ </div>
+</div>
+<div class="modal-footer">
+ <button class="btn btn-primary" ng-click="confirmModal.confirm()">Ok</button>
+ <button class="btn btn-default" ng-click="confirmModal.cancel()">Cancel</button>
+</div>
diff --git a/cvp/3rd_party/static/testapi-ui/shared/alerts/confirmModalFactory.js b/cvp/3rd_party/static/testapi-ui/shared/alerts/confirmModalFactory.js
new file mode 100644
index 00000000..76c74df9
--- /dev/null
+++ b/cvp/3rd_party/static/testapi-ui/shared/alerts/confirmModalFactory.js
@@ -0,0 +1,67 @@
+(function () {
+ 'use strict';
+
+ angular
+ .module('testapiApp')
+ .factory('confirmModal', confirmModal);
+
+ confirmModal.$inject = ['$uibModal'];
+
+ /**
+ * Opens confirm modal dialog with input textbox
+ */
+ function confirmModal($uibModal) {
+ return function(text, successHandler) {
+ $uibModal.open({
+ templateUrl: '/shared/alerts/confirmModal.html',
+ controller: 'CustomConfirmModalController as confirmModal',
+ size: 'md',
+ resolve: {
+ data: function () {
+ return {
+ text: text,
+ successHandler: successHandler
+ };
+ }
+ }
+ });
+ };
+ }
+
+ angular
+ .module('testapiApp')
+ .controller('CustomConfirmModalController',
+ CustomConfirmModalController);
+
+ CustomConfirmModalController.$inject = ['$uibModalInstance', 'data'];
+
+ /**
+ * This is the controller for the alert pop-up.
+ */
+ function CustomConfirmModalController($uibModalInstance, data) {
+ var ctrl = this;
+
+ ctrl.confirm = confirm;
+ ctrl.cancel = cancel;
+
+ ctrl.data = angular.copy(data);
+
+ /**
+ * Initiate confirmation and call the success handler with the
+ * input text.
+ */
+ function confirm() {
+ $uibModalInstance.close();
+ if (angular.isDefined(ctrl.data.successHandler)) {
+ ctrl.data.successHandler(ctrl.inputText);
+ }
+ }
+
+ /**
+ * Close the confirm modal without initiating changes.
+ */
+ function cancel() {
+ $uibModalInstance.dismiss('cancel');
+ }
+ }
+})();
diff --git a/cvp/3rd_party/static/testapi-ui/shared/filters.js b/cvp/3rd_party/static/testapi-ui/shared/filters.js
new file mode 100644
index 00000000..538c02e9
--- /dev/null
+++ b/cvp/3rd_party/static/testapi-ui/shared/filters.js
@@ -0,0 +1,100 @@
+/*
+ * 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';
+
+ /**
+ * Convert an object of objects to an array of objects to use with ng-repeat
+ * filters.
+ */
+ angular
+ .module('testapiApp')
+ .filter('arrayConverter', arrayConverter);
+
+ /**
+ * Convert an object of objects to an array of objects to use with ng-repeat
+ * filters.
+ */
+ function arrayConverter() {
+ return function (objects) {
+ var array = [];
+ angular.forEach(objects, function (object, key) {
+ if (!('id' in object)) {
+ object.id = key;
+ }
+ array.push(object);
+ });
+ return array;
+ };
+ }
+
+ angular
+ .module('testapiApp')
+ .filter('capitalize', capitalize);
+
+ /**
+ * Angular filter that will capitalize the first letter of a string.
+ */
+ function capitalize() {
+ return function (string) {
+ return string.substring(0, 1).toUpperCase() + string.substring(1);
+ };
+ }
+
+ angular
+ .module('testapiApp')
+ .filter('tagExtractor', tagExtractor);
+
+ function tagExtractor() {
+ return function (string) {
+ return string.substring(13, string.indexOf('dovetail')-1);
+ };
+ }
+
+ angular
+ .module('testapiApp')
+ .filter('checkFlag', checkFlag);
+
+ function checkFlag() {
+ return function (string) {
+ return string == undefined || string == "true";
+ };
+ }
+
+ angular
+ .module('testapiApp')
+ .filter('category', category);
+
+ function category() {
+ return function (string) {
+ if (string == "soft&hard")
+ return "software and hardware";
+ return "software and third party hardware";
+ };
+ }
+
+ angular
+ .module('testapiApp')
+ .filter('labLocation', labLocation);
+
+ function labLocation() {
+ return function (string) {
+ if (string == "internal")
+ return "internal vendor lab";
+ return "third-party lab";
+ };
+ }
+
+})();
diff --git a/cvp/3rd_party/static/testapi-ui/shared/footer/footer.html b/cvp/3rd_party/static/testapi-ui/shared/footer/footer.html
new file mode 100644
index 00000000..c33fe61b
--- /dev/null
+++ b/cvp/3rd_party/static/testapi-ui/shared/footer/footer.html
@@ -0,0 +1,3 @@
+<div>
+<span class="hide">version: web.cvp.0.7.0</span>
+</div>
diff --git a/cvp/3rd_party/static/testapi-ui/shared/header/header.html b/cvp/3rd_party/static/testapi-ui/shared/header/header.html
new file mode 100644
index 00000000..cf6c8af9
--- /dev/null
+++ b/cvp/3rd_party/static/testapi-ui/shared/header/header.html
@@ -0,0 +1,59 @@
+<div class="heading "><a ui-sref="home"></a>
+ <div class="pull-left left">
+ <img src="testapi-ui/assets/img/opnfv-logo.png" alt="OPNFV">
+ </div>
+ <h2 style="padding-top:25px;">Compliance Verification Program</h2>
+</div>
+<nav class="navbar navbar-default" role="navigation" ng-controller="HeaderController as header">
+ <div class="container-fluid">
+ <!-- Brand and toggle get grouped for better mobile display -->
+ <div class="navbar-header">
+ <button type="button" class="navbar-toggle collapsed" ng-click="header.navbarCollapsed = !header.navbarCollapsed">
+ <span class="sr-only">Toggle navigation</span>
+ <span class="icon-bar"></span>
+ <span class="icon-bar"></span>
+ <span class="icon-bar"></span>
+ </button>
+ </div>
+
+ <div class="collapse navbar-collapse" id="navbar" uib-collapse="header.navbarCollapsed">
+ <ul class="nav navbar-nav">
+ <li ng-class="{ active: header.isActive('/')}"><a ui-sref="home">Home</a></li>
+ <!--
+ <li ng-class="{ active: header.isActive('/about')}"><a ui-sref="about">About</a></li>
+ <li ng-class="{ active: header.isActive('/guidelines')}"><a ui-sref="guidelines">OPNFV Ready&#8482; Guidelines</a></li>
+ <li ng-class="{ active: header.isActive('/community_results')}"><a ui-sref="communityResults">Community Results</a></li>
+
+ <li ng-class="{ active: header.isCatalogActive('public')}" class="dropdown" uib-dropdown>
+ <a role="button" class="dropdown-toggle" uib-dropdown-toggle>
+ Catalog <strong class="caret"></strong>
+ </a>
+ <ul class="dropdown-menu">
+ <li><a ui-sref="publicVendors">Vendors</a></li>
+ <li><a ui-sref="publicProducts">Products</a></li>
+ </ul>
+ </li>
+ -->
+ </ul>
+ <ul class="nav navbar-nav navbar-right">
+ <li ng-class="{ active: header.isActive('/application')}" ng-if="auth.isAuthenticated && auth.currentUser.role.indexOf('administrator') != -1"><a ui-sref="application">Applications</a></li>
+ <li ng-class="{ active: header.isActive('/user_results')}" ng-if="auth.isAuthenticated"><a ui-sref="userResults">My Results</a></li>
+ <!--
+ <li ng-if="auth.isAuthenticated" ng-class="{ active: header.isCatalogActive('user')}" class="dropdown" uib-dropdown>
+ <a role="button" class="dropdown-toggle" uib-dropdown-toggle>
+ My Catalog <strong class="caret"></strong>
+ </a>
+ <ul class="dropdown-menu">
+ <li><a ui-sref="userVendors">My Vendors</a></li>
+ <li><a ui-sref="userProducts">My Products</a></li>
+ </ul>
+ </li>
+ -->
+ <li ng-class="{ active: header.isActive('/profile')}" ng-if="auth.isAuthenticated"><a ui-sref="profile">Profile</a></li>
+ <li ng-if="auth.isAuthenticated"><a href="" ng-click="auth.doSignOut()">Sign Out</a></li>
+ <li ng-if="!auth.isAuthenticated"><a href="" ng-click="auth.doSignIn('cas')">Sign In / Sign Up</a></li>
+ </ul>
+ </div>
+ </div>
+</nav>
+
diff --git a/cvp/3rd_party/static/testapi-ui/shared/header/headerController.js b/cvp/3rd_party/static/testapi-ui/shared/header/headerController.js
new file mode 100644
index 00000000..0a14a415
--- /dev/null
+++ b/cvp/3rd_party/static/testapi-ui/shared/header/headerController.js
@@ -0,0 +1,63 @@
+/*
+ * 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('testapiApp')
+ .controller('HeaderController', HeaderController);
+
+ HeaderController.$inject = ['$location'];
+
+ /**
+ * TestAPI Header Controller
+ * This controller is for the header template which contains the site
+ * navigation.
+ */
+ function HeaderController($location) {
+ var ctrl = this;
+
+ ctrl.isActive = isActive;
+ ctrl.isCatalogActive = isCatalogActive;
+
+ /** Whether the Navbar is collapsed for small displays. */
+ ctrl.navbarCollapsed = true;
+
+ /**
+ * This determines whether a button should be in the active state based
+ * on the URL.
+ */
+ function isActive(viewLocation) {
+ var path = $location.path().substr(0, viewLocation.length);
+ if (path === viewLocation) {
+ // Make sure "/" only matches when viewLocation is "/".
+ if (!($location.path().substr(0).length > 1 &&
+ viewLocation.length === 1 )) {
+ return true;
+ }
+ }
+ return false;
+ }
+
+ /** This determines the active state for the catalog dropdown. Type
+ * parameter should be passed in to specify if the catalog is the
+ * public or user one.
+ */
+ function isCatalogActive(type) {
+ return ctrl.isActive('/' + type + '_vendors')
+ || ctrl.isActive('/' + type + '_products');
+ }
+ }
+})();