Sync Integ to Master
[sdc.git] / catalog-ui / src / app / ng2 / components / ui / palette-animation / palette-animation.component.ts
1 /*-
2  * ============LICENSE_START=======================================================
3  * SDC
4  * ================================================================================
5  * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License");
8  * you may not use this file except in compliance with the License.
9  * You may obtain a copy of the License at
10  * 
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  * 
13  * Unless required by applicable law or agreed to in writing, software
14  * distributed under the License is distributed on an "AS IS" BASIS,
15  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16  * See the License for the specific language governing permissions and
17  * limitations under the License.
18  * ============LICENSE_END=========================================================
19  */
20
21 import {Component, Input } from '@angular/core';
22 import {BrowserModule} from '@angular/platform-browser';
23 import { setTimeout } from 'core-js/library/web/timers';
24 import { EventListenerService } from 'app/services';
25 import { GRAPH_EVENTS } from 'app/utils';
26 import { Point } from 'app/models';
27  
28
29
30 @Component({
31   selector: 'palette-animation',
32   templateUrl: './palette-animation.component.html',
33   styleUrls:['./palette-animation.component.less'],
34 })
35
36 export class PaletteAnimationComponent  {
37   
38   @Input() from : Point;
39   @Input() to : Point;
40   @Input() iconName : string;
41   @Input() data : any;
42
43   public  animation;
44   private visible:boolean = false;
45   private transformStyle:string = "";
46
47
48   constructor(private eventListenerService:EventListenerService) {}
49   
50   public runAnimation() {
51     this.visible = true;
52     let positionDiff:Point = new Point(this.to.x - this.from.x, this.to.y - this.from.y);
53     setTimeout(()=>{
54      this.transformStyle = 'translate('+ positionDiff.x + 'px,' + positionDiff.y +'px)';
55     }, 0);
56   };
57
58   public animationComplete = (e) => {
59     this.visible = false;
60     this.eventListenerService.notifyObservers(GRAPH_EVENTS.ON_FINISH_ANIMATION_ZONE);
61   };
62
63
64 }