In Angular2 app, i am trying to make an animation
Here is component's html:
   <div  [@playBox]="state" id="toPlay" class="playBox rounded-box">
   </div>
Here is the animation:
animations:[
    trigger('playBox',[
            state('closed',style({
            width: '5%',
            backgroundColor:'red',
            transform:'translateX(0)'
          })),
          state('wided',style({
                width: '100%',
                border: '3px solid red',
                backgroundColor:'transparent'
          })),transition('closed => wided',animate(4000))])
  ]
I am going to triger this animation when the page get loaded:
export class AppComponent implements OnInit{
  state="closed";
 public ngOnInit(): any
 {
        if(this.state=="closed"){
            this.state="wided";
         }
}
 
                        
Not sure this is the most proper and elegant solution but changing
statein the next tick will trigger animation as expected:Otherwise,
this.state = "wided"kind of redefines initialclosedstate and component gets initialized withwidedas initial without animation.