406 lines
14 KiB
HTML
406 lines
14 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8">
|
|
<title>Notifications\notifications.js</title>
|
|
<link rel="stylesheet" href="http://yui.yahooapis.com/3.9.1/build/cssgrids/cssgrids-min.css">
|
|
<link rel="stylesheet" href="../assets/vendor/prettify/prettify-min.css">
|
|
<link rel="stylesheet" href="../assets/css/main.css" id="site_styles">
|
|
<link rel="shortcut icon" type="image/png" href="../assets/favicon.png">
|
|
<script src="http://yui.yahooapis.com/combo?3.9.1/build/yui/yui-min.js"></script>
|
|
</head>
|
|
<body class="yui3-skin-sam">
|
|
|
|
<div id="doc">
|
|
<div id="hd" class="yui3-g header">
|
|
<div class="yui3-u-3-4">
|
|
|
|
<h1><img src="../assets/css/logo.png" title=""></h1>
|
|
|
|
</div>
|
|
<div class="yui3-u-1-4 version">
|
|
<em>API Docs for: </em>
|
|
</div>
|
|
</div>
|
|
<div id="bd" class="yui3-g">
|
|
|
|
<div class="yui3-u-1-4">
|
|
<div id="docs-sidebar" class="sidebar apidocs">
|
|
<div id="api-list">
|
|
<h2 class="off-left">APIs</h2>
|
|
<div id="api-tabview" class="tabview">
|
|
<ul class="tabs">
|
|
<li><a href="#api-classes">Classes</a></li>
|
|
<li><a href="#api-modules">Modules</a></li>
|
|
</ul>
|
|
|
|
<div id="api-tabview-filter">
|
|
<input type="search" id="api-filter" placeholder="Type to filter APIs">
|
|
</div>
|
|
|
|
<div id="api-tabview-panel">
|
|
<ul id="api-classes" class="apis classes">
|
|
|
|
<li><a href="../classes/CallFeedbackRating.html">CallFeedbackRating</a></li>
|
|
|
|
<li><a href="../classes/CloseTicketReport.html">CloseTicketReport</a></li>
|
|
|
|
<li><a href="../classes/ConsolidatedReport.html">ConsolidatedReport</a></li>
|
|
|
|
<li><a href="../classes/CustomerReport.html">CustomerReport</a></li>
|
|
|
|
<li><a href="../classes/DealerWiseCallDetails.html">DealerWiseCallDetails</a></li>
|
|
|
|
<li><a href="../classes/DeclinedCalls.html">DeclinedCalls</a></li>
|
|
|
|
<li><a href="../classes/DropDownData.html">DropDownData</a></li>
|
|
|
|
<li><a href="../classes/EicherPromise.html">EicherPromise</a></li>
|
|
|
|
<li><a href="../classes/EosCallCount.html">EosCallCount</a></li>
|
|
|
|
<li><a href="../classes/GeoAnalysis.html">GeoAnalysis</a></li>
|
|
|
|
<li><a href="../classes/HdBusLmdContrCallFeedbackRatingibution.html">HdBusLmdContrCallFeedbackRatingibution</a></li>
|
|
|
|
<li><a href="../classes/HdBusLmdContribution.html">HdBusLmdContribution</a></li>
|
|
|
|
<li><a href="../classes/HistoryTracking.html">HistoryTracking</a></li>
|
|
|
|
<li><a href="../classes/LiveTracking.html">LiveTracking</a></li>
|
|
|
|
<li><a href="../classes/ManageEscalation.html">ManageEscalation</a></li>
|
|
|
|
<li><a href="../classes/ManageFleet.html">ManageFleet</a></li>
|
|
|
|
<li><a href="../classes/ManageFleet_Detail.html">ManageFleet_Detail</a></li>
|
|
|
|
<li><a href="../classes/ManageFleet_details.html">ManageFleet_details</a></li>
|
|
|
|
<li><a href="../classes/ManageOwner.html">ManageOwner</a></li>
|
|
|
|
<li><a href="../classes/ManageReason.html">ManageReason</a></li>
|
|
|
|
<li><a href="../classes/ManageVechile.html">ManageVechile</a></li>
|
|
|
|
<li><a href="../classes/ManageVehicle.html">ManageVehicle</a></li>
|
|
|
|
<li><a href="../classes/NonVecvUserManagement.html">NonVecvUserManagement</a></li>
|
|
|
|
<li><a href="../classes/Notifications.html">Notifications</a></li>
|
|
|
|
<li><a href="../classes/OpenTicketReport.html">OpenTicketReport</a></li>
|
|
|
|
<li><a href="../classes/OrganizationChart.html">OrganizationChart</a></li>
|
|
|
|
<li><a href="../classes/PositioningTool.html">PositioningTool</a></li>
|
|
|
|
<li><a href="../classes/PositioningTool_Report.html">PositioningTool_Report</a></li>
|
|
|
|
<li><a href="../classes/ReasonForClosure.html">ReasonForClosure</a></li>
|
|
|
|
<li><a href="../classes/Report.html">Report</a></li>
|
|
|
|
<li><a href="../classes/ShowDealerMap.html">ShowDealerMap</a></li>
|
|
|
|
<li><a href="../classes/TicketAdministration.html">TicketAdministration</a></li>
|
|
|
|
<li><a href="../classes/TicketAdministration_FullDetail.html">TicketAdministration_FullDetail</a></li>
|
|
|
|
<li><a href="../classes/TicketFeedback.html">TicketFeedback</a></li>
|
|
|
|
<li><a href="../classes/TicketForDealer.html">TicketForDealer</a></li>
|
|
|
|
<li><a href="../classes/TicketForDealer_FullDetails.html">TicketForDealer_FullDetails</a></li>
|
|
|
|
<li><a href="../classes/TicketReassign.html">TicketReassign</a></li>
|
|
|
|
<li><a href="../classes/TileDashboard.html">TileDashboard</a></li>
|
|
|
|
<li><a href="../classes/TimeSlotClosure.html">TimeSlotClosure</a></li>
|
|
|
|
<li><a href="../classes/TollFreeAndOpportunityLoss.html">TollFreeAndOpportunityLoss</a></li>
|
|
|
|
<li><a href="../classes/VanCoverageDesigner.html">VanCoverageDesigner</a></li>
|
|
|
|
<li><a href="../classes/VecvUserManagement.html">VecvUserManagement</a></li>
|
|
|
|
</ul>
|
|
|
|
<ul id="api-modules" class="apis modules">
|
|
|
|
<li><a href="../modules/Dashboard.html">Dashboard</a></li>
|
|
|
|
<li><a href="../modules/DropDownData.html">DropDownData</a></li>
|
|
|
|
<li><a href="../modules/Geo.html">Geo</a></li>
|
|
|
|
<li><a href="../modules/Inventory.html">Inventory</a></li>
|
|
|
|
<li><a href="../modules/Notifications.html">Notifications</a></li>
|
|
|
|
<li><a href="../modules/ReportModule.html">ReportModule</a></li>
|
|
|
|
<li><a href="../modules/Ticket.html">Ticket</a></li>
|
|
|
|
<li><a href="../modules/TrackingModule.html">TrackingModule</a></li>
|
|
|
|
<li><a href="../modules/UserManagement.html">UserManagement</a></li>
|
|
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
<div class="yui3-u-3-4">
|
|
<div id="api-options">
|
|
Show:
|
|
<label for="api-show-inherited">
|
|
<input type="checkbox" id="api-show-inherited" checked>
|
|
Inherited
|
|
</label>
|
|
|
|
<label for="api-show-protected">
|
|
<input type="checkbox" id="api-show-protected">
|
|
Protected
|
|
</label>
|
|
|
|
<label for="api-show-private">
|
|
<input type="checkbox" id="api-show-private">
|
|
Private
|
|
</label>
|
|
<label for="api-show-deprecated">
|
|
<input type="checkbox" id="api-show-deprecated">
|
|
Deprecated
|
|
</label>
|
|
|
|
</div>
|
|
|
|
|
|
<div class="apidocs">
|
|
<div id="docs-main">
|
|
<div class="content">
|
|
<h1 class="file-heading">File: Notifications\notifications.js</h1>
|
|
|
|
<div class="file">
|
|
<pre class="code prettyprint linenums">
|
|
/*================================================================================================================\
|
|
+
|
|
+ Project : GoData-VECV
|
|
+ Filename : notifications.js
|
|
+ Module Name : Notifications
|
|
+ Purpose : For display notifications
|
|
+ Coded By : Parul Gupta
|
|
+
|
|
+================================================================================================================*/
|
|
|
|
/**
|
|
* To display notifications
|
|
* @module Notifications
|
|
*/
|
|
|
|
|
|
/**
|
|
* This class contains functionality of Notfications for CCE & Dealer.
|
|
* @class Notifications
|
|
* @constructor
|
|
*/
|
|
|
|
|
|
//Global variables
|
|
var previousCount = "";
|
|
var newCount = "";
|
|
var xhr_getNotificationCount;
|
|
|
|
/**
|
|
* Function to bind all notifications data in drop down
|
|
* @method getNotifications
|
|
* @param {String} controller The name of controller action
|
|
* @for Notifications
|
|
*/
|
|
function getNotifications(controller) {
|
|
//console.log(controller);
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "/Notifications/" + controller + "/",
|
|
success: function (data) {
|
|
$("#divNotifications").html('');
|
|
$("#divNotifications").html(data);
|
|
},
|
|
error: function (data) {
|
|
console.log(data);
|
|
}
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Function to get notifications total count in drop down
|
|
* @method getNotificationCount
|
|
* @param {String} controller The name of controller action
|
|
* @for Notifications
|
|
*/
|
|
function getNotificationCount(controller) {
|
|
//console.log(controller);
|
|
previousCount = $("#spanCount").text();
|
|
//console.log(previousCount);
|
|
var notificationCount;
|
|
|
|
if (xhr_getNotificationCount && xhr_getNotificationCount.readystate != 4) {
|
|
console.log(xhr_getNotificationCount);
|
|
xhr_getNotificationCount.abort();
|
|
}
|
|
xhr_getNotificationCount = $.ajax({
|
|
type: "POST",
|
|
url: "/Notifications/" + controller + "/",
|
|
success: function (data) {
|
|
//console.log(data);
|
|
if (data.success == true) {
|
|
if (data.total > 0) {
|
|
notificationCount = data.total;
|
|
$("#spanCount").text(notificationCount);
|
|
$("#divNotificationCount").show();
|
|
} else if (data.total == 0) {
|
|
notificationCount = data.total;
|
|
$("#spanCount").text(notificationCount);
|
|
$("#divNotificationCount").hide();
|
|
}
|
|
}
|
|
},
|
|
global: false,
|
|
error: function (data) {
|
|
console.log(data);
|
|
}
|
|
});
|
|
}
|
|
|
|
|
|
/**
|
|
* Function to display notifications.
|
|
* @method displayNotifications
|
|
* @for Notifications
|
|
*/
|
|
function displayNotifications() {
|
|
|
|
//function call on click of div
|
|
$("#divShowNotification").click(function (e) {
|
|
|
|
//add and remove hide, show class
|
|
if ($("#divNotifications").hasClass('hide')) {
|
|
if (document.getElementById('toggleDiv').style.display == "none") {
|
|
$("#divNotifications").show();
|
|
$("#divNotifications").removeClass('hide');
|
|
} else {
|
|
$("#toggleDiv").hide();
|
|
$("#divNotifications").show();
|
|
$("#divNotifications").removeClass('hide');
|
|
}
|
|
getNotifications(controller);
|
|
|
|
//hide on mouse click anywhere on page if it displays notifications div
|
|
e.stopPropagation();
|
|
|
|
} else {
|
|
$("#divNotifications").hide();
|
|
$("#divNotifications").addClass('hide');
|
|
e.stopPropagation();
|
|
}
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Function to display notification count.
|
|
* @method showNotificationCount
|
|
* @for Notifications
|
|
*/
|
|
function showNotificationCount() {
|
|
|
|
getNotificationCount(countController);
|
|
|
|
var audioElement = document.createElement('audio');
|
|
audioElement.setAttribute('src', '../../Content/css/FacebookPop.mp3');
|
|
audioElement.pause();
|
|
|
|
setTimeout(function () {
|
|
newCount = $("#spanCount").text();
|
|
if (newCount == "") {
|
|
newCount = "0";
|
|
}
|
|
if (previousCount == "") {
|
|
previousCount = "0";
|
|
}
|
|
if (newCount > previousCount) {
|
|
audioElement.play();
|
|
}
|
|
}, 1000 * 2);
|
|
}
|
|
|
|
|
|
/**
|
|
* Function to display notifications on dealer page and remove seen notification from notification div.
|
|
* @method showDealerNotificationData
|
|
* @for Notifications
|
|
*/
|
|
function showDealerNotificationData($this) {
|
|
var ticketid = $this.id;
|
|
var assignedTo = document.getElementById(ticketid).getAttribute('data-assignedTo');
|
|
var notificationId = document.getElementById(ticketid).getAttribute('data-Id');
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "/Notifications/RemoveSeenNotificationsDealer/",
|
|
data: { ticketId: notificationId },
|
|
success: function (data) {
|
|
if (data.success == true) {
|
|
window.location.href = "/TicketAdministration_Dealer/Index?complaintNo=" + ticketid + "&assignedTo=" + assignedTo;
|
|
}
|
|
},
|
|
error: function (data) {
|
|
console.log(data);
|
|
}
|
|
});
|
|
}
|
|
|
|
|
|
/**
|
|
* Function to display notifications on cce page and remove seen notification from notification div.
|
|
* @method showNotificationData
|
|
* @for Notifications
|
|
*/
|
|
function showNotificationData($this) {
|
|
var ticketid = $this.id;
|
|
var notificationId = document.getElementById(ticketid).getAttribute('data-Id');
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "/Notifications/RemoveSeenNotifications/",
|
|
data: { ticketId: notificationId },
|
|
success: function (data) {
|
|
if (data.success == true) {
|
|
window.location.href = "/Ticket/TicketAdministration?complaintNo=" + ticketid;
|
|
}
|
|
},
|
|
error: function (data) {
|
|
console.log(data);
|
|
}
|
|
});
|
|
}
|
|
</pre>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<script src="../assets/vendor/prettify/prettify-min.js"></script>
|
|
<script>prettyPrint();</script>
|
|
<script src="../assets/js/yui-prettify.js"></script>
|
|
<script src="../assets/../api.js"></script>
|
|
<script src="../assets/js/api-filter.js"></script>
|
|
<script src="../assets/js/api-list.js"></script>
|
|
<script src="../assets/js/api-search.js"></script>
|
|
<script src="../assets/js/apidocs.js"></script>
|
|
</body>
|
|
</html>
|