Skip to content

Commit

Permalink
fix(picker): use sanitizer on translate3d css prop
Browse files Browse the repository at this point in the history
  • Loading branch information
adamdbradley committed May 19, 2016
1 parent 6708f95 commit 8598a2e
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 17 deletions.
2 changes: 1 addition & 1 deletion demos/datetime/main.html
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@

<ion-item>
<ion-label>Madison</ion-label>
<ion-datetime displayFormat="h:mm A" [(ngModel)]="madisonTime"></ion-datetime>
<ion-datetime displayFormat="h:mm a" [(ngModel)]="madisonTime"></ion-datetime>
</ion-item>

</ion-list>
Expand Down
22 changes: 6 additions & 16 deletions ionic/components/picker/picker.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import {Component, ElementRef, Input, Output, EventEmitter, ViewChildren, QueryList, ViewChild, Renderer, HostListener, ViewEncapsulation} from '@angular/core';
import {DomSanitizationService} from '@angular/platform-browser';

import {Animation} from '../../animations/animation';
import {Transition, TransitionOptions} from '../../transitions/transition';
Expand Down Expand Up @@ -88,7 +89,7 @@ export class Picker extends ViewController {
template:
'<div *ngIf="col.prefix" class="picker-prefix" [style.width]="col.prefixWidth">{{col.prefix}}</div>' +
'<div class="picker-opts" #colEle [style.width]="col.optionsWidth">' +
'<button *ngFor="let o of col.options; let i=index;" (click)="optClick($event, i)" type="button" category="picker-opt">' +
'<button *ngFor="let o of col.options; let i=index" [style.transform]="o._trans" [style.transitionDuration]="o._dur" [class.picker-opt-selected]="col.selectedIndex === i" [class.picker-opt-disabled]="o.disabled" (click)="optClick($event, i)" type="button" category="picker-opt">' +
'{{o.text}}' +
'</button>' +
'</div>' +
Expand Down Expand Up @@ -123,7 +124,7 @@ class PickerColumnCmp {
lastIndex: number;
@Output() change: EventEmitter<any> = new EventEmitter();

constructor(config: Config) {
constructor(config: Config, private _sanitizer: DomSanitizationService) {
this.rotateFactor = config.getNumber('pickerRotateFactor', 0);
}

Expand Down Expand Up @@ -342,15 +343,7 @@ class PickerColumnCmp {

this.col.selectedIndex = Math.max(Math.abs(Math.round(y / this.optHeight)), 0);

let colElements = this.colEle.nativeElement.querySelectorAll('.picker-opt');
if (colElements.length !== this.col.options.length) {
// TODO: temporary until [style.transform] is fixed within ng2
console.warn('colElements.length!=this.col.options.length');
return;
}

for (var i = 0; i < colElements.length; i++) {
var ele: HTMLElement = colElements[i];
for (var i = 0; i < this.col.options.length; i++) {
var opt = <any>this.col.options[i];
var optTop = (i * this.optHeight);
var optOffset = (optTop + y);
Expand All @@ -372,11 +365,8 @@ class PickerColumnCmp {
translateY = optOffset;
}

// TODO: setting by [style.transform]="o.transform" within the template is currently broke
ele.style[CSS.transform] = `rotateX(${rotateX}deg) translate3d(${translateX}px,${translateY}px,${translateZ}px)`;
ele.style[CSS.transitionDuration] = (duration > 0 ? duration + 'ms' : '');
ele.classList[this.col.selectedIndex === i ? 'add' : 'remove']('picker-opt-selected');
ele.classList[opt.disabled ? 'add' : 'remove']('picker-opt-disabled');
opt._trans = this._sanitizer.bypassSecurityTrustStyle(`rotateX(${rotateX}deg) translate3d(${translateX}px,${translateY}px,${translateZ}px)`);
opt._dur = (duration > 0 ? duration + 'ms' : '');
}

if (saveY) {
Expand Down

0 comments on commit 8598a2e

Please sign in to comment.