Compare View

switch
from
...
to
 
Commits (89)
400-SOURCECODE/AIAHTML5.Web/AIAHTML5.Web.csproj
... ... @@ -43135,6 +43135,8 @@
43135 43135 <Content Include="libs\angular\1.4.9\angular-route.min.js" />
43136 43136 <Content Include="libs\angular\1.4.9\ngStorage.js" />
43137 43137 <Content Include="libs\colorpicker\jquery.minicolors.min.js" />
  43138 + <Content Include="libs\FileSaver.js" />
  43139 + <Content Include="libs\html2canvas.js" />
43138 43140 <Content Include="libs\jcanvas\jcanvas.handle.min.js" />
43139 43141 <Content Include="libs\jcanvas\jcanvas.min.js" />
43140 43142 <Content Include="libs\jinqJs.js" />
... ...
400-SOURCECODE/AIAHTML5.Web/app/controllers/CAController.js
... ... @@ -58,9 +58,10 @@ function ($scope, $window, $rootScope, $compile, $http, log, $location, $timeout
58 58 }
59 59 else {
60 60 $scope.setActiveTab(1);
  61 + $scope.reRunSearchOnLoad();
61 62 }
62 63  
63   - $scope.reRunSearchOnLoad();
  64 +
64 65  
65 66 });
66 67  
... ... @@ -449,6 +450,8 @@ function ($scope, $window, $rootScope, $compile, $http, log, $location, $timeout
449 450 {
450 451 $('#AnnotaionPopupDiv').find('input, textarea, button, select,img,div').attr('disabled', 'disabled');
451 452 $('#slider-range-min-2').slider('disable');
  453 + $("#annotationpaintbrushsize").attr('disabled', 'disabled');
  454 + //$("#annotationpaintbrushsize").attr("href", "#");
452 455 }
453 456 $rootScope.isLoading = true;
454 457 $('#spinner').css('visibility', 'visible');
... ...
400-SOURCECODE/AIAHTML5.Web/app/controllers/CIController.js
... ... @@ -64,9 +64,10 @@ function ($scope, $window, $rootScope, $compile, $http, log, $location, $timeout
64 64 }
65 65 else {
66 66 $scope.setActiveTab(1);
  67 + $scope.reRunSearchOnLoad();
67 68 }
68 69  
69   - $scope.reRunSearchOnLoad();
  70 +
70 71  
71 72 });
72 73  
... ... @@ -562,7 +563,7 @@ function ($scope, $window, $rootScope, $compile, $http, log, $location, $timeout
562 563 theme: 'success',
563 564 currentController: 'CIController',
564 565 parentSlug: 'clinical-illustrations',
565   - content: '<div class="row"><div style="align:left;width:100%;height:100%"><canvas id="canvas" ng-click="BindCanvasDrawingListners($event)" width="1369" height="325" class="canvas-annotationStyle" style="position: absolute; background-color: transparent;z-index:1 "></canvas></div> <canvas id="canvasPaint" ng-click="FreeStylePaint($event)" width="1369" height="325" class="canvas-annotationStyle1" style="position: absolute;z-index:0;"></canvas>' +
  566 + content: '<div class="row" id="canvasDiv"><div style="align:left;width:100%;height:100%"><canvas id="canvas" ng-click="BindCanvasDrawingListners($event)" width="1369" height="325" class="canvas-annotationStyle" style="position: absolute; background-color: transparent;z-index:1 "></canvas></div> <canvas id="canvasPaint" ng-click="FreeStylePaint($event)" width="1369" height="325" class="canvas-annotationStyle1" style="position: absolute;z-index:0;"></canvas>' +
566 567 '<div class="col-sm-12 img-thumbnail" align="center">' +
567 568 '<img src="' + $scope.clickedCIImage + '" alt="" title="" class="img-responsive "><div class="col-sm-12 well">' +
568 569 '<div align="left" id="sid"><p>' + $scope.clickedCISummary + '</p></div><button id="btnTxtOnOff" class="btn btn-primary pull-right">Text Off</button>' +
... ... @@ -619,7 +620,7 @@ function ($scope, $window, $rootScope, $compile, $http, log, $location, $timeout
619 620 $("#canvasPaint").css("display", "block");
620 621  
621 622 $rootScope.BindCanvasDrawingListners();
622   - // $rootScope.FreeStylePaint();
  623 + $rootScope.FreeStylePaint();
623 624 });
624 625  
625 626 $scope.ReloadListViewImageDiv = function (id) {
... ...
400-SOURCECODE/AIAHTML5.Web/app/controllers/DAController.js
... ... @@ -15,6 +15,11 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
15 15 $rootScope.BodyLayerData;
16 16 $rootScope.VocabTermData;
17 17  
  18 + //for modesty image layers
  19 + $scope.lowerlayerNumberForModesty;
  20 + $scope.HigherlayerNumberForModesty;
  21 + $scope.layerInfoForModesty;
  22 +
18 23 $scope.VocabTermTxt;
19 24 $scope.CommonData
20 25 $rootScope.TermNumberData;
... ... @@ -89,7 +94,7 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
89 94  
90 95 //navigator man functionality
91 96 $scope.navigatorImage;
92   - $scope.NavigatorData;
  97 + $rootScope.NavigatorData;
93 98 $scope.navimgsrc;
94 99  
95 100 $scope.dragdivleft = 0;
... ... @@ -140,6 +145,7 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
140 145  
141 146 }
142 147  
  148 +
143 149 $scope.scroll = function () {
144 150 // $window.scrollTo(0, 0);
145 151 $("html,body").scrollTop(0);
... ... @@ -666,12 +672,12 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
666 672  
667 673 $http({ method: 'GET', url: NavigatorManJsonPath })
668 674 .success(function (data) {
669   - $scope.NavigatorData = data;
  675 + $rootScope.NavigatorData = data;
670 676  
671 677 $scope.skinTone = $rootScope.globalSetting.ethnicity;
672 678  
673 679 var navigatorManData = new jinqJs()
674   - .from($scope.NavigatorData.Navigtor.ViewOrientation)
  680 + .from($rootScope.NavigatorData.Navigtor.ViewOrientation)
675 681 .where("_ViewOrientationId == " + $rootScope.currentBodyViewId)
676 682 .select();
677 683  
... ... @@ -706,7 +712,8 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
706 712 navImageModesty = $scope.navigatorImage[0]._ImageName;
707 713 }
708 714  
709   - $scope.navimgsrc = "~/../content/images/DA/ethnicity/body-views/" + $scope.voId + '/' + $scope.skinTone + '/navigator_images/' + navImageModesty;
  715 + // $scope.navimgsrc = "~/../content/images/DA/ethnicity/body-views/" + $scope.voId + '/' + $scope.skinTone + '/navigator_images/' + navImageModesty;
  716 + document.getElementById('navimg').src = "~/../content/images/DA/ethnicity/body-views/" + $scope.voId + '/' + $scope.skinTone + '/navigator_images/' + navImageModesty;
710 717  
711 718 $('#navigatorDiv').css('visibility', 'visible');
712 719  
... ... @@ -769,21 +776,23 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
769 776  
770 777 //calculate coordinates for body region images
771 778 $scope.CalculateImageCordinates = function (viewOrientationId) {
772   -
  779 + $scope.layerInfoForModesty = [];
773 780 $rootScope.isLoading = true;
774 781 $('#spinner').css('visibility', 'visible');
775 782 $scope.modestyImageInfo = [];
776 783 // annotation toolbar canvas
777   - if ($("#canvasDiv").find("canvas[id='canvasPaint']").length == 0) {
778 784  
779   - $("#canvasDiv").append('<canvas id="canvasPaint" width="2277" height="3248" class="canvas-annotationStyle1"></canvas><canvas id="canvas" width="2277" height="3248" class="canvas-annotationStyle"></canvas>');
780   - $scope.BindCanvasDrawingListners();
  785 + //history code
  786 +
  787 + if ($("#canvasDiv").find("canvas[id='canvasPaint']").length == 0) {
  788 + var ATBarHtml = $("#canvasDiv").append('<canvas id="canvasPaint" width="2277" height="3248" ng-click="FreeStylePaint($event)" class="canvas-annotationStyle1"></canvas><canvas id="canvas" ng-click="onDrawingCanvasClick($event)" width="2277" height="3248" class="canvas-annotationStyle"></canvas>');
  789 + $compile(ATBarHtml)($scope);
  790 + $scope.onDrawingCanvasClick();
781 791 // $rootScope.FreeStylePaint();
782 792  
783 793 }
784 794  
785 795  
786   -
787 796 $scope.terminateCurrentlyRunningWPs();
788 797  
789 798 var drawnBodyRegionCount = [];
... ... @@ -963,9 +972,13 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
963 972 if ((dtlOfSktn != null || dtlOfSktn != undefined) && (dtlOfSktn.length > 0)) {
964 973  
965 974 if ((parseInt(dtlOfSktn[0]._lns) <= parseInt($scope.layerNumber)) && (parseInt(dtlOfSktn[0]._lne) > parseInt($scope.layerNumber)) && (dtlOfSktn[0]._isfr == 'Y')) {
  975 +
966 976 $scope.figLaefImageName = dtlOfSktn[0]._ImageId;
967   - //$scope.figLaefX = filtereddata[0]._X;
968   - //$scope.figLaefY = filtereddata[0]._Y;
  977 +
  978 +
  979 + $scope.lowerlayerNumberForModesty = dtlOfSktn[0]._lns;
  980 + $scope.HigherlayerNumberForModesty = dtlOfSktn[0]._lne;
  981 + $scope.layerInfoForModesty.push({ "bodyRegionId": value._BodyRegionId, "lowerlayerNumberForModesty": $scope.lowerlayerNumberForModesty, "HigherlayerNumberForModesty": $scope.HigherlayerNumberForModesty })
969 982  
970 983 var rectangle = scaleRectangle(value._X, value._Y, value._Height, value._Width, value._MirrorValue);
971 984  
... ... @@ -2983,6 +2996,15 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
2983 2996  
2984 2997 //$(".com").css("display", "none");
2985 2998 //$("#bord").css({ "width": "0px", "display": "none" });
  2999 +
  3000 + //history maintained issue
  3001 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == false) {
  3002 + $("#sppeachBubble").remove();
  3003 + $("#dot").remove();
  3004 + }
  3005 +
  3006 +
  3007 +
2986 3008 $(".com").remove();
2987 3009 $("#bord").remove();
2988 3010  
... ... @@ -3085,6 +3107,12 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
3085 3107 document.getElementById('sppeachBubble').style.left = (Globe[0].currentX) + 'px';
3086 3108 document.getElementById('sppeachBubble').style.top = (Globe[0].currentY) + 'px';
3087 3109  
  3110 +
  3111 + //history maintained issue
  3112 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == false) { document.getElementById('sppeachBubble').style.zIndex = "100000000000"; }
  3113 +
  3114 +
  3115 +
3088 3116 $('#sppeachBubble').draggable(
3089 3117 {
3090 3118 drag: function (evt) {
... ... @@ -3568,6 +3596,41 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
3568 3596  
3569 3597 }
3570 3598  
  3599 +
  3600 + if (document.getElementById("btnStrutureBox").name == "showAnnotationStructure") {
  3601 + $scope.showAnnotation()
  3602 +
  3603 + }
  3604 + else {
  3605 + $scope.hideAnnotation()
  3606 +
  3607 +
  3608 + }
  3609 + }
  3610 +
  3611 + $scope.showAnnotation = function()
  3612 + {
  3613 + $(".com").show();
  3614 + $('#dot').show();
  3615 + $('#bord').show();
  3616 + $('#sppeachBubble').show();
  3617 + $('#sppeachBubble_annotation').show();
  3618 +
  3619 + $("#bord_annotation").show();
  3620 + $("#dot_annotation").show();
  3621 + $(".dynCross_anno").parent().parent().parent().show();
  3622 + }
  3623 +
  3624 + $scope.hideAnnotation=function()
  3625 + {
  3626 + $(".com").hide();
  3627 + $('#dot').hide();
  3628 + $('#bord').hide();
  3629 + $('#sppeachBubble').hide();
  3630 + $('#sppeachBubble_annotation').hide();
  3631 + $("#bord_annotation").hide();
  3632 + $("#dot_annotation").hide();
  3633 + $(".dynCross_anno").parent().parent().parent().hide();
3571 3634 }
3572 3635  
3573 3636 $scope.createSpeechBubbleBasedOnAnnotationLength = function (pointClicked, x, y, id) {
... ... @@ -4380,13 +4443,6 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
4380 4443 //keep the original image on temp canavs to use it in changing transparency
4381 4444  
4382 4445  
4383   -
4384   - //if (document.getElementById(modestyTransTempCanvasId) != undefined || document.getElementById(modestyTransTempCanvasId) != null) {
4385   - // var contxModesty = document.getElementById(modestyTransTempCanvasId).getContext('2d');
4386   - // var tbTempCanvas = document.getElementById(tempCanvasID)
4387   - // contx.drawImage(tbTempCanvas, XforCopyImage, YforCopyImage, WidthforCopyImage, HeightforCopyImage, XforTransImage, YforTransImage, WidthforTransImage, HeightforTransImage);
4388   -
4389   - //}
4390 4446 if ($rootScope.isModestyOn == true && (bodyRegionId.match('modestyImg'))) {
4391 4447 var modestyTempCanvasId = 'tempCanvasModesty_' + bodyRegionId;
4392 4448 if (document.getElementById(modestyTempCanvasId) != undefined || document.getElementById(modestyTempCanvasId) != null) {
... ... @@ -4476,6 +4532,7 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
4476 4532 }
4477 4533 tempImg.src = tranparencyImgSrc;//"http://localhost/AIA/" + tranparencyImgSrc;
4478 4534  
  4535 +
4479 4536 }
4480 4537  
4481 4538  
... ... @@ -4510,9 +4567,41 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
4510 4567 PreviousBodyRegionX = XforTransImage;
4511 4568 previousBodyRegionId = bodyRegionId;
4512 4569  
4513   - // $scope.layerNumber = parseInt($scope.layerNumber - 1);
4514 4570  
4515   - //}
  4571 + //set modesty image visiblility true/false as per layer
  4572 +
  4573 +
  4574 + var layerInfo = new jinqJs()
  4575 + .from($scope.layerInfoForModesty)
  4576 + .where('bodyRegionId == ' + bodyRegionId)
  4577 + .select();
  4578 + if (layerInfo != undefined && layerInfo.length>0){
  4579 + var lowerlayerNumberForModesty = layerInfo[0].lowerlayerNumberForModesty;
  4580 + var HigherlayerNumberForModesty = layerInfo[0].HigherlayerNumberForModesty;
  4581 +
  4582 + var modestyTransCanvases = $("canvas[id*='modestyTransCanavs']");
  4583 +
  4584 + if (modestyTransCanvases != null || modestyTransCanvases != undefined && modestyTransCanvases.length > 0) {
  4585 + for (var j = 0; j < modestyTransCanvases.length; j++) {
  4586 +
  4587 + if (modestyTransCanvases[j].id.match(bodyRegionId)) {
  4588 +
  4589 + var modestyCanavs = document.getElementById(modestyTransCanvases[j].id);
  4590 +
  4591 + if ((parseInt(lowerlayerNumberForModesty) <= parseInt($scope.layerNumber)) && (HigherlayerNumberForModesty) > parseInt($scope.layerNumber)) {
  4592 +
  4593 + modestyCanavs.style.visibility = 'visible';
  4594 + }
  4595 + else {
  4596 +
  4597 + modestyCanavs.style.visibility = 'hidden';
  4598 +
  4599 + }
  4600 + }
  4601 +
  4602 + }
  4603 + }
  4604 + }
4516 4605  
4517 4606 }
4518 4607  
... ... @@ -4607,6 +4696,114 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
4607 4696 //}
4608 4697 }
4609 4698  
  4699 + // History Maintained Issue//
  4700 +
  4701 + $rootScope.getAnnotationTextBasedOnSelectedBodyRegion = function (event) {
  4702 +
  4703 +
  4704 + var canvasDiv = document.getElementById('canvasDiv');
  4705 + var verticalScrollPosition = canvasDiv.scrollTop;
  4706 + var horizontlScrollPosition = canvasDiv.scrollLeft;
  4707 +
  4708 +
  4709 + $rootScope.Xaxis = event.pageX - $('#canvasDiv').offset().left + horizontlScrollPosition;
  4710 + $rootScope.Yaxis = event.pageY - $('#canvasDiv').offset().top + verticalScrollPosition;
  4711 +
  4712 +
  4713 + $rootScope.setSelectedBodyRegionData();
  4714 +
  4715 + if ($rootScope.isMirrorBodyRegion == "No") {
  4716 + var maskCanvasId = "imageCanvas" + $rootScope.BRId + "_mci";
  4717 + var maskCanvas = document.getElementById(maskCanvasId);
  4718 + var maskCanvasContext = maskCanvas.getContext("2d");
  4719 + //var canvasDiv = document.getElementById('canvasDiv');
  4720 + //var verticalScrollPosition = canvasDiv.scrollTop;
  4721 + //var horizontlScrollPosition = canvasDiv.scrollLeft;
  4722 + var actulalX = $rootScope.Xaxis;
  4723 + var actualY = $rootScope.Yaxis;
  4724 + var RGBColor = $scope.GetRGBColor(maskCanvasContext, actulalX, actualY, $rootScope.BodyRegionXAxis, $rootScope.BodyRegionYAxis);
  4725 + var annotationText = $scope.GetAnnotationText(parseInt(RGBColor));
  4726 +
  4727 + }
  4728 + else {
  4729 +
  4730 + var maskCanvasId = "imageCanvas" + $rootScope.BRId + "_MR_mci";
  4731 + var maskoffsetval = $('#' + maskCanvasId).offset();
  4732 + var mirrorCanvasX = maskoffsetval.left;
  4733 + //alert(mirrorCanvasX);
  4734 + var mirrorImageCanvas = document.getElementById(maskCanvasId);
  4735 + var mirrorCanvasWidth = mirrorImageCanvas.clientWidth;
  4736 + // alert(mirrorCanvasWidth);
  4737 + var maskCanvas = document.getElementById(maskCanvasId);
  4738 + var maskCanvasContext = maskCanvas.getContext("2d");
  4739 +
  4740 + var distanceXOnMirrorImage = (parseInt(mirrorCanvasX) + parseInt(mirrorCanvasWidth)) - (parseInt(event.pageX) + horizontlScrollPosition);// - 135);
  4741 + var mirrorXOnNormalImage = parseInt(maskCanvasContext.canvas.offsetLeft) + parseInt(distanceXOnMirrorImage);
  4742 + var actulalX = mirrorXOnNormalImage;
  4743 + var actualY = event.pageY + verticalScrollPosition;
  4744 + var pixelData = maskCanvasContext.getImageData(Math.round(actulalX - parseInt(maskCanvasContext.canvas.offsetLeft)), Math.round(actualY - $rootScope.BodyRegionYAxis), 1, 1);
  4745 + pixelData.data[0] = pixelData.data[0] - 9;
  4746 + pixelData.data[1] = pixelData.data[1] - 9;
  4747 + pixelData.data[2] = pixelData.data[2] - 9
  4748 + var Red;
  4749 + var Green;
  4750 + var Blue;
  4751 + var zero = "0";
  4752 + if ((pixelData.data[0]).toString().length != 2) {
  4753 + Red = zero.concat((pixelData.data[0]).toString())
  4754 + }
  4755 + else {
  4756 + Red = (pixelData.data[0]).toString()
  4757 + }
  4758 + if ((pixelData.data[1]).toString().length != 2) {
  4759 + Green = zero.concat((pixelData.data[1]).toString())
  4760 + }
  4761 + else {
  4762 + Green = (pixelData.data[1]).toString()
  4763 + }
  4764 + if ((pixelData.data[2]).toString().length != 2) {
  4765 + Blue = zero.concat((pixelData.data[2]).toString())
  4766 + }
  4767 + else {
  4768 + Blue = (pixelData.data[2]).toString()
  4769 + }
  4770 + var RGBColor = (Red + Green + Blue);
  4771 + // alert(RGBColor);
  4772 + //$rootScope.previousHighlightList.push(RGBColor);
  4773 +
  4774 + }
  4775 +
  4776 + // var maskCanvasId = "imageCanvas" + $rootScope.BRId + "_mci";
  4777 +
  4778 + // alert(annotationText);
  4779 + $scope.MultiLanguageAnnationArray = [];
  4780 + $scope.MultiLanguageAnnationArray.push(annotationText);
  4781 + if (annotationText == "undefined") {
  4782 + }
  4783 + else {
  4784 + $scope.createDynamicSpeechBubble(event, event.pageX + horizontlScrollPosition - $('#canvasDiv').offset().left, event.pageY + verticalScrollPosition - $('#canvasDiv').offset().top, true)
  4785 + }
  4786 +
  4787 +
  4788 + }
  4789 +
  4790 +
  4791 + $rootScope.setSelectedBodyRegionData = function () {
  4792 + var BodyRegionDictionary = $rootScope.BodyRegionCordinatesData;
  4793 +
  4794 + $.each(BodyRegionDictionary, function (index, value) {
  4795 + var bodyRegionRight = parseInt(value.X) + parseInt(value.Width);
  4796 + var bodyRegionBottom = parseInt(value.Y) + parseInt(value.Height);
  4797 + if ($rootScope.Xaxis <= bodyRegionRight && $rootScope.Yaxis <= bodyRegionBottom && value.X <= $rootScope.Xaxis && value.Y <= $rootScope.Yaxis) {
  4798 + $rootScope.BRId = value.bodyRegionId;
  4799 + $rootScope.BodyRegionXAxis = value.X;
  4800 + $rootScope.BodyRegionYAxis = value.Y;
  4801 + $rootScope.isMirrorBodyRegion = value.IsMirror;
  4802 + return false;
  4803 + }
  4804 + });
  4805 + }
  4806 +
4610 4807  
4611 4808  
4612 4809 function resizeCanvas() {
... ... @@ -5212,7 +5409,6 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
5212 5409 ctx.putImageData(originalTransparencyData, 0, 0);
5213 5410  
5214 5411  
5215   - //for modesty
5216 5412  
5217 5413 //for modesty
5218 5414 if ($rootScope.isModestyOn == true && $scope.modestyImageInfo.length > 0) {
... ... @@ -5222,10 +5418,13 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
5222 5418  
5223 5419 var modestyTransTempCanvasId = 'tempCanvasModesty_' + brId;
5224 5420 var modestyTransCanvasId = 'modestyTransCanavs_' + brId;
5225   - var tempCanvasContext = document.getElementById(modestyTransTempCanvasId).getContext('2d');
5226   - var originalTransparencyData = tempCanvasContext.getImageData(0, 0, value.Width, value.Height);
5227   - var ctx = document.getElementById(modestyTransCanvasId).getContext('2d');
5228   - ctx.putImageData(originalTransparencyData, 0, 0);
  5421 + if (document.getElementById(modestyTransTempCanvasId) != null) {
  5422 +
  5423 + var tempCanvasContext = document.getElementById(modestyTransTempCanvasId).getContext('2d');
  5424 + var originalTransparencyData = tempCanvasContext.getImageData(0, 0, value.Width, value.Height);
  5425 + var ctx = document.getElementById(modestyTransCanvasId).getContext('2d');
  5426 + ctx.putImageData(originalTransparencyData, 0, 0);
  5427 + }
5229 5428 })
5230 5429 }
5231 5430  
... ... @@ -5877,20 +6076,24 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
5877 6076  
5878 6077  
5879 6078 //if listanager is visisble then close it
  6079 +
5880 6080  
5881 6081 $rootScope.isListManagerSelected = false;
5882 6082 $rootScope.CloseListManager();
  6083 + var btnStrutureBoxname = document.getElementById("btnStrutureBox").name;
5883 6084  
5884   - $(".com").toggle();
5885   - $('#dot').toggle();
5886   - $('#bord').toggle();
5887   - $('#sppeachBubble').toggle();
5888   - $('#sppeachBubble_annotation').toggle();
5889   -
5890   - $("#bord_annotation").toggle();
5891   - $("#dot_annotation").toggle();
5892   - $(".dynCross_anno").parent().parent().parent().toggle();
  6085 + if (btnStrutureBoxname == "showAnnotationStructure") {
  6086 + $("#btnStrutureBox").addClass("disableHideShowStructure");
  6087 + $scope.hideAnnotation();
  6088 + document.getElementById("btnStrutureBox").name = "hideAnnotationStructure";
  6089 + }
  6090 + else {
  6091 + $("#btnStrutureBox").removeClass("disableHideShowStructure");
  6092 + $scope.showAnnotation();
5893 6093  
  6094 + document.getElementById("btnStrutureBox").name = "showAnnotationStructure";
  6095 + }
  6096 +
5894 6097 }
5895 6098  
5896 6099  
... ... @@ -6405,7 +6608,7 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6405 6608  
6406 6609  
6407 6610 //4.
6408   - $scope.loadSelectedBodyViewNavigator(currentBodyViewId);
  6611 + $scope.loadNavigatorForSelectedBodyView(currentBodyViewId);
6409 6612  
6410 6613 //5. change the search terms as per the selected bodyview
6411 6614 $scope.loadSearchDataForBodyView();
... ... @@ -6437,7 +6640,7 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6437 6640  
6438 6641  
6439 6642 //4.
6440   - $scope.loadSelectedBodyViewNavigator(currentBodyViewId);
  6643 + $scope.loadNavigatorForSelectedBodyView(currentBodyViewId);
6441 6644  
6442 6645 //5. change the search terms as per the selected bodyview
6443 6646 $scope.loadSearchDataForBodyView();
... ... @@ -6637,7 +6840,7 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6637 6840 $scope.loadSelectedBodyView($rootScope.voId);
6638 6841  
6639 6842 //3. load corresponding navigator man
6640   - $scope.loadSelectedBodyViewNavigator($rootScope.voId);
  6843 + $scope.loadNavigatorForSelectedBodyView($rootScope.voId);
6641 6844  
6642 6845 //4. change the search terms as per the selected bodyview
6643 6846 $scope.loadSearchDataForBodyView();
... ... @@ -6671,7 +6874,7 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6671 6874 $scope.loadSelectedBodyView($rootScope.voId);
6672 6875  
6673 6876 //2.
6674   - $scope.loadSelectedBodyViewNavigator($rootScope.voId);
  6877 + $scope.loadNavigatorForSelectedBodyView($rootScope.voId);
6675 6878 };
6676 6879  
6677 6880  
... ... @@ -6757,20 +6960,28 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6757 6960  
6758 6961 })
6759 6962  
  6963 + $scope.$on('changeNavigatorModestyEvent', function (event, data) {
  6964 + console.log('changeNavigatorModestyEvent');
  6965 +
  6966 + $scope.loadNavigatorForSelectedBodyView(data.bodyViewId);
  6967 +
  6968 + })
6760 6969 //Reload DA controller Body View after setting Change
6761 6970 $scope.$on('reloadDABodyViewEvent', function (event, data) {
6762 6971 //console.log('reloadDABodyViewEvent');
6763   - $scope.layerNumber = parseInt($('#txtlayerNumber').val());
6764   - //alert('mouseUp');
  6972 + if ($rootScope.isSettingEventAlredayDispachted == true) {
  6973 + $rootScope.isSettingEventAlredayDispachted = false;
  6974 + $scope.layerNumber = parseInt($('#txtlayerNumber').val());
  6975 + //alert('mouseUp');
6765 6976  
6766 6977  
6767   - if ($scope.layerNumber == 0) {
6768   - $scope.loadSelectedBodyView(data.reloadDABodyViewId);
6769   - }
6770   - // $scope.loadSelectedBodyView(data.reloadDABodyViewId);
6771   -
6772   - $scope.loadSelectedBodyViewNavigator(data.reloadDABodyViewId);
  6978 + if ($scope.layerNumber == 0) {
  6979 + $scope.loadSelectedBodyView(data.reloadDABodyViewId);
  6980 + }
  6981 + // $scope.loadSelectedBodyView(data.reloadDABodyViewId);
6773 6982  
  6983 + $scope.loadNavigatorForSelectedBodyView(data.reloadDABodyViewId);
  6984 + }
6774 6985 // $scope.currentTitleFromJson = localStorage.getItem("currentViewTitle");
6775 6986  
6776 6987 //$rootScope.isSettingEventAlredayDispachted = false;
... ... @@ -6778,17 +6989,15 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6778 6989  
6779 6990 })
6780 6991  
6781   -
6782   -
6783   - $scope.loadSelectedBodyViewNavigator = function (currentBodyViewId) {
  6992 + $scope.loadNavigatorForSelectedBodyView = function (currentBodyViewId) {
6784 6993  
6785 6994 //$rootScope.voId = currentBodyViewId;
6786 6995  
6787 6996 //$scope.skinTone = $rootScope.globalSetting.ethnicity;
6788 6997  
6789   - if ($scope.NavigatorData != null || $scope.NavigatorData != undefined) {
  6998 + if ($rootScope.NavigatorData != null || $rootScope.NavigatorData != undefined) {
6790 6999 var navdtlOrient = new jinqJs()
6791   - .from($scope.NavigatorData.Navigtor.ViewOrientation)
  7000 + .from($rootScope.NavigatorData.Navigtor.ViewOrientation)
6792 7001 .where("_ViewOrientationId == " + currentBodyViewId)
6793 7002 .select();
6794 7003  
... ... @@ -6818,7 +7027,8 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6818 7027  
6819 7028 }
6820 7029  
6821   - $scope.navimgsrc = "~/../content/images/DA/ethnicity/body-views/" + $scope.voId + '/' + $rootScope.globalSetting.ethnicity + '/navigator_images/' + navImageModesty;
  7030 + // $scope.navimgsrc = 'http://localhost/AIAHTML5/content/images/DA/ethnicity/body-views/' + $scope.voId + '/' + $rootScope.globalSetting.ethnicity + '/navigator_images/' + navImageModesty;//"~/../content/images/DA/ethnicity/body-views/" + $scope.voId + '/' + $rootScope.globalSetting.ethnicity + '/navigator_images/' + navImageModesty;
  7031 + document.getElementById('navimg').src = '~/../content/images/DA/ethnicity/body-views/' + $scope.voId + '/' + $rootScope.globalSetting.ethnicity + '/navigator_images/' + navImageModesty;//"~/../content/images/DA/ethnicity/body-views/" + $scope.voId + '/' + $rootScope.globalSetting.ethnicity + '/navigator_images/' + navImageModesty;
6822 7032 }
6823 7033 }
6824 7034  
... ... @@ -6843,7 +7053,7 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6843 7053  
6844 7054 $("#canvas").css("display", "block");
6845 7055 $("#canvasPaint").css("display", "block");
6846   - $rootScope.BindCanvasDrawingListners();
  7056 + $rootScope.onDrawingCanvasClick();
6847 7057 $rootScope.FreeStylePaint();
6848 7058 });
6849 7059 $scope.mousePs;
... ... @@ -6857,114 +7067,8 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
6857 7067  
6858 7068  
6859 7069  
6860   - $rootScope.FreeStylePaint = function (e) {
6861   -
6862   - var annotationCanvas = document.getElementById("canvas");
6863   - // document.getElementById("canvasPaint").addEventListener("mouseup", OnPaintBrushCanvasMouseUp);
6864   -
6865   - annotationCanvas.addEventListener('mousedown', $scope.OnPaintCanvasMouseDown, false);
6866   -
6867   - annotationCanvas.addEventListener('mouseup', $scope.OnPaintBrushCanvasMouseUp, false);
6868   - }
6869   - $scope.OnPaintCanvasMouseDown = function (event) {
6870   - $rootScope.isMousedownOnPaintCanvas = true;
6871   - $scope.isStartPointDeleted = false;
6872   - var annotationCanvas = document.getElementById("canvas");
6873   - $scope.startPageX = parseInt(event.clientX - ($("#canvas").offset().left));
6874   - $scope.startPageY = parseInt(event.clientY - ($("#canvas").offset().top));
6875   -
6876   - annotationCanvas.addEventListener('mousemove', $scope.OnPaintCanvasMouseMove, false);
6877   -
6878   -
6879   -
6880   - }
6881   - $scope.OnPaintCanvasMouseMove = function (event) {
6882   -
6883   -
6884   - $rootScope.xPage = parseInt(event.clientX - ($("#canvas").offset().left));
6885   - $rootScope.yPage = parseInt(event.clientY - ($("#canvas").offset().top));
6886   -
6887   - var btneraseBrushSizeValue = $("#btnBrushSize").val();
6888   - $rootScope.eraseshapeSize = parseInt(btneraseBrushSizeValue);
6889   -
6890   - if ($rootScope.isEraseToolSelected == true && $rootScope.isMousedownOnPaintCanvas == true) {
6891   -
6892   - var sktch = $('#canvasPaint').sketch();
6893   - $('#canvasPaint').sketch().actions = [];
6894   - var paintCanvas = document.getElementById("canvasPaint");
6895   - var paintCanvasContext = paintCanvas.getContext('2d');
6896   - if ($scope.isStartPointDeleted == false) {
6897   -
6898   - paintCanvasContext.clearRect($scope.startPageX, $scope.startPageY, $rootScope.eraseshapeSize, $rootScope.eraseshapeSize);
6899   -
6900   - $scope.isStartPointDeleted = true;
6901   - }
6902   -
6903   - paintCanvasContext.clearRect($rootScope.xPage, $rootScope.yPage, $rootScope.eraseshapeSize, $rootScope.eraseshapeSize);
6904   -
6905   -
6906   - }
6907   - }
6908   - $scope.OnPaintBrushCanvasMouseDown = function (event) {
6909   - switch ($rootScope.shapeType) {
6910   -
6911   - case "FreeStylePaint":
6912   -
6913   -
6914   -
6915   - // $('#canvasPaint').sketch();
6916   - // $('#canvasPaint').sketch({ defaultSize: 1 });
6917   - // if ($("#amount-2").val() == '') {
6918   - // //$('#canvasPaint').sketch({ defaultSize: $scope.shapesize });
6919   - // $('#canvasPaint').sketch();
6920   - // }
6921   - // else {
6922   -
6923   - // // var a = $("#amount-2").val();
6924   - //// $scope.shapesize = parseInt(a);
6925   - // // $('#canvasPaint').sketch({ defaultSize: $rootScope.shapeSize });
6926   - // // $('#canvasPaint').sketch({ defaultSize: $scope.shapesize });
6927   -
6928   - // }
6929   -
6930   -
6931   - break;
6932   -
6933   - }
6934   - }
6935   - $scope.OnPaintBrushCanvasMouseUp = function (event) {
6936   - $rootScope.isMousedownOnPaintCanvas = false;
6937   - $rootScope.isEraseToolSelected = false;
6938   -
6939   - // var canvasElement1 = document.getElementById("canvasPaint");
6940   - // var ctx1 = canvasElement1.getContext("2d");
6941   -
6942   - //switch($rootScope.shapeType)
6943   - //{
6944   -
6945   - // case "FreeStylePaint":
6946   -
6947   -
6948   - // if ($("#amount-2").val() == '')
6949   - // {
6950   - // $('#canvasPaint').sketch({ defaultSize: $scope.shapesize });
6951   - // }
6952   - // else
6953   - // {
6954   -
6955   - // var a = $("#amount-2").val();
6956   - // $scope.shapesize = parseInt(a);
6957   - // alert(JSON.stringify({ defaultSize: $scope.shapesize }));
6958   - // $('#canvasPaint').sketch({ defaultSize: $scope.shapesize });
6959   -
6960   - // }
6961   -
6962   -
6963   - // break;
6964   -
6965   - //}
6966   -
6967   - }
  7070 +
  7071 +
6968 7072  
6969 7073  
6970 7074  
... ... @@ -7314,6 +7418,8 @@ function ($scope, $rootScope, $compile, $http, $log, $location, $timeout, DA, Mo
7314 7418 $('#termList option[value="' + $rootScope.searchSelectedText + '"]').prop("selected", true);
7315 7419 $("#termList").find("option").css({ "background-color": "#ffffff", "color": "#000000" });
7316 7420 $('#termList option[value="' + $rootScope.searchSelectedText + '"]').css({ "background-color": "#3399FF", "color": "#ffffff" });
  7421 +
  7422 +
7317 7423 $rootScope.isLoading = true;
7318 7424  
7319 7425 $('#spinner').css('visibility', 'visible');
... ...
400-SOURCECODE/AIAHTML5.Web/app/controllers/HomeController.js
... ... @@ -64,19 +64,30 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
64 64  
65 65 $rootScope.isEraseToolSelected = false;
66 66 $rootScope.isMousedownOnPaintCanvas = false;
  67 + //opacity code
  68 + $rootScope.shapestyleOpacity = 1;
  69 + $rootScope.shapestyleFillColor = "#fff";
  70 + $rootScope.shapestyleFillBorderColor = "black";
  71 + $rootScope.shapestyleborderWidth = 2;
  72 + $rootScope.shapestyleborderStyles = "solid";
67 73  
68 74 $rootScope.$on("$locationChangeSuccess", function () {
69 75  
70   - if (($location.url() == "/da-body-view") || ($location.url() == "/clinical-illustrations-detail") || ($location.url() == "/clinical-animations-detail")) {
  76 + if (($location.url() == "/da-body-view")) {
71 77 $rootScope.disableMenuannotation = " ";
72 78 $rootScope.disableMenuoption = " ";
73 79  
74   -
  80 + }
  81 + else if (($location.url() == "/clinical-illustrations-detail") || ($location.url() == "/clinical-animations-detail")) {
  82 + $rootScope.disableMenuannotation = " ";
  83 + $rootScope.disableMenuoption = " ";
  84 + $rootScope.disableSubMenu = "disableSubMenu";
75 85 }
76 86 else {
77 87  
78 88 $rootScope.disableMenuannotation = "disableMenuannotation";
79 89 $rootScope.disableMenuoption = "disableMenuoption";
  90 + $rootScope.disableSubMenu = "";
80 91 $rootScope.CloseAnnotationTool();
81 92 $rootScope.CloseListManager();
82 93 angular.element('#modal-settings').modal('hide');
... ... @@ -140,16 +151,6 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
140 151 }
141 152 }
142 153  
143   - // $rootScope.DrawLine = function () {
144   - //$rootScope.isIdetifyClicked = false;
145   - //$rootScope.isDrawingToolSelected = true;
146   - //$rootScope.isLineDrawSelecyed = true;
147   - // $rootScope.shapeType = "Line";
148   - // alert($rootScope.shapeType);
149   -
150   -
151   - // }
152   -
153 154 $rootScope.ClearIframe = function () {
154 155 if ($('#daImagePanel') != null)
155 156 $('#daImagePanel').remove();
... ... @@ -171,18 +172,25 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
171 172 //7904
172 173 if ($rootScope.MenuModuleName == "DA") {
173 174 if ($rootScope.disableAnnotationtoolOnListManager == true) {
174   - $('#AnnotaionPopupDiv').find('input, textarea, button, select,img,div').attr('disabled', 'disabled');
  175 + $('#AnnotaionPopupDiv').find('a,input, textarea, button, select,img,div').attr('disabled', 'disabled');
175 176 $('#slider-range-min-2').slider('disable');
  177 + $("#annotationpaintbrushsize").attr('disabled', 'disabled');
  178 +
176 179  
177 180 // $rootScope.disableAnnotationTB = false;
178 181 } else {
179 182 $('#AnnotaionPopupDiv').find('input, textarea, button, select,img,div').removeAttr('disabled', 'disabled');
180 183 $('#slider-range-min-2').slider('enable');
  184 + $("#annotationpaintbrushsize").removeAttr('disabled', 'disabled');
181 185 }
182 186 // document.getElementById('modelbackground').style.display = "block";
183 187 // document.getElementById('modeleditstyle').style.display = "block";
184 188  
185 189 }
  190 + if ($rootScope.MenuModuleName == "CA")
  191 + {
  192 + $("#annotationpaintbrushsize").attr("href", "#");
  193 + }
186 194 $("#OnIdentify").addClass("annotationtoolbartab");
187 195 $("#annotationToolBarOptions").addClass("active");
188 196 $("#annotationButton").addClass("active");
... ... @@ -190,8 +198,8 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
190 198 $rootScope.isAnnotationWindowOpen = true;
191 199 $(".annotationTollbar").css("display", "block");
192 200 $rootScope.$broadcast('annotationToolEvent', true);
193   - $("#canvasPaint").css("display", "none");
194   - $("#canvas").css("display", "none");
  201 + // $("#canvasPaint").css("display", "none");
  202 + // $("#canvas").css("display", "none");
195 203  
196 204 var FontFamilyJson = '~/../content/data/json/settings/fontstyle.json';
197 205 if ($rootScope.isFontFamilyLoaded == false) {
... ... @@ -232,10 +240,11 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
232 240  
233 241 $(".annotationTollbar").css("display", "none");
234 242 $rootScope.isAnnotationWindowClose = true;
235   - $("#canvasPaint").css("display", "none");
236   - $("#canvas").css("display", "none");
  243 + // $("#canvasPaint").css("display", "none");
  244 + // $("#canvas").css("display", "none");
237 245 $('.btnCursor').removeClass('activebtncolor');
238 246 $(".btn-annotation").removeClass("activebtncolor");
  247 + $rootScope.isAnnotaionToolBarDrawingModeActive = true;
239 248 }
240 249 $rootScope.CIAnotationIdentifyModeOff = false;
241 250 $rootScope.OnIdentifyClick = function () {
... ... @@ -249,25 +258,31 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
249 258 $('.btnCursor').removeClass('activebtncolor');
250 259  
251 260 } else {
252   - $("#canvasPaint").css("display", "none");
253   - $("#canvas").css("display", "none");
  261 + // $("#canvasPaint").css("display", "none");
  262 + // $("#canvas").css("display", "none");
254 263  
255 264 // $("#canvasPaint").css("z-index", "0");
256 265 // $("#canvas").css("z-index", "0");
257 266 $('.btnCursor').removeClass('activebtncolor');
258 267  
259 268 }
  269 +
  270 + $rootScope.isAnnotaionToolBarDrawingModeActive = false;
  271 + $rootScope.switchCanvas();
260 272 }
261 273  
262 274  
263 275  
264 276 $rootScope.DrawingMode = function () {
  277 + //Annotation History
  278 + $rootScope.isAnnotaionToolBarDrawingModeActive = true;
265 279 $("#OnIdentify").removeClass("annotationtoolbartab");
266 280 $("#DrawMode").addClass("annotationtoolbartab");
267 281 $('.btnCursor').addClass('activebtncolor');
268 282 $rootScope.switchCanvas();
269   - $("#canvasPaint").css("display", "block");
270   - $("#canvas").css("display", "block");
  283 +
  284 + // $("#canvasPaint").css("display", "block");
  285 + // $("#canvas").css("display", "block");
271 286  
272 287 }
273 288  
... ... @@ -280,14 +295,12 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
280 295 $('#modal-settings').modal('toggle');
281 296 }
282 297  
283   -
284 298 }
285 299  
286   -
287   -
288 300 //----Annotation Toolbar: Jcanvas-----
289 301  
290   - $rootScope.DrLine = function (e) {
  302 + $rootScope.DrawLine = function (e)
  303 + {
291 304 $rootScope.setListManagerZindex = true;
292 305 $("#canvasPaint").css("display", "block");
293 306 $("#canvas").css("display", "block");
... ... @@ -295,7 +308,6 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
295 308 $rootScope.switchCanvas();
296 309 $rootScope.shapeType = "Line";
297 310  
298   -
299 311 $('.btnCursor').removeClass('activebtncolor');
300 312 $(".btn-annotation").removeClass("activebtncolor");
301 313 $(".btn-annotation-line").addClass("activebtncolor");
... ... @@ -304,7 +316,7 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
304 316 }
305 317  
306 318  
307   - $rootScope.DrPin = function (e) {
  319 + $rootScope.DrawPin = function (e) {
308 320 $("#canvasPaint").css("display", "block");
309 321 $("#canvas").css("display", "block");
310 322  
... ... @@ -338,32 +350,53 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
338 350 $(".btn-annotation").removeClass("activebtncolor");
339 351 $(".btn-annotation-rectangle").addClass("activebtncolor");
340 352 }
  353 +
341 354 $rootScope.paintBrush = function () {
342   - // debugger;
343   - // $('.btnCursor').addClass('activebtncolor');
344   - $rootScope.setListManagerZindex = true;
345   - $("#canvasPaint").css("display", "block");
346   - $("#canvas").css("display", "block");
347   - $rootScope.switchCanvasToPaintCanvas();
348   - $rootScope.shapeType = "FreeStylePaint";
  355 + $rootScope.isAnnotaionToolBarDrawingModeActive = false;
  356 + if ($rootScope.disableAnnotationtoolOnListManager == true) {
  357 + $rootScope.switchCanvas();
  358 + var canvasPaintZindex = $('#canvasPaint').css("z-index"); //x
  359 +
  360 + var canvasZindex = $('#canvas').css("z-index"); //y
  361 + var listManagerZindex = $('#listManager').css("z-index"); //z
  362 + if (canvasPaintZindex > canvasZindex) {
  363 +
  364 + $('#listManager').css("z-index", canvasPaintZindex);
  365 +
  366 + } else {
  367 +
  368 + $('#listManager').css("z-index", canvasZindex);
  369 + }
  370 +
  371 + } else {
  372 +
  373 + // $('.btnCursor').addClass('activebtncolor');
  374 + $rootScope.setListManagerZindex = true;
  375 + $("#canvasPaint").css("display", "block");
  376 + $("#canvas").css("display", "block");
  377 + $rootScope.switchCanvasToPaintCanvas();
  378 + $rootScope.shapeType = "FreeStylePaint";
349 379 var btnBrushSizeValue = $("#btnBrushSize").val();
350 380 $rootScope.shapeSize = parseInt(btnBrushSizeValue);
351 381 $("#annotationpaintbrushsize").attr("data-size", $rootScope.shapeSize);
352 382  
353   - $("#annotationpaintbrushsize").attr("data-color", $rootScope.shapestyleFillColor);
  383 + $("#annotationpaintbrushsize").attr("data-color", $rootScope.shapestyleColorWithOpacity);
354 384  
355   - if ($rootScope.shapeSize == '') {
356   - $('#canvasPaint').sketch({ defaultSize: 1 });
357   - }
358   - else {
359   - $('#canvasPaint').sketch();
360 385  
361   - }
362 386  
  387 + if ($rootScope.shapeSize == '') {
  388 + $('#canvasPaint').sketch({ defaultSize: 1 });
  389 + }
  390 + else {
  391 + $('#canvasPaint').sketch();
363 392  
364   - // $('#canvasPaint').sketch();
  393 + }
365 394  
  395 + }
366 396  
  397 + $('.btnCursor').removeClass('activebtncolor');
  398 + $(".btn-annotation").removeClass("activebtncolor");
  399 + $(".btn-annotation-brush").addClass("activebtncolor");
367 400  
368 401 }
369 402  
... ... @@ -412,23 +445,16 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
412 445 $('.btnCursor').removeClass('activebtncolor');
413 446 $(".btn-annotation").removeClass("activebtncolor");
414 447 $(".btn-annotation-Text").addClass("activebtncolor");
415   - // $("#text_area").val('');
416   - // $("#text_area").css({ " font-family": 'Verdana, sans-serif', "font-size": "14px", "font-weight": "normal", "font-style": "normal", "color": "#000", "text-align": "left", "text-decoration": "none" });
417   - }
  448 + }
418 449  
419 450 $rootScope.DrawPolygon = function () {
420 451 $rootScope.setListManagerZindex = true;
421 452 $("#canvasPaint").css("display", "block");
422 453 $("#canvas").css("display", "block");
423 454 $rootScope.shapeType = "DrawPolygon";
424   -
425 455 }
426 456  
427 457  
428   - $rootScope.OpacityModal = function () {
429   -
430   -
431   - }
432 458 $rootScope.switchCanvas = function () {
433 459 var x = $('#canvasPaint').css("z-index");
434 460  
... ... @@ -441,72 +467,75 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
441 467 $('#canvas').css("z-index", y);
442 468 }
443 469 $rootScope.EraseDrawing = function () {
  470 + $rootScope.isAnnotaionToolBarDrawingModeActive = false;
444 471 $rootScope.switchCanvas();
445 472 $rootScope.isEraseToolSelected = true;
446 473 //$rootScope.switchCanvasToPaintCanvas();
447   - //// $('#canvasPaint').sketch({ defaultColor: "yellow", defaultSize: 1 });
448   - //var sktch = $('#canvasPaint').sketch();
449   - //$('#canvasPaint').sketch().actions = []; // this line empties the actions.
450   - //var myCanvas = document.getElementById("canvasPaint");
451   - //var ctx = myCanvas.getContext('2d');
452   - //ctx.clearRect(0, 0, myCanvas.width, myCanvas.height);
453   - //$rootScope.switchCanvas();
454   -
  474 + $('.btnCursor').removeClass('activebtncolor');
  475 + $(".btn-annotation").removeClass("activebtncolor");
  476 + $(".btn-annotation-erase").addClass("activebtncolor");
455 477 }
456 478  
457   - //opacity code
458   - $rootScope.shapestyleOpacity = 1;
459   - $rootScope.shapestyleFillColor = "#fff";
460   - $rootScope.shapestyleFillBorderColor = "black";
461   - $rootScope.shapestyleborderWidth = 2;
462   - $rootScope.shapestyleborderStyles = "solid";
463   - $rootScope.shapestyle = function (id) {
464   - // debugger;
465   - document.getElementById('modelbackground').style.display = "none";
466   - document.getElementById('modeleditstyle').style.display = "none";
467   -
468   - $rootScope.shapestyleOpacity = $("#" + id).css('opacity');
469   - $("#shapeStyleDiv").parent().css("opacity", $rootScope.shapestyleOpacity);
470   - $rootScope.shapestyleFillColor = $("#" + id).css('background-color');
471   - $("#shapeStyleDiv").css("background-color", $rootScope.shapestyleFillColor);
472   - $rootScope.shapestyleborderColor = $("#" + id).parent().css("border-top-color");
473   - $("#shapeStyleDiv").parent().css("border-color", $rootScope.shapestyleborderColor);
474   - $rootScope.shapestyleborderWidthSeparatingPixel = $("#" + id).parent().css("border-top-width");
475   - $("#shapeStyleDiv").parent().css("border-width", $rootScope.shapestyleborderWidthSeparatingPixel);
476   - var pixelSeparation = $rootScope.shapestyleborderWidthSeparatingPixel;
477   - var intPart = pixelSeparation.split("p");
478   -
479   - $rootScope.shapestyleborderWidth = intPart[0];
480   - $rootScope.shapestyleborderStyles = "solid";
  479 + $rootScope.isShapeSyleOkBtnClicked = false;
  480 + $rootScope.setPropertiesForShapes = function (id) {
  481 + $rootScope.isShapeSyleOkBtnClicked = true;
  482 +
  483 + if ((document.getElementById('fill-option').checked == false) && (document.getElementById('Outline-Option').checked == false)) {
  484 + // $('#btnShapeStyle').attr('disabled', 'disabled');
  485 + } else {
  486 + //$('#btnShapeStyle').removeAttr('disabled', 'disabled');
  487 + document.getElementById('modelbackground').style.display = "none";
  488 + document.getElementById('modeleditstyle').style.display = "none";
481 489  
  490 + $rootScope.shapestyleOpacity = $("#" + id).css('opacity');
  491 + $("#shapeStyleDiv").parent().css("opacity", $rootScope.shapestyleOpacity);
  492 + $rootScope.shapestyleFillColor = $("#" + id).css('background-color');
  493 + $rootScope.shapeStyleColorRGBA = $rootScope.shapestyleFillColor.replace("rgb", "rgba");
  494 + $rootScope.shapestyleColorWithOpacity = $rootScope.shapeStyleColorRGBA.substring(0, $rootScope.shapeStyleColorRGBA.length - 1) + " " + "," + $rootScope.shapestyleOpacity + ")";
  495 + $("#shapeStyleDiv").css("background-color", $rootScope.shapestyleFillColor);
  496 + $rootScope.shapestyleborderColor = $("#" + id).parent().css("border-top-color");
  497 + // $("#shapeStyleDiv").parent().css("border-color", $rootScope.shapestyleborderColor);
  498 + $rootScope.borderDimensions = $("#" + id).parent().css("border-top-width");
  499 +
  500 + document.getElementById("shapeStyleDiv").parentNode.style.border = $rootScope.borderDimensions + " " + "solid" + " " + $rootScope.shapestyleborderColor;
482 501  
483   - $('#editshapestyle').modal('hide');
484   - // name: 'Circle_' + $rootScope.resetCircle,
  502 + // $("#shapeStyleDiv").parent().css("border-width", $rootScope.shapestyleborderWidthSeparatingPixel);
485 503  
  504 + var borderDimensions = $rootScope.borderDimensions;
  505 + var borderDimensionSplitArray = borderDimensions.split("p");
486 506  
487   - // $("#canvas").removeLayer("TextRect_" + $rootScope.resetTextRect).drawLayers();
  507 + $rootScope.shapestyleborderWidth = borderDimensionSplitArray[0];
  508 + $rootScope.shapestyleborderStyles = "solid";
488 509  
489   - //Edit Shape Style popup should open at it's default position
490   - $("#modeleditstyle").css({ "left": "40%", "right": "0", "top": "70px" });
491 510  
  511 + $('#editshapestyle').modal('hide');
  512 +
  513 + //Edit Shape Style popup should open at it's default position
  514 + $("#modeleditstyle").css({ "left": "40%", "right": "0", "top": "70px" });
  515 + }
492 516 }
493 517  
494 518 $rootScope.enableAnnotationToolBar = function () {
495 519 if ($rootScope.disableAnnotationTB == true) {
496 520 document.getElementById('modelbackground').style.display = "none";
497   - //$("#editshapestyle").modal('show');
498 521 document.getElementById('modeleditstyle').style.display = "none";
499 522 }
500 523 else {
501 524 document.getElementById('modelbackground').style.display = "block";
502   - //$("#editshapestyle").modal('show');
503 525 document.getElementById('modeleditstyle').style.display = "block";
  526 +
  527 + // alert(document.getElementById('outlinedivId').style.border);
  528 + // alert(document.getElementById('imgOpacity').style.backgroundColor);
  529 + $('#editstylebackgroundcolor .minicolors >.minicolors-swatch > .minicolors-swatch-color').css("background-color", document.getElementById('imgOpacity').style.backgroundColor);
  530 + $('#outlineColor .minicolors >.minicolors-swatch > .minicolors-swatch-color').css("background-color", document.getElementById('outlinedivId').style.border);
  531 +
504 532 if ($('#modeleditstyle').css("display") == "block") { //Check if the modal is already showing
505 533 var previewOpacity = $('#imgOpacity').css("opacity");
506 534 $('#slider-range-min-4 div.ui-slider-range-min').css("width", (previewOpacity * 100) + "%");
507 535 $('#slider-range-min-4 span.ui-slider-handle').css("left", (previewOpacity * 100) + "%");
508 536  
509 537 };
  538 +
510 539 }
511 540 }
512 541  
... ... @@ -522,308 +551,418 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
522 551  
523 552 $(".custom-tooltip-annotation").css('display', 'none');
524 553 $("#edit-block").removeClass("custom-tooltip-annotation");
525   -
526   -
527 554 }
528 555  
529 556  
530 557 $rootScope.disableAnnotationToolBar = function () {
531   -
  558 + if ($rootScope.isShapeSyleOkBtnClicked == false) {
  559 + $('#editstylebackgroundcolor .minicolors >.minicolors-swatch > .minicolors-swatch-color').css("background-color", "rgb(255,255,255)");
  560 + $('#outlineColor .minicolors >.minicolors-swatch > .minicolors-swatch-color').css("background-color", "rgb(0,0,0)");
  561 + var previewBorderColor = $("#outlineColor span.minicolors-swatch-color").css('background-color');
  562 + $(".marginTopBtm10 div.outlinediv").css("border-color", previewBorderColor);
  563 + var previewBgColor = $("#editstylebackgroundcolor span.minicolors-swatch-color").css('background-color');
  564 + $("#imgOpacity").css("background-color", previewBgColor);
  565 + $('#borderWidthCanvasElement').val(1);
  566 + $('.marginTopBtm10 div.outlinediv').css("border-width", 1);
  567 + $("#imgOpacity").css("opacity", 1);
  568 + $(".marginTopBtm10 div.outlinediv").css("opacity", 1);
  569 + //$("#borderWidthCanvasElement").change(function () {
  570 + // $(".marginTopBtm10 div.outlinediv").css("border-color", x);
  571 + //});
  572 + } else {
  573 + var previewBgColor = $("#shapeStyleDiv").css('background-color');
  574 + var previewBorderColor = $('#previewBorder').css('border-color');
  575 + var previewBorderWidth = $('#previewBorder').css('border-width');
  576 + var previewOpacity = $('#previewBorder').css('opacity');
  577 + $('#editstylebackgroundcolor .minicolors >.minicolors-swatch > .minicolors-swatch-color').css("background-color", previewBgColor);
  578 + $("#imgOpacity").css("background-color", previewBgColor);
  579 + $('#outlineColor .minicolors >.minicolors-swatch > .minicolors-swatch-color').css("background-color", previewBorderColor);
  580 + $(".marginTopBtm10 div.outlinediv").css("border-color", previewBorderColor);
  581 + $('.marginTopBtm10 div.outlinediv').css("border-width", previewBorderWidth);
  582 + $('#borderWidthCanvasElement').val(previewBorderWidth.split("px"));
  583 + $("#imgOpacity").css("opacity", previewOpacity);
  584 + $(".marginTopBtm10 div.outlinediv").css("opacity", previewOpacity);
  585 + }
532 586 document.getElementById('modelbackground').style.display = "none";
533 587 document.getElementById('modeleditstyle').style.display = "none";
534 588 //Edit Shape Style popup should open at it's default position
535 589 $("#modeleditstyle").css({ "left": "40%", "right": "0", "top": "70px" });
536   -
537   -
  590 +
538 591 }
539 592  
540 593  
541   - //----End-------------
542   -
543 594 //--Common code of Annotation Toolbar for CI and DA-------
544   - $rootScope.LineFn = function (canvasId, LineNumber, shapestyleborderColor, shapestyleborderWidth, offsetX1, offsetY1, x, y) {
545   - $(canvasId).addLayer({
546   - name: 'Line_' + LineNumber,
547   - layer: true,
548   - type: 'line',
549   - draggable: true,
550   - strokeStyle: shapestyleborderColor,
551   - strokeWidth: shapestyleborderWidth,
552   - rounded: true,
553   - x1: offsetX1, y1: offsetY1,
554   - x2: x, y2: y,
555   -
556   - click: function (layer) {
557   - $rootScope.canvasLayerNameCollection = [];
558   - $rootScope.canvasLayerNameCollection.push(layer.name);
559   - $(canvasId).setLayer(layer.name, {
560   - handle: {
561   - type: 'arc',
562   - fillStyle: '#fff',
563   - strokeStyle: '#c33',
564   - strokeWidth: 2,
565   - radius: 3
566   - }
567   - }).drawLayers();
  595 + $rootScope.DrawLineOnModuleItem = function (canvasId, LineNumber, shapestyleborderColor, shapestyleborderWidth, offsetX1, offsetY1, x, y) {
  596 + if ($rootScope.isLinePreviewCompleted == true) {
  597 + $rootScope.isLinePreviewCompleted = false;
  598 + $(canvasId).addLayer({
  599 + name: 'Line_' + LineNumber,
  600 + layer: true,
  601 + type: 'line',
  602 + draggable: true,
  603 + strokeStyle: shapestyleborderColor,
  604 + strokeWidth: shapestyleborderWidth,
  605 + rounded: true,
  606 + x1: offsetX1, y1: offsetY1,
  607 + x2: x, y2: y,
568 608  
  609 + click: function (layer) {
  610 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  611 + //jcanvas property
  612 + layer.draggable = true;
  613 + $rootScope.canvasLayerNameCollection = [];
  614 + $rootScope.canvasLayerNameCollection.push(layer.name);
  615 + $(canvasId).setLayer(layer.name, {
  616 + handle: {
  617 + type: 'arc',
  618 + fillStyle: '#fff',
  619 + strokeStyle: '#c33',
  620 + strokeWidth: 2,
  621 + radius: 3
  622 + }
  623 + }).drawLayers();
569 624  
570   - },
571   - mouseout: function (layer) {
572   - $rootScope.canvasLayerNameCollection = [];
573   - $(canvasId).setLayer(layer.name, {
574   - handle: {
575   - type: 'arc',
576   - fillStyle: '#fff',
577   - strokeStyle: '#c33',
578   - strokeWidth: 0,
579   - radius: 0
580 625 }
  626 + else {
  627 + //jcanvas property
  628 + layer.draggable = false;
  629 + }
  630 + },
  631 + mouseout: function (layer) {
  632 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  633 + //jcanvas property
  634 + layer.draggable = true;
  635 + $rootScope.canvasLayerNameCollection = [];
  636 + $(canvasId).setLayer(layer.name, {
  637 + handle: {
  638 + type: 'arc',
  639 + fillStyle: '#fff',
  640 + strokeStyle: '#c33',
  641 + strokeWidth: 0,
  642 + radius: 0
  643 + }
  644 +
  645 + }).drawLayers();
  646 + }
  647 + else {
  648 + //jcanvas property
  649 + layer.draggable = false;
  650 + }
  651 + },
  652 + mouseover: function (layer) {
581 653  
582   - }).drawLayers();
583   -
584   - },
585   - mouseover: function (layer) {
586   -
587   -
588   - $(canvasId).setLayer(layer.name, {
589   - handle: {
590   - type: 'arc',
591   - fillStyle: '#fff',
592   - strokeStyle: '#c33',
593   - strokeWidth: 2,
594   - radius: 3
  654 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  655 + //jcanvas property
  656 + layer.draggable = true;
  657 +
  658 + $(canvasId).setLayer(layer.name, {
  659 + handle: {
  660 + type: 'arc',
  661 + fillStyle: '#fff',
  662 + strokeStyle: '#c33',
  663 + strokeWidth: 2,
  664 + radius: 3
  665 + }
  666 + }).drawLayers();
595 667 }
596   - }).drawLayers();
  668 + else {
  669 + //jcanvas property
  670 + layer.draggable = false;
  671 + }
  672 + }
597 673  
598   - }
  674 + }).drawLayers();
599 675  
600   - }).drawLayers();
  676 + }
  677 +
601 678  
602 679 $('.btnCursor').trigger('click');
603 680 $(".btn-annotation").removeClass("activebtncolor");
604 681 $('.btnCursor').addClass('activebtncolor');
605 682 }
606 683  
607   - $rootScope.RectangleFn = function (canvasId, RectNumber, shapestyleFillColor, shapestyleborderColor, shapestyleOpacity, shapestyleborderWidth, offsetX1, offsetY1, x, y) {
608   - $(canvasId).addLayer({
609   - layer: true,
610   - name: 'Rect_' + RectNumber,
611   - fillStyle: shapestyleFillColor,
612   - type: 'rectangle',
613   - draggable: true,
614   - strokeStyle: shapestyleborderColor,
615   - opacity: shapestyleOpacity,
616   - strokeWidth: shapestyleborderWidth,
617   - x: offsetX1, y: offsetY1,
618   - width: x - offsetX1,
619   - height: y - offsetY1,
  684 + $rootScope.DrawRectangleOnModuleItem = function (canvasId, RectNumber, shapestyleFillColor, shapestyleborderColor, shapestyleOpacity, shapestyleborderWidth, offsetX1, offsetY1, x, y) {
  685 + if ($rootScope.isRectanglePreviewCompleted == true) {
  686 + $rootScope.isRectanglePreviewCompleted = false;
  687 + $(canvasId).addLayer({
  688 + layer: true,
  689 + name: 'Rect_' + RectNumber,
  690 + fillStyle: shapestyleFillColor,
  691 + type: 'rectangle',
  692 + draggable: true,
  693 + strokeStyle: shapestyleborderColor,
  694 + opacity: shapestyleOpacity,
  695 + strokeWidth: shapestyleborderWidth,
  696 + fromCenter: false,
  697 + x: offsetX1, y: offsetY1,
  698 + width: (x - offsetX1),
  699 + height: (y - offsetY1),
620 700  
621 701 resizeFromCenter: false,
622 702  
623   - dblclick: function () {
624   - // $rootScope.backOpacity();
  703 + dblclick: function () {
625 704  
626   - },
  705 + },
627 706  
628 707 click: function (layer) {
629   - $rootScope.canvasLayerNameCollection = [];
630   - $rootScope.canvasLayerNameCollection.push(layer.name);
631   - $(canvasId).setLayer(layer.name, {
632   - handle: {
633   - type: 'rectangle',
634   - fillStyle: '#fff',
635   - strokeStyle: '#c33',
636   - strokeWidth: 2,
637   - width: 5, height: 5,
638   - cornerRadius: 3
639   - }
640   - }).drawLayers();
641   -
642   - },
  708 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  709 + //jcanvas property
  710 + layer.draggable = true;
  711 + $rootScope.canvasLayerNameCollection = [];
  712 + $rootScope.canvasLayerNameCollection.push(layer.name);
  713 + $(canvasId).setLayer(layer.name, {
  714 + handle: {
  715 + type: 'rectangle',
  716 + fillStyle: '#fff',
  717 + strokeStyle: '#c33',
  718 + strokeWidth: 2,
  719 + width: 5, height: 5,
  720 + cornerRadius: 3
  721 + }
  722 + }).drawLayers();
  723 + }
  724 + else {
  725 + //jcanvas property
  726 + layer.draggable = false;
  727 + }
  728 + },
643 729 mouseout: function (layer) {
644   - $rootScope.canvasLayerNameCollection = [];
645   - $(canvasId).setLayer(layer.name, {
646   - handle: {
647   - type: 'rectangle',
648   - fillStyle: 'pink',
649   - strokeStyle: 'yellow',
650   - strokeWidth: 0,
651   - width: 0, height: 0,
652   - cornerRadius: 0
653   - }
654   -
655   - }).drawLayers();
656   -
657   - },
658   - mouseover: function (layer) {
659   -
  730 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  731 + //jcanvas property
  732 + layer.draggable = true;
  733 + $rootScope.canvasLayerNameCollection = [];
  734 + $(canvasId).setLayer(layer.name, {
  735 + handle: {
  736 + type: 'rectangle',
  737 + fillStyle: 'pink',
  738 + strokeStyle: 'yellow',
  739 + strokeWidth: 0,
  740 + width: 0, height: 0,
  741 + cornerRadius: 0
  742 + }
660 743  
661   - $(canvasId).setLayer(layer.name, {
662   - handle: {
663   - type: 'rectangle',
664   - fillStyle: '#fff',
665   - strokeStyle: '#c33',
666   - strokeWidth: 2,
667   - width: 5, height: 5,
668   - cornerRadius: 3
  744 + }).drawLayers();
  745 + }
  746 + else {
  747 + //jcanvas property
  748 + layer.draggable = false;
  749 + }
  750 + },
  751 + mouseover: function (layer) {
  752 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  753 + //jcanvas property
  754 + layer.draggable = true;
  755 +
  756 + $(canvasId).setLayer(layer.name, {
  757 + handle: {
  758 + type: 'rectangle',
  759 + fillStyle: '#fff',
  760 + strokeStyle: '#c33',
  761 + strokeWidth: 2,
  762 + width: 5, height: 5,
  763 + cornerRadius: 3
  764 + }
  765 + }).drawLayers();
669 766 }
670   - }).drawLayers();
671   -
672   - }
673   - }).drawLayers();
674   -
675   -
676   -
  767 + else {
  768 + //jcanvas property
  769 + layer.draggable = false;
  770 + }
  771 + }
  772 + }).drawLayers();
  773 + }
677 774 $('.btnCursor').trigger('click');
678 775 $(".btn-annotation").removeClass("activebtncolor");
679 776 $('.btnCursor').addClass('activebtncolor');
680 777  
681 778 }
682 779  
683   - $rootScope.CircleFn = function (canvasId, CircleNumber, shapestyleOpacity, shapestyleborderColor, shapestyleborderWidth, shapestyleFillColor, offsetX1, offsetY1, x, y) {
684   -
685   - $(canvasId).addLayer({
686   - layer: true,
687   - name: 'Circle_' + CircleNumber,
688   - type: 'ellipse',
689   - opacity: shapestyleOpacity,
690   - draggable: true,
691   - strokeStyle: shapestyleborderColor,
692   - strokeWidth: shapestyleborderWidth,
693   - fillStyle: shapestyleFillColor,
694   - x: offsetX1, y: offsetY1,
695   - width: (x - offsetX1) * 2, height: (y - offsetY1) * 2,
696   - // Place a handle at each side and each corner
697   - handlePlacement: 'both',
698   -
699   -
700   -
701   - click: function (layer) {
702   -
703   - $rootScope.canvasLayerNameCollection = [];
704   - $rootScope.canvasLayerNameCollection.push(layer.name);
705   - $(canvasId).setLayer(layer.name, {
706   - handle: {
707   - type: 'arc',
708   - fillStyle: '#fff',
709   - strokeStyle: '#c33',
710   - strokeWidth: 2,
711   - radius: 3
  780 + $rootScope.DrawCircleOnModuleItem = function (canvasId, CircleNumber, shapestyleOpacity, shapestyleborderColor, shapestyleborderWidth, shapestyleFillColor, offsetX1, offsetY1, x, y) {
  781 + // console.log("up"+ offsetX1 + " " + offsetY1 + " " + (x - offsetX1) + " " + (y - offsetY1));
  782 + if ($rootScope.isCirclePreviewCompleted == true) {
  783 + $rootScope.isCirclePreviewCompleted = false;
  784 + $(canvasId).addLayer({
  785 + layer: true,
  786 + name: 'Circle_' + CircleNumber,
  787 + type: 'ellipse',
  788 + opacity: shapestyleOpacity,
  789 + draggable: true,
  790 + strokeStyle: shapestyleborderColor,
  791 + strokeWidth: shapestyleborderWidth,
  792 + fillStyle: shapestyleFillColor,
  793 + fromCenter: false,
  794 + x: (offsetX1), y: (offsetY1),
  795 + width: (x - offsetX1), height: (y - offsetY1),
  796 + // Place a handle at each side and each corner
  797 + resizeFromCenter: false,
  798 + handlePlacement: 'both',
  799 + click: function (layer) {
  800 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  801 + //jcanvas property
  802 + layer.draggable = true;
  803 + $rootScope.canvasLayerNameCollection = [];
  804 + $rootScope.canvasLayerNameCollection.push(layer.name);
  805 + $(canvasId).setLayer(layer.name, {
  806 + handle: {
  807 + type: 'arc',
  808 + fillStyle: '#fff',
  809 + strokeStyle: '#c33',
  810 + strokeWidth: 2,
  811 + radius: 3
  812 + }
  813 + }).drawLayers();
712 814 }
713   - }).drawLayers();
714   -
715   - },
716   - mouseout: function (layer) {
717   - $rootScope.canvasLayerNameCollection = [];
718   -
719   - $(canvasId).setLayer(layer.name, {
720   - handle: {
721   - type: 'arc',
722   - fillStyle: '#fff',
723   - strokeStyle: '#c33',
724   - strokeWidth: 0,
725   - // width: 0, height: 0,
726   - radius: 0
  815 + else {
  816 + //jcanvas property
  817 + layer.draggable = false;
727 818 }
728   -
729   - }).drawLayers();
730   -
731   - },
732   - mouseover: function (layer) {
733   -
734   -
735   - $(canvasId).setLayer(layer.name, {
736   - handle: {
737   - type: 'arc',
738   - fillStyle: '#fff',
739   - strokeStyle: '#c33',
740   - strokeWidth: 2,
741   - // width: 5, height: 5,
742   - radius: 3
  819 + },
  820 + mouseout: function (layer) {
  821 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  822 + //jcanvas property
  823 + layer.draggable = true;
  824 + $rootScope.canvasLayerNameCollection = [];
  825 +
  826 + $(canvasId).setLayer(layer.name, {
  827 + handle: {
  828 + type: 'arc',
  829 + fillStyle: '#fff',
  830 + strokeStyle: '#c33',
  831 + strokeWidth: 0,
  832 + // width: 0, height: 0,
  833 + radius: 0
  834 + }
  835 +
  836 + }).drawLayers();
743 837 }
744   - }).drawLayers();
745   -
746   - }
747   - }).drawLayers();
  838 + else {
  839 + layer.draggable = false;
  840 + }
  841 + },
  842 + mouseover: function (layer) {
  843 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  844 + //jcanvas property
  845 + layer.draggable = true;
  846 +
  847 + $(canvasId).setLayer(layer.name, {
  848 + handle: {
  849 + type: 'arc',
  850 + fillStyle: '#fff',
  851 + strokeStyle: '#c33',
  852 + strokeWidth: 2,
  853 + // width: 5, height: 5,
  854 + radius: 3
  855 + }
  856 + }).drawLayers();
  857 + }
  858 + else {
  859 + //jcanvas property
  860 + layer.draggable = false;
  861 + }
  862 + }
  863 + }).drawLayers();
  864 + }
748 865 $('.btnCursor').trigger('click');
749 866 $(".btn-annotation").removeClass("activebtncolor");
750 867 $('.btnCursor').addClass('activebtncolor');
751 868 }
752 869  
753   - $rootScope.ArrowFn = function (canvasId, ArrowNumber, shapestyleborderColor, shapestyleborderWidth, offsetX1, offsetY1, x, y) {
754   -
755   - $('#canvas').drawLine({
756   - layer: true,
757   - name: 'Arrow_' + ArrowNumber,
758   - draggable: true,
759   - strokeStyle: shapestyleborderColor,
760   - strokeWidth: shapestyleborderWidth,
761   - rounded: true,
762   - startArrow: true,
763   - arrowRadius: 7,
764   - arrowAngle: 90,
765   - x1: offsetX1, y1: offsetY1,
766   - x2: x, y2: y,
  870 + $rootScope.DrawArrowOnModuleItem = function (canvasId, ArrowNumber, shapestyleborderColor, shapestyleborderWidth, offsetX1, offsetY1, x, y) {
  871 + if ($rootScope.isArrowPreviewCompleted == true) {
  872 + $rootScope.isArrowPreviewCompleted = false;
  873 + $('#canvas').drawLine({
  874 + layer: true,
  875 + name: 'Arrow_' + ArrowNumber,
  876 + draggable: true,
  877 + strokeStyle: shapestyleborderColor,
  878 + strokeWidth: shapestyleborderWidth,
  879 + rounded: true,
  880 + startArrow: true,
  881 + arrowRadius: 7,
  882 + arrowAngle: 90,
  883 + x1: offsetX1, y1: offsetY1,
  884 + x2: x, y2: y,
767 885  
768   - click: function (layer) {
769   - $rootScope.canvasLayerNameCollection = [];
770   - $rootScope.canvasLayerNameCollection.push(layer.name);
771   - $(canvasId).setLayer(layer.name, {
772   - handle: {
773   - type: 'arc',
774   - fillStyle: '#fff',
775   - strokeStyle: '#c33',
776   - strokeWidth: 2,
777   - // width: 5, height: 5,
778   - radius: 3
  886 + click: function (layer) {
  887 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  888 + //jcanvas property
  889 + layer.draggable = true;
  890 + $rootScope.canvasLayerNameCollection = [];
  891 + $rootScope.canvasLayerNameCollection.push(layer.name);
  892 + $(canvasId).setLayer(layer.name, {
  893 + handle: {
  894 + type: 'arc',
  895 + fillStyle: '#fff',
  896 + strokeStyle: '#c33',
  897 + strokeWidth: 2,
  898 + // width: 5, height: 5,
  899 + radius: 3
  900 + }
  901 + }).drawLayers();
  902 + // $("#canvas").removeLayer(layer.name).drawLayers();
779 903 }
780   - }).drawLayers();
781   - // $("#canvas").removeLayer(layer.name).drawLayers();
782   -
783   - },
784   - mouseout: function (layer) {
785   - $rootScope.canvasLayerNameCollection = [];
786   - $(canvasId).setLayer(layer.name, {
787   - handle: {
788   - type: 'arc',
789   - fillStyle: '#fff',
790   - strokeStyle: '#c33',
791   - strokeWidth: 0,
792   - // width: 0, height: 0,
793   - radius: 0
  904 + else {
  905 + //jcanvas property
  906 + layer.draggable = false;
794 907 }
795 908  
796   - }).drawLayers();
797   -
798   - },
799   - mouseover: function (layer) {
800   -
801   -
802   - $(canvasId).setLayer(layer.name, {
803   - handle: {
804   - type: 'arc',
805   - fillStyle: '#fff',
806   - strokeStyle: '#c33',
807   - strokeWidth: 2,
808   - // width: 5, height: 5,
809   - radius: 3
  909 + },
  910 + mouseout: function (layer) {
  911 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  912 + //jcanvas property
  913 + layer.draggable = true;
  914 + $rootScope.canvasLayerNameCollection = [];
  915 + $(canvasId).setLayer(layer.name, {
  916 + handle: {
  917 + type: 'arc',
  918 + fillStyle: '#fff',
  919 + strokeStyle: '#c33',
  920 + strokeWidth: 0,
  921 + // width: 0, height: 0,
  922 + radius: 0
  923 + }
  924 +
  925 + }).drawLayers();
  926 + }
  927 + else {
  928 + //jcanvas property
  929 + layer.draggable = false;
810 930 }
811   - }).drawLayers();
  931 + },
  932 + mouseover: function (layer) {
812 933  
813   - }
  934 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  935 + //jcanvas property
  936 + layer.draggable = true;
  937 + $(canvasId).setLayer(layer.name, {
  938 + handle: {
  939 + type: 'arc',
  940 + fillStyle: '#fff',
  941 + strokeStyle: '#c33',
  942 + strokeWidth: 2,
  943 + // width: 5, height: 5,
  944 + radius: 3
  945 + }
  946 + }).drawLayers();
  947 + }
  948 + else {
  949 + //jcanvas property
  950 + layer.draggable = false;
  951 + }
  952 + }
814 953  
815   - });
  954 + });
  955 + }
  956 +
816 957 $('.btnCursor').trigger('click');
817 958 $(".btn-annotation").removeClass("activebtncolor");
818 959 $('.btnCursor').addClass('activebtncolor');
819 960 }
820 961  
821   - $rootScope.PinFn = function (canvasId, PinNumber, offsetX1, offsetY1, x, y, PinArcNumber) {
822   -
823   - var xAxisPinDiff = offsetX1 - x;
824   - var yAxisPinDiff = offsetY1 - y;
825   - if (xAxisPinDiff != 0 && yAxisPinDiff != 0)
826   - {
  962 + $rootScope.DrawPinOnModuleItem = function (canvasId, PinNumber, offsetX1, offsetY1, x, y, PinArcNumber) {
  963 +
  964 + if ($rootScope.isPinPreviewCompleted == true) {
  965 + $rootScope.isPinPreviewCompleted = false;
827 966 var radial = $('#canvas').createGradient({
828 967 x1: 50, y1: 50,
829 968 x2: 50, y2: 50,
... ... @@ -843,59 +982,77 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
843 982 x2: x, y2: y,
844 983  
845 984 click: function (layer) {
  985 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  986 + //jcanvas property
  987 + layer.draggable = true;
  988 + $rootScope.shapeTypePin = "Pin";
  989 + $rootScope.canvasLayerNameCollection = [];
  990 + var pinLine_layer = layer.name;
  991 + var pinLine_layer_split = pinLine_layer.split("_");
  992 + var pinArcName = "ArcPin_";
  993 + var pinResult = pinArcName.concat(pinLine_layer_split[1]);
  994 +
  995 + $rootScope.canvasLayerNameCollection.push({ pinName: layer.name, ArcName: pinResult });
  996 +
  997 + $(canvasId).setLayer(layer.name, {
  998 + handle: {
  999 + type: 'arc',
  1000 + fillStyle: '#fff',
  1001 + strokeStyle: '#c33',
  1002 + strokeWidth: 2,
  1003 + // width: 5, height: 5,
  1004 + radius: 3
  1005 + }
  1006 + }).drawLayers();
846 1007  
847   - $rootScope.shapeTypePin = "Pin";
848   - $rootScope.canvasLayerNameCollection = [];
849   - var pinLine_layer = layer.name;
850   - var pinLine_layer_split = pinLine_layer.split("_");
851   - var pinArcName = "ArcPin_";
852   - var pinResult = pinArcName.concat(pinLine_layer_split[1]);
853   -
854   - $rootScope.canvasLayerNameCollection.push({ pinName: layer.name, ArcName: pinResult });
855   -
856   - $(canvasId).setLayer(layer.name, {
857   - handle: {
858   - type: 'arc',
859   - fillStyle: '#fff',
860   - strokeStyle: '#c33',
861   - strokeWidth: 2,
862   - // width: 5, height: 5,
863   - radius: 3
864   - }
865   - }).drawLayers();
866   -
867   -
  1008 + }
  1009 + else {
  1010 + //jcanvas property
  1011 + layer.draggable = false;
  1012 + }
868 1013 },
869 1014 mouseout: function (layer) {
870   -
871   - $rootScope.canvasLayerNameCollection = [];
872   - $(canvasId).setLayer(layer.name, {
873   - handle: {
874   - type: 'arc',
875   - fillStyle: '#fff',
876   - strokeStyle: '#c33',
877   - strokeWidth: 0,
878   - // width: 0, height: 0,
879   - radius: 0
880   - }
881   -
882   - }).drawLayers();
883   -
  1015 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1016 + //jcanvas property
  1017 + layer.draggable = true;
  1018 + $rootScope.canvasLayerNameCollection = [];
  1019 + $(canvasId).setLayer(layer.name, {
  1020 + handle: {
  1021 + type: 'arc',
  1022 + fillStyle: '#fff',
  1023 + strokeStyle: '#c33',
  1024 + strokeWidth: 0,
  1025 + // width: 0, height: 0,
  1026 + radius: 0
  1027 + }
  1028 +
  1029 + }).drawLayers();
  1030 + }
  1031 + else {
  1032 + //jcanvas property
  1033 + layer.draggable = false;
  1034 + }
884 1035 },
885 1036 mouseover: function (layer) {
886 1037  
887   -
888   - $(canvasId).setLayer(layer.name, {
889   - handle: {
890   - type: 'arc',
891   - fillStyle: '#fff',
892   - strokeStyle: '#c33',
893   - strokeWidth: 2,
894   - // width: 5, height: 5,
895   - radius: 3
896   - }
897   - }).drawLayers();
898   -
  1038 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1039 + //jcanvas property
  1040 + layer.draggable = true;
  1041 + $(canvasId).setLayer(layer.name, {
  1042 + handle: {
  1043 + type: 'arc',
  1044 + fillStyle: '#fff',
  1045 + strokeStyle: '#c33',
  1046 + strokeWidth: 2,
  1047 + // width: 5, height: 5,
  1048 + radius: 3
  1049 + }
  1050 + }).drawLayers();
  1051 + }
  1052 + else {
  1053 + //jcanvas property
  1054 + layer.draggable = false;
  1055 + }
899 1056 }
900 1057 }).drawArc({
901 1058 draggable: true,
... ... @@ -909,13 +1066,7 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
909 1066 fillStyle: radial,
910 1067 x: offsetX1, y: offsetY1,
911 1068 radius: 5,
912   - //handle: {
913   - // type: 'arc',
914   - // fillStyle: '#fff',
915   - // strokeStyle: '#c33',
916   - // strokeWidth: 2,
917   - // radius: 3
918   - //},
  1069 +
919 1070  
920 1071 add: function (layer) {
921 1072  
... ... @@ -927,17 +1078,16 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
927 1078  
928 1079 }).drawLayers();
929 1080 }
930   -
  1081 +
  1082 +
931 1083 $('.btnCursor').trigger('click');
932 1084 $(".btn-annotation").removeClass("activebtncolor");
933 1085 $('.btnCursor').addClass('activebtncolor');
934 1086 }
935 1087  
936   - $rootScope.TextAreaFn = function (canvasId, TextNumber, offsetX1, offsetY1, resetTextRect, shapestyleOpacity, shapestyleborderColor, shapestyleborderWidth, shapestyleFillColor, x, y) {
937   -
938   -
939   - debugger;
940   -
  1088 + $rootScope.TextEditorFunctionality = function (canvasId, TextNumber, offsetX1, offsetY1, resetTextRect, shapestyleOpacity, shapestyleborderColor, shapestyleborderWidth, shapestyleFillColor, x, y) {
  1089 + if ($rootScope.isTextAreaPreviewCompleted == true) {
  1090 + $rootScope.isTextAreaPreviewCompleted = false;
941 1091 $('#canvas').drawText({
942 1092 layer: true,
943 1093 draggable: true,
... ... @@ -948,6 +1098,7 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
948 1098 fillStyle: '#36c',
949 1099 strokeWidth: 0,
950 1100 x: $rootScope.offsetX1, y: $rootScope.offsetY1,
  1101 + fromCenter: false,
951 1102 fontSize: '14pt',
952 1103 align: "left",
953 1104 fontFamily: 'Verdana, sans-serif',
... ... @@ -959,117 +1110,146 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
959 1110  
960 1111  
961 1112 })
962   - // Draw rect as wide as the text
963   - .drawRect({
964   - layer: true,
965   - name: "TextRect_" + $rootScope.TextNumber,
966   - dragGroups: ['shapes'],
967   - opacity: $rootScope.shapestyleOpacity,
968   - strokeStyle: $rootScope.shapestyleborderColor,
969   - strokeWidth: $rootScope.shapestyleborderWidth,
970   - fillStyle: $rootScope.shapestyleFillColor,
971   - x: $rootScope.offsetX1, y: $rootScope.offsetY1,
972   - width: $rootScope.x - $rootScope.offsetX1,
973   - height: $rootScope.y - $rootScope.offsetY1,
974   - add: function (layer) {
975   -
976   - $rootScope.TextAreaRectID = layer.name;
977   - $rootScope.rectDimension.push({ width: layer.width, height: layer.height, x: layer.x, y: layer.y });
978   - $rootScope.CurrentWidth = layer.width;
979   - $rootScope.CurrentHeight = layer.height;
980   -
981   - },
982   - click: function (layer) {
983   -
984   - $rootScope.canvasLayerNameCollection = [];
985   - $rootScope.canvasLayerNameCollection.push(layer.name);
986   - $('#canvas').setLayer(layer.name, {
987   - handle: {
988   - type: 'rectangle',
989   - fillStyle: '#fff',
990   - strokeStyle: '#c33',
991   - strokeWidth: 2,
992   - width: 5, height: 5,
993   - cornerRadius: 3
994   - }
995   - }).drawLayers();
996   -
997   - },
998   - dblclick: function (layer) {
999   -
1000   - $rootScope.IsTextAlreadySave = false;
1001   - var RectNameArray = (layer.name).split("_");
1002   -
1003   - var TextAreaRectangleName = "TextArea_";
1004   - var TextAreaRectNameConcat = TextAreaRectangleName.concat(RectNameArray[1]);
1005   - $rootScope.TextAreaRectID = layer.name;
1006   - $rootScope.TextID = TextAreaRectNameConcat;
1007   -
1008   - $rootScope.rectDimension.push({ width: layer.width, height: layer.height, x: layer.x, y: layer.y });
1009   - $("#annotationTextModal").css("padding-right", "0px");
1010   - document.getElementById('modelbackground').style.display = "block";
1011   - $("#annotationTextModal").modal("toggle");
1012   -
1013   - $("#text_area").val('');
1014   - $("#text_area").css({ "font-family": "Arial", "font-size": "14px", "font-weight": "normal", "font-style": "normal", "color": "#000", "text-align": "left", "text-decoration": "none" });
1015   - $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").css({ "background-color": "#000000" });
1016   - // $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").addClass("ActiveDefaultColorAnnotation");
1017   -
1018   - $("#selected-font-family option:eq(0)").prop('selected', true);
1019   - $("#selected-font-size option:eq(0)").prop('selected', true);
1020   -
1021   - $("#text-italic").removeClass("ActiveFormattingButtonClass");
1022   -
1023   - $("#text-bold").removeClass("ActiveFormattingButtonClass");
1024   -
1025   - $("#text-underline").removeClass("ActiveFormattingButtonClass");
1026   -
1027   - $("#text-left").removeClass("ActiveFormattingButtonClass");
1028   -
1029   - $("#text-right").removeClass("ActiveFormattingButtonClass");
1030   -
1031   - $("#text-center").removeClass("ActiveFormattingButtonClass");
1032   -
1033   - },
1034   - mouseout: function (layer) {
1035   - $rootScope.canvasLayerNameCollection = [];
1036   - $('#canvas').setLayer(layer.name, {
1037   - handle: {
1038   - type: 'rectangle',
1039   - fillStyle: 'pink',
1040   - strokeStyle: 'yellow',
1041   - strokeWidth: 0,
1042   - width: 0, height: 0,
1043   - cornerRadius: 0
1044   - }
1045   -
1046   - }).drawLayers();
1047   -
1048   - },
1049   - mouseover: function (layer) {
1050   -
1051   - $('#canvas').setLayer(layer.name, {
1052   - handle: {
1053   - type: 'rectangle',
1054   - fillStyle: '#fff',
1055   - strokeStyle: '#c33',
1056   - strokeWidth: 2,
1057   - width: 5, height: 5,
1058   - cornerRadius: 3
1059   - }
1060   - }).drawLayers();
1061   -
1062   - }
1063   - });
  1113 + // Draw rect as wide as the text
  1114 + .drawRect({
  1115 + layer: true,
  1116 + name: "TextRect_" + $rootScope.TextNumber,
  1117 + dragGroups: ['shapes'],
  1118 + opacity: $rootScope.shapestyleOpacity,
  1119 + strokeStyle: $rootScope.shapestyleborderColor,
  1120 + fromCenter: false,
  1121 + strokeWidth: $rootScope.shapestyleborderWidth,
  1122 + fillStyle: $rootScope.shapestyleFillColor,
  1123 + x: $rootScope.offsetX1, y: $rootScope.offsetY1,
  1124 + width: ($rootScope.x - $rootScope.offsetX1),
  1125 + height: ($rootScope.y - $rootScope.offsetY1),
  1126 + resizeFromCenter: false,
  1127 + add: function (layer) {
  1128 +
  1129 + $rootScope.TextAreaRectID = layer.name;
  1130 + $rootScope.rectDimension.push({ width: layer.width, height: layer.height, x: layer.x, y: layer.y });
  1131 + // $rootScope.CurrentWidth = layer.width;
  1132 + // $rootScope.CurrentHeight = layer.height;
  1133 +
  1134 + },
  1135 + click: function (layer) {
  1136 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1137 + //jcanvas property
  1138 + layer.draggable = true;
  1139 + $rootScope.canvasLayerNameCollection = [];
  1140 + $rootScope.canvasLayerNameCollection.push(layer.name);
  1141 + $('#canvas').setLayer(layer.name, {
  1142 + handle: {
  1143 + type: 'rectangle',
  1144 + fillStyle: '#fff',
  1145 + strokeStyle: '#c33',
  1146 + strokeWidth: 2,
  1147 + width: 5, height: 5,
  1148 + cornerRadius: 3
  1149 + }
  1150 + }).drawLayers();
  1151 + }
  1152 + else {
  1153 + //jcanvas property
  1154 + layer.draggable = false;
  1155 + }
  1156 + },
  1157 + dblclick: function (layer) {
  1158 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1159 + //jcanvas property
  1160 + layer.draggable = true;
  1161 + $rootScope.IsTextAlreadySave = false;
  1162 + var RectNameArray = (layer.name).split("_");
  1163 +
  1164 + var TextAreaRectangleName = "TextArea_";
  1165 + var TextAreaRectNameConcat = TextAreaRectangleName.concat(RectNameArray[1]);
  1166 + $rootScope.TextAreaRectID = layer.name;
  1167 + $rootScope.TextID = TextAreaRectNameConcat;
  1168 +
  1169 + $rootScope.rectDimension.push({ width: layer.width, height: layer.height, x: layer.x, y: layer.y });
  1170 + $("#annotationTextModal").css("padding-right", "0px");
  1171 + document.getElementById('modelbackground').style.display = "block";
  1172 + $("#annotationTextModal").modal("toggle");
  1173 +
  1174 + $("#text_area").val('');
  1175 + $("#text_area").css({ "font-family": "Arial", "font-size": "14px", "font-weight": "normal", "font-style": "normal", "color": "#000", "text-align": "left", "text-decoration": "none" });
  1176 + $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").css({ "background-color": "#000000" });
  1177 + // $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").addClass("ActiveDefaultColorAnnotation");
  1178 +
  1179 + $("#selected-font-family option:eq(0)").prop('selected', true);
  1180 + $("#selected-font-size option:eq(0)").prop('selected', true);
  1181 +
  1182 + $("#text-italic").removeClass("ActiveFormattingButtonClass");
  1183 +
  1184 + $("#text-bold").removeClass("ActiveFormattingButtonClass");
  1185 +
  1186 + $("#text-underline").removeClass("ActiveFormattingButtonClass");
  1187 +
  1188 + $("#text-left").removeClass("ActiveFormattingButtonClass");
  1189 +
  1190 + $("#text-right").removeClass("ActiveFormattingButtonClass");
  1191 +
  1192 + $("#text-center").removeClass("ActiveFormattingButtonClass");
  1193 + }
  1194 + else {
  1195 + //jcanvas property
  1196 + layer.draggable = false;
  1197 + }
  1198 + },
  1199 + mouseout: function (layer) {
  1200 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1201 + //jcanvas property
  1202 + layer.draggable = true;
  1203 + $rootScope.canvasLayerNameCollection = [];
  1204 + $('#canvas').setLayer(layer.name, {
  1205 + handle: {
  1206 + type: 'rectangle',
  1207 + fillStyle: 'pink',
  1208 + strokeStyle: 'yellow',
  1209 + strokeWidth: 0,
  1210 + width: 0, height: 0,
  1211 + cornerRadius: 0
  1212 + }
  1213 +
  1214 + }).drawLayers();
  1215 + }
  1216 + else {
  1217 + //jcanvas property
  1218 + layer.draggable = false;
  1219 + }
  1220 + },
  1221 + mouseover: function (layer) {
  1222 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1223 + //jcanvas property
  1224 + layer.draggable = true;
  1225 + $('#canvas').setLayer(layer.name, {
  1226 + handle: {
  1227 + type: 'rectangle',
  1228 + fillStyle: '#fff',
  1229 + strokeStyle: '#c33',
  1230 + strokeWidth: 2,
  1231 + width: 5, height: 5,
  1232 + cornerRadius: 3
  1233 + }
  1234 + }).drawLayers();
  1235 +
  1236 + }
  1237 + else {
  1238 + //jcanvas property
  1239 + layer.draggable = false;
  1240 + }
  1241 + }
  1242 + });
  1243 +
  1244 +
  1245 +
1064 1246 // Annotation: Edit Text option is missing.
1065   - // alert($rootScope.CurrentWidth);
1066   - // alert($rootScope.CurrentHeight);
1067 1247 $("#annotationTextModal").css("padding-right", "0px");
1068   - if (($rootScope.CurrentWidth > 0 && $rootScope.CurrentHeight > 0) || ($rootScope.CurrentWidth > 0 && $rootScope.CurrentHeight <= 0) || ($rootScope.CurrentWidth <= 0 && $rootScope.CurrentHeight > 0)) {
1069   - $("#annotationTextModal").modal("toggle");
1070   - document.getElementById('modelbackground').style.display = "block";
1071   - }
1072   - $('.btnCursor').trigger('click');
  1248 + $("#annotationTextModal").modal("toggle");
  1249 + document.getElementById('modelbackground').style.display = "block";
  1250 +
  1251 + }
  1252 + $('.btnCursor').trigger('click');
1073 1253 $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").css({ "background-color": "#000000" });
1074 1254  
1075 1255 $("#text_area").val('');
... ... @@ -1095,9 +1275,7 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1095 1275  
1096 1276 $(".btn-annotation").removeClass("activebtncolor");
1097 1277  
1098   - $('.btnCursor').addClass('activebtncolor');
1099   -
1100   -
  1278 + $('.btnCursor').addClass('activebtncolor');
1101 1279  
1102 1280 }
1103 1281  
... ... @@ -1120,15 +1298,18 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1120 1298 // var y = event.clientY;
1121 1299 $rootScope.offsetX1 = 0;
1122 1300 $rootScope.offsetY1 = 0;
  1301 + //alert($location.path());
  1302 +
  1303 + var canvasDiv = document.getElementById('canvasDiv');
  1304 + var verticalScrollPosition = canvasDiv.scrollTop;
  1305 + var horizontlScrollPosition = canvasDiv.scrollLeft;
1123 1306 $rootScope.offsetX1 = event.offsetX;
1124 1307 $rootScope.offsetY1 = event.offsetY;
1125   -
1126 1308 ctx.clearRect(0, 0, 2277, 3248);
1127 1309 $rootScope.clicked = true;
1128   -
1129 1310 // alert("x:"+$rootScope.offsetX1 + " y:" + $rootScope.offsetY1);
  1311 + canvasElement.addEventListener('mousemove', $rootScope.OnPaintCanvasMouseMove, false);
1130 1312 }
1131   -
1132 1313 $rootScope.rectNumber = 0;
1133 1314 $rootScope.LineNumber = 0;
1134 1315 $rootScope.CircleNumber = 0;
... ... @@ -1145,98 +1326,163 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1145 1326 var arrayRect = {};
1146 1327  
1147 1328 var storeLine = '';
1148   - //$rootScope.canvasLayerNameCollection1 = [];
  1329 +
1149 1330 $rootScope.OnPaintCanvasMouseUp = function (event) {
1150 1331  
1151 1332 if (!$rootScope.clicked) {
1152 1333 return;
1153 1334 }
  1335 + var AnnotationCanvas = document.getElementById('canvas');
  1336 + AnnotationCanvas.removeEventListener('mousemove', $rootScope.OnPaintCanvasMouseMove, false);
  1337 +
  1338 + $(".line").remove();
  1339 + $(".arrow").remove();
  1340 + $(".pin").remove();
  1341 + $(".circle").remove();
  1342 + $(".rectangle").remove();
  1343 + $(".textarea").remove();
1154 1344 $rootScope.clicked = false;
1155 1345 $rootScope.x = 0;
1156 1346 $rootScope.y = 0;
1157   -
1158   - $rootScope.x = parseInt(event.clientX - ($("#canvas").offset().left));
1159   - $rootScope.y = parseInt(event.clientY - ($("#canvas").offset().top));
1160   -
1161   -
  1347 + var canvasDiv = document.getElementById('canvasDiv');
  1348 + var verticalScrollPosition = canvasDiv.scrollTop;
  1349 + var horizontlScrollPosition = canvasDiv.scrollLeft;
  1350 + $rootScope.x = event.pageX + horizontlScrollPosition - $('#canvasDiv').offset().left;
  1351 + $rootScope.y = event.pageY + verticalScrollPosition - $('#canvasDiv').offset().top;
1162 1352 var canvasElement = document.getElementById("canvas");
1163 1353 var ctx = canvasElement.getContext("2d");
1164   -
1165 1354 var canvasPaintElement = document.getElementById("canvasPaint");
1166 1355 var PaintCanvasctx = canvasPaintElement.getContext("2d");
1167   -
1168   -
1169 1356 switch ($rootScope.shapeType) {
1170   -
1171 1357 case "cursor":
1172   - // ctx.clearRect(0, 0, 2277, 3248);
1173 1358 ctx.beginPath();
1174 1359 PaintCanvasctx.beginPath();
1175   -
1176   -
1177 1360 break;
1178   -
1179 1361 case "Line":
1180   - //$rootScope.canvasLayerNameCollection = [];
  1362 + $rootScope.isAnnotaionToolBarDrawingModeActive = true;
1181 1363 $rootScope.LineNumber = $rootScope.ObjectIndex++;
1182   -
1183   - $rootScope.LineFn('#canvas', $rootScope.LineNumber, $rootScope.shapestyleborderColor, $rootScope.shapestyleborderWidth, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y)
1184   -
  1364 + // $rootScope.isLinePreviewCompleted = true;
  1365 + $rootScope.DrawLineOnModuleItem('#canvas', $rootScope.LineNumber, $rootScope.shapestyleborderColor, $rootScope.shapestyleborderWidth, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y)
1185 1366 break;
1186   -
1187 1367 case "Rectangle":
  1368 + $rootScope.isAnnotaionToolBarDrawingModeActive = true;
1188 1369 $rootScope.rectNumber = $rootScope.ObjectIndex++;
1189   - $rootScope.RectangleFn('#canvas', $rootScope.rectNumber, $rootScope.shapestyleFillColor, $rootScope.shapestyleborderColor, $rootScope.shapestyleOpacity, $rootScope.shapestyleborderWidth, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y);
1190   -
  1370 + // $rootScope.isRectanglePreviewCompleted = true;
  1371 + $rootScope.DrawRectangleOnModuleItem('#canvas', $rootScope.rectNumber, $rootScope.shapestyleFillColor, $rootScope.shapestyleborderColor, $rootScope.shapestyleOpacity, $rootScope.shapestyleborderWidth, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y);
  1372 +
1191 1373 break;
1192   -
1193 1374 case "Circle":
1194   - // alert($rootScope.shapestyleborderWidth);
  1375 + $rootScope.isAnnotaionToolBarDrawingModeActive = true;
1195 1376 $rootScope.CircleNumber = $rootScope.ObjectIndex++;
1196   -
1197   - $rootScope.CircleFn('#canvas', $rootScope.CircleNumber, $rootScope.shapestyleOpacity, $rootScope.shapestyleborderColor, $rootScope.shapestyleborderWidth, $rootScope.shapestyleFillColor, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y);
  1377 + // $rootScope.isCirclePreviewCompleted = true;
  1378 + $rootScope.DrawCircleOnModuleItem('#canvas', $rootScope.CircleNumber, $rootScope.shapestyleOpacity, $rootScope.shapestyleborderColor, $rootScope.shapestyleborderWidth, $rootScope.shapestyleFillColor, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y);
1198 1379 break;
1199 1380 case "Arrow":
  1381 + $rootScope.isAnnotaionToolBarDrawingModeActive = true;
1200 1382 $rootScope.ArrowNumber = $rootScope.ObjectIndex++;
1201   -
1202   - $rootScope.ArrowFn('#canvas', $rootScope.ArrowNumber, $rootScope.shapestyleborderColor, $rootScope.shapestyleborderWidth, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y);
1203   -
1204   - // $scope.resetRect += 1;
  1383 + //$rootScope.isArrowPreviewCompleted = true;
  1384 + $rootScope.DrawArrowOnModuleItem('#canvas', $rootScope.ArrowNumber, $rootScope.shapestyleborderColor, $rootScope.shapestyleborderWidth, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y);
1205 1385 break;
1206 1386 case "Pin":
  1387 + $rootScope.isAnnotaionToolBarDrawingModeActive = true;
1207 1388 $rootScope.PinNumber = $rootScope.PinObjectIndex++;
1208 1389 $rootScope.PinArcNumber = $rootScope.ArcObjectIndex++;
1209   - $rootScope.PinFn('#canvas', $rootScope.PinNumber, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y, $rootScope.PinArcNumber);
1210 1390  
  1391 + //$rootScope.isPinPreviewCompleted = true;
  1392 +
  1393 + $rootScope.DrawPinOnModuleItem('#canvas', $rootScope.PinNumber, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.x, $rootScope.y, $rootScope.PinArcNumber);
1211 1394 break;
1212 1395 case "TextArea":
1213   -
  1396 + $rootScope.isAnnotaionToolBarDrawingModeActive = true;
1214 1397 $rootScope.IsTextAlreadySave = false;
1215 1398 $("#text_area").val('');
1216 1399 // Draw text
1217 1400 $rootScope.resetTextRect = $rootScope.ObjectIndex++;
1218 1401 $rootScope.TextNumber = $rootScope.ObjectIndex++;
1219   - $rootScope.TextAreaFn('#canvas', $rootScope.TextNumber, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.resetTextRect, $rootScope.shapestyleOpacity, $rootScope.shapestyleborderColor, $rootScope.shapestyleborderWidth, $rootScope.shapestyleFillColor, $rootScope.x, $rootScope.y);
  1402 + // $rootScope.isTextAreaPreviewCompleted = true;
  1403 + $rootScope.TextEditorFunctionality('#canvas', $rootScope.TextNumber, $rootScope.offsetX1, $rootScope.offsetY1, $rootScope.resetTextRect, $rootScope.shapestyleOpacity, $rootScope.shapestyleborderColor, $rootScope.shapestyleborderWidth, $rootScope.shapestyleFillColor, $rootScope.x, $rootScope.y);
1220 1404 break;
1221   -
1222 1405 case "DrawPolygon":
1223   -
1224 1406 break;
1225 1407  
1226 1408 }
1227 1409 //}
1228 1410  
1229 1411 }
1230   -
1231   -
1232   -
1233   -
1234   -
  1412 + $rootScope.OnPaintCanvasMouseMove = function (event) {
  1413 + var canvasDiv = document.getElementById('canvasDiv');
  1414 + var verticalScrollPosition = canvasDiv.scrollTop;
  1415 + var horizontlScrollPosition = canvasDiv.scrollLeft;
  1416 + $rootScope.MouseMoveXAxis = event.pageX + horizontlScrollPosition - $('#canvasDiv').offset().left;
  1417 + $rootScope.MouseMoveYAxis = event.pageY + verticalScrollPosition - $('#canvasDiv').offset().top;
  1418 + switch ($rootScope.shapeType) {
  1419 + case "Line":
  1420 + $(".line").remove();
  1421 + $rootScope.isLinePreviewCompleted = true;
  1422 + $("#canvasDiv").append("<div class='line' style='border:1px dashed #000000;position:absolute;left:" + $rootScope.offsetX1 + "px;top:" + $rootScope.offsetY1 + "px;'></div>");
  1423 + $rootScope.Annotationangle();
  1424 + break;
  1425 + case "Arrow":
  1426 + $(".arrow").remove();
  1427 + $rootScope.isArrowPreviewCompleted = true;
  1428 + $("#canvasDiv").append("<div class='arrow' style='border:1px dashed #000000;position:absolute;left:" + $rootScope.offsetX1 + "px;top:" + $rootScope.offsetY1 + "px;width:" + Math.abs($rootScope.MouseMoveXAxis - $rootScope.offsetX1) + "px;'><div style='border-bottom: 9px solid transparent;border-right: 12px dashed #ccc;border-top: 7px solid transparent;height: 0;left: -6px;position: absolute;top: -8px;width: 0;'></div></div>");
  1429 + $rootScope.Annotationangle();
  1430 + break;
  1431 + case "Pin":
  1432 + $(".pin").remove();
  1433 + $rootScope.isPinPreviewCompleted = true;
  1434 + $("#canvasDiv").append("<div class='pin' style='border:1px dashed #000000;position:absolute;left:" + $rootScope.offsetX1 + "px;top:" + $rootScope.offsetY1 + "px;width:" + Math.abs($rootScope.MouseMoveXAxis - $rootScope.offsetX1) + "px;'><div style='background-color:#fff;left: -8px;position: absolute;top: -6px;width: 10;height:12px;width:12px;border:2px dashed #808080;border-radius:50%;'></div></div>");
  1435 + $rootScope.Annotationangle();
  1436 + break;
  1437 + case "Circle":
  1438 + $(".circle").remove();
  1439 + $rootScope.isCirclePreviewCompleted = true;
  1440 + $("#canvasDiv").append("<div class='circle' style='border-radius:50%;border:1px dashed #000000;position:absolute;left:" + $rootScope.offsetX1 + "px;top:" + $rootScope.offsetY1 + "px;width:" + (Math.abs($rootScope.MouseMoveXAxis - $rootScope.offsetX1)) + "px;height:" + (Math.abs($rootScope.MouseMoveYAxis - $rootScope.offsetY1)) + "px;'></div>");
  1441 + break;
  1442 + case "Rectangle":
  1443 + $(".rectangle").remove();
  1444 + $rootScope.isRectanglePreviewCompleted = true;
  1445 + $("#canvasDiv").append("<div class='rectangle' style='border:1px dashed #000000;position:absolute;left:" + $rootScope.offsetX1 + "px;top:" + $rootScope.offsetY1 + "px;width:" + (Math.abs($rootScope.MouseMoveXAxis - $rootScope.offsetX1)) + "px;height:" + (Math.abs($rootScope.MouseMoveYAxis - $rootScope.offsetY1)) + "px;'></div>");
  1446 + break;
  1447 + case "TextArea":
  1448 + $(".textarea").remove();
  1449 + $rootScope.isTextAreaPreviewCompleted = true;
  1450 + $("#canvasDiv").append("<div class='textarea' style='border:1px dashed #000000;position:absolute;left:" + $rootScope.offsetX1 + "px;top:" + $rootScope.offsetY1 + "px;width:" + (Math.abs($rootScope.MouseMoveXAxis - $rootScope.offsetX1)) + "px;height:" + (Math.abs($rootScope.MouseMoveYAxis - $rootScope.offsetY1)) + "px;'></div>");
  1451 + break;
  1452 + }
  1453 + }
  1454 + $rootScope.Annotationangle = function (event) {
  1455 + var dy = $rootScope.MouseMoveYAxis - $rootScope.offsetY1;
  1456 + var dx = $rootScope.MouseMoveXAxis - $rootScope.offsetX1;
  1457 + var theta = 0;
  1458 + if (dx < 0) {
  1459 + theta = Math.atan(dy / dx) * (180 / Math.PI);
  1460 + theta = theta + 180;
  1461 + }
  1462 + else if (dy < 0) {
  1463 + theta = Math.atan(dy / dx) * (180 / Math.PI);
  1464 + theta = theta + 360;
  1465 + }
  1466 + else {
  1467 + theta = Math.atan(dy / dx) * (180 / Math.PI);
  1468 + }
  1469 + var dottedLineWidth = Math.sqrt(($rootScope.offsetX1 - $rootScope.MouseMoveXAxis) * ($rootScope.offsetX1 - $rootScope.MouseMoveXAxis) + ($rootScope.offsetY1 - $rootScope.MouseMoveYAxis) * ($rootScope.offsetY1 - $rootScope.MouseMoveYAxis));
  1470 + switch ($rootScope.shapeType) {
  1471 + case "Line":
  1472 + $('.line').css({ 'transform': 'rotate(' + theta + 'deg)', '-moz-transform': 'rotate(' + theta + 'deg)', '-webkit-transform': 'rotate(' + theta + 'deg)', 'transform-origin': '0% 0%', 'width': dottedLineWidth + 'px' });
  1473 + break;
  1474 + case "Arrow":
  1475 + $('.arrow').css({ 'transform': 'rotate(' + theta + 'deg)', '-moz-transform': 'rotate(' + theta + 'deg)', '-webkit-transform': 'rotate(' + theta + 'deg)', 'transform-origin': '0% 0%', 'width': dottedLineWidth + 'px' });
  1476 + break;
  1477 + case "Pin":
  1478 + $('.pin').css({ 'transform': 'rotate(' + theta + 'deg)', '-moz-transform': 'rotate(' + theta + 'deg)', '-webkit-transform': 'rotate(' + theta + 'deg)', 'transform-origin': '0% 0%', 'width': dottedLineWidth + 'px' });
  1479 + break;
  1480 + }
  1481 + }
1235 1482  
1236 1483 ///-----
1237   -
1238 1484 $rootScope.saveText = function () {
1239   - debugger;
  1485 +
1240 1486 document.getElementById('modelbackground').style.display = "none";
1241 1487 // this part will work first time when save button will be clicked
1242 1488 if ($rootScope.IsTextAlreadySave == false) {
... ... @@ -1251,15 +1497,8 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1251 1497 $rootScope.textArea = $("#text_area").val();
1252 1498  
1253 1499 // deleting previous text area
1254   -
1255   -
1256 1500 $("#canvas").removeLayer($rootScope.TextID).drawLayers();
1257 1501 $("#canvas").removeLayer($rootScope.TextAreaRectID).drawLayers();
1258   -
1259   -
1260   - // $("#canvas").removeLayer('TextArea_' + $rootScope.TextNumber).drawLayers();
1261   - // $("#canvas").removeLayer("TextRect_" + $rootScope.TextNumber).drawLayers();
1262   -
1263 1502 // Text After Saving in Rectangle
1264 1503 $rootScope.resetTextRect = $rootScope.ObjectIndex++;
1265 1504 $('#canvas').drawText({
... ... @@ -1271,6 +1510,7 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1271 1510 fillStyle: $rootScope.fontColor,
1272 1511 fontStyle: $rootScope.fontWeight + " " + $rootScope.fontStyle,
1273 1512 fontSize: $rootScope.fontSizes,
  1513 + fromCenter: false,
1274 1514 fontFamily: $rootScope.fontFamily,
1275 1515 align: $rootScope.textAlignmt,
1276 1516 strokeWidth: 0,
... ... @@ -1294,228 +1534,221 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1294 1534 opacity: $rootScope.shapestyleOpacity,
1295 1535 strokeStyle: $rootScope.shapestyleborderColor,
1296 1536 strokeWidth: $rootScope.shapestyleborderWidth,
  1537 + fromCenter: false,
1297 1538 x: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].x, y: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].y,
1298 1539 width: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].width,
1299 1540 height: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].height,
  1541 + resizeFromCenter: false,
1300 1542 click: function (layer) {
1301   - $rootScope.shapeTypeText = "textAreaRect";
1302   -
1303   - var layerNameSplit = layer.name;
1304   - var splitedName = layerNameSplit.split("_");
1305   - var textValName = "TextAreaNew_";
1306   - var concatinateResult = textValName.concat(splitedName[1]);
1307   - $rootScope.canvasLayerNameCollection = [];
1308   - $rootScope.canvasLayerNameCollection.push({ textareaRectangle: layer.name, textareaString: concatinateResult });
1309   - $('#canvas').setLayer(layer.name, {
1310   - handle: {
1311   - type: 'rectangle',
1312   - fillStyle: '#fff',
1313   - strokeStyle: '#c33',
1314   - strokeWidth: 2,
1315   - width: 5, height: 5,
1316   - cornerRadius: 3
  1543 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1544 + //jcanvas property
  1545 + layer.draggable = true;
  1546 + $rootScope.shapeTypeText = "textAreaRect";
  1547 +
  1548 + var layerName = layer.name;
  1549 + var splitedName = layerName.split("_");
  1550 + var textValName = "TextAreaNew_";
  1551 + var concatinateResult = textValName.concat(splitedName[1]);
  1552 + $rootScope.canvasLayerNameCollection = [];
  1553 + $rootScope.canvasLayerNameCollection.push({ textareaRectangle: layer.name, textareaString: concatinateResult });
  1554 + $('#canvas').setLayer(layer.name, {
  1555 + handle: {
  1556 + type: 'rectangle',
  1557 + fillStyle: '#fff',
  1558 + strokeStyle: '#c33',
  1559 + strokeWidth: 2,
  1560 + width: 5, height: 5,
  1561 + cornerRadius: 3
  1562 + }
  1563 + }).drawLayers();
  1564 + }
  1565 + else {
  1566 + //jcanvas property
  1567 + layer.draggable = false;
1317 1568 }
1318   - }).drawLayers();
1319 1569 },
1320 1570 dblclick: function (layer) {
  1571 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1572 + //jcanvas property
  1573 + layer.draggable = true;
  1574 + $rootScope.isTextAreaClosedButtonActive = false;
  1575 + $rootScope.IsTextAlreadySave = true;
1321 1576  
1322   - $rootScope.isTextAreaClosedButtonActive = false;
1323   - $rootScope.IsTextAlreadySave = true;
1324   -
1325   - var _rectLayerOnSave = layer.name;
1326   - var _rectLayerOnSaveSplit = _rectLayerOnSave.split("_");
1327   - var TextAreaRectName = "TextAreaNew_";
1328   - var TextAreaRectNameConcatenated = TextAreaRectName.concat(_rectLayerOnSaveSplit[1]);
1329   - // alert(TextAreaRectNameConcatenated);
1330   - //if (_rectLayerOnSaveSplit[1]%2 == 0)
1331   - //{
1332   - // _rectLayerOnSaveSplit[1] = _rectLayerOnSaveSplit[1] - 1;
1333   -
1334   - //}
1335   - //else
1336   - //{
1337   -
1338   - // _rectLayerOnSaveSplit[1] = _rectLayerOnSaveSplit[1];
1339   - //}
1340   -
1341   - $rootScope.layerNameArr = layer.name;
1342   - $rootScope.rectTextArr = TextAreaRectNameConcatenated;
1343   -
1344   -
1345   - $rootScope.rectDimension.push({ width: layer.width, height: layer.height, x: layer.x, y: layer.y });
1346   - // var _rectLayerOnSaveSplitInt;
1347   -
1348   -
1349   - // _rectLayerOnSaveSplitInt = parseInt(_rectLayerOnSaveSplit[1]);
  1577 + var _rectLayerOnSave = layer.name;
  1578 + var _rectLayerOnSaveSplit = _rectLayerOnSave.split("_");
  1579 + var TextAreaRectName = "TextAreaNew_";
  1580 + var TextAreaRectNameConcatenated = TextAreaRectName.concat(_rectLayerOnSaveSplit[1]);
1350 1581  
1351   - //alert(_rectLayerOnSaveSplitInt);
1352   - // alert($rootScope.TextPropertyArray.length);
  1582 + $rootScope.layerNameArr = layer.name;
  1583 + $rootScope.rectTextArr = TextAreaRectNameConcatenated;
1353 1584  
1354 1585  
1355   - for (var i = 0; i <= $rootScope.TextPropertyArray.length - 1; i++) {
1356   - if ($rootScope.TextPropertyArray[i].layerName == TextAreaRectNameConcatenated) {
  1586 + $rootScope.rectDimension.push({ width: layer.width, height: layer.height, x: layer.x, y: layer.y });
1357 1587  
1358   - var textArrVal = $rootScope.TextPropertyArray[i].Rect_Text;
1359   - $("#text_area").val(textArrVal);
1360   - var fontStyleProp = $rootScope.TextPropertyArray[i].FontStyle;
1361   - var fontWeightProp = fontStyleProp.split(" ");
  1588 + for (var i = 0; i <= $rootScope.TextPropertyArray.length - 1; i++) {
  1589 + if ($rootScope.TextPropertyArray[i].layerName == TextAreaRectNameConcatenated) {
1362 1590  
1363   - $("#text_area").css("font-size", $rootScope.TextPropertyArray[i].FontSize);
1364   - $("#text_area").css("font-weight", fontWeightProp[0]);
1365   - $("#text_area").css("font-style", fontWeightProp[1]);
1366   - $("#text_area").css("text-align", $rootScope.TextPropertyArray[i].Align);
1367   - $("#text_area").css("color", $rootScope.TextPropertyArray[i].FontColor);
1368   - $("#text_area").css("font-family", $rootScope.TextPropertyArray[i].FontFamily);
1369   - $("#text_area").css("text-decoration", $rootScope.TextPropertyArray[i].TextDecoration);
1370   - $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").css({ "background-color": $rootScope.TextPropertyArray[i].FontColor });
  1591 + var textArrVal = $rootScope.TextPropertyArray[i].Rect_Text;
  1592 + $("#text_area").val(textArrVal);
  1593 + var fontStyleProp = $rootScope.TextPropertyArray[i].FontStyle;
  1594 + var fontWeightProp = fontStyleProp.split(" ");
1371 1595  
1372   - var CurrentFontFamily = $rootScope.TextPropertyArray[i].FontFamily;
1373   - // alert(CurrentFontFamily);
1374   - // CurrentFontFamily = CurrentFontFamily.replace(/'/g, "");
1375   - var CurrentFontSize = parseInt($rootScope.TextPropertyArray[i].FontSize);
1376   - $("#selected-font-family option[value=" + CurrentFontFamily + "]").prop('selected', true);
1377   - $("#selected-font-size option[value=" + CurrentFontSize + "]").prop('selected', true);
  1596 + $("#text_area").css("font-size", $rootScope.TextPropertyArray[i].FontSize);
  1597 + $("#text_area").css("font-weight", fontWeightProp[0]);
  1598 + $("#text_area").css("font-style", fontWeightProp[1]);
  1599 + $("#text_area").css("text-align", $rootScope.TextPropertyArray[i].Align);
  1600 + $("#text_area").css("color", $rootScope.TextPropertyArray[i].FontColor);
  1601 + $("#text_area").css("font-family", $rootScope.TextPropertyArray[i].FontFamily);
  1602 + $("#text_area").css("text-decoration", $rootScope.TextPropertyArray[i].TextDecoration);
  1603 + $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").css({ "background-color": $rootScope.TextPropertyArray[i].FontColor });
1378 1604  
1379   - CurrentFontFamily = '';
1380   - CurrentFontSize = '';
  1605 + var CurrentFontFamily = $rootScope.TextPropertyArray[i].FontFamily;
  1606 + // alert(CurrentFontFamily);
  1607 + // CurrentFontFamily = CurrentFontFamily.replace(/'/g, "");
  1608 + var CurrentFontSize = parseInt($rootScope.TextPropertyArray[i].FontSize);
  1609 + $("#selected-font-family option[value=" + CurrentFontFamily + "]").prop('selected', true);
  1610 + $("#selected-font-size option[value=" + CurrentFontSize + "]").prop('selected', true);
1381 1611  
1382   - // $(".ActiveDefaultColorAnnotation").css({ "background-color": $rootScope.TextPropertyArray[_rectLayerOnSaveSplitInt].FontColor + "!important" });
1383   - // $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").addClass("ActiveDefaultColorAnnotation");
  1612 + CurrentFontFamily = '';
  1613 + CurrentFontSize = '';
1384 1614  
1385 1615  
1386   - //adding text text decoration active class in text edit pop-up
  1616 + if ($rootScope.TextPropertyArray[i].TextDecoration == "underline") {
1387 1617  
  1618 + $("#text-underline").addClass("ActiveFormattingButtonClass");
1388 1619  
  1620 + }
1389 1621  
  1622 + else {
1390 1623  
1391   - if ($rootScope.TextPropertyArray[i].TextDecoration == "underline") {
1392   -
1393   - $("#text-underline").addClass("ActiveFormattingButtonClass");
1394   -
1395   - }
1396   -
1397   - else {
1398   -
1399   - $("#text-underline").removeClass("ActiveFormattingButtonClass");
1400   -
1401   - }
  1624 + $("#text-underline").removeClass("ActiveFormattingButtonClass");
1402 1625  
  1626 + }
1403 1627  
  1628 + //adding text font weight active class in text edit pop-up
1404 1629  
1405   - //adding text font weight active class in text edit pop-up
  1630 + if (fontWeightProp[0] == 700) {
1406 1631  
1407   - if (fontWeightProp[0] == 700) {
  1632 + $("#text-bold").addClass("ActiveFormattingButtonClass");
1408 1633  
  1634 + }
1409 1635  
  1636 + else {
1410 1637  
1411   - $("#text-bold").addClass("ActiveFormattingButtonClass");
  1638 + $("#text-bold").removeClass("ActiveFormattingButtonClass");
1412 1639  
1413   - }
  1640 + }
1414 1641  
1415   - else {
  1642 + //adding text font style active class in text edit pop-up
1416 1643  
1417   - $("#text-bold").removeClass("ActiveFormattingButtonClass");
  1644 + if (fontWeightProp[1] == "italic") {
1418 1645  
1419   - }
1420 1646  
1421   - //adding text font style active class in text edit pop-up
  1647 + $("#text-italic").addClass("ActiveFormattingButtonClass");
  1648 + }
  1649 + else {
  1650 + $("#text-italic").removeClass("ActiveFormattingButtonClass");
1422 1651  
1423   - if (fontWeightProp[1] == "italic") {
1424 1652  
  1653 + }
1425 1654  
1426   - $("#text-italic").addClass("ActiveFormattingButtonClass");
1427   - }
1428   - else {
1429   - $("#text-italic").removeClass("ActiveFormattingButtonClass");
  1655 + //adding text alignment active class in text edit pop-up
1430 1656  
  1657 + if ($rootScope.TextPropertyArray[i].Align == "left") {
1431 1658  
1432   - }
  1659 + $("#text-right").removeClass("ActiveFormattingButtonClass");
1433 1660  
1434   - //adding text alignment active class in text edit pop-up
  1661 + $("#text-center").removeClass("ActiveFormattingButtonClass")
1435 1662  
1436   - if ($rootScope.TextPropertyArray[i].Align == "left") {
  1663 + $("#text-left").addClass("ActiveFormattingButtonClass");
1437 1664  
1438   - $("#text-right").removeClass("ActiveFormattingButtonClass");
  1665 + }
1439 1666  
1440   - $("#text-center").removeClass("ActiveFormattingButtonClass")
  1667 + else if ($rootScope.TextPropertyArray[i].Align == "right") {
1441 1668  
1442   - $("#text-left").addClass("ActiveFormattingButtonClass");
1443 1669  
1444   - }
1445 1670  
1446   - else if ($rootScope.TextPropertyArray[i].Align == "right") {
  1671 + $("#text-center").removeClass("ActiveFormattingButtonClass")
1447 1672  
  1673 + $("#text-left").removeClass("ActiveFormattingButtonClass");
1448 1674  
  1675 + $("#text-right").addClass("ActiveFormattingButtonClass");
  1676 + }
1449 1677  
1450   - $("#text-center").removeClass("ActiveFormattingButtonClass")
  1678 + else if ($rootScope.TextPropertyArray[i].Align == "center") {
1451 1679  
1452   - $("#text-left").removeClass("ActiveFormattingButtonClass");
  1680 + $("#text-left").removeClass("ActiveFormattingButtonClass");
1453 1681  
1454   - $("#text-right").addClass("ActiveFormattingButtonClass");
  1682 + $("#text-right").removeClass("ActiveFormattingButtonClass");
1455 1683  
  1684 + $("#text-center").addClass("ActiveFormattingButtonClass");
1456 1685  
  1686 + }
1457 1687  
1458 1688 }
1459   -
1460   - else if ($rootScope.TextPropertyArray[i].Align == "center") {
1461   -
1462   - $("#text-left").removeClass("ActiveFormattingButtonClass");
1463   -
1464   - $("#text-right").removeClass("ActiveFormattingButtonClass");
1465   -
1466   - $("#text-center").addClass("ActiveFormattingButtonClass");
1467   -
1468   -
  1689 + else {
  1690 + // alert("no");
1469 1691  
1470 1692 }
1471 1693  
1472   -
1473   -
1474 1694 }
1475   - else {
1476   - // alert("no");
1477   -
1478   - }
1479   -
1480   - }
1481   -
1482 1695  
1483   - // _rectLayerOnSaveSplitInt = '';
1484   - textArrVal = '';
1485   - $("#annotationTextModal").css("padding-right", "0px");
1486   - document.getElementById('modelbackground').style.display = "block";
1487   - $("#annotationTextModal").modal("toggle");
1488 1696  
1489   - // $("#selected-font-family").val(CurrentFontFamily);
1490   - // $("#selected-font-size").val(CurrentFontSize);
  1697 + // _rectLayerOnSaveSplitInt = '';
  1698 + textArrVal = '';
  1699 + $("#annotationTextModal").css("padding-right", "0px");
  1700 + document.getElementById('modelbackground').style.display = "block";
  1701 + $("#annotationTextModal").modal("toggle");
1491 1702  
  1703 + // $("#selected-font-family").val(CurrentFontFamily);
  1704 + // $("#selected-font-size").val(CurrentFontSize);
  1705 + }
  1706 + else {
  1707 + //jcanvas property
  1708 + layer.draggable = false;
  1709 + }
1492 1710  
1493 1711 },
1494 1712 mouseout: function (layer) {
1495   - $rootScope.canvasLayerNameCollection = [];
1496   - $('#canvas').setLayer(layer.name, {
1497   - handle: {
1498   - type: 'rectangle',
1499   - fillStyle: 'pink',
1500   - strokeStyle: 'yellow',
1501   - strokeWidth: 0,
1502   - width: 0, height: 0,
1503   - cornerRadius: 0
1504   - }
1505   - }).drawLayers();
  1713 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1714 + //jcanvas property
  1715 + layer.draggable = true;
  1716 + $rootScope.canvasLayerNameCollection = [];
  1717 + $('#canvas').setLayer(layer.name, {
  1718 + handle: {
  1719 + type: 'rectangle',
  1720 + fillStyle: 'pink',
  1721 + strokeStyle: 'yellow',
  1722 + strokeWidth: 0,
  1723 + width: 0, height: 0,
  1724 + cornerRadius: 0
  1725 + }
  1726 + }).drawLayers();
  1727 + }
  1728 + else {
  1729 + //jcanvas property
  1730 + layer.draggable = false;
  1731 + }
1506 1732 },
1507 1733 mouseover: function (layer) {
1508   - $('#canvas').setLayer(layer.name, {
1509   - handle: {
1510   - type: 'rectangle',
1511   - fillStyle: '#fff',
1512   - strokeStyle: '#c33',
1513   - strokeWidth: 2,
1514   - width: 5, height: 5,
1515   - cornerRadius: 3
1516   - }
1517   - }).drawLayers();
1518   -
  1734 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1735 + //jcanvas property
  1736 + layer.draggable = true;
  1737 + $('#canvas').setLayer(layer.name, {
  1738 + handle: {
  1739 + type: 'rectangle',
  1740 + fillStyle: '#fff',
  1741 + strokeStyle: '#c33',
  1742 + strokeWidth: 2,
  1743 + width: 5, height: 5,
  1744 + cornerRadius: 3
  1745 + }
  1746 + }).drawLayers();
  1747 + }
  1748 + else {
  1749 + //jcanvas property
  1750 + layer.draggable = false;
  1751 + }
1519 1752 }
1520 1753 });
1521 1754 $("#text_area").val('');
... ... @@ -1581,6 +1814,7 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1581 1814 fontFamily: _modifiedFontFamily,
1582 1815 align: _modifiedTextAlign,
1583 1816 strokeWidth: 0,
  1817 + fromCenter: false,
1584 1818 text: _modifiedText,
1585 1819 x: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].x, y: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].y,
1586 1820 maxWidth: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].width,
... ... @@ -1595,154 +1829,189 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1595 1829 groups: ['TextAreaAfterEdit_' + $rootScope.resetTextSave],
1596 1830 dragGroups: ['TextAreaAfterEdit_' + $rootScope.resetTextSave],
1597 1831 opacity: $rootScope.shapestyleOpacity,
  1832 + fromCenter: false,
1598 1833 strokeStyle: $rootScope.shapestyleborderColor,
1599 1834 strokeWidth: $rootScope.shapestyleborderWidth,
1600 1835 x: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].x, y: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].y,
1601 1836 width: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].width,
1602 1837 height: $rootScope.rectDimension[$rootScope.rectDimension.length - 1].height,
  1838 + resizeFromCenter: false,
1603 1839 click: function (layer) {
1604   - $rootScope.shapeTypeText = "textAreaRect";
1605   - var layerNameSplit = layer.name;
1606   - var splitedName = layerNameSplit.split("_");
1607   - var textValName = "TextAreaAfterEdit_";
1608   - var concatinateResult = textValName.concat(splitedName[1]);
1609   - $rootScope.canvasLayerNameCollection = [];
1610   - $rootScope.canvasLayerNameCollection.push({ textareaRectangle: layer.name, textareaString: concatinateResult });
1611   -
1612   - $('#canvas').setLayer(layer.name, {
1613   - handle: {
1614   - type: 'rectangle',
1615   - fillStyle: '#fff',
1616   - strokeStyle: '#c33',
1617   - strokeWidth: 2,
1618   - width: 5, height: 5,
1619   - cornerRadius: 3
1620   - }
1621   - }).drawLayers();
  1840 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1841 + //jcanvas property
  1842 + layer.draggable = true;
  1843 + $rootScope.shapeTypeText = "textAreaRect";
  1844 + var layerName = layer.name;
  1845 + var splitedName = layerName.split("_");
  1846 + var textValName = "TextAreaAfterEdit_";
  1847 + var concatinateResult = textValName.concat(splitedName[1]);
  1848 + $rootScope.canvasLayerNameCollection = [];
  1849 + $rootScope.canvasLayerNameCollection.push({ textareaRectangle: layer.name, textareaString: concatinateResult });
  1850 +
  1851 + $('#canvas').setLayer(layer.name, {
  1852 + handle: {
  1853 + type: 'rectangle',
  1854 + fillStyle: '#fff',
  1855 + strokeStyle: '#c33',
  1856 + strokeWidth: 2,
  1857 + width: 5, height: 5,
  1858 + cornerRadius: 3
  1859 + }
  1860 + }).drawLayers();
  1861 + }
  1862 + else {
  1863 + //jcanvas property
  1864 + layer.draggable = false;
  1865 + }
1622 1866  
1623 1867 },
1624 1868 dblclick: function (layer) {
1625 1869  
  1870 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1871 + //jcanvas property
  1872 + layer.draggable = true;
  1873 + $rootScope.isTextAreaClosedButtonActive = false;
  1874 + $rootScope.IsTextAlreadySave = true;
  1875 + var _rectLayerOnSave = layer.name;
  1876 + var _rectLayerOnSaveSplit = _rectLayerOnSave.split("_");
  1877 + var RectNameAfterEdit = "TextAreaAfterEdit_";
  1878 + var RectNameAfterEditResult = RectNameAfterEdit.concat(_rectLayerOnSaveSplit[1]);
  1879 + $rootScope.modifySavedTextIndexNumber = _rectLayerOnSaveSplit[1];
  1880 +
  1881 + $rootScope.layerNameArr = layer.name;
  1882 + $rootScope.rectTextArr = RectNameAfterEditResult;
  1883 +
  1884 + $rootScope.rectDimension.push({ width: layer.width, height: layer.height, x: layer.x, y: layer.y });
  1885 + $("#text_area").val(_modifiedText);
  1886 + $("#text_area").css("font-size", _modifiedFontSize);
  1887 + $("#text_area").css("font-weight", _modifiedFontWeight);
  1888 + $("#text_area").css("font-style", _modifiedFontStyle);
  1889 + $("#text_area").css("text-align", _modifiedTextAlign);
  1890 + $("#text_area").css("color", _modifiedFontColor);
  1891 + $("#text_area").css("font-family", _modifiedFontFamily);
  1892 + $("#text_area").css("text-decoration", _modifiedFontDecoration);
  1893 + $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").css({ "background-color": _modifiedFontColor });
  1894 +
  1895 + // $(".ActiveDefaultColorAnnotation").css({ "background-color": _modifiedFontColor + "!important" });
  1896 + // $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").addClass("ActiveDefaultColorAnnotation");
  1897 +
  1898 + //khushbu
  1899 + var CurrentFontFamily = _modifiedFontFamily;
  1900 + // alert(CurrentFontFamily);
  1901 + // CurrentFontFamily = CurrentFontFamily.replace(/'/g, "");
  1902 + var CurrentFontSize = parseInt(_modifiedFontSize);
  1903 + $("#selected-font-family option[value=" + CurrentFontFamily + "]").prop('selected', true);
  1904 + $("#selected-font-size option[value=" + CurrentFontSize + "]").prop('selected', true);
  1905 + CurrentFontFamily = '';
  1906 + CurrentFontSize = '';
  1907 + //adding text text decoration active class in text edit pop-up
  1908 + if (_modifiedFontDecoration == "underline") {
  1909 + $("#text-underline").addClass("ActiveFormattingButtonClass");
  1910 + }
  1911 + else {
  1912 + $("#text-underline").removeClass("ActiveFormattingButtonClass");
  1913 + }
1626 1914  
1627   - $rootScope.isTextAreaClosedButtonActive = false;
1628   - $rootScope.IsTextAlreadySave = true;
1629   - var _rectLayerOnSave = layer.name;
1630   - var _rectLayerOnSaveSplit = _rectLayerOnSave.split("_");
1631   - var RectNameAfterEdit = "TextAreaAfterEdit_";
1632   - var RectNameAfterEditResult = RectNameAfterEdit.concat(_rectLayerOnSaveSplit[1]);
1633   - $rootScope.modifySavedTextIndexNumber = _rectLayerOnSaveSplit[1];
1634   -
1635   - $rootScope.layerNameArr = layer.name;
1636   - $rootScope.rectTextArr = RectNameAfterEditResult;
1637   -
1638   - $rootScope.rectDimension.push({ width: layer.width, height: layer.height, x: layer.x, y: layer.y });
1639   - $("#text_area").val(_modifiedText);
1640   - $("#text_area").css("font-size", _modifiedFontSize);
1641   - $("#text_area").css("font-weight", _modifiedFontWeight);
1642   - $("#text_area").css("font-style", _modifiedFontStyle);
1643   - $("#text_area").css("text-align", _modifiedTextAlign);
1644   - $("#text_area").css("color", _modifiedFontColor);
1645   - $("#text_area").css("font-family", _modifiedFontFamily);
1646   - $("#text_area").css("text-decoration", _modifiedFontDecoration);
1647   - $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").css({ "background-color": _modifiedFontColor });
1648   -
1649   - // $(".ActiveDefaultColorAnnotation").css({ "background-color": _modifiedFontColor + "!important" });
1650   - // $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").addClass("ActiveDefaultColorAnnotation");
1651   -
1652   - //khushbu
1653   - var CurrentFontFamily = _modifiedFontFamily;
1654   - // alert(CurrentFontFamily);
1655   - // CurrentFontFamily = CurrentFontFamily.replace(/'/g, "");
1656   - var CurrentFontSize = parseInt(_modifiedFontSize);
1657   - $("#selected-font-family option[value=" + CurrentFontFamily + "]").prop('selected', true);
1658   - $("#selected-font-size option[value=" + CurrentFontSize + "]").prop('selected', true);
1659   - CurrentFontFamily = '';
1660   - CurrentFontSize = '';
1661   - //adding text text decoration active class in text edit pop-up
1662   - if (_modifiedFontDecoration == "underline") {
1663   - $("#text-underline").addClass("ActiveFormattingButtonClass");
1664   - }
1665   - else {
1666   - $("#text-underline").removeClass("ActiveFormattingButtonClass");
1667   - }
  1915 + //adding text font weight active class in text edit pop-up
  1916 + if (_modifiedFontWeight == 700) {
1668 1917  
1669   - //adding text font weight active class in text edit pop-up
1670   - if (_modifiedFontWeight == 700) {
  1918 + $("#text-bold").addClass("ActiveFormattingButtonClass");
  1919 + }
  1920 + else {
1671 1921  
1672   - $("#text-bold").addClass("ActiveFormattingButtonClass");
1673   - }
1674   - else {
  1922 + $("#text-bold").removeClass("ActiveFormattingButtonClass");
1675 1923  
1676   - $("#text-bold").removeClass("ActiveFormattingButtonClass");
  1924 + }
1677 1925  
1678   - }
  1926 + //adding text font style active class in text edit pop-up
  1927 + if (_modifiedFontStyle == "italic") {
1679 1928  
1680   - //adding text font style active class in text edit pop-up
1681   - if (_modifiedFontStyle == "italic") {
  1929 + $("#text-italic").addClass("ActiveFormattingButtonClass");
  1930 + }
  1931 + else {
  1932 + $("#text-italic").removeClass("ActiveFormattingButtonClass");
1682 1933  
1683   - $("#text-italic").addClass("ActiveFormattingButtonClass");
1684   - }
1685   - else {
1686   - $("#text-italic").removeClass("ActiveFormattingButtonClass");
  1934 + }
1687 1935  
1688   - }
  1936 + //adding text alignment active class in text edit pop-up
  1937 + if (_modifiedTextAlign == "left") {
  1938 + $("#text-right").removeClass("ActiveFormattingButtonClass");
  1939 + $("#text-center").removeClass("ActiveFormattingButtonClass")
  1940 + $("#text-left").addClass("ActiveFormattingButtonClass");
  1941 + }
  1942 + else if (_modifiedTextAlign == "right") {
1689 1943  
1690   - //adding text alignment active class in text edit pop-up
1691   - if (_modifiedTextAlign == "left") {
1692   - $("#text-right").removeClass("ActiveFormattingButtonClass");
1693   - $("#text-center").removeClass("ActiveFormattingButtonClass")
1694   - $("#text-left").addClass("ActiveFormattingButtonClass");
1695   - }
1696   - else if (_modifiedTextAlign == "right") {
  1944 + $("#text-center").removeClass("ActiveFormattingButtonClass")
  1945 + $("#text-left").removeClass("ActiveFormattingButtonClass");
  1946 + $("#text-right").addClass("ActiveFormattingButtonClass");
1697 1947  
1698   - $("#text-center").removeClass("ActiveFormattingButtonClass")
1699   - $("#text-left").removeClass("ActiveFormattingButtonClass");
1700   - $("#text-right").addClass("ActiveFormattingButtonClass");
  1948 + }
  1949 + else if (_modifiedTextAlign == "center") {
  1950 + $("#text-left").removeClass("ActiveFormattingButtonClass");
  1951 + $("#text-right").removeClass("ActiveFormattingButtonClass");
  1952 + $("#text-center").addClass("ActiveFormattingButtonClass");
1701 1953  
1702   - }
1703   - else if (_modifiedTextAlign == "center") {
1704   - $("#text-left").removeClass("ActiveFormattingButtonClass");
1705   - $("#text-right").removeClass("ActiveFormattingButtonClass");
1706   - $("#text-center").addClass("ActiveFormattingButtonClass");
  1954 + }
1707 1955  
  1956 + document.getElementById('modelbackground').style.display = "block";
  1957 + $("#annotationTextModal").modal("toggle");
1708 1958 }
1709   -
1710   - document.getElementById('modelbackground').style.display = "block";
1711   - $("#annotationTextModal").modal("toggle");
  1959 + else {
  1960 + //jcanvas property
  1961 + layer.draggable = false;
  1962 + }
1712 1963 },
1713 1964 mouseout: function (layer) {
1714   - $rootScope.canvasLayerNameCollection = [];
1715   - $('#canvas').setLayer(layer.name, {
1716   - handle: {
1717   - type: 'rectangle',
1718   - fillStyle: 'pink',
1719   - strokeStyle: 'yellow',
1720   - strokeWidth: 0,
1721   - width: 0, height: 0,
1722   - cornerRadius: 0
1723   - }
1724   - }).drawLayers();
  1965 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1966 + //jcanvas property
  1967 + layer.draggable = true;
  1968 + $rootScope.canvasLayerNameCollection = [];
  1969 + $('#canvas').setLayer(layer.name, {
  1970 + handle: {
  1971 + type: 'rectangle',
  1972 + fillStyle: 'pink',
  1973 + strokeStyle: 'yellow',
  1974 + strokeWidth: 0,
  1975 + width: 0, height: 0,
  1976 + cornerRadius: 0
  1977 + }
  1978 + }).drawLayers();
  1979 + }
  1980 + else {
  1981 + //jcanvas property
  1982 + layer.draggable = false;
  1983 + }
1725 1984 },
1726 1985 mouseover: function (layer) {
1727   - $('#canvas').setLayer(layer.name, {
1728   - handle: {
1729   - type: 'rectangle',
1730   - fillStyle: '#fff',
1731   - strokeStyle: '#c33',
1732   - strokeWidth: 2,
1733   - width: 5, height: 5,
1734   - cornerRadius: 3
1735   - }
1736   - }).drawLayers();
  1986 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  1987 + //jcanvas property
  1988 + layer.draggable = true;
  1989 + $('#canvas').setLayer(layer.name, {
  1990 + handle: {
  1991 + type: 'rectangle',
  1992 + fillStyle: '#fff',
  1993 + strokeStyle: '#c33',
  1994 + strokeWidth: 2,
  1995 + width: 5, height: 5,
  1996 + cornerRadius: 3
  1997 + }
  1998 + }).drawLayers();
1737 1999  
  2000 + }
  2001 +
  2002 + else {
  2003 + //jcanvas property
  2004 + layer.draggable = false;
  2005 + }
1738 2006 }
  2007 +
1739 2008 });
1740 2009  
1741 2010 }
1742 2011 }
1743 2012 //----
1744 2013  
1745   - $rootScope.BindCanvasDrawingListners = function (event) {
  2014 + $rootScope.onDrawingCanvasClick = function (event) {
1746 2015  
1747 2016 $rootScope.clicked = true;
1748 2017 // OnPaintCanvasMouseDown(event);
... ... @@ -1753,6 +2022,16 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1753 2022 annotationCanvas.addEventListener('mouseup', $rootScope.OnPaintCanvasMouseUp, false);
1754 2023 }
1755 2024 // alert("doclick");
  2025 + // annotation history
  2026 + if (event != undefined) {
  2027 + if ($rootScope.isAnnotaionToolBarDrawingModeActive == false) {
  2028 +
  2029 + $rootScope.getAnnotationTextBasedOnSelectedBodyRegion(event);
  2030 +
  2031 + }
  2032 + }
  2033 +
  2034 +
1756 2035 };
1757 2036  
1758 2037  
... ... @@ -1770,9 +2049,6 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1770 2049  
1771 2050 }
1772 2051 else if ($rootScope.shapeTypeText == "textAreaRect") {
1773   -
1774   -
1775   -
1776 2052 $("#canvas").removeLayer($rootScope.canvasLayerNameCollection[0].textareaRectangle).drawLayers();
1777 2053 $("#canvas").removeLayer($rootScope.canvasLayerNameCollection[0].textareaString).drawLayers();
1778 2054 $rootScope.shapeTypeText = "";
... ... @@ -1780,7 +2056,6 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1780 2056 }
1781 2057 else {
1782 2058  
1783   - // alert($rootScope.canvasLayerNameCollection);
1784 2059 $("#canvas").removeLayer($rootScope.canvasLayerNameCollection).drawLayers();
1785 2060 }
1786 2061  
... ... @@ -1794,12 +2069,6 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1794 2069  
1795 2070 document.getElementById('modelbackground').style.display = "none";
1796 2071  
1797   - //if ($rootScope.isTextAreaClosedButtonActive == true) {
1798   - // $("#canvas").removeLayer('TextArea_' + $rootScope.TextNumber).drawLayers();
1799   - // $("#canvas").removeLayer("TextRect_" + $rootScope.resetTextRect).drawLayers();
1800   -
1801   - //}
1802   -
1803 2072 }
1804 2073 //-- End ----------------------------
1805 2074  
... ... @@ -1836,17 +2105,9 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1836 2105 $rootScope.PaintCanvasMousedownListener = function (canvasContext, x, y) {
1837 2106 if ($rootScope.isLineDrawSelecyed == true) {
1838 2107  
1839   - canvasContext.lineWidth = 0.1;
1840   - //$scope.paintCanvasContext.lineJoin = 'round';
1841   - //$scope.paintCanvasContext.lineCap = 'round';
  2108 + canvasContext.lineWidth = 0.1;
1842 2109 canvasContext.strokeStyle = 'red';
1843   -
1844   -
1845 2110 canvasContext.beginPath();
1846   -
1847   - //var canvasOffset = $("#myCanvas").offset();
1848   - //var offsetX = canvasOffset.left;
1849   - //var offsetY = canvasOffset.top;
1850 2111 canvasContext.moveTo(x, y);
1851 2112 }
1852 2113  
... ... @@ -1891,41 +2152,50 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1891 2152  
1892 2153 $rootScope.disableAnnotationtoolOnListManager = false;
1893 2154 $rootScope.ShowListManager = function () {
  2155 + $rootScope.switchCanvas();
  2156 + $("#annotationpaintbrushsize").attr("href", "#");
1894 2157 console.log('ShowListManager')
1895 2158 $rootScope.disableAnnotationtoolOnListManager = true;
1896   - $('#AnnotaionPopupDiv').find('input, textarea, button, select,img,div').attr('disabled', 'disabled');
  2159 + $('#AnnotaionPopupDiv').find('a,input, textarea, button, select,img,div').attr('disabled', 'disabled');
1897 2160 $('#slider-range-min-2').slider('disable');
  2161 + $("#annotationpaintbrushsize").attr('disabled', 'disabled');
1898 2162 $rootScope.isLoading = true;
1899 2163 $('#spinner').css('visibility', 'visible');
1900 2164  
1901 2165 $('#listManager').css('display', 'block');
1902 2166 $("#listManager").css("visibility", "visible");
1903   -
1904   - // $('#termList option[selected="selected"]').prop("selected", false);
1905   - // $("#termList").find("option[value=" + $rootScope.searchSelectedText + "]").prop("selected", true);
1906   - // $("#termList").find("option").css({ "background-color": "#ffffff", "color": "#000000" });
1907   - // $("#termList").find("option[value=" + $rootScope.searchSelectedText + "]").css({ "background-color": "#3399FF", "color": "#ffffff" });
  2167 +
  2168 + // $('#termList option[selected="selected"]').prop("selected", false);
  2169 + // $("#termList").find("option[value=" + $rootScope.searchSelectedText + "]").prop("selected", true);
  2170 + // $("#termList").find("option").css({ "background-color": "#ffffff", "color": "#000000" });
  2171 + // $("#termList").find("option[value=" + $rootScope.searchSelectedText + "]").css({ "background-color": "#3399FF", "color": "#ffffff" });
1908 2172 $('#listManager').draggable();
1909 2173  
1910 2174  
1911 2175 $rootScope.islistManagerEventAlredayDispachted = true;
1912 2176  
1913 2177 $rootScope.$broadcast('listManagerEvent', true);
1914   -
  2178 +
1915 2179 $('#termList option[selected="selected"]').prop("selected", false);
1916 2180 $('#termList option[value="' + $rootScope.searchSelectedText + '"]').prop("selected", true);
1917 2181 $("#termList").find("option").css({ "background-color": "#ffffff", "color": "#000000" });
1918 2182 $('#termList option[value="' + $rootScope.searchSelectedText + '"]').css({ "background-color": "#3399FF", "color": "#ffffff" });
  2183 +
  2184 +
1919 2185 }
1920 2186  
1921 2187 $rootScope.CloseListManager = function () {
1922   - console.log('close')
  2188 +
  2189 +
  2190 + console.log('close');
1923 2191 $rootScope.disableAnnotationtoolOnListManager = false;
1924 2192 if ($rootScope.MenuModuleName == "DA") {
1925   -
  2193 + $("#annotationpaintbrushsize").attr("href", "#canvasPaint");
1926 2194 if ($rootScope.disableAnnotationtoolOnListManager == false) {
1927   - $('#AnnotaionPopupDiv').find('input, textarea, button, select,img,div').removeAttr('disabled', 'disabled');
  2195 + $('#AnnotaionPopupDiv').find('a,input, textarea, button, select,img,div').removeAttr('disabled', 'disabled');
1928 2196 $('#slider-range-min-2').slider('enable');
  2197 + $("#annotationpaintbrushsize").removeAttr('disabled', 'disabled');
  2198 + $rootScope.switchCanvasToPaintCanvas();
1929 2199 }
1930 2200 }
1931 2201 $('#listManager').css('display', 'none');
... ... @@ -1948,7 +2218,7 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
1948 2218 }
1949 2219 }
1950 2220  
1951   -
  2221 + $rootScope.prevId = "";
1952 2222 }
1953 2223  
1954 2224 function fillListManagerTerms() {
... ... @@ -2068,39 +2338,137 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
2068 2338 };
2069 2339  
2070 2340 $rootScope.UpdateSetting = function (setting) {
2071   -
  2341 + var isReloadingViewRequired = false;
2072 2342 //1.
2073 2343 if (typeof (setting.ethnicity) !== "undefined" && setting.ethnicity !== null) {
2074 2344 $rootScope.ChangeEthnicity(setting, setting.ethnicity);
  2345 + }
  2346 + if (typeof (setting.modesty) !== "undefined" && setting.modesty !== null) {
  2347 + $rootScope.ChangeModesty(setting, setting.modesty);
  2348 + }
  2349 +
  2350 + //2.
  2351 + if((setting.ethnicity!=null && setting.ethnicity!= $rootScope.globalSetting.ethnicity) && (setting.modesty!=null && setting.modesty != $rootScope.globalSetting.modesty) ){
2075 2352 $rootScope.globalSetting.ethnicity = setting.ethnicity;
2076 2353 localStorage.setItem("globalEthnicity", $rootScope.globalSetting.ethnicity);
2077   - $rootScope.setEthncitySettings($rootScope.globalSetting.ethnicity);
  2354 +
  2355 + $rootScope.globalSetting.modesty = setting.modesty;
  2356 + localStorage.setItem("globalModesty", setting.modesty);
  2357 +
  2358 + isReloadingViewRequired = true;
  2359 +
2078 2360 }
2079   - if (typeof (setting.modesty) !== "undefined" && setting.modesty !== null) {
2080   - $rootScope.ChangeModesty(setting, setting.modesty);
  2361 +
  2362 + else if (setting.ethnicity!=null && setting.ethnicity != $rootScope.globalSetting.ethnicity) {
  2363 +
  2364 + $rootScope.globalSetting.ethnicity = setting.ethnicity;
  2365 + localStorage.setItem("globalEthnicity", $rootScope.globalSetting.ethnicity);
  2366 +
  2367 + $rootScope.globalSetting.modesty = localStorage.getItem("globalModesty");
  2368 +
  2369 + isReloadingViewRequired = true;
  2370 + }
  2371 + else if (setting.modesty!= null && setting.modesty != $rootScope.globalSetting.modesty) {
2081 2372 $rootScope.globalSetting.modesty = setting.modesty;
2082 2373 localStorage.setItem("globalModesty", $rootScope.globalSetting.modesty);
2083   - $rootScope.setModestySettings($rootScope.globalSetting.modesty);
  2374 +
  2375 + $rootScope.globalSetting.ethnicity = localStorage.getItem("globalEthnicity");
  2376 +
  2377 + if ($('.modestyImg') != null) {
  2378 + if (($rootScope.globalSetting.modesty == 'Y')) {
  2379 + $('.modestyImg').css('visibility', 'visible');
  2380 + }
  2381 +
  2382 + else {
  2383 + $('.modestyImg').css('visibility', 'hidden');
  2384 + }
  2385 + }
  2386 + $rootScope.changeNavigatorModesty();
2084 2387 }
  2388 +
  2389 + var len = $rootScope.openModules.length;
  2390 + if (len > 0) {
  2391 + if (isReloadingViewRequired == true) {
  2392 + $rootScope.reloadChildController();
  2393 + }
  2394 + }
  2395 + else {
  2396 + $('#modal-settings').modal('hide');
  2397 + }
2085 2398  
2086   - //2.
2087   - //localStorage.setItem("globalEthnicity", $rootScope.globalSetting.ethnicity);
  2399 + };
2088 2400  
2089   - //3.
2090   - //localStorage.setItem("globalModesty", $rootScope.globalSetting.modesty);
2091 2401  
2092   - //4.
2093   - //$rootScope.reloadChildController();
2094 2402  
2095   - var len = $rootScope.openModules.length;
2096   - if (len > 0) {
2097   - $rootScope.reloadChildController();
  2403 + $rootScope.FreeStylePaint = function (e) {
  2404 +
  2405 + var annotationCanvas = document.getElementById("canvas");
  2406 + annotationCanvas.addEventListener('mousedown', $rootScope.OnPaintBrushCanvasMouseDown, false);
  2407 + annotationCanvas.addEventListener('mouseup', $rootScope.OnPaintBrushCanvasMouseUp, false);
  2408 + // document.getElementById("canvasPaint").addEventListener("mouseup", OnPaintBrushCanvasMouseUp);
  2409 + //alert($rootScope.isAnnotaionToolBarDrawingModeActive);
  2410 + //if ($rootScope.isAnnotaionToolBarDrawingModeActive == true) {
  2411 +
  2412 + // alert($rootScope.isAnnotaionToolBarDrawingModeActive);
  2413 + // $rootScope.getAnnotationTextBasedOnSelectedBodyRegion(e);
  2414 +
  2415 + //}
  2416 + //else {
  2417 +
  2418 +
  2419 +
  2420 + //}
2098 2421 }
2099   - else {
2100   - $('#modal-settings').modal('hide');
  2422 +
  2423 +
  2424 +
  2425 +
  2426 +
  2427 +
  2428 +
  2429 + $rootScope.OnPaintBrushCanvasMouseDown = function (event) {
  2430 + $rootScope.isMousedownOnPaintCanvas = true;
  2431 + $rootScope.isStartPointDeleted = false;
  2432 + var annotationCanvas = document.getElementById("canvas");
  2433 + $rootScope.startPageX = parseInt(event.clientX - ($("#canvas").offset().left));
  2434 + $rootScope.startPageY = parseInt(event.clientY - ($("#canvas").offset().top));
  2435 +
  2436 + annotationCanvas.addEventListener('mousemove', $rootScope.OnPaintBrushCanvasMouseMove, false);
  2437 +
  2438 + }
  2439 + $rootScope.OnPaintBrushCanvasMouseMove = function (event) {
  2440 +
  2441 + $rootScope.xPage = parseInt(event.clientX - ($("#canvas").offset().left));
  2442 + $rootScope.yPage = parseInt(event.clientY - ($("#canvas").offset().top));
  2443 +
  2444 + var btneraseBrushSizeValue = $("#btnBrushSize").val();
  2445 + $rootScope.eraseshapeSize = parseInt(btneraseBrushSizeValue);
  2446 +
  2447 + if ($rootScope.isEraseToolSelected == true && $rootScope.isMousedownOnPaintCanvas == true) {
  2448 +
  2449 + var sktch = $('#canvasPaint').sketch();
  2450 + $('#canvasPaint').sketch().actions = [];
  2451 + var paintCanvas = document.getElementById("canvasPaint");
  2452 + var paintCanvasContext = paintCanvas.getContext('2d');
  2453 + if ($rootScope.isStartPointDeleted == false) {
  2454 +
  2455 + paintCanvasContext.clearRect($rootScope.startPageX, $rootScope.startPageY, $rootScope.eraseshapeSize, $rootScope.eraseshapeSize);
  2456 +
  2457 + $rootScope.isStartPointDeleted = true;
  2458 + }
  2459 +
  2460 + paintCanvasContext.clearRect($rootScope.xPage, $rootScope.yPage, $rootScope.eraseshapeSize, $rootScope.eraseshapeSize);
  2461 +
  2462 +
2101 2463 }
  2464 + }
  2465 + $rootScope.OnPaintBrushCanvasMouseUp = function (event) {
  2466 + $rootScope.isMousedownOnPaintCanvas = false;
  2467 + $rootScope.isEraseToolSelected = false;
  2468 + $(".btn-annotation-erase").removeClass("activebtncolor");
  2469 +
  2470 + }
2102 2471  
2103   - };
2104 2472  
2105 2473 $rootScope.reloadChildController = function () {
2106 2474  
... ... @@ -2114,8 +2482,8 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
2114 2482 //Check that what current bodyview is open
2115 2483 if ($rootScope.openViews.length > 0) {
2116 2484 var openViewLen = $rootScope.openViews.length;
2117   - var currentOpenViewId = $rootScope.openViews[openViewLen - 1].BodyViewId;
2118   - //$rootScope.isSettingEventAlredayDispachted = true;
  2485 + var currentOpenViewId = localStorage.getItem("currentBodyViewId");//$rootScope.openViews[openViewLen - 1].BodyViewId;
  2486 + $rootScope.isSettingEventAlredayDispachted = true;
2119 2487 $rootScope.$broadcast('reloadDABodyViewEvent', { reloadDABodyViewId: currentOpenViewId }, true);
2120 2488 }
2121 2489 else {
... ... @@ -2125,6 +2493,14 @@ AIA.controller(&quot;HomeController&quot;, [&quot;$rootScope&quot;, &quot;Modules&quot;, &quot;$log&quot;, &quot;$location&quot;,
2125 2493 }
2126 2494 };
2127 2495  
  2496 + $rootScope.ShowExportImageWindow = function () {
  2497 + $(".export-image").css("display", "block");
  2498 + };
2128 2499  
  2500 + $rootScope.CloseExportImageWindow = function () {
  2501 + console.log('close')
  2502 + $(".export-image").css("display", "none");
  2503 + };
  2504 +
2129 2505 }]
2130 2506 );
2131 2507 \ No newline at end of file
... ...
400-SOURCECODE/AIAHTML5.Web/app/views/ca/ca-view.html
... ... @@ -59,43 +59,43 @@
59 59 </div>
60 60 <div role="tabpanel" ng-class="{'tab-pane active' : activeTab === 2,'tab-pane' : activeTab !==2 }" id="list-view">
61 61 <div class="panel col-sm-12 table-responsive" style="padding-left:0px; padding-right:0; margin-left:11px; margin-bottom:0; width:99%;">
62   - <table class="table table-hover table-fixed bg-white table-txt12" style="padding-left:25px; width:100%;">
  62 + <table class="table table-hover table-fixed bg-white table-txt12 tablecaview" style="padding-left:25px; width:100%;">
63 63 <thead class="clstheadca">
64   - <tr class="active">
65   - <th style="min-width: 250px;">Title</th>
66   - <th style="min-width: 250px;">Region</th>
67   - <th style="min-width: 260px;">System</th>
68   - <th style="min-width: 280px;">Specialty</th>
  64 + <tr class="active" style="background:#f5f5f5;">
  65 + <th style="width:25%">Title</th>
  66 + <th style="width:25%">Region</th>
  67 + <th style="width:25%">System</th>
  68 + <th style="width:25%">Specialty</th>
69 69 </tr>
70 70 </thead>
71 71 <tbody id="ListViewDiv" ng-if="!filterstring" class="clstbodyca">
72 72 <tr id="{{item._id}}" ng-class="{selected: item._id === idSelected}" ng-click="showItem(item._id)" ng-dblclick="openView($event)" ng-repeat="item in selectedCAListViewData">
73   - <td style="max-width: 250px;">
  73 + <td style="width:25%">
74 74 {{item._Title}}
75 75 </td>
76   - <td style="max-width: 250px;">
  76 + <td style="width:25%">
77 77 {{item._BodyRegion}}
78 78 </td>
79   - <td style="min-width: 260px;">
  79 + <td style="width:25%">
80 80 {{item._BodySystem}}
81 81 </td>
82   - <td style="max-width: 280px;">
  82 + <td style="width:25%">
83 83 {{item._MedicalSpecialty}}
84 84 </td>
85 85 </tr>
86 86 </tbody>
87 87 <tbody id="ListViewDiv" ng-if="filterstring" class="clstbodyca">
88 88 <tr ng-click="showItem(item._id)" ng-class="{selected: item._id === idSelected}" ng-dblclick="openView($event)" ng-repeat="item in searchCAListViewData">
89   - <td style="max-width: 250px;">
  89 + <td style="width:25%">
90 90 {{item._Title}}
91 91 </td>
92   - <td style="max-width: 250px;">
  92 + <td style="width:25%">
93 93 {{item._BodyRegion}}
94 94 </td>
95   - <td style="min-width: 260px;">
  95 + <td style="width:25%">
96 96 {{item._BodySystem}}
97 97 </td>
98   - <td style="max-width: 280px;">
  98 + <td style="width:25%">
99 99 {{item._MedicalSpecialty}}
100 100 </td>
101 101 </tr>
... ...
400-SOURCECODE/AIAHTML5.Web/app/views/da/da-view.html
... ... @@ -238,7 +238,7 @@
238 238 </div>
239 239  
240 240 <div class="col-xs-12">
241   - <button id="btnStrutureBox" onclick="enableShowHideStructureBox()" class="btn btn-primary btn-sm marginTop5 btn-block tooltip-custom" data-toggle="tooltip" data-placement="bottom" title="Show/Hide Structure Name Boxes"> <img src="content/images/comment-box.png" alt=""></button>
  241 + <button id="btnStrutureBox" onclick="enableShowHideStructureBox()" class="btn btn-primary btn-sm marginTop5 btn-block tooltip-custom" data-toggle="tooltip" data-placement="bottom" name="showAnnotationStructure" title="Show/Hide Structure Name Boxes"> <img src="content/images/comment-box.png" alt=""></button>
242 242 </div>
243 243  
244 244 </div>
... ... @@ -313,7 +313,7 @@
313 313  
314 314 <div class="dropdown-menu active" id="navigatorDiv" style="min-height:auto; min-width:auto; ">
315 315 <div id="containment-wrapper" align="center" style="min-width:auto;height:119px; ">
316   - <img id="navimg" ng-src="{{navimgsrc}}" alt=""></img>
  316 + <img id="navimg" alt=""></img>
317 317 <div id="draggable" class="draggable ui-widget-content" ng-mouseup="ScrollCanvasDiv()" ng-style="dragdivposition">
318 318 </div>
319 319 </div>
... ... @@ -328,7 +328,7 @@
328 328 <div class="row">
329 329 <div id="canvasDiv" class="col-sm-12 img-thumbnail" align="center">
330 330 <canvas id="canvasPaint" ng-click="FreeStylePaint($event)" width="2277" height="3248" class="canvas-annotationStyle1"></canvas>
331   - <canvas id="canvas" ng-click="BindCanvasDrawingListners($event)" width="2277" height="3248" class="canvas-annotationStyle"></canvas>
  331 + <canvas id="canvas" ng-click="onDrawingCanvasClick($event)" width="2277" height="3248" class="canvas-annotationStyle"></canvas>
332 332 </div>
333 333 <!--<div id="canvasDiv" style=" width: 95% !important;top:0px;overflow:scroll;background-color:white;">-->
334 334 <!--<div id="daLoaderLabel">Loading....</div>-->
... ...
400-SOURCECODE/AIAHTML5.Web/app/widget/TopMenu.html
... ... @@ -15,7 +15,7 @@
15 15 <li><a href="#">Open Existing Curriculum</a></li>
16 16 <li><a href="#">Save Curriculum As</a></li>
17 17 <li role="separator" class="divider"></li>
18   - <li><a href="#">Export Image</a></li>
  18 + <li><a href="" id="exportImageAnchor" data-toggle="modal" ng-click="ShowExportImageWindow()">Export Image</a></li>
19 19 <li role="separator" class="divider"></li>
20 20 <li><a href="#">Print Active Viewer</a></li>
21 21 <li><a href="#">Print All Open Viewers</a></li>
... ... @@ -30,14 +30,14 @@
30 30 <ul class="dropdown-menu">
31 31 <!--<li><a href="#" ng-click="ShowListManager()">List Manager</a></li>-->
32 32  
33   - <li><a href="#" ng-click="ShowListManager()">List Manager</a></li>
  33 + <li ng-class="disableSubMenu"><a href="#" ng-click="ShowListManager()">List Manager</a></li>
34 34 <!--#7904-->
35 35 <li><a href="#" id="annotationToolBarOptions" ng-click="ShowAnnotationWindow()">Annotation Toolbar</a></li>
36 36  
37   - <li><a href="#">Add to Existing Curriculum</a></li>
  37 + <li ng-class="disableSubMenu"><a href="#">Add to Existing Curriculum</a></li>
38 38 <li><a ng-click="ShowSettingWindow()" class="cursor-pointer">Settings</a></li>
39 39 <li role="separator" class="divider"></li>
40   - <li><a href="#">Lab Exercises PDF</a></li>
  40 + <li ng-class="disableMenuoption"><a href="#">Lab Exercises PDF</a></li>
41 41 </ul>
42 42 </li>
43 43 <li class="dropdown">
... ... @@ -87,5 +87,5 @@
87 87 </div>
88 88 </div>
89 89 </div>
90   -
  90 +
91 91 </div>
... ...
400-SOURCECODE/AIAHTML5.Web/content/data/json/settings/fontstyle.json
... ... @@ -160,8 +160,6 @@
160 160 },{
161 161 "FontName": "Vivaldi"
162 162 },{
163   -"FontName": "Webdings"
164   -},{
165 163 "FontName": "Wide Latin"
166 164 },{
167 165 "FontName": "Wingdings"
... ...
400-SOURCECODE/AIAHTML5.Web/index.html
1 1 <!DOCTYPE html>
2 2 <html lang="en" ng-cloak ng-app="AIA">
3 3 <head>
4   - <!--<base href="/AIAHTML5/" />-->
  4 + <!--<base href="/AIAHTML5/" />-->
5 5 <!--<base href="/AIA/" />-->
6 6 <base href="/" />
7 7 <meta charset="utf-8">
... ... @@ -23,7 +23,6 @@
23 23 <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Open+Sans:400,800,700,600,400italic">
24 24  
25 25 <!--<link rel="styleSheet" href="themes/default/css/uigrid/ui-grid.min.css" />-->
26   -
27 26 <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
28 27 <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
29 28 <!--[if lt IE 9]>
... ... @@ -42,7 +41,6 @@
42 41  
43 42 <!--Annotation Toolbar: Jcanvas-->
44 43 <style>
45   -
46 44 /*.ActiveDefaultColorAnnotation {
47 45 background-color: #000000!important;
48 46 }*/
... ... @@ -53,9 +51,9 @@
53 51 color: #fff !important;
54 52  
55 53 }
56   -
57   -
58   - .ActiveFormattingButtonClass {
  54 +
  55 +
  56 + .ActiveFormattingButtonClass {
59 57 background-color: #1B92D0 !important;
60 58 }
61 59  
... ... @@ -151,7 +149,6 @@
151 149 color: #000;
152 150 border-radius: 0;
153 151 }
154   -
155 152 </style>
156 153  
157 154  
... ... @@ -487,7 +484,7 @@
487 484 <button type="button" class="close" aria-label="Close" ng-click="CloseAnnotationTool()"><span aria-hidden="true">&times;</span></button>
488 485 <h4 class="modal-title" id="myModalLabel">Annotation</h4>
489 486 </div>
490   - <div class="modal-body" id="AnnotaionPopupDiv" >
  487 + <div class="modal-body" id="AnnotaionPopupDiv">
491 488 <div class="row">
492 489 <div class="col-sm-12">
493 490 <h5>Mode</h5>
... ... @@ -495,7 +492,7 @@
495 492 <div class="btn-group btn-group-justified" role="group" aria-label="...">
496 493 <div class="btn-group" role="group" tooltip>
497 494 <div id="identify-block" style="display: none; font-size:13px;">Identify Mode</div>
498   - <button id="OnIdentify" type="button" class="btn btn-sm btn-success" ng-click="OnIdentifyClick()">Identify</button>
  495 + <button id="OnIdentify" type="button" class="btn btn-sm btn-success" ng-click="OnIdentifyClick()">Identify</button>
499 496 </div>
500 497 <div class="btn-group" role="group">
501 498 <div id="draw-block" style="display: none; font-size: 13px;">Draw Mode</div>
... ... @@ -511,24 +508,24 @@
511 508 <div class="" role="group" align="center">
512 509 <div id="cursor-block" style="display: none; font-size:13px;"></div>
513 510 <button type="button" class="btn btn-black-annotation btn-xs mrgnBtm5 btnCursor" ng-mouseover="mouseMoveToolTip(75, 60, 120, 'Select Cursor(s)')" ng-mouseleave="mouseOutToolTip()" ng-click="Cursor()"><img src="content/images/icon-identity.png" alt="" title=""></button>
514   - <button type="button" class="btn btn-black-annotation btn-xs mrgnBtm5 btn-annotation btn-annotation-pin" ng-mouseover="mouseMoveToolTip(75, 100, 120, 'Draw Pin')" ng-mouseleave="mouseOutToolTip()" ng-click="DrPin($event)"><img src="content/images/draw-pin.png" alt="" title=""></button>
  511 + <button type="button" class="btn btn-black-annotation btn-xs mrgnBtm5 btn-annotation btn-annotation-pin" ng-mouseover="mouseMoveToolTip(75, 100, 120, 'Draw Pin')" ng-mouseleave="mouseOutToolTip()" ng-click="DrawPin($event)"><img src="content/images/draw-pin.png" alt="" title=""></button>
515 512 <button type="button" class="btn btn-black-annotation btn-xs mrgnBtm5 btn-annotation btn-annotation-arrow" ng-mouseover="mouseMoveToolTip(75, 120, 120, 'Draw Arrow')" ng-mouseleave="mouseOutToolTip()" ng-click="DrawArrow($event)"><img src="content/images/draw-arrow.png" alt="" title=""></button>
516 513 <button type="button" class="btn btn-black-annotation btn-xs mrgnBtm5 btn-annotation btn-annotation-Text" ng-mouseover="mouseMoveToolTip(75, 140, 120, 'Draw Text')" ng-mouseleave="mouseOutToolTip()" ng-click="DrawText($event)"><img src="content/images/draw-text.png" alt="" title=""></button>
517 514 </div>
518 515 <div class="" role="group" align="center">
519   - <button type="button" class="btn btn-black-annotation btn-xs btn-annotation btn-annotation-line" ng-mouseover="mouseMoveToolTip(95, 60, 120, 'Draw Line')" ng-mouseleave="mouseOutToolTip()" ng-click="DrLine($event)"><img src="content/images/draw-line.png" alt="" title=""></button>
  516 + <button type="button" class="btn btn-black-annotation btn-xs btn-annotation btn-annotation-line" ng-mouseover="mouseMoveToolTip(95, 60, 120, 'Draw Line')" ng-mouseleave="mouseOutToolTip()" ng-click="DrawLine($event)"><img src="content/images/draw-line.png" alt="" title=""></button>
520 517 <button type="button" class="btn btn-black-annotation btn-xs btn-annotation btn-annotation-rectangle" ng-mouseover="mouseMoveToolTip(95, 100, 120, 'Draw Rectangle')" ng-mouseleave="mouseOutToolTip()" ng-click="DrawRectangle($event)"><img src="content/images/draw-rec.png" alt="" title=""></button>
521 518 <button type="button" class="btn btn-black-annotation btn-xs btn-annotation btn-annotation-circle" ng-mouseover="mouseMoveToolTip(95, 120, 120, 'Draw Circle')" ng-mouseleave="mouseOutToolTip()" ng-click="DrawCircle($event)"><img src="content/images/draw-cir.png" alt="" title=""></button>
522   - <button type="button" class="btn btn-black-annotation btn-xs btn-annotation" ng-mouseover="mouseMoveToolTip(95, 140, 120, 'Draw Polygon')" ng-mouseleave="mouseOutToolTip()" ng-click="DrawPolygon($event)"><img src="content/images/draw-poly.png" alt="" title=""></button>
  519 + <!--<button type="button" class="btn btn-black-annotation btn-xs btn-annotation" ng-mouseover="mouseMoveToolTip(95, 140, 120, 'Draw Polygon')" ng-mouseleave="mouseOutToolTip()" ng-click="DrawPolygon($event)"><img src="content/images/draw-poly.png" alt="" title=""></button>-->
523 520 </div>
524 521 </div>
525 522 </div>
526   - <div class="well-popup well blankshapediv">
  523 + <div class="well-popup well blankshapediv" ng-mouseover="mouseMoveToolTip(200, 170, 120, 'Edit Style')" ng-mouseleave="mouseOutToolTip()">
527 524 <!--#7931-->
528 525  
529 526 <div id="edit-block" style="display: none; font-size: 13px;">Edit Shape Style</div>
530   - <div class="outlinediv">
531   - <div id="shapeStyleDiv" class="fullcolordiv" ng-click="disableAnnotationtoolOnListManager||enableAnnotationToolBar()">
  527 + <div id="previewBorder" class="outlinediv" ng-mouseover="mouseMoveToolTip(170, 170, 120, 'Edit Style')" ng-mouseleave="mouseOutToolTip()">
  528 + <div id="shapeStyleDiv" style="background-color: #ffffff;" class="fullcolordiv" ng-click="disableAnnotationtoolOnListManager||enableAnnotationToolBar()">
532 529  
533 530 </div>
534 531  
... ... @@ -537,21 +534,21 @@
537 534 <div class="well well-popup">
538 535 <div class="" role="group" aria-label="...">
539 536 <div>
540   - <a href="#canvasPaint" data-size="1" data-color="#fff" id="annotationpaintbrushsize" class="btn btn-primary btn-xs pull-left btn-annotation" role="button" data-toggle="tooltip" data-placement="top" title="Paint" style="margin-right:1%;" ng-click="paintBrush()"><i class="fa fa-paint-brush"></i></a>
541   - <button type="button" class="btn btn-primary btn-xs pull-left btn-annotation" data-toggle="tooltip" data-placement="top" title="Erase" ng-click="EraseDrawing()"><i class="fa fa-eraser"></i></button>&nbsp;
  537 + <a href="#canvasPaint" data-size="1" data-color="#fff" id="annotationpaintbrushsize" ng-mouseover="mouseMoveToolTip(270, 50, 120, 'Paint')" ng-mouseleave="mouseOutToolTip()" class="btn btn-black-annotation btn-xs pull-left btn-annotation btn-annotation-brush" role="button" data-placement="top" style="margin-right:1%;" ng-click="paintBrush()"><i class="fa fa-paint-brush"></i></a>
  538 + <button type="button" class="btn btn-black-annotation btn-xs pull-left btn-annotation btn-annotation-erase" data-placement="top" ng-click="EraseDrawing()" ng-mouseover="mouseMoveToolTip(270, 70, 120, 'Erase')" ng-mouseleave="mouseOutToolTip()"><i class="fa fa-eraser"></i></button>&nbsp;
542 539 <div style="width: 80px; margin: 0px 0px 0px 4px; display: inline-block;float:left;">
543   - <div style="width: 58px; float: left;">
  540 + <div style="width: 58px; float: left;" ng-mouseover="mouseMoveToolTip(270, 100, 120, 'Brush Size')" ng-mouseleave="mouseOutToolTip()">
544 541 <input type="text" id="btnBrushSize" class="form-control" value="1" style="height:32px;border-radius:0;" oninput="Brushsize(this)">
545 542 </div>
546 543 <div style="width: 22px; float: left;">
547 544 <div style="width: 100%; float: left; height: 16px;">
548   - <button type="button" id="btnBrushSizeIncrement" class="btn btn-default" style="padding:0 5px;border-radius:0;font-size: 10px;vertical-align:top;">
  545 + <button type="button" id="btnBrushSizeIncrement" ng-mouseover="mouseMoveToolTip(270, 100, 120, 'Brush Size')" ng-mouseleave="mouseOutToolTip()" class="btn btn-default" style="padding:0 5px;border-radius:0;font-size: 10px;vertical-align:top;">
549 546  
550 547 <img style="width:10px;height:10px;" src="~/../content/images/DA/angle-up.png">
551 548 </button>
552 549 </div>
553 550 <div style="width: 100%; float: left; height: 16px;">
554   - <button type="button" id="btnBrushSizeDecrease" class="btn btn-default" style="padding:0 5px;border-radius:0;font-size: 10px;vertical-align:top;">
  551 + <button type="button" id="btnBrushSizeDecrease" ng-mouseover="mouseMoveToolTip(270, 100, 120, 'Brush Size')" ng-mouseleave="mouseOutToolTip()" class="btn btn-default" style="padding:0 5px;border-radius:0;font-size: 10px;vertical-align:top;">
555 552 <img style="width:10px;height:10px;" src="~/../content/images/DA/angle-down.png">
556 553 </button>
557 554 </div>
... ... @@ -560,7 +557,7 @@
560 557 </div>
561 558  
562 559 <div class="pull-left" style="width:45%; margin-left:2%;margin-top:5px;">
563   - <div id="slider-range-min-2"></div>
  560 + <div id="slider-range-min-2" ng-mouseover="mouseMoveToolTip(270, 170, 120, 'Brush Size')" ng-mouseleave="mouseOutToolTip()"></div>
564 561 </div>
565 562 <div class="clearfix"></div>
566 563 </div>
... ... @@ -579,77 +576,77 @@
579 576 </div>
580 577  
581 578 <!--Modal For Annotation Text Box-->
582   - <div id="annotationTextModal" style="display:none;z-index: 1000000000;width:500px;height:241px;padding-right:0!important;position:fixed;left:0;right:0;top:0px;bottom:0;margin:auto;">
583   -
584   - <div class="modal-content">
585   - <div class="modal-header" style="background-color: #808D43;padding:10px;border-bottom:0;">
586   - <!--<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>-->
587   - <h4 class="modal-title" id="myModalLabel" style="font-weight:bold;">Enter Text to be put in a box</h4>
588   - </div>
589   - <div class="modal-body">
590   - <div class="col-xs-12" style="padding:20px 0;">
591   - <div class="form-inline">
592   - <!--Annotation: Text in different font style is same.-->
593   - <select class="form-control" id="selected-font-family"></select>
594   - <select class="form-control" id="selected-font-size">
595   - <option>14</option>
596   - <option>16</option>
597   - <option>18</option>
598   - <option>20</option>
599   - <option>22</option>
600   - <option>24</option>
601   - <option>26</option>
602   - <option>28</option>
603   - <option>36</option>
604   - <option>48</option>
605   - <option>72</option>
606   - </select>
607   - <span style="vertical-align:middle;">
608   - <span id="text-bold" class="Edittext-btn-css">
609   - <i aria-hidden="true" class="fa fa-bold" style="color: #fff"></i>
610   - </span>
611   - <span id="text-italic" class="Edittext-btn-css">
612   - <i class="fa fa-italic" aria-hidden="true" style="color: #fff"></i>
613   -
614   - </span>
615   - <span id="text-underline" class="underline-btn-css">
616   - <i class="fa fa-underline" aria-hidden="true" style="color: #fff"></i>
617   - </span>
  579 + <div id="annotationTextModal" style="display:none;z-index: 1000000000;width:500px;height:241px;padding-right:0!important;position:fixed;left:0;right:0;top:0px;bottom:0;margin:auto;">
  580 +
  581 + <div class="modal-content">
  582 + <div class="modal-header" style="background-color: #808D43;padding:10px;border-bottom:0;">
  583 + <!--<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>-->
  584 + <h4 class="modal-title" id="myModalLabel" style="font-weight:bold;">Enter Text to be put in a box</h4>
  585 + </div>
  586 + <div class="modal-body">
  587 + <div class="col-xs-12" style="padding:20px 0;">
  588 + <div class="form-inline">
  589 + <!--Annotation: Text in different font style is same.-->
  590 + <select class="form-control" id="selected-font-family"></select>
  591 + <select class="form-control" id="selected-font-size">
  592 + <option>14</option>
  593 + <option>16</option>
  594 + <option>18</option>
  595 + <option>20</option>
  596 + <option>22</option>
  597 + <option>24</option>
  598 + <option>26</option>
  599 + <option>28</option>
  600 + <option>36</option>
  601 + <option>48</option>
  602 + <option>72</option>
  603 + </select>
  604 + <span style="vertical-align:middle;">
  605 + <span id="text-bold" class="Edittext-btn-css">
  606 + <i aria-hidden="true" class="fa fa-bold" style="color: #fff"></i>
  607 + </span>
  608 + <span id="text-italic" class="Edittext-btn-css">
  609 + <i class="fa fa-italic" aria-hidden="true" style="color: #fff"></i>
  610 +
  611 + </span>
  612 + <span id="text-underline" class="underline-btn-css">
  613 + <i class="fa fa-underline" aria-hidden="true" style="color: #fff"></i>
618 614 </span>
  615 + </span>
619 616  
620   - <div class="form-group" id="font-color" style="display:inline-flex;vertical-align:top;cursor:pointer;margin-right:36px;">
  617 + <div class="form-group" id="font-color" style="display:inline-flex;vertical-align:top;cursor:pointer;margin-right:36px;">
621 618  
622   - <input type="text" id="saturation-demo" class="form-control demo" data-control="saturation" style="display:none;" value="#0088cc">
623   - </div>
  619 + <input type="text" id="saturation-demo" class="form-control demo" data-control="saturation" style="display:none;" value="#0088cc">
  620 + </div>
624 621  
625   - <span style="vertical-align:middle;">
626   - <span id="text-left" class="Edittext-btn-css">
627   - <i aria-hidden="true" class="fa fa-align-left" style="color: #fff"></i>
628   - </span>
629   - <span id="text-center" class="Edittext-btn-css">
630   - <i class="fa fa-align-center" aria-hidden="true" style="color: #fff"></i>
  622 + <span style="vertical-align:middle;">
  623 + <span id="text-left" class="Edittext-btn-css">
  624 + <i aria-hidden="true" class="fa fa-align-left" style="color: #fff"></i>
  625 + </span>
  626 + <span id="text-center" class="Edittext-btn-css">
  627 + <i class="fa fa-align-center" aria-hidden="true" style="color: #fff"></i>
631 628  
632 629  
633   - </span>
634   - <span id="text-right" class="underline-btn-css">
635   - <i class="fa fa-align-right" aria-hidden="true" style="color: #fff"></i>
  630 + </span>
  631 + <span id="text-right" class="underline-btn-css">
  632 + <i class="fa fa-align-right" aria-hidden="true" style="color: #fff"></i>
636 633  
637 634  
638   - </span>
639 635 </span>
  636 + </span>
640 637  
641 638  
642   - </div>
643 639 </div>
644   - <textarea class="form-control" id="text_area" rows="3" style="font-family: 'Verdana, sans-serif';font-size:14px; font-weight: normal; font-style: normal; color: #000; text-align: left; text-decoration: none;"></textarea>
645   - </div>
646   - <div class="modal-footer">
647   - <!--<button type="button" class="btn btn-default" ng-click="closeModal()" data-dismiss="modal">Close</button>-->
648   - <button type="button" class="btn btn-default" ng-click="closeModal()" id="closeEditText" data-dismiss="modal">Close</button>
649   - <button type="button" id="saveBtn" class="btn btn-primary" data-dismiss="modal" ng-click="saveText()">Save</button>
650 640 </div>
  641 + <textarea class="form-control" id="text_area" rows="3" style="font-family: 'Verdana, sans-serif';font-size:14px; font-weight: normal; font-style: normal; color: #000; text-align: left; text-decoration: none;"></textarea>
  642 + </div>
  643 + <div class="modal-footer">
  644 + <!--<button type="button" class="btn btn-default" ng-click="closeModal()" data-dismiss="modal">Close</button>-->
  645 + <button type="button" class="btn btn-default" ng-click="closeModal()" id="closeEditText" data-dismiss="modal">Close</button>
  646 + <button type="button" id="saveBtn" class="btn btn-primary" data-dismiss="modal" ng-click="saveText()">Save</button>
651 647 </div>
652   -
  648 + </div>
  649 +
653 650 </div>
654 651  
655 652  
... ... @@ -670,7 +667,7 @@
670 667 top: 170px;
671 668 left: 140px;
672 669 display: none;
673   - z-index: 1100;
  670 + z-index: 110000;
674 671 }
675 672  
676 673 #listManager .annotation-modal-header {
... ... @@ -773,7 +770,7 @@
773 770 <!--Edit Shape Modal-->
774 771  
775 772  
776   - <div class="modeleditstyle" id="modeleditstyle" style="z-index: 1000000000; background: white; height: 433px; width: 302px;position:absolute;left:40%;right:0;top:70px;">
  773 + <div class="modeleditstyle" id="modeleditstyle" style="z-index: 1000000000; background: white;width: 302px;position:absolute;left:40%;right:0;top:70px;">
777 774 <div class="modal-content">
778 775 <div class="modal-header annotation-modal-header">
779 776 <h4 class="modal-title" id="myModalLabel33">Edit Shape Style</h4>
... ... @@ -790,13 +787,13 @@
790 787 </div>
791 788 </div>
792 789 <div class="col-sm-6 enableDisableOpacity">
793   - <div class="radio">
  790 + <!--<div class="radio">
794 791 <label>
795 792 <input type="radio" name="filloption" id="filloption1" value="filloption1">
796 793 <span class="">Texture</span>
797 794 <img id="editstyleTexture" src="~/../content/images/common/annotation-tool-bar/pattern-picker.png" alt="" class="pattern-picker" data-toggle="modal" data-target="#pattern">
798 795 </label>
799   - </div>
  796 + </div>-->
800 797 <div class="radio">
801 798 <label>
802 799 <input type="radio" name="filloption" id="filloption2" value="filloption2" checked style="margin-top:8px;">
... ... @@ -878,18 +875,18 @@
878 875 </div>
879 876  
880 877 <div class="marginTopBtm10">
881   -
  878 +
882 879 <div class="well well-sm no-margin-btm blankshapediv">
883   - <div class="outlinediv">
884   - <div id="imgOpacity" class="fullcolordiv imgopacity">
885   - </div>
886   - </div>
887   - </div>
  880 + <div class="outlinediv" id="outlinedivId" style="border: 1px solid #000000;">
  881 + <div id="imgOpacity" style="background-color: #ffffff" class="fullcolordiv imgopacity">
  882 + </div>
  883 + </div>
  884 + </div>
888 885  
889 886 </div>
890 887 </div>
891 888 <div class="modal-footer">
892   - <button type="button" class="btn btn-primary btn-sm" ng-click="shapestyle('imgOpacity')">
  889 + <button id="btnShapeStyle" type="button" class="btn btn-primary btn-sm" ng-click="setPropertiesForShapes('imgOpacity')">
893 890 OK
894 891 </button>
895 892 <button type="button" class="btn btn-primary btn-sm" data-dismiss="modal" ng-click="disableAnnotationToolBar()">Cancel</button>
... ... @@ -897,8 +894,39 @@
897 894 </div>
898 895 </div>
899 896  
  897 + <!--Export Image Modal-->
  898 + <div class="modal fade export-image ui-draggable in" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" style="display: none;">
  899 + <div class="modal-dialog modal-sm" role="document">
  900 + <div class="modal-content">
  901 + <div class="modal-header annotation-modal-header ui-draggable-handle">
  902 + <button type="button" class="close" data-dismiss="modal" ng-click="CloseExportImageWindow()" aria-label="Close"><span aria-hidden="true">×</span></button>
  903 + <h4 class="modal-title" id="">Save As</h4>
  904 + </div>
  905 + <div class="modal-body">
  906 + <div class="row paddTopbtm15">
  907 + <div class="col-sm-12">
  908 + <div class="form-group">
  909 + <label for="filename">Filename:</label>
  910 + <div class="input-group">
  911 + <input type="text" class="form-control" id="filename" placeholder="" ng-model="filename">
  912 + <div class="input-group-addon">.jpg</div>
  913 + </div>
  914 + </div>
  915 + </div>
  916 + </div>
900 917  
  918 + </div>
  919 + <div class="modal-footer">
  920 + <div class="row">
  921 + <input type="file" id="file1" style="display:none">
  922 + <!--<a href="data:application/xml;charset=utf-8,your code here" download="filename.html">Save</a-->>
  923 + <div class="col-sm-12"><button id="btnSaveEI" class="btn btn-primary" type="button">Ok</button></div> <!--onclick="makeScreenshot();"--><!--ng-click="dialogs.saveAs()"--><!--ng-click="ShowAlert()"-->
  924 + </div>
  925 + </div>
901 926  
  927 + </div>
  928 + </div>
  929 + </div>
902 930  
903 931 <!--<div class="modal fade" id="editshapestyle" tabindex="-1" role="dialog" aria-labelledby="myModalLabel33" style="z-index:1000000000;width:302px;margin-left:auto;margin-right:auto;overflow:hidden;height:460px;">
904 932 <div class="modal-dialog modal-sm" role="document">
... ... @@ -936,7 +964,7 @@
936 964 </div>
937 965  
938 966  
939   -
  967 +
940 968 </label>
941 969 </div>
942 970 </div>
... ... @@ -945,7 +973,7 @@
945 973 <label class="pull-left" style="font-weight:normal;">Scale</label>
946 974 <div id="edit-slider-3" class="pull-left" style="width:62%; margin-left:3%; margin-top:2%;">
947 975 <div id="slider-range-min-3"></div>
948   -
  976 +
949 977 </div>
950 978 </div>
951 979  
... ... @@ -1014,7 +1042,7 @@
1014 1042 </div>
1015 1043 </div>
1016 1044 <div class="modal-footer">
1017   - <button type="button" class="btn btn-primary btn-sm" ng-click="shapestyle('imgOpacity')">
  1045 + <button type="button" class="btn btn-primary btn-sm" ng-click="setPropertiesForShapes('imgOpacity')">
1018 1046 OK
1019 1047 </button>
1020 1048 <button type="button" class="btn btn-primary btn-sm" data-dismiss="modal" ng-click="disableAnnotationToolBar()">Cancel</button>
... ... @@ -1024,14 +1052,17 @@
1024 1052 </div>-->
1025 1053  
1026 1054 <script>
1027   - function enableDisableFillOption()
1028   - {
1029   -
1030   - if (document.getElementById('fill-option').checked)
1031   - {
1032   -
  1055 +
  1056 + function enableDisableFillOption() {
  1057 + //debugger;
  1058 + if (document.getElementById('fill-option').checked) {
  1059 + // $('#imgOpacity').attr("background-color");
  1060 + //$('#imgOpacity').css({"background-color"})
1033 1061 //$("#filloption1").css({ "pointer-events": "auto" });
1034 1062 //$("#filloption12").css({ "pointer-events": "auto" });
  1063 +
  1064 + var x = $("#editstylebackgroundcolor span.minicolors-swatch-color").css('background-color');
  1065 + $("#imgOpacity").css("background-color", x);
1035 1066 $("#edit-slider-3").css({ "pointer-events": "auto" });
1036 1067 $("#edit-slider-4").css({ "pointer-events": "auto" });
1037 1068 $("#editstylebackgroundcolor").css({ "pointer-events": "auto" });
... ... @@ -1046,14 +1077,13 @@
1046 1077  
1047 1078  
1048 1079 }
1049   - else
1050   - {
1051   -
  1080 + else {
  1081 + $('#imgOpacity').css("background-color","transparent");
1052 1082 //$("#filloption1").css({ "pointer-events": "none" });
1053 1083 //$("#filloption2").css({ "pointer-events": "none" });
1054   - $("#edit-slider-3").css({ "pointer-events": "none"});
1055   - $("#edit-slider-4").css({ "pointer-events": "none"});
1056   - $("#editstylebackgroundcolor").css({ "pointer-events": "none"});
  1084 + $("#edit-slider-3").css({ "pointer-events": "none" });
  1085 + $("#edit-slider-4").css({ "pointer-events": "none" });
  1086 + $("#editstylebackgroundcolor").css({ "pointer-events": "none" });
1057 1087 $("#editstyleTexture").css({ "pointer-events": "none" });
1058 1088 $(".enableDisableOpacity label").css({ "cursor": "default" });
1059 1089 $(".enableDisableOpacity").css({ "opacity": ".5" })
... ... @@ -1070,32 +1100,37 @@
1070 1100 function enableDisableOutline() {
1071 1101  
1072 1102 if (document.getElementById('Outline-Option').checked) {
  1103 + var x = $("#outlineColor span.minicolors-swatch-color").css('background-color');
  1104 + $(".marginTopBtm10 div.outlinediv").css("border-color", x);
  1105 + // var borderWidth = $("#outlineColor span.minicolors-swatch-color").css('border-width');
  1106 + // $("#imgOpacity").css("border-width", borderWidth);
1073 1107  
1074 1108 $("#borderWidthCanvasElement").css({ "pointer-events": "auto" });
1075 1109 $("#outlineColor").css({ "pointer-events": "auto" });
1076 1110 $(".setEnableDisableForEditShapeStyle").css({ "opacity": "1" })
1077 1111 }
1078 1112 else {
  1113 + $('.marginTopBtm10 div.outlinediv').css("border-color", "transparent");
1079 1114 $("#borderWidthCanvasElement").css({ "pointer-events": "none" });
1080 1115 $("#outlineColor").css({ "pointer-events": "none" });
1081 1116 $(".setEnableDisableForEditShapeStyle").css({ "opacity": ".5" })
1082 1117 }
1083 1118 }
1084 1119  
1085   - </script>
  1120 + </script>
1086 1121  
1087   - <script>
1088   - function mytoggle() {
1089   - var div = document.getElementById("divSection");
1090   - if (div.style.display == 'block') {
1091   - div.style.display = 'none';
1092   - return;
1093   - }
1094   - div.style.display = 'block';
  1122 + <script>
  1123 + function mytoggle() {
  1124 + var div = document.getElementById("divSection");
  1125 + if (div.style.display == 'block') {
  1126 + div.style.display = 'none';
  1127 + return;
1095 1128 }
  1129 + div.style.display = 'block';
  1130 + }
1096 1131 </script>
1097 1132  
1098   -
  1133 +
1099 1134 <script>
1100 1135 function mytoggle() {
1101 1136 var div = document.getElementById("divSection");
... ... @@ -1111,17 +1146,16 @@
1111 1146  
1112 1147 object.value = object.value.replace(/[^0-9]/g, '');
1113 1148 if (parseInt(object.value) <= 0) {
1114   - object.value =1;
  1149 + object.value = 1;
1115 1150 }
1116   - if (parseInt(object.value)>=1 && parseInt(object.value) <= 60) {
  1151 + if (parseInt(object.value) >= 1 && parseInt(object.value) <= 60) {
1117 1152 object.value = object.value;
1118 1153 }
1119   - if(parseInt(object.value) > 60)
1120   - {
  1154 + if (parseInt(object.value) > 60) {
1121 1155 object.value = object.value.slice(0, 1);
1122   -
  1156 +
1123 1157 }
1124   -
  1158 +
1125 1159 }
1126 1160 </script>
1127 1161  
... ... @@ -1169,12 +1203,16 @@
1169 1203 <script src="app/controllers/LinkController.js"></script>
1170 1204 <script src="app/services/DataService.js"></script>
1171 1205 <script src="libs/jquery/jquery_plugin/jqueryui.js"></script>
1172   -
1173   - <script src="libs/jquery/jquery_plugin/color-picker/jquery.minicolors.min.js"></script>
  1206 +
  1207 + <script src="libs/jquery/jquery_plugin/color-picker/jquery.minicolors.min.js"></script>
1174 1208 <!--<script src="libs/colorpicker/jquery.minicolors.min.js"></script>-->
1175 1209 <!--<script src="libs/color-picker/jquery.minicolors.min.js"></script>-->
1176 1210  
1177 1211 <script src="libs/sketch.js"></script>
  1212 +
  1213 + <!--<script src="https://cdnjs.cloudflare.com/ajax/libs/html2canvas/0.4.1/html2canvas.js"></script>-->
  1214 + <script src="libs/html2canvas.js"></script>
  1215 + <script src="libs/FileSaver.js"></script>
1178 1216 <!--<script type="text/javascript">
1179 1217 $(function () {
1180 1218 $('#canvas').sketch();
... ... @@ -1225,9 +1263,14 @@
1225 1263 $("#slider-range-min-2").slider("value", parseInt(brushIncrementedValue));
1226 1264 }
1227 1265 });
1228   - $("#btnBrushSizeDecrease").click(function () {
  1266 + $("#btnBrushSizeDecrease").click(function () {
1229 1267 var brushDecreaseVar = $("#btnBrushSize").val();
1230   - if (brushDecreaseVar <= 1) {
  1268 + if (brushDecreaseVar == "") {
  1269 + var brushDecrementedValue = 1;
  1270 + $("#btnBrushSize").val(brushDecrementedValue);
  1271 + $("#slider-range-min-2").slider("value", parseInt(brushDecrementedValue));
  1272 + }
  1273 + else if (brushDecreaseVar <= 1) {
1231 1274 $("#slider-range-min-2").slider("value", 1);
1232 1275 }
1233 1276 else {
... ... @@ -1398,7 +1441,7 @@
1398 1441 $("#text_area").css("text-decoration", "none");
1399 1442 }
1400 1443  
1401   -
  1444 +
1402 1445 });
1403 1446  
1404 1447  
... ... @@ -1428,22 +1471,24 @@
1428 1471 var borderWidth = 1;
1429 1472 var borderColor = "#000";
1430 1473 $("#borderWidthCanvasElement").change(function () {
1431   -
1432 1474 borderWidth = $(this).val();
1433   -
  1475 + borderColor = $('#outlineColor .minicolors >.minicolors-swatch > .minicolors-swatch-color').css("background-color");
  1476 +
1434 1477 if (borderColor != null) {
1435   -
1436   - $("#imgOpacity").parent().css("border", borderWidth + "px" + " " + "solid" + borderColor);
  1478 + document.getElementById("imgOpacity").parentNode.style.border = borderWidth + "px" + " " + "solid" + " " + borderColor;
  1479 + //$("#imgOpacity").parent().css("border", borderWidth + "px" + " " + "solid" + borderColor);
1437 1480 } else {
1438 1481  
1439   - $("#imgOpacity").parent().css("border", borderWidth + "px" + " " + "solid");
  1482 + // $("#imgOpacity").parent().css("border", borderWidth + "px" + " " + "solid");
  1483 + document.getElementById("imgOpacity").parentNode.style.border = borderWidth + "px" + " " + "solid" + " " + borderColor;
  1484 +
1440 1485 }
1441 1486 });
1442 1487  
1443   -
  1488 +
1444 1489  
1445 1490 $('.borderColorCanvasPreview').each(function () {
1446   - // $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").addClass("ActiveDefaultColorAnnotation");
  1491 + // $("#font-color .minicolors .minicolors-swatch .minicolors-swatch-color").addClass("ActiveDefaultColorAnnotation");
1447 1492 $(this).minicolors({
1448 1493 control: $(this).attr('data-control') || 'hue',
1449 1494 defaultValue: $(this).attr('data-defaultValue') || '',
... ... @@ -1459,9 +1504,10 @@
1459 1504 if (opacity) value += ', ' + opacity;
1460 1505 if (typeof console === 'object') {
1461 1506 console.log(value);
1462   -
1463   - borderColor = value;
1464   - $("#imgOpacity").parent().css("border", borderWidth + "px" + " " + "solid" + borderColor);
  1507 +
  1508 + borderColor = value;
  1509 + //$("#imgOpacity").parent().css("border", borderWidth + "px" + " " + "solid" + borderColor);
  1510 + document.getElementById("imgOpacity").parentNode.style.border = borderWidth + "px" + " " + "solid" + " " + borderColor;
1465 1511  
1466 1512  
1467 1513 }
... ... @@ -1469,12 +1515,12 @@
1469 1515 theme: 'bootstrap'
1470 1516 });
1471 1517  
1472   -
  1518 +
1473 1519 });
1474 1520  
1475 1521  
1476 1522 $('.outerBackgroundColor').each(function () {
1477   -
  1523 +
1478 1524 $(this).minicolors({
1479 1525 control: $(this).attr('data-control') || 'hue',
1480 1526 defaultValue: $(this).attr('data-defaultValue') || '',
... ... @@ -1502,7 +1548,7 @@
1502 1548  
1503 1549 });
1504 1550 </script>
1505   -
  1551 +
1506 1552 <script>
1507 1553 $(function () {
1508 1554 $("#slider-range-min-3").slider({
... ... @@ -1534,10 +1580,9 @@
1534 1580 max: 1,
1535 1581 step: .1,
1536 1582 slide: function (event, ui) {
1537   -
1538   - $(".marginTopBtm10 .imgopacity").css("opacity", ui.value);
1539   - // $("#slider-value").html(ui.value);
1540 1583  
  1584 + $(".marginTopBtm10 .imgopacity").css("opacity", ui.value);
  1585 + $(".marginTopBtm10 div.outlinediv").css("opacity", ui.value);
1541 1586 }
1542 1587  
1543 1588 }
... ... @@ -1554,24 +1599,24 @@
1554 1599  
1555 1600 <script>
1556 1601 $(function () {
1557   -
  1602 +
1558 1603  
1559 1604 $("#OnIdentify").on('mouseover', function () {
1560 1605 $("#identify-block").addClass("custom-tooltip-annotation");
1561 1606 $(".custom-tooltip-annotation").css('display', 'block');
1562 1607 }).on('mouseout', function () {
1563   - // $("#identify-block").removeClass("custom-tooltip-annotation");
  1608 + // $("#identify-block").removeClass("custom-tooltip-annotation");
1564 1609 $(".custom-tooltip-annotation").css('display', 'none');
1565 1610 $("#identify-block").removeClass("custom-tooltip-annotation");
1566 1611 });
1567 1612  
1568   -
  1613 +
1569 1614 $("#DrawMode").on('mouseover', function () {
1570 1615 $("#draw-block").addClass("custom-tooltip-annotation");
1571 1616 $(".custom-tooltip-annotation").css('display', 'block');
1572   -
  1617 +
1573 1618 }).on('mouseout', function () {
1574   -
  1619 +
1575 1620 $(".custom-tooltip-annotation").css('display', 'none');
1576 1621 $("#draw-block").removeClass("custom-tooltip-annotation");
1577 1622 });
... ... @@ -1589,9 +1634,34 @@
1589 1634  
1590 1635 });
1591 1636 </script>
1592   -
1593   -
1594   -
1595   -
  1637 + <!-- Export Image Save Click-->
  1638 + <script>
  1639 + $(function () {
  1640 + $("#btnSaveEI").click(function () {
  1641 + html2canvas($("#canvasDiv"), {
  1642 + onrendered: function (canvas) {
  1643 + theCanvas = canvas;
  1644 + var fileName = document.getElementById("filename").value + '.jpg';
  1645 + if (typeof (fileName) == "undefined" || fileName == ".jpg")
  1646 + fileName = "Untitled.jpg"
  1647 + var dataURL = canvas.toDataURL("image/jpeg");
  1648 + var blob = dataURItoBlob(dataURL);
  1649 + saveAs(blob, fileName);
  1650 + $("#filename").val("");
  1651 + }
  1652 + });
  1653 + $(".export-image").css("display", "none");
  1654 + });
  1655 + });
  1656 + function dataURItoBlob(dataURI) {
  1657 + var byteString = atob(dataURI.split(',')[1]);
  1658 + var ab = new ArrayBuffer(byteString.length);
  1659 + var ia = new Uint8Array(ab);
  1660 + for (var i = 0; i < byteString.length; i++) {
  1661 + ia[i] = byteString.charCodeAt(i);
  1662 + }
  1663 + return new Blob([ab], { type: 'image/jpeg' });
  1664 + }
  1665 + </script>
1596 1666 </body>
1597 1667 </html>
1598 1668 \ No newline at end of file
... ...
400-SOURCECODE/AIAHTML5.Web/libs/FileSaver.js 0 → 100644
  1 +/* FileSaver.js
  2 + * A saveAs() & saveTextAs() FileSaver implementation.
  3 + * 2014-06-24
  4 + *
  5 + * Modify by Brian Chen
  6 + * Author: Eli Grey, http://eligrey.com
  7 + * License: X11/MIT
  8 + * See https://github.com/eligrey/FileSaver.js/blob/master/LICENSE.md
  9 + */
  10 +
  11 +/*global self */
  12 +/*jslint bitwise: true, indent: 4, laxbreak: true, laxcomma: true, smarttabs: true, plusplus: true */
  13 +
  14 +/*! @source http://purl.eligrey.com/github/FileSaver.js/blob/master/FileSaver.js */
  15 +
  16 +var saveAs = saveAs
  17 + // IE 10+ (native saveAs)
  18 + || (typeof navigator !== "undefined" &&
  19 + navigator.msSaveOrOpenBlob && navigator.msSaveOrOpenBlob.bind(navigator))
  20 + // Everyone else
  21 + || (function (view) {
  22 + "use strict";
  23 + // IE <10 is explicitly unsupported
  24 + if (typeof navigator !== "undefined" &&
  25 + /MSIE [1-9]\./.test(navigator.userAgent)) {
  26 + return;
  27 + }
  28 + var
  29 + doc = view.document
  30 + // only get URL when necessary in case Blob.js hasn't overridden it yet
  31 + , get_URL = function () {
  32 + return view.URL || view.webkitURL || view;
  33 + }
  34 + , save_link = doc.createElementNS("http://www.w3.org/1999/xhtml", "a")
  35 + , can_use_save_link = !view.externalHost && "download" in save_link
  36 + , click = function (node) {
  37 + var event = doc.createEvent("MouseEvents");
  38 + event.initMouseEvent(
  39 + "click", true, false, view, 0, 0, 0, 0, 0
  40 + , false, false, false, false, 0, null
  41 + );
  42 + node.dispatchEvent(event);
  43 + }
  44 + , webkit_req_fs = view.webkitRequestFileSystem
  45 + , req_fs = view.requestFileSystem || webkit_req_fs || view.mozRequestFileSystem
  46 + , throw_outside = function (ex) {
  47 + (view.setImmediate || view.setTimeout)(function () {
  48 + throw ex;
  49 + }, 0);
  50 + }
  51 + , force_saveable_type = "application/octet-stream"
  52 + , fs_min_size = 0
  53 + , deletion_queue = []
  54 + , process_deletion_queue = function () {
  55 + var i = deletion_queue.length;
  56 + while (i--) {
  57 + var file = deletion_queue[i];
  58 + if (typeof file === "string") { // file is an object URL
  59 + get_URL().revokeObjectURL(file);
  60 + } else { // file is a File
  61 + file.remove();
  62 + }
  63 + }
  64 + deletion_queue.length = 0; // clear queue
  65 + }
  66 + , dispatch = function (filesaver, event_types, event) {
  67 + event_types = [].concat(event_types);
  68 + var i = event_types.length;
  69 + while (i--) {
  70 + var listener = filesaver["on" + event_types[i]];
  71 + if (typeof listener === "function") {
  72 + try {
  73 + listener.call(filesaver, event || filesaver);
  74 + } catch (ex) {
  75 + throw_outside(ex);
  76 + }
  77 + }
  78 + }
  79 + }
  80 + , FileSaver = function (blob, name) {
  81 + // First try a.download, then web filesystem, then object URLs
  82 + var
  83 + filesaver = this
  84 + , type = blob.type
  85 + , blob_changed = false
  86 + , object_url
  87 + , target_view
  88 + , get_object_url = function () {
  89 + var object_url = get_URL().createObjectURL(blob);
  90 + deletion_queue.push(object_url);
  91 + return object_url;
  92 + }
  93 + , dispatch_all = function () {
  94 + dispatch(filesaver, "writestart progress write writeend".split(" "));
  95 + }
  96 + // on any filesys errors revert to saving with object URLs
  97 + , fs_error = function () {
  98 + // don't create more object URLs than needed
  99 + if (blob_changed || !object_url) {
  100 + object_url = get_object_url(blob);
  101 + }
  102 + if (target_view) {
  103 + target_view.location.href = object_url;
  104 + } else {
  105 + window.open(object_url, "_blank");
  106 + }
  107 + filesaver.readyState = filesaver.DONE;
  108 + dispatch_all();
  109 + }
  110 + , abortable = function (func) {
  111 + return function () {
  112 + if (filesaver.readyState !== filesaver.DONE) {
  113 + return func.apply(this, arguments);
  114 + }
  115 + };
  116 + }
  117 + , create_if_not_found = { create: true, exclusive: false }
  118 + , slice
  119 + ;
  120 + filesaver.readyState = filesaver.INIT;
  121 + if (!name) {
  122 + name = "download";
  123 + }
  124 + if (can_use_save_link) {
  125 + object_url = get_object_url(blob);
  126 + save_link.href = object_url;
  127 + save_link.download = name;
  128 + click(save_link);
  129 + filesaver.readyState = filesaver.DONE;
  130 + dispatch_all();
  131 + return;
  132 + }
  133 + // Object and web filesystem URLs have a problem saving in Google Chrome when
  134 + // viewed in a tab, so I force save with application/octet-stream
  135 + // http://code.google.com/p/chromium/issues/detail?id=91158
  136 + if (view.chrome && type && type !== force_saveable_type) {
  137 + slice = blob.slice || blob.webkitSlice;
  138 + blob = slice.call(blob, 0, blob.size, force_saveable_type);
  139 + blob_changed = true;
  140 + }
  141 + // Since I can't be sure that the guessed media type will trigger a download
  142 + // in WebKit, I append .download to the filename.
  143 + // https://bugs.webkit.org/show_bug.cgi?id=65440
  144 + if (webkit_req_fs && name !== "download") {
  145 + name += ".download";
  146 + }
  147 + if (type === force_saveable_type || webkit_req_fs) {
  148 + target_view = view;
  149 + }
  150 + if (!req_fs) {
  151 + fs_error();
  152 + return;
  153 + }
  154 + fs_min_size += blob.size;
  155 + req_fs(view.TEMPORARY, fs_min_size, abortable(function (fs) {
  156 + fs.root.getDirectory("saved", create_if_not_found, abortable(function (dir) {
  157 + var save = function () {
  158 + dir.getFile(name, create_if_not_found, abortable(function (file) {
  159 + file.createWriter(abortable(function (writer) {
  160 + writer.onwriteend = function (event) {
  161 + target_view.location.href = file.toURL();
  162 + deletion_queue.push(file);
  163 + filesaver.readyState = filesaver.DONE;
  164 + dispatch(filesaver, "writeend", event);
  165 + };
  166 + writer.onerror = function () {
  167 + var error = writer.error;
  168 + if (error.code !== error.ABORT_ERR) {
  169 + fs_error();
  170 + }
  171 + };
  172 + "writestart progress write abort".split(" ").forEach(function (event) {
  173 + writer["on" + event] = filesaver["on" + event];
  174 + });
  175 + writer.write(blob);
  176 + filesaver.abort = function () {
  177 + writer.abort();
  178 + filesaver.readyState = filesaver.DONE;
  179 + };
  180 + filesaver.readyState = filesaver.WRITING;
  181 + }), fs_error);
  182 + }), fs_error);
  183 + };
  184 + dir.getFile(name, { create: false }, abortable(function (file) {
  185 + // delete file if it already exists
  186 + file.remove();
  187 + save();
  188 + }), abortable(function (ex) {
  189 + if (ex.code === ex.NOT_FOUND_ERR) {
  190 + save();
  191 + } else {
  192 + fs_error();
  193 + }
  194 + }));
  195 + }), fs_error);
  196 + }), fs_error);
  197 + }
  198 + , FS_proto = FileSaver.prototype
  199 + , saveAs = function (blob, name) {
  200 + return new FileSaver(blob, name);
  201 + }
  202 + ;
  203 + FS_proto.abort = function () {
  204 + var filesaver = this;
  205 + filesaver.readyState = filesaver.DONE;
  206 + dispatch(filesaver, "abort");
  207 + };
  208 + FS_proto.readyState = FS_proto.INIT = 0;
  209 + FS_proto.WRITING = 1;
  210 + FS_proto.DONE = 2;
  211 +
  212 + FS_proto.error =
  213 + FS_proto.onwritestart =
  214 + FS_proto.onprogress =
  215 + FS_proto.onwrite =
  216 + FS_proto.onabort =
  217 + FS_proto.onerror =
  218 + FS_proto.onwriteend =
  219 + null;
  220 +
  221 + view.addEventListener("unload", process_deletion_queue, false);
  222 + saveAs.unload = function () {
  223 + process_deletion_queue();
  224 + view.removeEventListener("unload", process_deletion_queue, false);
  225 + };
  226 + return saveAs;
  227 + }(
  228 + typeof self !== "undefined" && self
  229 + || typeof window !== "undefined" && window
  230 + || this.content
  231 +));
  232 +// `self` is undefined in Firefox for Android content script context
  233 +// while `this` is nsIContentFrameMessageManager
  234 +// with an attribute `content` that corresponds to the window
  235 +
  236 +if (typeof module !== "undefined" && module !== null) {
  237 + module.exports = saveAs;
  238 +} else if ((typeof define !== "undefined" && define !== null) && (define.amd != null)) {
  239 + define([], function () {
  240 + return saveAs;
  241 + });
  242 +}
  243 +
  244 +String.prototype.endsWithAny = function () {
  245 + var strArray = Array.prototype.slice.call(arguments),
  246 + $this = this.toLowerCase().toString();
  247 + for (var i = 0; i < strArray.length; i++) {
  248 + if ($this.indexOf(strArray[i], $this.length - strArray[i].length) !== -1) return true;
  249 + }
  250 + return false;
  251 +};
  252 +
  253 +var saveTextAs = saveTextAs
  254 +|| (function (textContent, fileName, charset) {
  255 + fileName = fileName || 'Untitled.jpg';
  256 + //charset = charset || 'utf-8';
  257 + textContent = (textContent || '').replace(/\r?\n/g, "\r\n");
  258 + if (saveAs && Blob) {
  259 + var blob = new Blob([textContent], { type: "image/jpg;"});
  260 + saveAs(blob, fileName);
  261 + return true;
  262 + } else {//IE9-
  263 + var saveTxtWindow = window.frames.saveTxtWindow;
  264 + if (!saveTxtWindow) {
  265 + saveTxtWindow = document.createElement('iframe');
  266 + saveTxtWindow.id = 'saveTxtWindow';
  267 + saveTxtWindow.style.display = 'none';
  268 + document.body.insertBefore(saveTxtWindow, null);
  269 + saveTxtWindow = window.frames.saveTxtWindow;
  270 + if (!saveTxtWindow) {
  271 + saveTxtWindow = window.open('', '_temp', 'width=100,height=100');
  272 + if (!saveTxtWindow) {
  273 + window.alert('Sorry, download file could not be created.');
  274 + return false;
  275 + }
  276 + }
  277 + }
  278 +
  279 + var doc = saveTxtWindow.document;
  280 + doc.open('text/html', 'replace');
  281 + doc.charset = charset;
  282 + if (fileName.endsWithAny('.htm', '.html')) {
  283 + doc.close();
  284 + doc.body.innerHTML = '\r\n' + textContent + '\r\n';
  285 + } else {
  286 + if (!fileName.endsWithAny('.jpg')) fileName += '.jpg';
  287 + doc.write(textContent);
  288 + doc.close();
  289 + }
  290 +
  291 + var retValue = doc.execCommand('SaveAs', null, fileName);
  292 + saveTxtWindow.close();
  293 + return retValue;
  294 + }
  295 +})
0 296 \ No newline at end of file
... ...
400-SOURCECODE/AIAHTML5.Web/libs/html2canvas.js 0 → 100644
  1 +/*
  2 + html2canvas 0.4.1 <http://html2canvas.hertzen.com>
  3 + Copyright (c) 2013 Niklas von Hertzen
  4 +
  5 + Released under MIT License
  6 +*/
  7 +
  8 +(function(window, document, undefined){
  9 +
  10 +"use strict";
  11 +
  12 +var _html2canvas = {},
  13 +previousElement,
  14 +computedCSS,
  15 +html2canvas;
  16 +
  17 +_html2canvas.Util = {};
  18 +
  19 +_html2canvas.Util.log = function(a) {
  20 + if (_html2canvas.logging && window.console && window.console.log) {
  21 + window.console.log(a);
  22 + }
  23 +};
  24 +
  25 +_html2canvas.Util.trimText = (function(isNative){
  26 + return function(input) {
  27 + return isNative ? isNative.apply(input) : ((input || '') + '').replace( /^\s+|\s+$/g , '' );
  28 + };
  29 +})(String.prototype.trim);
  30 +
  31 +_html2canvas.Util.asFloat = function(v) {
  32 + return parseFloat(v);
  33 +};
  34 +
  35 +(function() {
  36 + // TODO: support all possible length values
  37 + var TEXT_SHADOW_PROPERTY = /((rgba|rgb)\([^\)]+\)(\s-?\d+px){0,})/g;
  38 + var TEXT_SHADOW_VALUES = /(-?\d+px)|(#.+)|(rgb\(.+\))|(rgba\(.+\))/g;
  39 + _html2canvas.Util.parseTextShadows = function (value) {
  40 + if (!value || value === 'none') {
  41 + return [];
  42 + }
  43 +
  44 + // find multiple shadow declarations
  45 + var shadows = value.match(TEXT_SHADOW_PROPERTY),
  46 + results = [];
  47 + for (var i = 0; shadows && (i < shadows.length); i++) {
  48 + var s = shadows[i].match(TEXT_SHADOW_VALUES);
  49 + results.push({
  50 + color: s[0],
  51 + offsetX: s[1] ? s[1].replace('px', '') : 0,
  52 + offsetY: s[2] ? s[2].replace('px', '') : 0,
  53 + blur: s[3] ? s[3].replace('px', '') : 0
  54 + });
  55 + }
  56 + return results;
  57 + };
  58 +})();
  59 +
  60 +
  61 +_html2canvas.Util.parseBackgroundImage = function (value) {
  62 + var whitespace = ' \r\n\t',
  63 + method, definition, prefix, prefix_i, block, results = [],
  64 + c, mode = 0, numParen = 0, quote, args;
  65 +
  66 + var appendResult = function(){
  67 + if(method) {
  68 + if(definition.substr( 0, 1 ) === '"') {
  69 + definition = definition.substr( 1, definition.length - 2 );
  70 + }
  71 + if(definition) {
  72 + args.push(definition);
  73 + }
  74 + if(method.substr( 0, 1 ) === '-' &&
  75 + (prefix_i = method.indexOf( '-', 1 ) + 1) > 0) {
  76 + prefix = method.substr( 0, prefix_i);
  77 + method = method.substr( prefix_i );
  78 + }
  79 + results.push({
  80 + prefix: prefix,
  81 + method: method.toLowerCase(),
  82 + value: block,
  83 + args: args
  84 + });
  85 + }
  86 + args = []; //for some odd reason, setting .length = 0 didn't work in safari
  87 + method =
  88 + prefix =
  89 + definition =
  90 + block = '';
  91 + };
  92 +
  93 + appendResult();
  94 + for(var i = 0, ii = value.length; i<ii; i++) {
  95 + c = value[i];
  96 + if(mode === 0 && whitespace.indexOf( c ) > -1){
  97 + continue;
  98 + }
  99 + switch(c) {
  100 + case '"':
  101 + if(!quote) {
  102 + quote = c;
  103 + }
  104 + else if(quote === c) {
  105 + quote = null;
  106 + }
  107 + break;
  108 +
  109 + case '(':
  110 + if(quote) { break; }
  111 + else if(mode === 0) {
  112 + mode = 1;
  113 + block += c;
  114 + continue;
  115 + } else {
  116 + numParen++;
  117 + }
  118 + break;
  119 +
  120 + case ')':
  121 + if(quote) { break; }
  122 + else if(mode === 1) {
  123 + if(numParen === 0) {
  124 + mode = 0;
  125 + block += c;
  126 + appendResult();
  127 + continue;
  128 + } else {
  129 + numParen--;
  130 + }
  131 + }
  132 + break;
  133 +
  134 + case ',':
  135 + if(quote) { break; }
  136 + else if(mode === 0) {
  137 + appendResult();
  138 + continue;
  139 + }
  140 + else if (mode === 1) {
  141 + if(numParen === 0 && !method.match(/^url$/i)) {
  142 + args.push(definition);
  143 + definition = '';
  144 + block += c;
  145 + continue;
  146 + }
  147 + }
  148 + break;
  149 + }
  150 +
  151 + block += c;
  152 + if(mode === 0) { method += c; }
  153 + else { definition += c; }
  154 + }
  155 + appendResult();
  156 +
  157 + return results;
  158 +};
  159 +
  160 +_html2canvas.Util.Bounds = function (element) {
  161 + var clientRect, bounds = {};
  162 +
  163 + if (element.getBoundingClientRect){
  164 + clientRect = element.getBoundingClientRect();
  165 +
  166 + // TODO add scroll position to bounds, so no scrolling of window necessary
  167 + bounds.top = clientRect.top;
  168 + bounds.bottom = clientRect.bottom || (clientRect.top + clientRect.height);
  169 + bounds.left = clientRect.left;
  170 +
  171 + bounds.width = element.offsetWidth;
  172 + bounds.height = element.offsetHeight;
  173 + }
  174 +
  175 + return bounds;
  176 +};
  177 +
  178 +// TODO ideally, we'd want everything to go through this function instead of Util.Bounds,
  179 +// but would require further work to calculate the correct positions for elements with offsetParents
  180 +_html2canvas.Util.OffsetBounds = function (element) {
  181 + var parent = element.offsetParent ? _html2canvas.Util.OffsetBounds(element.offsetParent) : {top: 0, left: 0};
  182 +
  183 + return {
  184 + top: element.offsetTop + parent.top,
  185 + bottom: element.offsetTop + element.offsetHeight + parent.top,
  186 + left: element.offsetLeft + parent.left,
  187 + width: element.offsetWidth,
  188 + height: element.offsetHeight
  189 + };
  190 +};
  191 +
  192 +function toPX(element, attribute, value ) {
  193 + var rsLeft = element.runtimeStyle && element.runtimeStyle[attribute],
  194 + left,
  195 + style = element.style;
  196 +
  197 + // Check if we are not dealing with pixels, (Opera has issues with this)
  198 + // Ported from jQuery css.js
  199 + // From the awesome hack by Dean Edwards
  200 + // http://erik.eae.net/archives/2007/07/27/18.54.15/#comment-102291
  201 +
  202 + // If we're not dealing with a regular pixel number
  203 + // but a number that has a weird ending, we need to convert it to pixels
  204 +
  205 + if ( !/^-?[0-9]+\.?[0-9]*(?:px)?$/i.test( value ) && /^-?\d/.test(value) ) {
  206 + // Remember the original values
  207 + left = style.left;
  208 +
  209 + // Put in the new values to get a computed value out
  210 + if (rsLeft) {
  211 + element.runtimeStyle.left = element.currentStyle.left;
  212 + }
  213 + style.left = attribute === "fontSize" ? "1em" : (value || 0);
  214 + value = style.pixelLeft + "px";
  215 +
  216 + // Revert the changed values
  217 + style.left = left;
  218 + if (rsLeft) {
  219 + element.runtimeStyle.left = rsLeft;
  220 + }
  221 + }
  222 +
  223 + if (!/^(thin|medium|thick)$/i.test(value)) {
  224 + return Math.round(parseFloat(value)) + "px";
  225 + }
  226 +
  227 + return value;
  228 +}
  229 +
  230 +function asInt(val) {
  231 + return parseInt(val, 10);
  232 +}
  233 +
  234 +function parseBackgroundSizePosition(value, element, attribute, index) {
  235 + value = (value || '').split(',');
  236 + value = value[index || 0] || value[0] || 'auto';
  237 + value = _html2canvas.Util.trimText(value).split(' ');
  238 +
  239 + if(attribute === 'backgroundSize' && (!value[0] || value[0].match(/cover|contain|auto/))) {
  240 + //these values will be handled in the parent function
  241 + } else {
  242 + value[0] = (value[0].indexOf( "%" ) === -1) ? toPX(element, attribute + "X", value[0]) : value[0];
  243 + if(value[1] === undefined) {
  244 + if(attribute === 'backgroundSize') {
  245 + value[1] = 'auto';
  246 + return value;
  247 + } else {
  248 + // IE 9 doesn't return double digit always
  249 + value[1] = value[0];
  250 + }
  251 + }
  252 + value[1] = (value[1].indexOf("%") === -1) ? toPX(element, attribute + "Y", value[1]) : value[1];
  253 + }
  254 + return value;
  255 +}
  256 +
  257 +_html2canvas.Util.getCSS = function (element, attribute, index) {
  258 + if (previousElement !== element) {
  259 + computedCSS = document.defaultView.getComputedStyle(element, null);
  260 + }
  261 +
  262 + var value = computedCSS[attribute];
  263 +
  264 + if (/^background(Size|Position)$/.test(attribute)) {
  265 + return parseBackgroundSizePosition(value, element, attribute, index);
  266 + } else if (/border(Top|Bottom)(Left|Right)Radius/.test(attribute)) {
  267 + var arr = value.split(" ");
  268 + if (arr.length <= 1) {
  269 + arr[1] = arr[0];
  270 + }
  271 + return arr.map(asInt);
  272 + }
  273 +
  274 + return value;
  275 +};
  276 +
  277 +_html2canvas.Util.resizeBounds = function( current_width, current_height, target_width, target_height, stretch_mode ){
  278 + var target_ratio = target_width / target_height,
  279 + current_ratio = current_width / current_height,
  280 + output_width, output_height;
  281 +
  282 + if(!stretch_mode || stretch_mode === 'auto') {
  283 + output_width = target_width;
  284 + output_height = target_height;
  285 + } else if(target_ratio < current_ratio ^ stretch_mode === 'contain') {
  286 + output_height = target_height;
  287 + output_width = target_height * current_ratio;
  288 + } else {
  289 + output_width = target_width;
  290 + output_height = target_width / current_ratio;
  291 + }
  292 +
  293 + return {
  294 + width: output_width,
  295 + height: output_height
  296 + };
  297 +};
  298 +
  299 +function backgroundBoundsFactory( prop, el, bounds, image, imageIndex, backgroundSize ) {
  300 + var bgposition = _html2canvas.Util.getCSS( el, prop, imageIndex ) ,
  301 + topPos,
  302 + left,
  303 + percentage,
  304 + val;
  305 +
  306 + if (bgposition.length === 1){
  307 + val = bgposition[0];
  308 +
  309 + bgposition = [];
  310 +
  311 + bgposition[0] = val;
  312 + bgposition[1] = val;
  313 + }
  314 +
  315 + if (bgposition[0].toString().indexOf("%") !== -1){
  316 + percentage = (parseFloat(bgposition[0])/100);
  317 + left = bounds.width * percentage;
  318 + if(prop !== 'backgroundSize') {
  319 + left -= (backgroundSize || image).width*percentage;
  320 + }
  321 + } else {
  322 + if(prop === 'backgroundSize') {
  323 + if(bgposition[0] === 'auto') {
  324 + left = image.width;
  325 + } else {
  326 + if (/contain|cover/.test(bgposition[0])) {
  327 + var resized = _html2canvas.Util.resizeBounds(image.width, image.height, bounds.width, bounds.height, bgposition[0]);
  328 + left = resized.width;
  329 + topPos = resized.height;
  330 + } else {
  331 + left = parseInt(bgposition[0], 10);
  332 + }
  333 + }
  334 + } else {
  335 + left = parseInt( bgposition[0], 10);
  336 + }
  337 + }
  338 +
  339 +
  340 + if(bgposition[1] === 'auto') {
  341 + topPos = left / image.width * image.height;
  342 + } else if (bgposition[1].toString().indexOf("%") !== -1){
  343 + percentage = (parseFloat(bgposition[1])/100);
  344 + topPos = bounds.height * percentage;
  345 + if(prop !== 'backgroundSize') {
  346 + topPos -= (backgroundSize || image).height * percentage;
  347 + }
  348 +
  349 + } else {
  350 + topPos = parseInt(bgposition[1],10);
  351 + }
  352 +
  353 + return [left, topPos];
  354 +}
  355 +
  356 +_html2canvas.Util.BackgroundPosition = function( el, bounds, image, imageIndex, backgroundSize ) {
  357 + var result = backgroundBoundsFactory( 'backgroundPosition', el, bounds, image, imageIndex, backgroundSize );
  358 + return { left: result[0], top: result[1] };
  359 +};
  360 +
  361 +_html2canvas.Util.BackgroundSize = function( el, bounds, image, imageIndex ) {
  362 + var result = backgroundBoundsFactory( 'backgroundSize', el, bounds, image, imageIndex );
  363 + return { width: result[0], height: result[1] };
  364 +};
  365 +
  366 +_html2canvas.Util.Extend = function (options, defaults) {
  367 + for (var key in options) {
  368 + if (options.hasOwnProperty(key)) {
  369 + defaults[key] = options[key];
  370 + }
  371 + }
  372 + return defaults;
  373 +};
  374 +
  375 +
  376 +/*
  377 + * Derived from jQuery.contents()
  378 + * Copyright 2010, John Resig
  379 + * Dual licensed under the MIT or GPL Version 2 licenses.
  380 + * http://jquery.org/license
  381 + */
  382 +_html2canvas.Util.Children = function( elem ) {
  383 + var children;
  384 + try {
  385 + children = (elem.nodeName && elem.nodeName.toUpperCase() === "IFRAME") ? elem.contentDocument || elem.contentWindow.document : (function(array) {
  386 + var ret = [];
  387 + if (array !== null) {
  388 + (function(first, second ) {
  389 + var i = first.length,
  390 + j = 0;
  391 +
  392 + if (typeof second.length === "number") {
  393 + for (var l = second.length; j < l; j++) {
  394 + first[i++] = second[j];
  395 + }
  396 + } else {
  397 + while (second[j] !== undefined) {
  398 + first[i++] = second[j++];
  399 + }
  400 + }
  401 +
  402 + first.length = i;
  403 +
  404 + return first;
  405 + })(ret, array);
  406 + }
  407 + return ret;
  408 + })(elem.childNodes);
  409 +
  410 + } catch (ex) {
  411 + _html2canvas.Util.log("html2canvas.Util.Children failed with exception: " + ex.message);
  412 + children = [];
  413 + }
  414 + return children;
  415 +};
  416 +
  417 +_html2canvas.Util.isTransparent = function(backgroundColor) {
  418 + return (backgroundColor === "transparent" || backgroundColor === "rgba(0, 0, 0, 0)");
  419 +};
  420 +_html2canvas.Util.Font = (function () {
  421 +
  422 + var fontData = {};
  423 +
  424 + return function(font, fontSize, doc) {
  425 + if (fontData[font + "-" + fontSize] !== undefined) {
  426 + return fontData[font + "-" + fontSize];
  427 + }
  428 +
  429 + var container = doc.createElement('div'),
  430 + img = doc.createElement('img'),
  431 + span = doc.createElement('span'),
  432 + sampleText = 'Hidden Text',
  433 + baseline,
  434 + middle,
  435 + metricsObj;
  436 +
  437 + container.style.visibility = "hidden";
  438 + container.style.fontFamily = font;
  439 + container.style.fontSize = fontSize;
  440 + container.style.margin = 0;
  441 + container.style.padding = 0;
  442 +
  443 + doc.body.appendChild(container);
  444 +
  445 + // http://probablyprogramming.com/2009/03/15/the-tiniest-gif-ever (handtinywhite.gif)
  446 + img.src = "";
  447 + img.width = 1;
  448 + img.height = 1;
  449 +
  450 + img.style.margin = 0;
  451 + img.style.padding = 0;
  452 + img.style.verticalAlign = "baseline";
  453 +
  454 + span.style.fontFamily = font;
  455 + span.style.fontSize = fontSize;
  456 + span.style.margin = 0;
  457 + span.style.padding = 0;
  458 +
  459 + span.appendChild(doc.createTextNode(sampleText));
  460 + container.appendChild(span);
  461 + container.appendChild(img);
  462 + baseline = (img.offsetTop - span.offsetTop) + 1;
  463 +
  464 + container.removeChild(span);
  465 + container.appendChild(doc.createTextNode(sampleText));
  466 +
  467 + container.style.lineHeight = "normal";
  468 + img.style.verticalAlign = "super";
  469 +
  470 + middle = (img.offsetTop-container.offsetTop) + 1;
  471 + metricsObj = {
  472 + baseline: baseline,
  473 + lineWidth: 1,
  474 + middle: middle
  475 + };
  476 +
  477 + fontData[font + "-" + fontSize] = metricsObj;
  478 +
  479 + doc.body.removeChild(container);
  480 +
  481 + return metricsObj;
  482 + };
  483 +})();
  484 +
  485 +(function(){
  486 + var Util = _html2canvas.Util,
  487 + Generate = {};
  488 +
  489 + _html2canvas.Generate = Generate;
  490 +
  491 + var reGradients = [
  492 + /^(-webkit-linear-gradient)\(([a-z\s]+)([\w\d\.\s,%\(\)]+)\)$/,
  493 + /^(-o-linear-gradient)\(([a-z\s]+)([\w\d\.\s,%\(\)]+)\)$/,
  494 + /^(-webkit-gradient)\((linear|radial),\s((?:\d{1,3}%?)\s(?:\d{1,3}%?),\s(?:\d{1,3}%?)\s(?:\d{1,3}%?))([\w\d\.\s,%\(\)\-]+)\)$/,
  495 + /^(-moz-linear-gradient)\(((?:\d{1,3}%?)\s(?:\d{1,3}%?))([\w\d\.\s,%\(\)]+)\)$/,
  496 + /^(-webkit-radial-gradient)\(((?:\d{1,3}%?)\s(?:\d{1,3}%?)),\s(\w+)\s([a-z\-]+)([\w\d\.\s,%\(\)]+)\)$/,
  497 + /^(-moz-radial-gradient)\(((?:\d{1,3}%?)\s(?:\d{1,3}%?)),\s(\w+)\s?([a-z\-]*)([\w\d\.\s,%\(\)]+)\)$/,
  498 + /^(-o-radial-gradient)\(((?:\d{1,3}%?)\s(?:\d{1,3}%?)),\s(\w+)\s([a-z\-]+)([\w\d\.\s,%\(\)]+)\)$/
  499 + ];
  500 +
  501 + /*
  502 + * TODO: Add IE10 vendor prefix (-ms) support
  503 + * TODO: Add W3C gradient (linear-gradient) support
  504 + * TODO: Add old Webkit -webkit-gradient(radial, ...) support
  505 + * TODO: Maybe some RegExp optimizations are possible ;o)
  506 + */
  507 + Generate.parseGradient = function(css, bounds) {
  508 + var gradient, i, len = reGradients.length, m1, stop, m2, m2Len, step, m3, tl,tr,br,bl;
  509 +
  510 + for(i = 0; i < len; i+=1){
  511 + m1 = css.match(reGradients[i]);
  512 + if(m1) {
  513 + break;
  514 + }
  515 + }
  516 +
  517 + if(m1) {
  518 + switch(m1[1]) {
  519 + case '-webkit-linear-gradient':
  520 + case '-o-linear-gradient':
  521 +
  522 + gradient = {
  523 + type: 'linear',
  524 + x0: null,
  525 + y0: null,
  526 + x1: null,
  527 + y1: null,
  528 + colorStops: []
  529 + };
  530 +
  531 + // get coordinates
  532 + m2 = m1[2].match(/\w+/g);
  533 + if(m2){
  534 + m2Len = m2.length;
  535 + for(i = 0; i < m2Len; i+=1){
  536 + switch(m2[i]) {
  537 + case 'top':
  538 + gradient.y0 = 0;
  539 + gradient.y1 = bounds.height;
  540 + break;
  541 +
  542 + case 'right':
  543 + gradient.x0 = bounds.width;
  544 + gradient.x1 = 0;
  545 + break;
  546 +
  547 + case 'bottom':
  548 + gradient.y0 = bounds.height;
  549 + gradient.y1 = 0;
  550 + break;
  551 +
  552 + case 'left':
  553 + gradient.x0 = 0;
  554 + gradient.x1 = bounds.width;
  555 + break;
  556 + }
  557 + }
  558 + }
  559 + if(gradient.x0 === null && gradient.x1 === null){ // center
  560 + gradient.x0 = gradient.x1 = bounds.width / 2;
  561 + }
  562 + if(gradient.y0 === null && gradient.y1 === null){ // center
  563 + gradient.y0 = gradient.y1 = bounds.height / 2;
  564 + }
  565 +
  566 + // get colors and stops
  567 + m2 = m1[3].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\)(?:\s\d{1,3}(?:%|px))?)+/g);
  568 + if(m2){
  569 + m2Len = m2.length;
  570 + step = 1 / Math.max(m2Len - 1, 1);
  571 + for(i = 0; i < m2Len; i+=1){
  572 + m3 = m2[i].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\))\s*(\d{1,3})?(%|px)?/);
  573 + if(m3[2]){
  574 + stop = parseFloat(m3[2]);
  575 + if(m3[3] === '%'){
  576 + stop /= 100;
  577 + } else { // px - stupid opera
  578 + stop /= bounds.width;
  579 + }
  580 + } else {
  581 + stop = i * step;
  582 + }
  583 + gradient.colorStops.push({
  584 + color: m3[1],
  585 + stop: stop
  586 + });
  587 + }
  588 + }
  589 + break;
  590 +
  591 + case '-webkit-gradient':
  592 +
  593 + gradient = {
  594 + type: m1[2] === 'radial' ? 'circle' : m1[2], // TODO: Add radial gradient support for older mozilla definitions
  595 + x0: 0,
  596 + y0: 0,
  597 + x1: 0,
  598 + y1: 0,
  599 + colorStops: []
  600 + };
  601 +
  602 + // get coordinates
  603 + m2 = m1[3].match(/(\d{1,3})%?\s(\d{1,3})%?,\s(\d{1,3})%?\s(\d{1,3})%?/);
  604 + if(m2){
  605 + gradient.x0 = (m2[1] * bounds.width) / 100;
  606 + gradient.y0 = (m2[2] * bounds.height) / 100;
  607 + gradient.x1 = (m2[3] * bounds.width) / 100;
  608 + gradient.y1 = (m2[4] * bounds.height) / 100;
  609 + }
  610 +
  611 + // get colors and stops
  612 + m2 = m1[4].match(/((?:from|to|color-stop)\((?:[0-9\.]+,\s)?(?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\)\))+/g);
  613 + if(m2){
  614 + m2Len = m2.length;
  615 + for(i = 0; i < m2Len; i+=1){
  616 + m3 = m2[i].match(/(from|to|color-stop)\(([0-9\.]+)?(?:,\s)?((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\))\)/);
  617 + stop = parseFloat(m3[2]);
  618 + if(m3[1] === 'from') {
  619 + stop = 0.0;
  620 + }
  621 + if(m3[1] === 'to') {
  622 + stop = 1.0;
  623 + }
  624 + gradient.colorStops.push({
  625 + color: m3[3],
  626 + stop: stop
  627 + });
  628 + }
  629 + }
  630 + break;
  631 +
  632 + case '-moz-linear-gradient':
  633 +
  634 + gradient = {
  635 + type: 'linear',
  636 + x0: 0,
  637 + y0: 0,
  638 + x1: 0,
  639 + y1: 0,
  640 + colorStops: []
  641 + };
  642 +
  643 + // get coordinates
  644 + m2 = m1[2].match(/(\d{1,3})%?\s(\d{1,3})%?/);
  645 +
  646 + // m2[1] == 0% -> left
  647 + // m2[1] == 50% -> center
  648 + // m2[1] == 100% -> right
  649 +
  650 + // m2[2] == 0% -> top
  651 + // m2[2] == 50% -> center
  652 + // m2[2] == 100% -> bottom
  653 +
  654 + if(m2){
  655 + gradient.x0 = (m2[1] * bounds.width) / 100;
  656 + gradient.y0 = (m2[2] * bounds.height) / 100;
  657 + gradient.x1 = bounds.width - gradient.x0;
  658 + gradient.y1 = bounds.height - gradient.y0;
  659 + }
  660 +
  661 + // get colors and stops
  662 + m2 = m1[3].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\)(?:\s\d{1,3}%)?)+/g);
  663 + if(m2){
  664 + m2Len = m2.length;
  665 + step = 1 / Math.max(m2Len - 1, 1);
  666 + for(i = 0; i < m2Len; i+=1){
  667 + m3 = m2[i].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\))\s*(\d{1,3})?(%)?/);
  668 + if(m3[2]){
  669 + stop = parseFloat(m3[2]);
  670 + if(m3[3]){ // percentage
  671 + stop /= 100;
  672 + }
  673 + } else {
  674 + stop = i * step;
  675 + }
  676 + gradient.colorStops.push({
  677 + color: m3[1],
  678 + stop: stop
  679 + });
  680 + }
  681 + }
  682 + break;
  683 +
  684 + case '-webkit-radial-gradient':
  685 + case '-moz-radial-gradient':
  686 + case '-o-radial-gradient':
  687 +
  688 + gradient = {
  689 + type: 'circle',
  690 + x0: 0,
  691 + y0: 0,
  692 + x1: bounds.width,
  693 + y1: bounds.height,
  694 + cx: 0,
  695 + cy: 0,
  696 + rx: 0,
  697 + ry: 0,
  698 + colorStops: []
  699 + };
  700 +
  701 + // center
  702 + m2 = m1[2].match(/(\d{1,3})%?\s(\d{1,3})%?/);
  703 + if(m2){
  704 + gradient.cx = (m2[1] * bounds.width) / 100;
  705 + gradient.cy = (m2[2] * bounds.height) / 100;
  706 + }
  707 +
  708 + // size
  709 + m2 = m1[3].match(/\w+/);
  710 + m3 = m1[4].match(/[a-z\-]*/);
  711 + if(m2 && m3){
  712 + switch(m3[0]){
  713 + case 'farthest-corner':
  714 + case 'cover': // is equivalent to farthest-corner
  715 + case '': // mozilla removes "cover" from definition :(
  716 + tl = Math.sqrt(Math.pow(gradient.cx, 2) + Math.pow(gradient.cy, 2));
  717 + tr = Math.sqrt(Math.pow(gradient.cx, 2) + Math.pow(gradient.y1 - gradient.cy, 2));
  718 + br = Math.sqrt(Math.pow(gradient.x1 - gradient.cx, 2) + Math.pow(gradient.y1 - gradient.cy, 2));
  719 + bl = Math.sqrt(Math.pow(gradient.x1 - gradient.cx, 2) + Math.pow(gradient.cy, 2));
  720 + gradient.rx = gradient.ry = Math.max(tl, tr, br, bl);
  721 + break;
  722 + case 'closest-corner':
  723 + tl = Math.sqrt(Math.pow(gradient.cx, 2) + Math.pow(gradient.cy, 2));
  724 + tr = Math.sqrt(Math.pow(gradient.cx, 2) + Math.pow(gradient.y1 - gradient.cy, 2));
  725 + br = Math.sqrt(Math.pow(gradient.x1 - gradient.cx, 2) + Math.pow(gradient.y1 - gradient.cy, 2));
  726 + bl = Math.sqrt(Math.pow(gradient.x1 - gradient.cx, 2) + Math.pow(gradient.cy, 2));
  727 + gradient.rx = gradient.ry = Math.min(tl, tr, br, bl);
  728 + break;
  729 + case 'farthest-side':
  730 + if(m2[0] === 'circle'){
  731 + gradient.rx = gradient.ry = Math.max(
  732 + gradient.cx,
  733 + gradient.cy,
  734 + gradient.x1 - gradient.cx,
  735 + gradient.y1 - gradient.cy
  736 + );
  737 + } else { // ellipse
  738 +
  739 + gradient.type = m2[0];
  740 +
  741 + gradient.rx = Math.max(
  742 + gradient.cx,
  743 + gradient.x1 - gradient.cx
  744 + );
  745 + gradient.ry = Math.max(
  746 + gradient.cy,
  747 + gradient.y1 - gradient.cy
  748 + );
  749 + }
  750 + break;
  751 + case 'closest-side':
  752 + case 'contain': // is equivalent to closest-side
  753 + if(m2[0] === 'circle'){
  754 + gradient.rx = gradient.ry = Math.min(
  755 + gradient.cx,
  756 + gradient.cy,
  757 + gradient.x1 - gradient.cx,
  758 + gradient.y1 - gradient.cy
  759 + );
  760 + } else { // ellipse
  761 +
  762 + gradient.type = m2[0];
  763 +
  764 + gradient.rx = Math.min(
  765 + gradient.cx,
  766 + gradient.x1 - gradient.cx
  767 + );
  768 + gradient.ry = Math.min(
  769 + gradient.cy,
  770 + gradient.y1 - gradient.cy
  771 + );
  772 + }
  773 + break;
  774 +
  775 + // TODO: add support for "30px 40px" sizes (webkit only)
  776 + }
  777 + }
  778 +
  779 + // color stops
  780 + m2 = m1[5].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\)(?:\s\d{1,3}(?:%|px))?)+/g);
  781 + if(m2){
  782 + m2Len = m2.length;
  783 + step = 1 / Math.max(m2Len - 1, 1);
  784 + for(i = 0; i < m2Len; i+=1){
  785 + m3 = m2[i].match(/((?:rgb|rgba)\(\d{1,3},\s\d{1,3},\s\d{1,3}(?:,\s[0-9\.]+)?\))\s*(\d{1,3})?(%|px)?/);
  786 + if(m3[2]){
  787 + stop = parseFloat(m3[2]);
  788 + if(m3[3] === '%'){
  789 + stop /= 100;
  790 + } else { // px - stupid opera
  791 + stop /= bounds.width;
  792 + }
  793 + } else {
  794 + stop = i * step;
  795 + }
  796 + gradient.colorStops.push({
  797 + color: m3[1],
  798 + stop: stop
  799 + });
  800 + }
  801 + }
  802 + break;
  803 + }
  804 + }
  805 +
  806 + return gradient;
  807 + };
  808 +
  809 + function addScrollStops(grad) {
  810 + return function(colorStop) {
  811 + try {
  812 + grad.addColorStop(colorStop.stop, colorStop.color);
  813 + }
  814 + catch(e) {
  815 + Util.log(['failed to add color stop: ', e, '; tried to add: ', colorStop]);
  816 + }
  817 + };
  818 + }
  819 +
  820 + Generate.Gradient = function(src, bounds) {
  821 + if(bounds.width === 0 || bounds.height === 0) {
  822 + return;
  823 + }
  824 +
  825 + var canvas = document.createElement('canvas'),
  826 + ctx = canvas.getContext('2d'),
  827 + gradient, grad;
  828 +
  829 + canvas.width = bounds.width;
  830 + canvas.height = bounds.height;
  831 +
  832 + // TODO: add support for multi defined background gradients
  833 + gradient = _html2canvas.Generate.parseGradient(src, bounds);
  834 +
  835 + if(gradient) {
  836 + switch(gradient.type) {
  837 + case 'linear':
  838 + grad = ctx.createLinearGradient(gradient.x0, gradient.y0, gradient.x1, gradient.y1);
  839 + gradient.colorStops.forEach(addScrollStops(grad));
  840 + ctx.fillStyle = grad;
  841 + ctx.fillRect(0, 0, bounds.width, bounds.height);
  842 + break;
  843 +
  844 + case 'circle':
  845 + grad = ctx.createRadialGradient(gradient.cx, gradient.cy, 0, gradient.cx, gradient.cy, gradient.rx);
  846 + gradient.colorStops.forEach(addScrollStops(grad));
  847 + ctx.fillStyle = grad;
  848 + ctx.fillRect(0, 0, bounds.width, bounds.height);
  849 + break;
  850 +
  851 + case 'ellipse':
  852 + var canvasRadial = document.createElement('canvas'),
  853 + ctxRadial = canvasRadial.getContext('2d'),
  854 + ri = Math.max(gradient.rx, gradient.ry),
  855 + di = ri * 2;
  856 +
  857 + canvasRadial.width = canvasRadial.height = di;
  858 +
  859 + grad = ctxRadial.createRadialGradient(gradient.rx, gradient.ry, 0, gradient.rx, gradient.ry, ri);
  860 + gradient.colorStops.forEach(addScrollStops(grad));
  861 +
  862 + ctxRadial.fillStyle = grad;
  863 + ctxRadial.fillRect(0, 0, di, di);
  864 +
  865 + ctx.fillStyle = gradient.colorStops[gradient.colorStops.length - 1].color;
  866 + ctx.fillRect(0, 0, canvas.width, canvas.height);
  867 + ctx.drawImage(canvasRadial, gradient.cx - gradient.rx, gradient.cy - gradient.ry, 2 * gradient.rx, 2 * gradient.ry);
  868 + break;
  869 + }
  870 + }
  871 +
  872 + return canvas;
  873 + };
  874 +
  875 + Generate.ListAlpha = function(number) {
  876 + var tmp = "",
  877 + modulus;
  878 +
  879 + do {
  880 + modulus = number % 26;
  881 + tmp = String.fromCharCode((modulus) + 64) + tmp;
  882 + number = number / 26;
  883 + }while((number*26) > 26);
  884 +
  885 + return tmp;
  886 + };
  887 +
  888 + Generate.ListRoman = function(number) {
  889 + var romanArray = ["M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"],
  890 + decimal = [1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1],
  891 + roman = "",
  892 + v,
  893 + len = romanArray.length;
  894 +
  895 + if (number <= 0 || number >= 4000) {
  896 + return number;
  897 + }
  898 +
  899 + for (v=0; v < len; v+=1) {
  900 + while (number >= decimal[v]) {
  901 + number -= decimal[v];
  902 + roman += romanArray[v];
  903 + }
  904 + }
  905 +
  906 + return roman;
  907 + };
  908 +})();
  909 +function h2cRenderContext(width, height) {
  910 + var storage = [];
  911 + return {
  912 + storage: storage,
  913 + width: width,
  914 + height: height,
  915 + clip: function() {
  916 + storage.push({
  917 + type: "function",
  918 + name: "clip",
  919 + 'arguments': arguments
  920 + });
  921 + },
  922 + translate: function() {
  923 + storage.push({
  924 + type: "function",
  925 + name: "translate",
  926 + 'arguments': arguments
  927 + });
  928 + },
  929 + fill: function() {
  930 + storage.push({
  931 + type: "function",
  932 + name: "fill",
  933 + 'arguments': arguments
  934 + });
  935 + },
  936 + save: function() {
  937 + storage.push({
  938 + type: "function",
  939 + name: "save",
  940 + 'arguments': arguments
  941 + });
  942 + },
  943 + restore: function() {
  944 + storage.push({
  945 + type: "function",
  946 + name: "restore",
  947 + 'arguments': arguments
  948 + });
  949 + },
  950 + fillRect: function () {
  951 + storage.push({
  952 + type: "function",
  953 + name: "fillRect",
  954 + 'arguments': arguments
  955 + });
  956 + },
  957 + createPattern: function() {
  958 + storage.push({
  959 + type: "function",
  960 + name: "createPattern",
  961 + 'arguments': arguments
  962 + });
  963 + },
  964 + drawShape: function() {
  965 +
  966 + var shape = [];
  967 +
  968 + storage.push({
  969 + type: "function",
  970 + name: "drawShape",
  971 + 'arguments': shape
  972 + });
  973 +
  974 + return {
  975 + moveTo: function() {
  976 + shape.push({
  977 + name: "moveTo",
  978 + 'arguments': arguments
  979 + });
  980 + },
  981 + lineTo: function() {
  982 + shape.push({
  983 + name: "lineTo",
  984 + 'arguments': arguments
  985 + });
  986 + },
  987 + arcTo: function() {
  988 + shape.push({
  989 + name: "arcTo",
  990 + 'arguments': arguments
  991 + });
  992 + },
  993 + bezierCurveTo: function() {
  994 + shape.push({
  995 + name: "bezierCurveTo",
  996 + 'arguments': arguments
  997 + });
  998 + },
  999 + quadraticCurveTo: function() {
  1000 + shape.push({
  1001 + name: "quadraticCurveTo",
  1002 + 'arguments': arguments
  1003 + });
  1004 + }
  1005 + };
  1006 +
  1007 + },
  1008 + drawImage: function () {
  1009 + storage.push({
  1010 + type: "function",
  1011 + name: "drawImage",
  1012 + 'arguments': arguments
  1013 + });
  1014 + },
  1015 + fillText: function () {
  1016 + storage.push({
  1017 + type: "function",
  1018 + name: "fillText",
  1019 + 'arguments': arguments
  1020 + });
  1021 + },
  1022 + setVariable: function (variable, value) {
  1023 + storage.push({
  1024 + type: "variable",
  1025 + name: variable,
  1026 + 'arguments': value
  1027 + });
  1028 + return value;
  1029 + }
  1030 + };
  1031 +}
  1032 +_html2canvas.Parse = function (images, options) {
  1033 + window.scroll(0,0);
  1034 +
  1035 + var element = (( options.elements === undefined ) ? document.body : options.elements[0]), // select body by default
  1036 + numDraws = 0,
  1037 + doc = element.ownerDocument,
  1038 + Util = _html2canvas.Util,
  1039 + support = Util.Support(options, doc),
  1040 + ignoreElementsRegExp = new RegExp("(" + options.ignoreElements + ")"),
  1041 + body = doc.body,
  1042 + getCSS = Util.getCSS,
  1043 + pseudoHide = "___html2canvas___pseudoelement",
  1044 + hidePseudoElements = doc.createElement('style');
  1045 +
  1046 + hidePseudoElements.innerHTML = '.' + pseudoHide + '-before:before { content: "" !important; display: none !important; }' +
  1047 + '.' + pseudoHide + '-after:after { content: "" !important; display: none !important; }';
  1048 +
  1049 + body.appendChild(hidePseudoElements);
  1050 +
  1051 + images = images || {};
  1052 +
  1053 + function documentWidth () {
  1054 + return Math.max(
  1055 + Math.max(doc.body.scrollWidth, doc.documentElement.scrollWidth),
  1056 + Math.max(doc.body.offsetWidth, doc.documentElement.offsetWidth),
  1057 + Math.max(doc.body.clientWidth, doc.documentElement.clientWidth)
  1058 + );
  1059 + }
  1060 +
  1061 + function documentHeight () {
  1062 + return Math.max(
  1063 + Math.max(doc.body.scrollHeight, doc.documentElement.scrollHeight),
  1064 + Math.max(doc.body.offsetHeight, doc.documentElement.offsetHeight),
  1065 + Math.max(doc.body.clientHeight, doc.documentElement.clientHeight)
  1066 + );
  1067 + }
  1068 +
  1069 + function getCSSInt(element, attribute) {
  1070 + var val = parseInt(getCSS(element, attribute), 10);
  1071 + return (isNaN(val)) ? 0 : val; // borders in old IE are throwing 'medium' for demo.html
  1072 + }
  1073 +
  1074 + function renderRect (ctx, x, y, w, h, bgcolor) {
  1075 + if (bgcolor !== "transparent"){
  1076 + ctx.setVariable("fillStyle", bgcolor);
  1077 + ctx.fillRect(x, y, w, h);
  1078 + numDraws+=1;
  1079 + }
  1080 + }
  1081 +
  1082 + function capitalize(m, p1, p2) {
  1083 + if (m.length > 0) {
  1084 + return p1 + p2.toUpperCase();
  1085 + }
  1086 + }
  1087 +
  1088 + function textTransform (text, transform) {
  1089 + switch(transform){
  1090 + case "lowercase":
  1091 + return text.toLowerCase();
  1092 + case "capitalize":
  1093 + return text.replace( /(^|\s|:|-|\(|\))([a-z])/g, capitalize);
  1094 + case "uppercase":
  1095 + return text.toUpperCase();
  1096 + default:
  1097 + return text;
  1098 + }
  1099 + }
  1100 +
  1101 + function noLetterSpacing(letter_spacing) {
  1102 + return (/^(normal|none|0px)$/.test(letter_spacing));
  1103 + }
  1104 +
  1105 + function drawText(currentText, x, y, ctx){
  1106 + if (currentText !== null && Util.trimText(currentText).length > 0) {
  1107 + ctx.fillText(currentText, x, y);
  1108 + numDraws+=1;
  1109 + }
  1110 + }
  1111 +
  1112 + function setTextVariables(ctx, el, text_decoration, color) {
  1113 + var align = false,
  1114 + bold = getCSS(el, "fontWeight"),
  1115 + family = getCSS(el, "fontFamily"),
  1116 + size = getCSS(el, "fontSize"),
  1117 + shadows = Util.parseTextShadows(getCSS(el, "textShadow"));
  1118 +
  1119 + switch(parseInt(bold, 10)){
  1120 + case 401:
  1121 + bold = "bold";
  1122 + break;
  1123 + case 400:
  1124 + bold = "normal";
  1125 + break;
  1126 + }
  1127 +
  1128 + ctx.setVariable("fillStyle", color);
  1129 + ctx.setVariable("font", [getCSS(el, "fontStyle"), getCSS(el, "fontVariant"), bold, size, family].join(" "));
  1130 + ctx.setVariable("textAlign", (align) ? "right" : "left");
  1131 +
  1132 + if (shadows.length) {
  1133 + // TODO: support multiple text shadows
  1134 + // apply the first text shadow
  1135 + ctx.setVariable("shadowColor", shadows[0].color);
  1136 + ctx.setVariable("shadowOffsetX", shadows[0].offsetX);
  1137 + ctx.setVariable("shadowOffsetY", shadows[0].offsetY);
  1138 + ctx.setVariable("shadowBlur", shadows[0].blur);
  1139 + }
  1140 +
  1141 + if (text_decoration !== "none"){
  1142 + return Util.Font(family, size, doc);
  1143 + }
  1144 + }
  1145 +
  1146 + function renderTextDecoration(ctx, text_decoration, bounds, metrics, color) {
  1147 + switch(text_decoration) {
  1148 + case "underline":
  1149 + // Draws a line at the baseline of the font
  1150 + // TODO As some browsers display the line as more than 1px if the font-size is big, need to take that into account both in position and size
  1151 + renderRect(ctx, bounds.left, Math.round(bounds.top + metrics.baseline + metrics.lineWidth), bounds.width, 1, color);
  1152 + break;
  1153 + case "overline":
  1154 + renderRect(ctx, bounds.left, Math.round(bounds.top), bounds.width, 1, color);
  1155 + break;
  1156 + case "line-through":
  1157 + // TODO try and find exact position for line-through
  1158 + renderRect(ctx, bounds.left, Math.ceil(bounds.top + metrics.middle + metrics.lineWidth), bounds.width, 1, color);
  1159 + break;
  1160 + }
  1161 + }
  1162 +
  1163 + function getTextBounds(state, text, textDecoration, isLast, transform) {
  1164 + var bounds;
  1165 + if (support.rangeBounds && !transform) {
  1166 + if (textDecoration !== "none" || Util.trimText(text).length !== 0) {
  1167 + bounds = textRangeBounds(text, state.node, state.textOffset);
  1168 + }
  1169 + state.textOffset += text.length;
  1170 + } else if (state.node && typeof state.node.nodeValue === "string" ){
  1171 + var newTextNode = (isLast) ? state.node.splitText(text.length) : null;
  1172 + bounds = textWrapperBounds(state.node, transform);
  1173 + state.node = newTextNode;
  1174 + }
  1175 + return bounds;
  1176 + }
  1177 +
  1178 + function textRangeBounds(text, textNode, textOffset) {
  1179 + var range = doc.createRange();
  1180 + range.setStart(textNode, textOffset);
  1181 + range.setEnd(textNode, textOffset + text.length);
  1182 + return range.getBoundingClientRect();
  1183 + }
  1184 +
  1185 + function textWrapperBounds(oldTextNode, transform) {
  1186 + var parent = oldTextNode.parentNode,
  1187 + wrapElement = doc.createElement('wrapper'),
  1188 + backupText = oldTextNode.cloneNode(true);
  1189 +
  1190 + wrapElement.appendChild(oldTextNode.cloneNode(true));
  1191 + parent.replaceChild(wrapElement, oldTextNode);
  1192 +
  1193 + var bounds = transform ? Util.OffsetBounds(wrapElement) : Util.Bounds(wrapElement);
  1194 + parent.replaceChild(backupText, wrapElement);
  1195 + return bounds;
  1196 + }
  1197 +
  1198 + function renderText(el, textNode, stack) {
  1199 + var ctx = stack.ctx,
  1200 + color = getCSS(el, "color"),
  1201 + textDecoration = getCSS(el, "textDecoration"),
  1202 + textAlign = getCSS(el, "textAlign"),
  1203 + metrics,
  1204 + textList,
  1205 + state = {
  1206 + node: textNode,
  1207 + textOffset: 0
  1208 + };
  1209 +
  1210 + if (Util.trimText(textNode.nodeValue).length > 0) {
  1211 + textNode.nodeValue = textTransform(textNode.nodeValue, getCSS(el, "textTransform"));
  1212 + textAlign = textAlign.replace(["-webkit-auto"],["auto"]);
  1213 +
  1214 + textList = (!options.letterRendering && /^(left|right|justify|auto)$/.test(textAlign) && noLetterSpacing(getCSS(el, "letterSpacing"))) ?
  1215 + textNode.nodeValue.split(/(\b| )/)
  1216 + : textNode.nodeValue.split("");
  1217 +
  1218 + metrics = setTextVariables(ctx, el, textDecoration, color);
  1219 +
  1220 + if (options.chinese) {
  1221 + textList.forEach(function(word, index) {
  1222 + if (/.*[\u4E00-\u9FA5].*$/.test(word)) {
  1223 + word = word.split("");
  1224 + word.unshift(index, 1);
  1225 + textList.splice.apply(textList, word);
  1226 + }
  1227 + });
  1228 + }
  1229 +
  1230 + textList.forEach(function(text, index) {
  1231 + var bounds = getTextBounds(state, text, textDecoration, (index < textList.length - 1), stack.transform.matrix);
  1232 + if (bounds) {
  1233 + drawText(text, bounds.left, bounds.bottom, ctx);
  1234 + renderTextDecoration(ctx, textDecoration, bounds, metrics, color);
  1235 + }
  1236 + });
  1237 + }
  1238 + }
  1239 +
  1240 + function listPosition (element, val) {
  1241 + var boundElement = doc.createElement( "boundelement" ),
  1242 + originalType,
  1243 + bounds;
  1244 +
  1245 + boundElement.style.display = "inline";
  1246 +
  1247 + originalType = element.style.listStyleType;
  1248 + element.style.listStyleType = "none";
  1249 +
  1250 + boundElement.appendChild(doc.createTextNode(val));
  1251 +
  1252 + element.insertBefore(boundElement, element.firstChild);
  1253 +
  1254 + bounds = Util.Bounds(boundElement);
  1255 + element.removeChild(boundElement);
  1256 + element.style.listStyleType = originalType;
  1257 + return bounds;
  1258 + }
  1259 +
  1260 + function elementIndex(el) {
  1261 + var i = -1,
  1262 + count = 1,
  1263 + childs = el.parentNode.childNodes;
  1264 +
  1265 + if (el.parentNode) {
  1266 + while(childs[++i] !== el) {
  1267 + if (childs[i].nodeType === 1) {
  1268 + count++;
  1269 + }
  1270 + }
  1271 + return count;
  1272 + } else {
  1273 + return -1;
  1274 + }
  1275 + }
  1276 +
  1277 + function listItemText(element, type) {
  1278 + var currentIndex = elementIndex(element), text;
  1279 + switch(type){
  1280 + case "decimal":
  1281 + text = currentIndex;
  1282 + break;
  1283 + case "decimal-leading-zero":
  1284 + text = (currentIndex.toString().length === 1) ? currentIndex = "0" + currentIndex.toString() : currentIndex.toString();
  1285 + break;
  1286 + case "upper-roman":
  1287 + text = _html2canvas.Generate.ListRoman( currentIndex );
  1288 + break;
  1289 + case "lower-roman":
  1290 + text = _html2canvas.Generate.ListRoman( currentIndex ).toLowerCase();
  1291 + break;
  1292 + case "lower-alpha":
  1293 + text = _html2canvas.Generate.ListAlpha( currentIndex ).toLowerCase();
  1294 + break;
  1295 + case "upper-alpha":
  1296 + text = _html2canvas.Generate.ListAlpha( currentIndex );
  1297 + break;
  1298 + }
  1299 +
  1300 + return text + ". ";
  1301 + }
  1302 +
  1303 + function renderListItem(element, stack, elBounds) {
  1304 + var x,
  1305 + text,
  1306 + ctx = stack.ctx,
  1307 + type = getCSS(element, "listStyleType"),
  1308 + listBounds;
  1309 +
  1310 + if (/^(decimal|decimal-leading-zero|upper-alpha|upper-latin|upper-roman|lower-alpha|lower-greek|lower-latin|lower-roman)$/i.test(type)) {
  1311 + text = listItemText(element, type);
  1312 + listBounds = listPosition(element, text);
  1313 + setTextVariables(ctx, element, "none", getCSS(element, "color"));
  1314 +
  1315 + if (getCSS(element, "listStylePosition") === "inside") {
  1316 + ctx.setVariable("textAlign", "left");
  1317 + x = elBounds.left;
  1318 + } else {
  1319 + return;
  1320 + }
  1321 +
  1322 + drawText(text, x, listBounds.bottom, ctx);
  1323 + }
  1324 + }
  1325 +
  1326 + function loadImage (src){
  1327 + var img = images[src];
  1328 + return (img && img.succeeded === true) ? img.img : false;
  1329 + }
  1330 +
  1331 + function clipBounds(src, dst){
  1332 + var x = Math.max(src.left, dst.left),
  1333 + y = Math.max(src.top, dst.top),
  1334 + x2 = Math.min((src.left + src.width), (dst.left + dst.width)),
  1335 + y2 = Math.min((src.top + src.height), (dst.top + dst.height));
  1336 +
  1337 + return {
  1338 + left:x,
  1339 + top:y,
  1340 + width:x2-x,
  1341 + height:y2-y
  1342 + };
  1343 + }
  1344 +
  1345 + function setZ(element, stack, parentStack){
  1346 + var newContext,
  1347 + isPositioned = stack.cssPosition !== 'static',
  1348 + zIndex = isPositioned ? getCSS(element, 'zIndex') : 'auto',
  1349 + opacity = getCSS(element, 'opacity'),
  1350 + isFloated = getCSS(element, 'cssFloat') !== 'none';
  1351 +
  1352 + // https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Understanding_z_index/The_stacking_context
  1353 + // When a new stacking context should be created:
  1354 + // the root element (HTML),
  1355 + // positioned (absolutely or relatively) with a z-index value other than "auto",
  1356 + // elements with an opacity value less than 1. (See the specification for opacity),
  1357 + // on mobile WebKit and Chrome 22+, position: fixed always creates a new stacking context, even when z-index is "auto" (See this post)
  1358 +
  1359 + stack.zIndex = newContext = h2czContext(zIndex);
  1360 + newContext.isPositioned = isPositioned;
  1361 + newContext.isFloated = isFloated;
  1362 + newContext.opacity = opacity;
  1363 + newContext.ownStacking = (zIndex !== 'auto' || opacity < 1);
  1364 +
  1365 + if (parentStack) {
  1366 + parentStack.zIndex.children.push(stack);
  1367 + }
  1368 + }
  1369 +
  1370 + function renderImage(ctx, element, image, bounds, borders) {
  1371 +
  1372 + var paddingLeft = getCSSInt(element, 'paddingLeft'),
  1373 + paddingTop = getCSSInt(element, 'paddingTop'),
  1374 + paddingRight = getCSSInt(element, 'paddingRight'),
  1375 + paddingBottom = getCSSInt(element, 'paddingBottom');
  1376 +
  1377 + drawImage(
  1378 + ctx,
  1379 + image,
  1380 + 0, //sx
  1381 + 0, //sy
  1382 + image.width, //sw
  1383 + image.height, //sh
  1384 + bounds.left + paddingLeft + borders[3].width, //dx
  1385 + bounds.top + paddingTop + borders[0].width, // dy
  1386 + bounds.width - (borders[1].width + borders[3].width + paddingLeft + paddingRight), //dw
  1387 + bounds.height - (borders[0].width + borders[2].width + paddingTop + paddingBottom) //dh
  1388 + );
  1389 + }
  1390 +
  1391 + function getBorderData(element) {
  1392 + return ["Top", "Right", "Bottom", "Left"].map(function(side) {
  1393 + return {
  1394 + width: getCSSInt(element, 'border' + side + 'Width'),
  1395 + color: getCSS(element, 'border' + side + 'Color')
  1396 + };
  1397 + });
  1398 + }
  1399 +
  1400 + function getBorderRadiusData(element) {
  1401 + return ["TopLeft", "TopRight", "BottomRight", "BottomLeft"].map(function(side) {
  1402 + return getCSS(element, 'border' + side + 'Radius');
  1403 + });
  1404 + }
  1405 +
  1406 + var getCurvePoints = (function(kappa) {
  1407 +
  1408 + return function(x, y, r1, r2) {
  1409 + var ox = (r1) * kappa, // control point offset horizontal
  1410 + oy = (r2) * kappa, // control point offset vertical
  1411 + xm = x + r1, // x-middle
  1412 + ym = y + r2; // y-middle
  1413 + return {
  1414 + topLeft: bezierCurve({
  1415 + x:x,
  1416 + y:ym
  1417 + }, {
  1418 + x:x,
  1419 + y:ym - oy
  1420 + }, {
  1421 + x:xm - ox,
  1422 + y:y
  1423 + }, {
  1424 + x:xm,
  1425 + y:y
  1426 + }),
  1427 + topRight: bezierCurve({
  1428 + x:x,
  1429 + y:y
  1430 + }, {
  1431 + x:x + ox,
  1432 + y:y
  1433 + }, {
  1434 + x:xm,
  1435 + y:ym - oy
  1436 + }, {
  1437 + x:xm,
  1438 + y:ym
  1439 + }),
  1440 + bottomRight: bezierCurve({
  1441 + x:xm,
  1442 + y:y
  1443 + }, {
  1444 + x:xm,
  1445 + y:y + oy
  1446 + }, {
  1447 + x:x + ox,
  1448 + y:ym
  1449 + }, {
  1450 + x:x,
  1451 + y:ym
  1452 + }),
  1453 + bottomLeft: bezierCurve({
  1454 + x:xm,
  1455 + y:ym
  1456 + }, {
  1457 + x:xm - ox,
  1458 + y:ym
  1459 + }, {
  1460 + x:x,
  1461 + y:y + oy
  1462 + }, {
  1463 + x:x,
  1464 + y:y
  1465 + })
  1466 + };
  1467 + };
  1468 + })(4 * ((Math.sqrt(2) - 1) / 3));
  1469 +
  1470 + function bezierCurve(start, startControl, endControl, end) {
  1471 +
  1472 + var lerp = function (a, b, t) {
  1473 + return {
  1474 + x:a.x + (b.x - a.x) * t,
  1475 + y:a.y + (b.y - a.y) * t
  1476 + };
  1477 + };
  1478 +
  1479 + return {
  1480 + start: start,
  1481 + startControl: startControl,
  1482 + endControl: endControl,
  1483 + end: end,
  1484 + subdivide: function(t) {
  1485 + var ab = lerp(start, startControl, t),
  1486 + bc = lerp(startControl, endControl, t),
  1487 + cd = lerp(endControl, end, t),
  1488 + abbc = lerp(ab, bc, t),
  1489 + bccd = lerp(bc, cd, t),
  1490 + dest = lerp(abbc, bccd, t);
  1491 + return [bezierCurve(start, ab, abbc, dest), bezierCurve(dest, bccd, cd, end)];
  1492 + },
  1493 + curveTo: function(borderArgs) {
  1494 + borderArgs.push(["bezierCurve", startControl.x, startControl.y, endControl.x, endControl.y, end.x, end.y]);
  1495 + },
  1496 + curveToReversed: function(borderArgs) {
  1497 + borderArgs.push(["bezierCurve", endControl.x, endControl.y, startControl.x, startControl.y, start.x, start.y]);
  1498 + }
  1499 + };
  1500 + }
  1501 +
  1502 + function parseCorner(borderArgs, radius1, radius2, corner1, corner2, x, y) {
  1503 + if (radius1[0] > 0 || radius1[1] > 0) {
  1504 + borderArgs.push(["line", corner1[0].start.x, corner1[0].start.y]);
  1505 + corner1[0].curveTo(borderArgs);
  1506 + corner1[1].curveTo(borderArgs);
  1507 + } else {
  1508 + borderArgs.push(["line", x, y]);
  1509 + }
  1510 +
  1511 + if (radius2[0] > 0 || radius2[1] > 0) {
  1512 + borderArgs.push(["line", corner2[0].start.x, corner2[0].start.y]);
  1513 + }
  1514 + }
  1515 +
  1516 + function drawSide(borderData, radius1, radius2, outer1, inner1, outer2, inner2) {
  1517 + var borderArgs = [];
  1518 +
  1519 + if (radius1[0] > 0 || radius1[1] > 0) {
  1520 + borderArgs.push(["line", outer1[1].start.x, outer1[1].start.y]);
  1521 + outer1[1].curveTo(borderArgs);
  1522 + } else {
  1523 + borderArgs.push([ "line", borderData.c1[0], borderData.c1[1]]);
  1524 + }
  1525 +
  1526 + if (radius2[0] > 0 || radius2[1] > 0) {
  1527 + borderArgs.push(["line", outer2[0].start.x, outer2[0].start.y]);
  1528 + outer2[0].curveTo(borderArgs);
  1529 + borderArgs.push(["line", inner2[0].end.x, inner2[0].end.y]);
  1530 + inner2[0].curveToReversed(borderArgs);
  1531 + } else {
  1532 + borderArgs.push([ "line", borderData.c2[0], borderData.c2[1]]);
  1533 + borderArgs.push([ "line", borderData.c3[0], borderData.c3[1]]);
  1534 + }
  1535 +
  1536 + if (radius1[0] > 0 || radius1[1] > 0) {
  1537 + borderArgs.push(["line", inner1[1].end.x, inner1[1].end.y]);
  1538 + inner1[1].curveToReversed(borderArgs);
  1539 + } else {
  1540 + borderArgs.push([ "line", borderData.c4[0], borderData.c4[1]]);
  1541 + }
  1542 +
  1543 + return borderArgs;
  1544 + }
  1545 +
  1546 + function calculateCurvePoints(bounds, borderRadius, borders) {
  1547 +
  1548 + var x = bounds.left,
  1549 + y = bounds.top,
  1550 + width = bounds.width,
  1551 + height = bounds.height,
  1552 +
  1553 + tlh = borderRadius[0][0],
  1554 + tlv = borderRadius[0][1],
  1555 + trh = borderRadius[1][0],
  1556 + trv = borderRadius[1][1],
  1557 + brh = borderRadius[2][0],
  1558 + brv = borderRadius[2][1],
  1559 + blh = borderRadius[3][0],
  1560 + blv = borderRadius[3][1],
  1561 +
  1562 + topWidth = width - trh,
  1563 + rightHeight = height - brv,
  1564 + bottomWidth = width - brh,
  1565 + leftHeight = height - blv;
  1566 +
  1567 + return {
  1568 + topLeftOuter: getCurvePoints(
  1569 + x,
  1570 + y,
  1571 + tlh,
  1572 + tlv
  1573 + ).topLeft.subdivide(0.5),
  1574 +
  1575 + topLeftInner: getCurvePoints(
  1576 + x + borders[3].width,
  1577 + y + borders[0].width,
  1578 + Math.max(0, tlh - borders[3].width),
  1579 + Math.max(0, tlv - borders[0].width)
  1580 + ).topLeft.subdivide(0.5),
  1581 +
  1582 + topRightOuter: getCurvePoints(
  1583 + x + topWidth,
  1584 + y,
  1585 + trh,
  1586 + trv
  1587 + ).topRight.subdivide(0.5),
  1588 +
  1589 + topRightInner: getCurvePoints(
  1590 + x + Math.min(topWidth, width + borders[3].width),
  1591 + y + borders[0].width,
  1592 + (topWidth > width + borders[3].width) ? 0 :trh - borders[3].width,
  1593 + trv - borders[0].width
  1594 + ).topRight.subdivide(0.5),
  1595 +
  1596 + bottomRightOuter: getCurvePoints(
  1597 + x + bottomWidth,
  1598 + y + rightHeight,
  1599 + brh,
  1600 + brv
  1601 + ).bottomRight.subdivide(0.5),
  1602 +
  1603 + bottomRightInner: getCurvePoints(
  1604 + x + Math.min(bottomWidth, width + borders[3].width),
  1605 + y + Math.min(rightHeight, height + borders[0].width),
  1606 + Math.max(0, brh - borders[1].width),
  1607 + Math.max(0, brv - borders[2].width)
  1608 + ).bottomRight.subdivide(0.5),
  1609 +
  1610 + bottomLeftOuter: getCurvePoints(
  1611 + x,
  1612 + y + leftHeight,
  1613 + blh,
  1614 + blv
  1615 + ).bottomLeft.subdivide(0.5),
  1616 +
  1617 + bottomLeftInner: getCurvePoints(
  1618 + x + borders[3].width,
  1619 + y + leftHeight,
  1620 + Math.max(0, blh - borders[3].width),
  1621 + Math.max(0, blv - borders[2].width)
  1622 + ).bottomLeft.subdivide(0.5)
  1623 + };
  1624 + }
  1625 +
  1626 + function getBorderClip(element, borderPoints, borders, radius, bounds) {
  1627 + var backgroundClip = getCSS(element, 'backgroundClip'),
  1628 + borderArgs = [];
  1629 +
  1630 + switch(backgroundClip) {
  1631 + case "content-box":
  1632 + case "padding-box":
  1633 + parseCorner(borderArgs, radius[0], radius[1], borderPoints.topLeftInner, borderPoints.topRightInner, bounds.left + borders[3].width, bounds.top + borders[0].width);
  1634 + parseCorner(borderArgs, radius[1], radius[2], borderPoints.topRightInner, borderPoints.bottomRightInner, bounds.left + bounds.width - borders[1].width, bounds.top + borders[0].width);
  1635 + parseCorner(borderArgs, radius[2], radius[3], borderPoints.bottomRightInner, borderPoints.bottomLeftInner, bounds.left + bounds.width - borders[1].width, bounds.top + bounds.height - borders[2].width);
  1636 + parseCorner(borderArgs, radius[3], radius[0], borderPoints.bottomLeftInner, borderPoints.topLeftInner, bounds.left + borders[3].width, bounds.top + bounds.height - borders[2].width);
  1637 + break;
  1638 +
  1639 + default:
  1640 + parseCorner(borderArgs, radius[0], radius[1], borderPoints.topLeftOuter, borderPoints.topRightOuter, bounds.left, bounds.top);
  1641 + parseCorner(borderArgs, radius[1], radius[2], borderPoints.topRightOuter, borderPoints.bottomRightOuter, bounds.left + bounds.width, bounds.top);
  1642 + parseCorner(borderArgs, radius[2], radius[3], borderPoints.bottomRightOuter, borderPoints.bottomLeftOuter, bounds.left + bounds.width, bounds.top + bounds.height);
  1643 + parseCorner(borderArgs, radius[3], radius[0], borderPoints.bottomLeftOuter, borderPoints.topLeftOuter, bounds.left, bounds.top + bounds.height);
  1644 + break;
  1645 + }
  1646 +
  1647 + return borderArgs;
  1648 + }
  1649 +
  1650 + function parseBorders(element, bounds, borders){
  1651 + var x = bounds.left,
  1652 + y = bounds.top,
  1653 + width = bounds.width,
  1654 + height = bounds.height,
  1655 + borderSide,
  1656 + bx,
  1657 + by,
  1658 + bw,
  1659 + bh,
  1660 + borderArgs,
  1661 + // http://www.w3.org/TR/css3-background/#the-border-radius
  1662 + borderRadius = getBorderRadiusData(element),
  1663 + borderPoints = calculateCurvePoints(bounds, borderRadius, borders),
  1664 + borderData = {
  1665 + clip: getBorderClip(element, borderPoints, borders, borderRadius, bounds),
  1666 + borders: []
  1667 + };
  1668 +
  1669 + for (borderSide = 0; borderSide < 4; borderSide++) {
  1670 +
  1671 + if (borders[borderSide].width > 0) {
  1672 + bx = x;
  1673 + by = y;
  1674 + bw = width;
  1675 + bh = height - (borders[2].width);
  1676 +
  1677 + switch(borderSide) {
  1678 + case 0:
  1679 + // top border
  1680 + bh = borders[0].width;
  1681 +
  1682 + borderArgs = drawSide({
  1683 + c1: [bx, by],
  1684 + c2: [bx + bw, by],
  1685 + c3: [bx + bw - borders[1].width, by + bh],
  1686 + c4: [bx + borders[3].width, by + bh]
  1687 + }, borderRadius[0], borderRadius[1],
  1688 + borderPoints.topLeftOuter, borderPoints.topLeftInner, borderPoints.topRightOuter, borderPoints.topRightInner);
  1689 + break;
  1690 + case 1:
  1691 + // right border
  1692 + bx = x + width - (borders[1].width);
  1693 + bw = borders[1].width;
  1694 +
  1695 + borderArgs = drawSide({
  1696 + c1: [bx + bw, by],
  1697 + c2: [bx + bw, by + bh + borders[2].width],
  1698 + c3: [bx, by + bh],
  1699 + c4: [bx, by + borders[0].width]
  1700 + }, borderRadius[1], borderRadius[2],
  1701 + borderPoints.topRightOuter, borderPoints.topRightInner, borderPoints.bottomRightOuter, borderPoints.bottomRightInner);
  1702 + break;
  1703 + case 2:
  1704 + // bottom border
  1705 + by = (by + height) - (borders[2].width);
  1706 + bh = borders[2].width;
  1707 +
  1708 + borderArgs = drawSide({
  1709 + c1: [bx + bw, by + bh],
  1710 + c2: [bx, by + bh],
  1711 + c3: [bx + borders[3].width, by],
  1712 + c4: [bx + bw - borders[3].width, by]
  1713 + }, borderRadius[2], borderRadius[3],
  1714 + borderPoints.bottomRightOuter, borderPoints.bottomRightInner, borderPoints.bottomLeftOuter, borderPoints.bottomLeftInner);
  1715 + break;
  1716 + case 3:
  1717 + // left border
  1718 + bw = borders[3].width;
  1719 +
  1720 + borderArgs = drawSide({
  1721 + c1: [bx, by + bh + borders[2].width],
  1722 + c2: [bx, by],
  1723 + c3: [bx + bw, by + borders[0].width],
  1724 + c4: [bx + bw, by + bh]
  1725 + }, borderRadius[3], borderRadius[0],
  1726 + borderPoints.bottomLeftOuter, borderPoints.bottomLeftInner, borderPoints.topLeftOuter, borderPoints.topLeftInner);
  1727 + break;
  1728 + }
  1729 +
  1730 + borderData.borders.push({
  1731 + args: borderArgs,
  1732 + color: borders[borderSide].color
  1733 + });
  1734 +
  1735 + }
  1736 + }
  1737 +
  1738 + return borderData;
  1739 + }
  1740 +
  1741 + function createShape(ctx, args) {
  1742 + var shape = ctx.drawShape();
  1743 + args.forEach(function(border, index) {
  1744 + shape[(index === 0) ? "moveTo" : border[0] + "To" ].apply(null, border.slice(1));
  1745 + });
  1746 + return shape;
  1747 + }
  1748 +
  1749 + function renderBorders(ctx, borderArgs, color) {
  1750 + if (color !== "transparent") {
  1751 + ctx.setVariable( "fillStyle", color);
  1752 + createShape(ctx, borderArgs);
  1753 + ctx.fill();
  1754 + numDraws+=1;
  1755 + }
  1756 + }
  1757 +
  1758 + function renderFormValue (el, bounds, stack){
  1759 +
  1760 + var valueWrap = doc.createElement('valuewrap'),
  1761 + cssPropertyArray = ['lineHeight','textAlign','fontFamily','color','fontSize','paddingLeft','paddingTop','width','height','border','borderLeftWidth','borderTopWidth'],
  1762 + textValue,
  1763 + textNode;
  1764 +
  1765 + cssPropertyArray.forEach(function(property) {
  1766 + try {
  1767 + valueWrap.style[property] = getCSS(el, property);
  1768 + } catch(e) {
  1769 + // Older IE has issues with "border"
  1770 + Util.log("html2canvas: Parse: Exception caught in renderFormValue: " + e.message);
  1771 + }
  1772 + });
  1773 +
  1774 + valueWrap.style.borderColor = "black";
  1775 + valueWrap.style.borderStyle = "solid";
  1776 + valueWrap.style.display = "block";
  1777 + valueWrap.style.position = "absolute";
  1778 +
  1779 + if (/^(submit|reset|button|text|password)$/.test(el.type) || el.nodeName === "SELECT"){
  1780 + valueWrap.style.lineHeight = getCSS(el, "height");
  1781 + }
  1782 +
  1783 + valueWrap.style.top = bounds.top + "px";
  1784 + valueWrap.style.left = bounds.left + "px";
  1785 +
  1786 + textValue = (el.nodeName === "SELECT") ? (el.options[el.selectedIndex] || 0).text : el.value;
  1787 + if(!textValue) {
  1788 + textValue = el.placeholder;
  1789 + }
  1790 +
  1791 + textNode = doc.createTextNode(textValue);
  1792 +
  1793 + valueWrap.appendChild(textNode);
  1794 + body.appendChild(valueWrap);
  1795 +
  1796 + renderText(el, textNode, stack);
  1797 + body.removeChild(valueWrap);
  1798 + }
  1799 +
  1800 + function drawImage (ctx) {
  1801 + ctx.drawImage.apply(ctx, Array.prototype.slice.call(arguments, 1));
  1802 + numDraws+=1;
  1803 + }
  1804 +
  1805 + function getPseudoElement(el, which) {
  1806 + var elStyle = window.getComputedStyle(el, which);
  1807 + if(!elStyle || !elStyle.content || elStyle.content === "none" || elStyle.content === "-moz-alt-content" || elStyle.display === "none") {
  1808 + return;
  1809 + }
  1810 + var content = elStyle.content + '',
  1811 + first = content.substr( 0, 1 );
  1812 + //strips quotes
  1813 + if(first === content.substr( content.length - 1 ) && first.match(/'|"/)) {
  1814 + content = content.substr( 1, content.length - 2 );
  1815 + }
  1816 +
  1817 + var isImage = content.substr( 0, 3 ) === 'url',
  1818 + elps = document.createElement( isImage ? 'img' : 'span' );
  1819 +
  1820 + elps.className = pseudoHide + "-before " + pseudoHide + "-after";
  1821 +
  1822 + Object.keys(elStyle).filter(indexedProperty).forEach(function(prop) {
  1823 + // Prevent assigning of read only CSS Rules, ex. length, parentRule
  1824 + try {
  1825 + elps.style[prop] = elStyle[prop];
  1826 + } catch (e) {
  1827 + Util.log(['Tried to assign readonly property ', prop, 'Error:', e]);
  1828 + }
  1829 + });
  1830 +
  1831 + if(isImage) {
  1832 + elps.src = Util.parseBackgroundImage(content)[0].args[0];
  1833 + } else {
  1834 + elps.innerHTML = content;
  1835 + }
  1836 + return elps;
  1837 + }
  1838 +
  1839 + function indexedProperty(property) {
  1840 + return (isNaN(window.parseInt(property, 10)));
  1841 + }
  1842 +
  1843 + function injectPseudoElements(el, stack) {
  1844 + var before = getPseudoElement(el, ':before'),
  1845 + after = getPseudoElement(el, ':after');
  1846 + if(!before && !after) {
  1847 + return;
  1848 + }
  1849 +
  1850 + if(before) {
  1851 + el.className += " " + pseudoHide + "-before";
  1852 + el.parentNode.insertBefore(before, el);
  1853 + parseElement(before, stack, true);
  1854 + el.parentNode.removeChild(before);
  1855 + el.className = el.className.replace(pseudoHide + "-before", "").trim();
  1856 + }
  1857 +
  1858 + if (after) {
  1859 + el.className += " " + pseudoHide + "-after";
  1860 + el.appendChild(after);
  1861 + parseElement(after, stack, true);
  1862 + el.removeChild(after);
  1863 + el.className = el.className.replace(pseudoHide + "-after", "").trim();
  1864 + }
  1865 +
  1866 + }
  1867 +
  1868 + function renderBackgroundRepeat(ctx, image, backgroundPosition, bounds) {
  1869 + var offsetX = Math.round(bounds.left + backgroundPosition.left),
  1870 + offsetY = Math.round(bounds.top + backgroundPosition.top);
  1871 +
  1872 + ctx.createPattern(image);
  1873 + ctx.translate(offsetX, offsetY);
  1874 + ctx.fill();
  1875 + ctx.translate(-offsetX, -offsetY);
  1876 + }
  1877 +
  1878 + function backgroundRepeatShape(ctx, image, backgroundPosition, bounds, left, top, width, height) {
  1879 + var args = [];
  1880 + args.push(["line", Math.round(left), Math.round(top)]);
  1881 + args.push(["line", Math.round(left + width), Math.round(top)]);
  1882 + args.push(["line", Math.round(left + width), Math.round(height + top)]);
  1883 + args.push(["line", Math.round(left), Math.round(height + top)]);
  1884 + createShape(ctx, args);
  1885 + ctx.save();
  1886 + ctx.clip();
  1887 + renderBackgroundRepeat(ctx, image, backgroundPosition, bounds);
  1888 + ctx.restore();
  1889 + }
  1890 +
  1891 + function renderBackgroundColor(ctx, backgroundBounds, bgcolor) {
  1892 + renderRect(
  1893 + ctx,
  1894 + backgroundBounds.left,
  1895 + backgroundBounds.top,
  1896 + backgroundBounds.width,
  1897 + backgroundBounds.height,
  1898 + bgcolor
  1899 + );
  1900 + }
  1901 +
  1902 + function renderBackgroundRepeating(el, bounds, ctx, image, imageIndex) {
  1903 + var backgroundSize = Util.BackgroundSize(el, bounds, image, imageIndex),
  1904 + backgroundPosition = Util.BackgroundPosition(el, bounds, image, imageIndex, backgroundSize),
  1905 + backgroundRepeat = getCSS(el, "backgroundRepeat").split(",").map(Util.trimText);
  1906 +
  1907 + image = resizeImage(image, backgroundSize);
  1908 +
  1909 + backgroundRepeat = backgroundRepeat[imageIndex] || backgroundRepeat[0];
  1910 +
  1911 + switch (backgroundRepeat) {
  1912 + case "repeat-x":
  1913 + backgroundRepeatShape(ctx, image, backgroundPosition, bounds,
  1914 + bounds.left, bounds.top + backgroundPosition.top, 99999, image.height);
  1915 + break;
  1916 +
  1917 + case "repeat-y":
  1918 + backgroundRepeatShape(ctx, image, backgroundPosition, bounds,
  1919 + bounds.left + backgroundPosition.left, bounds.top, image.width, 99999);
  1920 + break;
  1921 +
  1922 + case "no-repeat":
  1923 + backgroundRepeatShape(ctx, image, backgroundPosition, bounds,
  1924 + bounds.left + backgroundPosition.left, bounds.top + backgroundPosition.top, image.width, image.height);
  1925 + break;
  1926 +
  1927 + default:
  1928 + renderBackgroundRepeat(ctx, image, backgroundPosition, {
  1929 + top: bounds.top,
  1930 + left: bounds.left,
  1931 + width: image.width,
  1932 + height: image.height
  1933 + });
  1934 + break;
  1935 + }
  1936 + }
  1937 +
  1938 + function renderBackgroundImage(element, bounds, ctx) {
  1939 + var backgroundImage = getCSS(element, "backgroundImage"),
  1940 + backgroundImages = Util.parseBackgroundImage(backgroundImage),
  1941 + image,
  1942 + imageIndex = backgroundImages.length;
  1943 +
  1944 + while(imageIndex--) {
  1945 + backgroundImage = backgroundImages[imageIndex];
  1946 +
  1947 + if (!backgroundImage.args || backgroundImage.args.length === 0) {
  1948 + continue;
  1949 + }
  1950 +
  1951 + var key = backgroundImage.method === 'url' ?
  1952 + backgroundImage.args[0] :
  1953 + backgroundImage.value;
  1954 +
  1955 + image = loadImage(key);
  1956 +
  1957 + // TODO add support for background-origin
  1958 + if (image) {
  1959 + renderBackgroundRepeating(element, bounds, ctx, image, imageIndex);
  1960 + } else {
  1961 + Util.log("html2canvas: Error loading background:", backgroundImage);
  1962 + }
  1963 + }
  1964 + }
  1965 +
  1966 + function resizeImage(image, bounds) {
  1967 + if(image.width === bounds.width && image.height === bounds.height) {
  1968 + return image;
  1969 + }
  1970 +
  1971 + var ctx, canvas = doc.createElement('canvas');
  1972 + canvas.width = bounds.width;
  1973 + canvas.height = bounds.height;
  1974 + ctx = canvas.getContext("2d");
  1975 + drawImage(ctx, image, 0, 0, image.width, image.height, 0, 0, bounds.width, bounds.height );
  1976 + return canvas;
  1977 + }
  1978 +
  1979 + function setOpacity(ctx, element, parentStack) {
  1980 + return ctx.setVariable("globalAlpha", getCSS(element, "opacity") * ((parentStack) ? parentStack.opacity : 1));
  1981 + }
  1982 +
  1983 + function removePx(str) {
  1984 + return str.replace("px", "");
  1985 + }
  1986 +
  1987 + var transformRegExp = /(matrix)\((.+)\)/;
  1988 +
  1989 + function getTransform(element, parentStack) {
  1990 + var transform = getCSS(element, "transform") || getCSS(element, "-webkit-transform") || getCSS(element, "-moz-transform") || getCSS(element, "-ms-transform") || getCSS(element, "-o-transform");
  1991 + var transformOrigin = getCSS(element, "transform-origin") || getCSS(element, "-webkit-transform-origin") || getCSS(element, "-moz-transform-origin") || getCSS(element, "-ms-transform-origin") || getCSS(element, "-o-transform-origin") || "0px 0px";
  1992 +
  1993 + transformOrigin = transformOrigin.split(" ").map(removePx).map(Util.asFloat);
  1994 +
  1995 + var matrix;
  1996 + if (transform && transform !== "none") {
  1997 + var match = transform.match(transformRegExp);
  1998 + if (match) {
  1999 + switch(match[1]) {
  2000 + case "matrix":
  2001 + matrix = match[2].split(",").map(Util.trimText).map(Util.asFloat);
  2002 + break;
  2003 + }
  2004 + }
  2005 + }
  2006 +
  2007 + return {
  2008 + origin: transformOrigin,
  2009 + matrix: matrix
  2010 + };
  2011 + }
  2012 +
  2013 + function createStack(element, parentStack, bounds, transform) {
  2014 + var ctx = h2cRenderContext((!parentStack) ? documentWidth() : bounds.width , (!parentStack) ? documentHeight() : bounds.height),
  2015 + stack = {
  2016 + ctx: ctx,
  2017 + opacity: setOpacity(ctx, element, parentStack),
  2018 + cssPosition: getCSS(element, "position"),
  2019 + borders: getBorderData(element),
  2020 + transform: transform,
  2021 + clip: (parentStack && parentStack.clip) ? Util.Extend( {}, parentStack.clip ) : null
  2022 + };
  2023 +
  2024 + setZ(element, stack, parentStack);
  2025 +
  2026 + // TODO correct overflow for absolute content residing under a static position
  2027 + if (options.useOverflow === true && /(hidden|scroll|auto)/.test(getCSS(element, "overflow")) === true && /(BODY)/i.test(element.nodeName) === false){
  2028 + stack.clip = (stack.clip) ? clipBounds(stack.clip, bounds) : bounds;
  2029 + }
  2030 +
  2031 + return stack;
  2032 + }
  2033 +
  2034 + function getBackgroundBounds(borders, bounds, clip) {
  2035 + var backgroundBounds = {
  2036 + left: bounds.left + borders[3].width,
  2037 + top: bounds.top + borders[0].width,
  2038 + width: bounds.width - (borders[1].width + borders[3].width),
  2039 + height: bounds.height - (borders[0].width + borders[2].width)
  2040 + };
  2041 +
  2042 + if (clip) {
  2043 + backgroundBounds = clipBounds(backgroundBounds, clip);
  2044 + }
  2045 +
  2046 + return backgroundBounds;
  2047 + }
  2048 +
  2049 + function getBounds(element, transform) {
  2050 + var bounds = (transform.matrix) ? Util.OffsetBounds(element) : Util.Bounds(element);
  2051 + transform.origin[0] += bounds.left;
  2052 + transform.origin[1] += bounds.top;
  2053 + return bounds;
  2054 + }
  2055 +
  2056 + function renderElement(element, parentStack, pseudoElement, ignoreBackground) {
  2057 + var transform = getTransform(element, parentStack),
  2058 + bounds = getBounds(element, transform),
  2059 + image,
  2060 + stack = createStack(element, parentStack, bounds, transform),
  2061 + borders = stack.borders,
  2062 + ctx = stack.ctx,
  2063 + backgroundBounds = getBackgroundBounds(borders, bounds, stack.clip),
  2064 + borderData = parseBorders(element, bounds, borders),
  2065 + backgroundColor = (ignoreElementsRegExp.test(element.nodeName)) ? "#efefef" : getCSS(element, "backgroundColor");
  2066 +
  2067 +
  2068 + createShape(ctx, borderData.clip);
  2069 +
  2070 + ctx.save();
  2071 + ctx.clip();
  2072 +
  2073 + if (backgroundBounds.height > 0 && backgroundBounds.width > 0 && !ignoreBackground) {
  2074 + renderBackgroundColor(ctx, bounds, backgroundColor);
  2075 + renderBackgroundImage(element, backgroundBounds, ctx);
  2076 + } else if (ignoreBackground) {
  2077 + stack.backgroundColor = backgroundColor;
  2078 + }
  2079 +
  2080 + ctx.restore();
  2081 +
  2082 + borderData.borders.forEach(function(border) {
  2083 + renderBorders(ctx, border.args, border.color);
  2084 + });
  2085 +
  2086 + if (!pseudoElement) {
  2087 + injectPseudoElements(element, stack);
  2088 + }
  2089 +
  2090 + switch(element.nodeName){
  2091 + case "IMG":
  2092 + if ((image = loadImage(element.getAttribute('src')))) {
  2093 + renderImage(ctx, element, image, bounds, borders);
  2094 + } else {
  2095 + Util.log("html2canvas: Error loading <img>:" + element.getAttribute('src'));
  2096 + }
  2097 + break;
  2098 + case "INPUT":
  2099 + // TODO add all relevant type's, i.e. HTML5 new stuff
  2100 + // todo add support for placeholder attribute for browsers which support it
  2101 + if (/^(text|url|email|submit|button|reset)$/.test(element.type) && (element.value || element.placeholder || "").length > 0){
  2102 + renderFormValue(element, bounds, stack);
  2103 + }
  2104 + break;
  2105 + case "TEXTAREA":
  2106 + if ((element.value || element.placeholder || "").length > 0){
  2107 + renderFormValue(element, bounds, stack);
  2108 + }
  2109 + break;
  2110 + case "SELECT":
  2111 + if ((element.options||element.placeholder || "").length > 0){
  2112 + renderFormValue(element, bounds, stack);
  2113 + }
  2114 + break;
  2115 + case "LI":
  2116 + renderListItem(element, stack, backgroundBounds);
  2117 + break;
  2118 + case "CANVAS":
  2119 + renderImage(ctx, element, element, bounds, borders);
  2120 + break;
  2121 + }
  2122 +
  2123 + return stack;
  2124 + }
  2125 +
  2126 + function isElementVisible(element) {
  2127 + return (getCSS(element, 'display') !== "none" && getCSS(element, 'visibility') !== "hidden" && !element.hasAttribute("data-html2canvas-ignore"));
  2128 + }
  2129 +
  2130 + function parseElement (element, stack, pseudoElement) {
  2131 + if (isElementVisible(element)) {
  2132 + stack = renderElement(element, stack, pseudoElement, false) || stack;
  2133 + if (!ignoreElementsRegExp.test(element.nodeName)) {
  2134 + parseChildren(element, stack, pseudoElement);
  2135 + }
  2136 + }
  2137 + }
  2138 +
  2139 + function parseChildren(element, stack, pseudoElement) {
  2140 + Util.Children(element).forEach(function(node) {
  2141 + if (node.nodeType === node.ELEMENT_NODE) {
  2142 + parseElement(node, stack, pseudoElement);
  2143 + } else if (node.nodeType === node.TEXT_NODE) {
  2144 + renderText(element, node, stack);
  2145 + }
  2146 + });
  2147 + }
  2148 +
  2149 + function init() {
  2150 + var background = getCSS(document.documentElement, "backgroundColor"),
  2151 + transparentBackground = (Util.isTransparent(background) && element === document.body),
  2152 + stack = renderElement(element, null, false, transparentBackground);
  2153 + parseChildren(element, stack);
  2154 +
  2155 + if (transparentBackground) {
  2156 + background = stack.backgroundColor;
  2157 + }
  2158 +
  2159 + body.removeChild(hidePseudoElements);
  2160 + return {
  2161 + backgroundColor: background,
  2162 + stack: stack
  2163 + };
  2164 + }
  2165 +
  2166 + return init();
  2167 +};
  2168 +
  2169 +function h2czContext(zindex) {
  2170 + return {
  2171 + zindex: zindex,
  2172 + children: []
  2173 + };
  2174 +}
  2175 +
  2176 +_html2canvas.Preload = function( options ) {
  2177 +
  2178 + var images = {
  2179 + numLoaded: 0, // also failed are counted here
  2180 + numFailed: 0,
  2181 + numTotal: 0,
  2182 + cleanupDone: false
  2183 + },
  2184 + pageOrigin,
  2185 + Util = _html2canvas.Util,
  2186 + methods,
  2187 + i,
  2188 + count = 0,
  2189 + element = options.elements[0] || document.body,
  2190 + doc = element.ownerDocument,
  2191 + domImages = element.getElementsByTagName('img'), // Fetch images of the present element only
  2192 + imgLen = domImages.length,
  2193 + link = doc.createElement("a"),
  2194 + supportCORS = (function( img ){
  2195 + return (img.crossOrigin !== undefined);
  2196 + })(new Image()),
  2197 + timeoutTimer;
  2198 +
  2199 + link.href = window.location.href;
  2200 + pageOrigin = link.protocol + link.host;
  2201 +
  2202 + function isSameOrigin(url){
  2203 + link.href = url;
  2204 + link.href = link.href; // YES, BELIEVE IT OR NOT, that is required for IE9 - http://jsfiddle.net/niklasvh/2e48b/
  2205 + var origin = link.protocol + link.host;
  2206 + return (origin === pageOrigin);
  2207 + }
  2208 +
  2209 + function start(){
  2210 + Util.log("html2canvas: start: images: " + images.numLoaded + " / " + images.numTotal + " (failed: " + images.numFailed + ")");
  2211 + if (!images.firstRun && images.numLoaded >= images.numTotal){
  2212 + Util.log("Finished loading images: # " + images.numTotal + " (failed: " + images.numFailed + ")");
  2213 +
  2214 + if (typeof options.complete === "function"){
  2215 + options.complete(images);
  2216 + }
  2217 +
  2218 + }
  2219 + }
  2220 +
  2221 + // TODO modify proxy to serve images with CORS enabled, where available
  2222 + function proxyGetImage(url, img, imageObj){
  2223 + var callback_name,
  2224 + scriptUrl = options.proxy,
  2225 + script;
  2226 +
  2227 + link.href = url;
  2228 + url = link.href; // work around for pages with base href="" set - WARNING: this may change the url
  2229 +
  2230 + callback_name = 'html2canvas_' + (count++);
  2231 + imageObj.callbackname = callback_name;
  2232 +
  2233 + if (scriptUrl.indexOf("?") > -1) {
  2234 + scriptUrl += "&";
  2235 + } else {
  2236 + scriptUrl += "?";
  2237 + }
  2238 + scriptUrl += 'url=' + encodeURIComponent(url) + '&callback=' + callback_name;
  2239 + script = doc.createElement("script");
  2240 +
  2241 + window[callback_name] = function(a){
  2242 + if (a.substring(0,6) === "error:"){
  2243 + imageObj.succeeded = false;
  2244 + images.numLoaded++;
  2245 + images.numFailed++;
  2246 + start();
  2247 + } else {
  2248 + setImageLoadHandlers(img, imageObj);
  2249 + img.src = a;
  2250 + }
  2251 + window[callback_name] = undefined; // to work with IE<9 // NOTE: that the undefined callback property-name still exists on the window object (for IE<9)
  2252 + try {
  2253 + delete window[callback_name]; // for all browser that support this
  2254 + } catch(ex) {}
  2255 + script.parentNode.removeChild(script);
  2256 + script = null;
  2257 + delete imageObj.script;
  2258 + delete imageObj.callbackname;
  2259 + };
  2260 +
  2261 + script.setAttribute("type", "text/javascript");
  2262 + script.setAttribute("src", scriptUrl);
  2263 + imageObj.script = script;
  2264 + window.document.body.appendChild(script);
  2265 +
  2266 + }
  2267 +
  2268 + function loadPseudoElement(element, type) {
  2269 + var style = window.getComputedStyle(element, type),
  2270 + content = style.content;
  2271 + if (content.substr(0, 3) === 'url') {
  2272 + methods.loadImage(_html2canvas.Util.parseBackgroundImage(content)[0].args[0]);
  2273 + }
  2274 + loadBackgroundImages(style.backgroundImage, element);
  2275 + }
  2276 +
  2277 + function loadPseudoElementImages(element) {
  2278 + loadPseudoElement(element, ":before");
  2279 + loadPseudoElement(element, ":after");
  2280 + }
  2281 +
  2282 + function loadGradientImage(backgroundImage, bounds) {
  2283 + var img = _html2canvas.Generate.Gradient(backgroundImage, bounds);
  2284 +
  2285 + if (img !== undefined){
  2286 + images[backgroundImage] = {
  2287 + img: img,
  2288 + succeeded: true
  2289 + };
  2290 + images.numTotal++;
  2291 + images.numLoaded++;
  2292 + start();
  2293 + }
  2294 + }
  2295 +
  2296 + function invalidBackgrounds(background_image) {
  2297 + return (background_image && background_image.method && background_image.args && background_image.args.length > 0 );
  2298 + }
  2299 +
  2300 + function loadBackgroundImages(background_image, el) {
  2301 + var bounds;
  2302 +
  2303 + _html2canvas.Util.parseBackgroundImage(background_image).filter(invalidBackgrounds).forEach(function(background_image) {
  2304 + if (background_image.method === 'url') {
  2305 + methods.loadImage(background_image.args[0]);
  2306 + } else if(background_image.method.match(/\-?gradient$/)) {
  2307 + if(bounds === undefined) {
  2308 + bounds = _html2canvas.Util.Bounds(el);
  2309 + }
  2310 + loadGradientImage(background_image.value, bounds);
  2311 + }
  2312 + });
  2313 + }
  2314 +
  2315 + function getImages (el) {
  2316 + var elNodeType = false;
  2317 +
  2318 + // Firefox fails with permission denied on pages with iframes
  2319 + try {
  2320 + Util.Children(el).forEach(getImages);
  2321 + }
  2322 + catch( e ) {}
  2323 +
  2324 + try {
  2325 + elNodeType = el.nodeType;
  2326 + } catch (ex) {
  2327 + elNodeType = false;
  2328 + Util.log("html2canvas: failed to access some element's nodeType - Exception: " + ex.message);
  2329 + }
  2330 +
  2331 + if (elNodeType === 1 || elNodeType === undefined) {
  2332 + loadPseudoElementImages(el);
  2333 + try {
  2334 + loadBackgroundImages(Util.getCSS(el, 'backgroundImage'), el);
  2335 + } catch(e) {
  2336 + Util.log("html2canvas: failed to get background-image - Exception: " + e.message);
  2337 + }
  2338 + loadBackgroundImages(el);
  2339 + }
  2340 + }
  2341 +
  2342 + function setImageLoadHandlers(img, imageObj) {
  2343 + img.onload = function() {
  2344 + if ( imageObj.timer !== undefined ) {
  2345 + // CORS succeeded
  2346 + window.clearTimeout( imageObj.timer );
  2347 + }
  2348 +
  2349 + images.numLoaded++;
  2350 + imageObj.succeeded = true;
  2351 + img.onerror = img.onload = null;
  2352 + start();
  2353 + };
  2354 + img.onerror = function() {
  2355 + if (img.crossOrigin === "anonymous") {
  2356 + // CORS failed
  2357 + window.clearTimeout( imageObj.timer );
  2358 +
  2359 + // let's try with proxy instead
  2360 + if ( options.proxy ) {
  2361 + var src = img.src;
  2362 + img = new Image();
  2363 + imageObj.img = img;
  2364 + img.src = src;
  2365 +
  2366 + proxyGetImage( img.src, img, imageObj );
  2367 + return;
  2368 + }
  2369 + }
  2370 +
  2371 + images.numLoaded++;
  2372 + images.numFailed++;
  2373 + imageObj.succeeded = false;
  2374 + img.onerror = img.onload = null;
  2375 + start();
  2376 + };
  2377 + }
  2378 +
  2379 + methods = {
  2380 + loadImage: function( src ) {
  2381 + var img, imageObj;
  2382 + if ( src && images[src] === undefined ) {
  2383 + img = new Image();
  2384 + if ( src.match(/data:image\/.*;base64,/i) ) {
  2385 + img.src = src.replace(/url\(['"]{0,}|['"]{0,}\)$/ig, '');
  2386 + imageObj = images[src] = {
  2387 + img: img
  2388 + };
  2389 + images.numTotal++;
  2390 + setImageLoadHandlers(img, imageObj);
  2391 + } else if ( isSameOrigin( src ) || options.allowTaint === true ) {
  2392 + imageObj = images[src] = {
  2393 + img: img
  2394 + };
  2395 + images.numTotal++;
  2396 + setImageLoadHandlers(img, imageObj);
  2397 + img.src = src;
  2398 + } else if ( supportCORS && !options.allowTaint && options.useCORS ) {
  2399 + // attempt to load with CORS
  2400 +
  2401 + img.crossOrigin = "anonymous";
  2402 + imageObj = images[src] = {
  2403 + img: img
  2404 + };
  2405 + images.numTotal++;
  2406 + setImageLoadHandlers(img, imageObj);
  2407 + img.src = src;
  2408 + } else if ( options.proxy ) {
  2409 + imageObj = images[src] = {
  2410 + img: img
  2411 + };
  2412 + images.numTotal++;
  2413 + proxyGetImage( src, img, imageObj );
  2414 + }
  2415 + }
  2416 +
  2417 + },
  2418 + cleanupDOM: function(cause) {
  2419 + var img, src;
  2420 + if (!images.cleanupDone) {
  2421 + if (cause && typeof cause === "string") {
  2422 + Util.log("html2canvas: Cleanup because: " + cause);
  2423 + } else {
  2424 + Util.log("html2canvas: Cleanup after timeout: " + options.timeout + " ms.");
  2425 + }
  2426 +
  2427 + for (src in images) {
  2428 + if (images.hasOwnProperty(src)) {
  2429 + img = images[src];
  2430 + if (typeof img === "object" && img.callbackname && img.succeeded === undefined) {
  2431 + // cancel proxy image request
  2432 + window[img.callbackname] = undefined; // to work with IE<9 // NOTE: that the undefined callback property-name still exists on the window object (for IE<9)
  2433 + try {
  2434 + delete window[img.callbackname]; // for all browser that support this
  2435 + } catch(ex) {}
  2436 + if (img.script && img.script.parentNode) {
  2437 + img.script.setAttribute("src", "about:blank"); // try to cancel running request
  2438 + img.script.parentNode.removeChild(img.script);
  2439 + }
  2440 + images.numLoaded++;
  2441 + images.numFailed++;
  2442 + Util.log("html2canvas: Cleaned up failed img: '" + src + "' Steps: " + images.numLoaded + " / " + images.numTotal);
  2443 + }
  2444 + }
  2445 + }
  2446 +
  2447 + // cancel any pending requests
  2448 + if(window.stop !== undefined) {
  2449 + window.stop();
  2450 + } else if(document.execCommand !== undefined) {
  2451 + document.execCommand("Stop", false);
  2452 + }
  2453 + if (document.close !== undefined) {
  2454 + document.close();
  2455 + }
  2456 + images.cleanupDone = true;
  2457 + if (!(cause && typeof cause === "string")) {
  2458 + start();
  2459 + }
  2460 + }
  2461 + },
  2462 +
  2463 + renderingDone: function() {
  2464 + if (timeoutTimer) {
  2465 + window.clearTimeout(timeoutTimer);
  2466 + }
  2467 + }
  2468 + };
  2469 +
  2470 + if (options.timeout > 0) {
  2471 + timeoutTimer = window.setTimeout(methods.cleanupDOM, options.timeout);
  2472 + }
  2473 +
  2474 + Util.log('html2canvas: Preload starts: finding background-images');
  2475 + images.firstRun = true;
  2476 +
  2477 + getImages(element);
  2478 +
  2479 + Util.log('html2canvas: Preload: Finding images');
  2480 + // load <img> images
  2481 + for (i = 0; i < imgLen; i+=1){
  2482 + methods.loadImage( domImages[i].getAttribute( "src" ) );
  2483 + }
  2484 +
  2485 + images.firstRun = false;
  2486 + Util.log('html2canvas: Preload: Done.');
  2487 + if (images.numTotal === images.numLoaded) {
  2488 + start();
  2489 + }
  2490 +
  2491 + return methods;
  2492 +};
  2493 +
  2494 +_html2canvas.Renderer = function(parseQueue, options){
  2495 +
  2496 + // http://www.w3.org/TR/CSS21/zindex.html
  2497 + function createRenderQueue(parseQueue) {
  2498 + var queue = [],
  2499 + rootContext;
  2500 +
  2501 + rootContext = (function buildStackingContext(rootNode) {
  2502 + var rootContext = {};
  2503 + function insert(context, node, specialParent) {
  2504 + var zi = (node.zIndex.zindex === 'auto') ? 0 : Number(node.zIndex.zindex),
  2505 + contextForChildren = context, // the stacking context for children
  2506 + isPositioned = node.zIndex.isPositioned,
  2507 + isFloated = node.zIndex.isFloated,
  2508 + stub = {node: node},
  2509 + childrenDest = specialParent; // where children without z-index should be pushed into
  2510 +
  2511 + if (node.zIndex.ownStacking) {
  2512 + // '!' comes before numbers in sorted array
  2513 + contextForChildren = stub.context = { '!': [{node:node, children: []}]};
  2514 + childrenDest = undefined;
  2515 + } else if (isPositioned || isFloated) {
  2516 + childrenDest = stub.children = [];
  2517 + }
  2518 +
  2519 + if (zi === 0 && specialParent) {
  2520 + specialParent.push(stub);
  2521 + } else {
  2522 + if (!context[zi]) { context[zi] = []; }
  2523 + context[zi].push(stub);
  2524 + }
  2525 +
  2526 + node.zIndex.children.forEach(function(childNode) {
  2527 + insert(contextForChildren, childNode, childrenDest);
  2528 + });
  2529 + }
  2530 + insert(rootContext, rootNode);
  2531 + return rootContext;
  2532 + })(parseQueue);
  2533 +
  2534 + function sortZ(context) {
  2535 + Object.keys(context).sort().forEach(function(zi) {
  2536 + var nonPositioned = [],
  2537 + floated = [],
  2538 + positioned = [],
  2539 + list = [];
  2540 +
  2541 + // positioned after static
  2542 + context[zi].forEach(function(v) {
  2543 + if (v.node.zIndex.isPositioned || v.node.zIndex.opacity < 1) {
  2544 + // http://www.w3.org/TR/css3-color/#transparency
  2545 + // non-positioned element with opactiy < 1 should be stacked as if it were a positioned element with ‘z-index: 0’ and ‘opacity: 1’.
  2546 + positioned.push(v);
  2547 + } else if (v.node.zIndex.isFloated) {
  2548 + floated.push(v);
  2549 + } else {
  2550 + nonPositioned.push(v);
  2551 + }
  2552 + });
  2553 +
  2554 + (function walk(arr) {
  2555 + arr.forEach(function(v) {
  2556 + list.push(v);
  2557 + if (v.children) { walk(v.children); }
  2558 + });
  2559 + })(nonPositioned.concat(floated, positioned));
  2560 +
  2561 + list.forEach(function(v) {
  2562 + if (v.context) {
  2563 + sortZ(v.context);
  2564 + } else {
  2565 + queue.push(v.node);
  2566 + }
  2567 + });
  2568 + });
  2569 + }
  2570 +
  2571 + sortZ(rootContext);
  2572 +
  2573 + return queue;
  2574 + }
  2575 +
  2576 + function getRenderer(rendererName) {
  2577 + var renderer;
  2578 +
  2579 + if (typeof options.renderer === "string" && _html2canvas.Renderer[rendererName] !== undefined) {
  2580 + renderer = _html2canvas.Renderer[rendererName](options);
  2581 + } else if (typeof rendererName === "function") {
  2582 + renderer = rendererName(options);
  2583 + } else {
  2584 + throw new Error("Unknown renderer");
  2585 + }
  2586 +
  2587 + if ( typeof renderer !== "function" ) {
  2588 + throw new Error("Invalid renderer defined");
  2589 + }
  2590 + return renderer;
  2591 + }
  2592 +
  2593 + return getRenderer(options.renderer)(parseQueue, options, document, createRenderQueue(parseQueue.stack), _html2canvas);
  2594 +};
  2595 +
  2596 +_html2canvas.Util.Support = function (options, doc) {
  2597 +
  2598 + function supportSVGRendering() {
  2599 + var img = new Image(),
  2600 + canvas = doc.createElement("canvas"),
  2601 + ctx = (canvas.getContext === undefined) ? false : canvas.getContext("2d");
  2602 + if (ctx === false) {
  2603 + return false;
  2604 + }
  2605 + canvas.width = canvas.height = 10;
  2606 + img.src = [
  2607 + "data:image/svg+xml,",
  2608 + "<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'>",
  2609 + "<foreignObject width='10' height='10'>",
  2610 + "<div xmlns='http://www.w3.org/1999/xhtml' style='width:10;height:10;'>",
  2611 + "sup",
  2612 + "</div>",
  2613 + "</foreignObject>",
  2614 + "</svg>"
  2615 + ].join("");
  2616 + try {
  2617 + ctx.drawImage(img, 0, 0);
  2618 + canvas.toDataURL();
  2619 + } catch(e) {
  2620 + return false;
  2621 + }
  2622 + _html2canvas.Util.log('html2canvas: Parse: SVG powered rendering available');
  2623 + return true;
  2624 + }
  2625 +
  2626 + // Test whether we can use ranges to measure bounding boxes
  2627 + // Opera doesn't provide valid bounds.height/bottom even though it supports the method.
  2628 +
  2629 + function supportRangeBounds() {
  2630 + var r, testElement, rangeBounds, rangeHeight, support = false;
  2631 +
  2632 + if (doc.createRange) {
  2633 + r = doc.createRange();
  2634 + if (r.getBoundingClientRect) {
  2635 + testElement = doc.createElement('boundtest');
  2636 + testElement.style.height = "123px";
  2637 + testElement.style.display = "block";
  2638 + doc.body.appendChild(testElement);
  2639 +
  2640 + r.selectNode(testElement);
  2641 + rangeBounds = r.getBoundingClientRect();
  2642 + rangeHeight = rangeBounds.height;
  2643 +
  2644 + if (rangeHeight === 123) {
  2645 + support = true;
  2646 + }
  2647 + doc.body.removeChild(testElement);
  2648 + }
  2649 + }
  2650 +
  2651 + return support;
  2652 + }
  2653 +
  2654 + return {
  2655 + rangeBounds: supportRangeBounds(),
  2656 + svgRendering: options.svgRendering && supportSVGRendering()
  2657 + };
  2658 +};
  2659 +window.html2canvas = function(elements, opts) {
  2660 + elements = (elements.length) ? elements : [elements];
  2661 + var queue,
  2662 + canvas,
  2663 + options = {
  2664 + // general
  2665 + logging: false,
  2666 + elements: elements,
  2667 + background: "#fff",
  2668 +
  2669 + // preload options
  2670 + proxy: null,
  2671 + timeout: 0, // no timeout
  2672 + useCORS: false, // try to load images as CORS (where available), before falling back to proxy
  2673 + allowTaint: false, // whether to allow images to taint the canvas, won't need proxy if set to true
  2674 +
  2675 + // parse options
  2676 + svgRendering: false, // use svg powered rendering where available (FF11+)
  2677 + ignoreElements: "IFRAME|OBJECT|PARAM",
  2678 + useOverflow: true,
  2679 + letterRendering: false,
  2680 + chinese: false,
  2681 +
  2682 + // render options
  2683 +
  2684 + width: null,
  2685 + height: null,
  2686 + taintTest: true, // do a taint test with all images before applying to canvas
  2687 + renderer: "Canvas"
  2688 + };
  2689 +
  2690 + options = _html2canvas.Util.Extend(opts, options);
  2691 +
  2692 + _html2canvas.logging = options.logging;
  2693 + options.complete = function( images ) {
  2694 +
  2695 + if (typeof options.onpreloaded === "function") {
  2696 + if ( options.onpreloaded( images ) === false ) {
  2697 + return;
  2698 + }
  2699 + }
  2700 + queue = _html2canvas.Parse( images, options );
  2701 +
  2702 + if (typeof options.onparsed === "function") {
  2703 + if ( options.onparsed( queue ) === false ) {
  2704 + return;
  2705 + }
  2706 + }
  2707 +
  2708 + canvas = _html2canvas.Renderer( queue, options );
  2709 +
  2710 + if (typeof options.onrendered === "function") {
  2711 + options.onrendered( canvas );
  2712 + }
  2713 +
  2714 +
  2715 + };
  2716 +
  2717 + // for pages without images, we still want this to be async, i.e. return methods before executing
  2718 + window.setTimeout( function(){
  2719 + _html2canvas.Preload( options );
  2720 + }, 0 );
  2721 +
  2722 + return {
  2723 + render: function( queue, opts ) {
  2724 + return _html2canvas.Renderer( queue, _html2canvas.Util.Extend(opts, options) );
  2725 + },
  2726 + parse: function( images, opts ) {
  2727 + return _html2canvas.Parse( images, _html2canvas.Util.Extend(opts, options) );
  2728 + },
  2729 + preload: function( opts ) {
  2730 + return _html2canvas.Preload( _html2canvas.Util.Extend(opts, options) );
  2731 + },
  2732 + log: _html2canvas.Util.log
  2733 + };
  2734 +};
  2735 +
  2736 +window.html2canvas.log = _html2canvas.Util.log; // for renderers
  2737 +window.html2canvas.Renderer = {
  2738 + Canvas: undefined // We are assuming this will be used
  2739 +};
  2740 +_html2canvas.Renderer.Canvas = function(options) {
  2741 + options = options || {};
  2742 +
  2743 + var doc = document,
  2744 + safeImages = [],
  2745 + testCanvas = document.createElement("canvas"),
  2746 + testctx = testCanvas.getContext("2d"),
  2747 + Util = _html2canvas.Util,
  2748 + canvas = options.canvas || doc.createElement('canvas');
  2749 +
  2750 + function createShape(ctx, args) {
  2751 + ctx.beginPath();
  2752 + args.forEach(function(arg) {
  2753 + ctx[arg.name].apply(ctx, arg['arguments']);
  2754 + });
  2755 + ctx.closePath();
  2756 + }
  2757 +
  2758 + function safeImage(item) {
  2759 + if (safeImages.indexOf(item['arguments'][0].src ) === -1) {
  2760 + testctx.drawImage(item['arguments'][0], 0, 0);
  2761 + try {
  2762 + testctx.getImageData(0, 0, 1, 1);
  2763 + } catch(e) {
  2764 + testCanvas = doc.createElement("canvas");
  2765 + testctx = testCanvas.getContext("2d");
  2766 + return false;
  2767 + }
  2768 + safeImages.push(item['arguments'][0].src);
  2769 + }
  2770 + return true;
  2771 + }
  2772 +
  2773 + function renderItem(ctx, item) {
  2774 + switch(item.type){
  2775 + case "variable":
  2776 + ctx[item.name] = item['arguments'];
  2777 + break;
  2778 + case "function":
  2779 + switch(item.name) {
  2780 + case "createPattern":
  2781 + if (item['arguments'][0].width > 0 && item['arguments'][0].height > 0) {
  2782 + try {
  2783 + ctx.fillStyle = ctx.createPattern(item['arguments'][0], "repeat");
  2784 + }
  2785 + catch(e) {
  2786 + Util.log("html2canvas: Renderer: Error creating pattern", e.message);
  2787 + }
  2788 + }
  2789 + break;
  2790 + case "drawShape":
  2791 + createShape(ctx, item['arguments']);
  2792 + break;
  2793 + case "drawImage":
  2794 + if (item['arguments'][8] > 0 && item['arguments'][7] > 0) {
  2795 + if (!options.taintTest || (options.taintTest && safeImage(item))) {
  2796 + ctx.drawImage.apply( ctx, item['arguments'] );
  2797 + }
  2798 + }
  2799 + break;
  2800 + default:
  2801 + ctx[item.name].apply(ctx, item['arguments']);
  2802 + }
  2803 + break;
  2804 + }
  2805 + }
  2806 +
  2807 + return function(parsedData, options, document, queue, _html2canvas) {
  2808 + var ctx = canvas.getContext("2d"),
  2809 + newCanvas,
  2810 + bounds,
  2811 + fstyle,
  2812 + zStack = parsedData.stack;
  2813 +
  2814 + canvas.width = canvas.style.width = options.width || zStack.ctx.width;
  2815 + canvas.height = canvas.style.height = options.height || zStack.ctx.height;
  2816 +
  2817 + fstyle = ctx.fillStyle;
  2818 + ctx.fillStyle = (Util.isTransparent(zStack.backgroundColor) && options.background !== undefined) ? options.background : parsedData.backgroundColor;
  2819 + ctx.fillRect(0, 0, canvas.width, canvas.height);
  2820 + ctx.fillStyle = fstyle;
  2821 +
  2822 + queue.forEach(function(storageContext) {
  2823 + // set common settings for canvas
  2824 + ctx.textBaseline = "bottom";
  2825 + ctx.save();
  2826 +
  2827 + if (storageContext.transform.matrix) {
  2828 + ctx.translate(storageContext.transform.origin[0], storageContext.transform.origin[1]);
  2829 + ctx.transform.apply(ctx, storageContext.transform.matrix);
  2830 + ctx.translate(-storageContext.transform.origin[0], -storageContext.transform.origin[1]);
  2831 + }
  2832 +
  2833 + if (storageContext.clip){
  2834 + ctx.beginPath();
  2835 + ctx.rect(storageContext.clip.left, storageContext.clip.top, storageContext.clip.width, storageContext.clip.height);
  2836 + ctx.clip();
  2837 + }
  2838 +
  2839 + if (storageContext.ctx.storage) {
  2840 + storageContext.ctx.storage.forEach(function(item) {
  2841 + renderItem(ctx, item);
  2842 + });
  2843 + }
  2844 +
  2845 + ctx.restore();
  2846 + });
  2847 +
  2848 + Util.log("html2canvas: Renderer: Canvas renderer done - returning canvas obj");
  2849 +
  2850 + if (options.elements.length === 1) {
  2851 + if (typeof options.elements[0] === "object" && options.elements[0].nodeName !== "BODY") {
  2852 + // crop image to the bounds of selected (single) element
  2853 + bounds = _html2canvas.Util.Bounds(options.elements[0]);
  2854 + newCanvas = document.createElement('canvas');
  2855 + newCanvas.width = Math.ceil(bounds.width);
  2856 + newCanvas.height = Math.ceil(bounds.height);
  2857 + ctx = newCanvas.getContext("2d");
  2858 +
  2859 + ctx.drawImage(canvas, bounds.left, bounds.top, bounds.width, bounds.height, 0, 0, bounds.width, bounds.height);
  2860 + canvas = null;
  2861 + return newCanvas;
  2862 + }
  2863 + }
  2864 +
  2865 + return canvas;
  2866 + };
  2867 +};
  2868 +})(window,document);
0 2869 \ No newline at end of file
... ...
400-SOURCECODE/AIAHTML5.Web/themes/default/css/bootstrap/3.3.6/main.css
... ... @@ -805,12 +805,36 @@ textarea {
805 805 }
806 806  
807 807 .clstbodyca tr td {
  808 + min-width: 275px;
808 809 /*max-width: 260px;*/
809 810 text-align: left;
810 811 word-wrap:break-word;
811 812  
812 813 }
813 814  
  815 +
  816 +
  817 +
  818 +.tablecaview .clstbody tr td {
  819 + min-width: 275px;
  820 + text-align: left;
  821 +}
  822 +
  823 +.tablecaview .clstheadca tr th {
  824 + min-width: 275px;
  825 + text-align: left;
  826 +}
  827 +
  828 +
  829 +.tablecaview .clstbody,.tablecaview .clstbodyca {
  830 + display: block;
  831 + height: 200px;
  832 + width: 100%;
  833 + overflow:scroll;
  834 +}
  835 +
  836 +
  837 +
814 838 .cur-pot {
815 839 cursor:pointer;
816 840 }
... ... @@ -884,10 +908,15 @@ cursor:pointer;
884 908 opacity:0.6;
885 909  
886 910 }
  911 +.disableSubMenu {
  912 + pointer-events: none;
  913 + opacity: 0.6;
  914 +}
887 915  
888 916 .blankshapediv
889 917 {
890 918 background-image: url("../../../../../content/images/blank-shapes.png");
  919 +background-size:cover;
891 920 }
892 921 .outlinediv
893 922 {
... ... @@ -909,4 +938,23 @@ background-image: url(&quot;../../../../../content/images/blank-shapes.png&quot;);
909 938 /*Bug #8679*/
910 939 .selected {
911 940 background-color: lightgrey;
912   - }
913 941 \ No newline at end of file
  942 + }
  943 +
  944 + .disableHideShowStructure
  945 + {
  946 + background:#4b4b4b !important;
  947 + border-color:#3f3f3f !important;
  948 + }
  949 +.btn-annotation-erase:hover
  950 + {
  951 + color: #fff;
  952 + }
  953 + .btn-annotation-brush:hover
  954 + {
  955 + color: #fff;
  956 + }
  957 + .fa-eraser,.fa-paint-brush
  958 + {
  959 + color: #fff;
  960 + }
  961 +
914 962 \ No newline at end of file
... ...