diff --git a/web/src/main/webapp/common/services/navbar-vo.service.js b/web/src/main/webapp/common/services/navbar-vo.service.js
index 2ec83d8b9465..8c36a803612a 100644
--- a/web/src/main/webapp/common/services/navbar-vo.service.js
+++ b/web/src/main/webapp/common/services/navbar-vo.service.js
@@ -205,6 +205,9 @@
self._nQueryStartTime = self._nQueryEndTime - self._nQueryPeriod;
return self;
};
+ this.getPartialURL = function( bAddApplication, bAddFilter) {
+ return (bAddApplication ? self.getApplication() + "/" : "" ) + self.getReadablePeriod() + "/" + self.getQueryEndDateTime() + ( bAddFilter ? ( self.getFilter() ? "/" + self.getFilter() : "" ) : "" );
+ }
};
}]);
})();
\ No newline at end of file
diff --git a/web/src/main/webapp/common/services/server-map-dao.service.js b/web/src/main/webapp/common/services/server-map-dao.service.js
index 5d8792ccb5e9..adafd0e6f629 100644
--- a/web/src/main/webapp/common/services/server-map-dao.service.js
+++ b/web/src/main/webapp/common/services/server-map-dao.service.js
@@ -73,7 +73,8 @@
filter: query.filter,
limit: cfg.FILTER_FETCH_LIMIT,
callerRange: query.callerRange,
- calleeRange: query.calleeRange
+ calleeRange: query.calleeRange,
+ v: 3
};
if ( isNaN( parseInt( query.serviceTypeName ) ) ) {
data.serviceTypeName = query.serviceTypeName;
diff --git a/web/src/main/webapp/common/services/tooltip.service.js b/web/src/main/webapp/common/services/tooltip.service.js
index 526fca19e9f0..3d73d1cb9e1d 100644
--- a/web/src/main/webapp/common/services/tooltip.service.js
+++ b/web/src/main/webapp/common/services/tooltip.service.js
@@ -9,6 +9,10 @@
* @class
*/
pinpointApp.constant('TooltipServiceConfig', {
+ "scatter": {
+ "position": "bottom",
+ "trigger": "click"
+ },
"navbar": {
"position": "bottom",
"trigger": "click"
@@ -47,6 +51,8 @@
function getTooltipStr( type ) {
switch( type ) {
+ case "scatter":
+ return function() { return helpContentTemplate(helpContentService.scatter["default"]); };
case "navbar":
return function() { return helpContentTemplate(helpContentService.navbar.applicationSelector) + helpContentTemplate(helpContentService.navbar.depth) + helpContentTemplate(helpContentService.navbar.periodSelector); };
case "agentList":
@@ -61,6 +67,5 @@
return function() { return helpContentTemplate(helpContentService.inspector.tps); };
}
}
-
}]);
})(jQuery);
\ No newline at end of file
diff --git a/web/src/main/webapp/features/navbar/navbar.directive.js b/web/src/main/webapp/features/navbar/navbar.directive.js
index 103cdc7a033c..52121253c3aa 100644
--- a/web/src/main/webapp/features/navbar/navbar.directive.js
+++ b/web/src/main/webapp/features/navbar/navbar.directive.js
@@ -610,17 +610,19 @@
bIsClickDepthInnerArea = false;
bIsClickDepthInnerBtn = true;
$("#navbar_depth .dropdown-menu").trigger("click.bs.dropdown");
- if ( prevCaller !== scope.caller || prevCallee !== scope.callee ) {
- prevCaller = scope.caller;
+ console.log( "previous :", prevCallee, prevCaller, ", current :", scope.callee, scope.caller );
+ if ( prevCallee !== scope.callee || prevCaller !== scope.caller ) {
prevCallee = scope.callee;
- setDepthToStorage(scope.application + "+caller", scope.caller);
+ prevCaller = scope.caller;
setDepthToStorage(scope.application + "+callee", scope.callee);
+ setDepthToStorage(scope.application + "+caller", scope.caller);
+
broadcast();
}
};
scope.cancelDepth = function( bHide ) {
- scope.caller = prevCaller;
scope.callee = prevCallee;
+ scope.caller = prevCaller;
if ( bHide ) {
bIsClickDepthInnerArea = false;
bIsClickDepthInnerBtn = true;
diff --git a/web/src/main/webapp/features/responseTimeChart/response-time-chart.directive.js b/web/src/main/webapp/features/responseTimeChart/response-time-chart.directive.js
index 7ce9f641cf8d..c3521ee78f73 100644
--- a/web/src/main/webapp/features/responseTimeChart/response-time-chart.directive.js
+++ b/web/src/main/webapp/features/responseTimeChart/response-time-chart.directive.js
@@ -100,7 +100,7 @@
oChart.addListener('clickGraphItem', function(event) {
analyticsService.send(analyticsService.CONST.MAIN, analyticsService.CONST.CLK_RESPONSE_GRAPH);
if ( event.item.category == "Error" ) {
- scope.$emit('responseTimeChartDirective.errorClicked' );
+ scope.$emit('responseTimeChartDirective.showErrorTransacitonList' );
}
if ( useFilterTransaction ) {
scope.$emit('responseTimeChartDirective.itemClicked.' + scope.namespace, event.item.serialDataItem.dataContext);
diff --git a/web/src/main/webapp/features/scatter/jquery.BigScatterChart.js b/web/src/main/webapp/features/scatter/jquery.BigScatterChart.js
index 87ed92adb04b..530719cc89b3 100644
--- a/web/src/main/webapp/features/scatter/jquery.BigScatterChart.js
+++ b/web/src/main/webapp/features/scatter/jquery.BigScatterChart.js
@@ -16,83 +16,84 @@ var BigScatterChart = $.Class({
* @param {Object} option option object
* @param {Service} helpContentService angularjs service object
*/
- $init: function (htOption, helpContentTemplate, helpContentService, webStorage, analyticsService) {
+ $init: function (htOption, aAgentList, tooltipService, webStorage, analyticsService) {
+ this._consts = {
+ "ALL": "All"
+ };
this.analyticsService = analyticsService;
+ this._aAgentList = aAgentList;
this.option({
- 'sContainerId': '',
- 'sPrefix': 'bigscatterchart-',
- 'nWidth': 600,
- 'nHeight': 400,
- 'nXMin': 0, 'nXMax': 100,
- 'nYMin': 0, 'nYMax': 100,
- 'nZMin': 0, 'nZMax': 1,
- 'nXSteps': 5,
- 'nYSteps': 5,
- 'nXLabel': null,
- 'nYLabel': null,
- 'nBubbleSize': 10,
- 'nPaddingTop': 40,
- 'nPaddingRight': 40,
- 'nPaddingBottom': 30,
- 'nPaddingLeft': 50,
- 'sLineColor': '#3d3d3d',
- 'htTypeAndColor': {
- 'Success': '#b6da54', // type name : color, also order
- 'Warning': '#fcc666',
- 'Failed': '#fd7865',
- 'Others': '#55c7c7'
+ "sContainerId": "",
+ "sPrefix": "bigscatterchart-",
+ "nWidth": 600,
+ "nHeight": 400,
+ "nXMin": 0, "nXMax": 100,
+ "nYMin": 0, "nYMax": 100,
+ "nZMin": 0, "nZMax": 1,
+ "nXSteps": 5,
+ "nYSteps": 5,
+ "nXLabel": null,
+ "nYLabel": null,
+ "nBubbleSize": 10,
+ "nPaddingTop": 40,
+ "nPaddingRight": 40,
+ "nPaddingBottom": 30,
+ "nPaddingLeft": 50,
+ "sLineColor": "#3d3d3d",
+ "htTypeAndColor": {
+ "Success": "#b6da54", // type name : color, also order
+ "Warning": "#fcc666",
+ "Failed": "#fd7865",
+ "Others": "#55c7c7"
},
- 'nZIndexForCanvas': 1,
- 'nDefaultRadius': 3,
- 'htGuideLine': {
- 'nLineWidth': 1,
- 'aLineDash': [2, 5],
- 'nGlobalAlpha': 0.2,
- 'sLineColor' : '#e3e3e3'
+ "nZIndexForCanvas": 1,
+ "nDefaultRadius": 3,
+ "htGuideLine": {
+ "nLineWidth": 1,
+ "aLineDash": [2, 5],
+ "nGlobalAlpha": 0.2,
+ "sLineColor" : "#e3e3e3"
},
- 'sTitle': 'Big Scatter Chart by Denny',
- 'htTitleStyle': {
- 'font-size': '12px',
- 'font-weight': 'bold'
+ "sTitle": "Big Scatter Chart by Denny",
+ "htTitleStyle": {
+ "font-size": "12px",
+ "font-weight": "bold"
},
- 'sXLabel': '',
- 'sYLabel': '',
- 'htLabelStyle': {
- 'font-size': '10px',
- 'line-height': '12px',
- 'height': '20px',
- 'padding-top': '5px'
+ "sXLabel": "",
+ "sYLabel": "",
+ "htLabelStyle": {
+ "font-size": "10px",
+ "line-height": "12px",
+ "height": "20px",
+ "padding-top": "5px"
},
- 'sShowLoading': 'Loading',
- 'sShowNoData': 'No Data',
- 'htShowNoDataStyle': {
- 'font-size': '15px',
- 'color': '#000',
- 'font-weight': 'bold'
+ "sShowLoading": "Loading",
+ "sShowNoData": "No Data",
+ "htShowNoDataStyle": {
+ "font-size": "15px",
+ "color": "#000",
+ "font-weight": "bold"
},
- 'bUseMouseGuideLine' : true,
- 'sDragToSelectClassName': 'jquery-drag-to-select',
- 'htCheckBoxImage': {
- 'checked': '',
- 'unchecked': ''
+ "bUseMouseGuideLine" : true,
+ "sDragToSelectClassName": "jquery-drag-to-select",
+ "htCheckBoxImage": {
+ "checked": "",
+ "unchecked": ""
},
- 'fXAxisFormat': function (nXStep, i) {
+ "fXAxisFormat": function (nXStep, i) {
var nMilliseconds = (nXStep * i + this._nXMin);
return moment(nMilliseconds).format("MM-DD") + "
" + moment(nMilliseconds).format("HH:mm:ss");
},
- 'fYAxisFormat': function (nYStep, i) {
+ "fYAxisFormat": function (nYStep, i) {
return this._addComma((this._nYMax + this._nYMin) - ((nYStep * i) + this._nYMin));
},
- 'htDataSource': {
- sUrl: function () {
- },
- htParam: function (htFetchedData) {
- },
- nFetch: function (htFetchedData) {
- },
+ "htDataSource": {
+ sUrl: function () {},
+ nFetch: function (htFetchedData) {},
+ htParam: function (htFetchedData) {},
htOption: {
- dataType: 'jsonp',
- jsonp: 'callback'
+ dataType: "jsonp",
+ jsonp: "callback"
},
index: {
x: 0,
@@ -101,16 +102,16 @@ var BigScatterChart = $.Class({
type: 3
},
type: {
- '0' : 'Failed',
- '1' : 'Success'
+ "0" : "Failed",
+ "1" : "Success"
}
},
- 'useTypeUlSort' : false,
- 'sConfigImage': '',
- 'sDownloadImage' : '',
- 'sFullScreenImage' : '',
- 'fFullScreenMode' : function () {
- }
+ "useTypeUlSort" : false,
+ "sConfigImage": "",
+ "sDownloadImage" : "",
+ "sFullScreenImage" : "",
+ "fFullScreenMode" : function () {},
+ "fOnSelect": function() {}
});
this.webStorage = webStorage;
this.option(htOption);
@@ -120,22 +121,9 @@ var BigScatterChart = $.Class({
this._initEvents();
this._drawXYAxis();
this.updateXYAxis();
- this._initTooltip( helpContentTemplate, helpContentService );
- },
- /**
- * initialize tooltipster
- * @ko tooltipster 를 초기화
- * @constructor
- * @method BigScatterChart#_initTooltip
- * @param {Service} helpContentService angularjs service object
- */
- _initTooltip: function(helpContentTemplate, helpContentService) {
- this._welContainer.find(".scatterTooltip").tooltipster({
- content: function() {
- return helpContentTemplate(helpContentService.scatter["default"]);
- },
- position: "bottom",
- trigger: "click"
+
+ setTimeout(function() {
+ tooltipService.init("scatter");
});
},
@@ -145,31 +133,31 @@ var BigScatterChart = $.Class({
this._aBubbleStep = [];
}
- var nPaddingTop = this.option('nPaddingTop'),
- nPaddingLeft = this.option('nPaddingLeft'),
- nPaddingBottom = this.option('nPaddingBottom'),
- nPaddingRight = this.option('nPaddingRight'),
- nBubbleSize = this.option('nBubbleSize'),
- nWidth = this.option('nWidth'),
- nHeight = this.option('nHeight');
+ var nPaddingTop = this.option("nPaddingTop"),
+ nPaddingLeft = this.option("nPaddingLeft"),
+ nPaddingBottom = this.option("nPaddingBottom"),
+ nPaddingRight = this.option("nPaddingRight"),
+ nBubbleSize = this.option("nBubbleSize"),
+ nWidth = this.option("nWidth"),
+ nHeight = this.option("nHeight");
- this._nXSteps = this.option('nXSteps') - 1;
- this._nYSteps = this.option('nYSteps') - 1;
+ this._nXSteps = this.option("nXSteps") - 1;
+ this._nYSteps = this.option("nYSteps") - 1;
- if (this.option('nYLabel')) this._paddingLeft += 30;
- if (this.option('nXLabel')) this._paddingBottom += 20;
+ if (this.option("nYLabel")) this._paddingLeft += 30;
+ if (this.option("nXLabel")) this._paddingBottom += 20;
this._nXWork = (nWidth - (nPaddingLeft + nPaddingRight)) - nBubbleSize * 2;
this._nYWork = (nHeight - (nPaddingTop + nPaddingBottom)) - nBubbleSize * 2;
- this._nXMax = this.option('nXMax');
- this._nXMin = this.option('nXMin');
+ this._nXMax = this.option("nXMax");
+ this._nXMin = this.option("nXMin");
- this._nYMax = this.webStorage.get("scatter-y-max") || this.option('nYMax');
- this._nYMin = this.webStorage.get("scatter-y-min") || this.option('nYMin');
+ this._nYMax = this.webStorage.get("scatter-y-max") || this.option("nYMax");
+ this._nYMin = this.webStorage.get("scatter-y-min") || this.option("nYMin");
- this._nZMax = this.option('nZMax');
- this._nZMin = this.option('nZMin');
+ this._nZMax = this.option("nZMax");
+ this._nZMin = this.option("nZMin");
this._awelXNumber = [];
this._awelYNumber = [];
@@ -186,158 +174,177 @@ var BigScatterChart = $.Class({
var self = this,
nXStep = this._nXWork / this._nXSteps,
nYStep = this._nYWork / this._nYSteps,
- nWidth = this.option('nWidth'),
- nHeight = this.option('nHeight'),
- nPaddingTop = this.option('nPaddingTop'),
- nPaddingLeft = this.option('nPaddingLeft'),
- nPaddingBottom = this.option('nPaddingBottom'),
- nPaddingRight = this.option('nPaddingRight'),
- nBubbleSize = this.option('nBubbleSize'),
- sLineColor = this.option('sLineColor'),
- htType = this.option('htTypeAndColor'),
- sPrefix = this.option('sPrefix'),
- nZIndexForCanvas = this.option('nZIndexForCanvas');
+ nWidth = this.option("nWidth"),
+ nHeight = this.option("nHeight"),
+ nPaddingTop = this.option("nPaddingTop"),
+ nPaddingLeft = this.option("nPaddingLeft"),
+ nPaddingBottom = this.option("nPaddingBottom"),
+ nPaddingRight = this.option("nPaddingRight"),
+ nBubbleSize = this.option("nBubbleSize"),
+ sLineColor = this.option("sLineColor"),
+ htType = this.option("htTypeAndColor"),
+ sPrefix = this.option("sPrefix"),
+ nZIndexForCanvas = this.option("nZIndexForCanvas");
// container
- var sContainerId = this.option('sContainerId');
- if (typeof sContainerId === 'string') {
- this._welContainer = $('#' + sContainerId);
- } else if (typeof sContainerId === 'object') {
+ var sContainerId = this.option("sContainerId");
+ if (typeof sContainerId === "string") {
+ this._welContainer = $("#" + sContainerId);
+ } else if (typeof sContainerId === "object") {
this._welContainer = sContainerId;
- } else if (typeof sContainerId === 'function') {
+ } else if (typeof sContainerId === "function") {
this._welContainer = sContainerId();
}
- if (typeof this._welContainer !== 'object') {
+ if (typeof this._welContainer !== "object") {
return false;
}
this._welContainer.css({
- 'position': 'relative',
- 'width': this.option('nWidth'),
- 'height': this.option('nHeight')
- }).addClass('bigscatterchart');
- this._welContainer.append( $('