Skip to content

Commit

Permalink
Merge branch 'olivierceulemans-master'
Browse files Browse the repository at this point in the history
  • Loading branch information
valorkin committed Mar 28, 2016
2 parents 9d87d49 + 413c2f1 commit 0c223f6
Show file tree
Hide file tree
Showing 5 changed files with 41 additions and 61 deletions.
18 changes: 6 additions & 12 deletions components/position.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,3 @@
import {
Injectable,
ElementRef
} from 'angular2/core';
import {IAttribute} from './common';

export class PositionService {
Expand All @@ -26,7 +22,6 @@ export class PositionService {
return nativeEl.style[cssProp];
}


/**
* Checks if a given element is statically positioned
* @param nativeEl - raw DOM element
Expand All @@ -35,9 +30,9 @@ export class PositionService {
return (this.getStyle(nativeEl, 'position') || 'static' ) === 'static';
}


/**
* returns the closest, non-statically positioned parentOffset of a given element
* returns the closest, non-statically positioned parentOffset of a given
* element
* @param nativeEl
*/
private parentOffsetEl(nativeEl:any) {
Expand All @@ -53,7 +48,7 @@ export class PositionService {
* Provides read-only equivalent of jQuery's position function:
* http://api.jquery.com/position/
*/
public position(nativeEl:any):{width: number, height: number, top: number, left: number} {
public position(nativeEl:any):{width:number, height:number, top:number, left:number} {
let elBCR = this.offset(nativeEl);
let offsetParentBCR = {top: 0, left: 0};
let offsetParentEl = this.parentOffsetEl(nativeEl);
Expand All @@ -76,7 +71,7 @@ export class PositionService {
* Provides read-only equivalent of jQuery's offset function:
* http://api.jquery.com/offset/
*/
public offset(nativeEl:any):{width: number, height: number, top: number, left: number} {
public offset(nativeEl:any):{width:number, height:number, top:number, left:number} {
let boundingClientRect = nativeEl.getBoundingClientRect();
return {
width: boundingClientRect.width || nativeEl.offsetWidth,
Expand All @@ -89,7 +84,7 @@ export class PositionService {
/**
* Provides coordinates for the targetEl in relation to hostEl
*/
public positionElements(hostEl:any, targetEl:any, positionStr:any, appendToBody:any):{top: number, left: number} {
public positionElements(hostEl:any, targetEl:any, positionStr:any, appendToBody:any):{top:number, left:number} {
let positionStrParts = positionStr.split('-');
let pos0 = positionStrParts[0];
let pos1 = positionStrParts[1] || 'center';
Expand All @@ -98,7 +93,6 @@ export class PositionService {
this.position(hostEl);
let targetElWidth = targetEl.offsetWidth;
let targetElHeight = targetEl.offsetHeight;

let shiftWidth:IAttribute = {
center: function () {
return hostElPos.left + hostElPos.width / 2 - targetElWidth / 2;
Expand All @@ -123,7 +117,7 @@ export class PositionService {
}
};

let targetElPos:{top: number, left: number};
let targetElPos:{top:number, left:number};
switch (pos0) {
case 'right':
targetElPos = {
Expand Down
59 changes: 27 additions & 32 deletions components/tooltip/tooltip-container.component.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,12 @@
import {
Component,
OnInit, Input, HostListener,
ElementRef, EventEmitter,
DynamicComponentLoader, ComponentRef, Inject, AfterViewChecked
} from 'angular2/core';
import {Component, ChangeDetectorRef, ElementRef, Inject, AfterViewInit} from 'angular2/core';
import {NgClass, NgStyle} from 'angular2/common';
import {positionService} from '../position';
import {TooltipOptions} from './tooltip-options.class';

@Component({
selector: 'tooltip-container',
directives: [NgClass, NgStyle],
// changeDetection: ChangeDetectionStrategy.OnPush,
template: `<div class="tooltip" role="tooltip"
[ngStyle]="{top: top, left: left, display: display}"
[ngClass]="classMap">
Expand All @@ -20,41 +16,40 @@ import {TooltipOptions} from './tooltip-options.class';
</div>
</div>`
})
export class TooltipContainer implements AfterViewChecked {
export class TooltipContainer implements AfterViewInit {
private classMap:any;
private positionMap:any;
private top:string;
private left:string;
private display:string;
private top:string = '-1000px';
private left:string = '-1000px';
private display:string = 'block';
private content:string;
private placement:string;
private appendToBody:boolean;

private popupClass:string;
private animation:boolean;
private isOpen:boolean;
private appendToBody:boolean;
private hostEl:ElementRef;

constructor(public element:ElementRef, @Inject(TooltipOptions) options:TooltipOptions) {
constructor(private element:ElementRef,
private cdr:ChangeDetectorRef,
@Inject(TooltipOptions) options:TooltipOptions) {
Object.assign(this, options);
this.classMap = {'in': false};
this.classMap = {'in': false, 'fade': false};
this.classMap[options.placement] = true;
}

ngAfterViewChecked() {
if (this.hostEl !== null) {
let p = positionService
.positionElements(this.hostEl.nativeElement,
this.element.nativeElement.children[0],
this.placement, this.appendToBody);
this.top = p.top + 'px';
this.left = p.left + 'px';
this.classMap['in'] = true;
}
}

public position(hostEl:ElementRef) {
this.display = 'block';
this.top = '-1000px';
this.left = '-1000px';
this.hostEl = hostEl;
ngAfterViewInit() {
let p = positionService
.positionElements(
this.hostEl.nativeElement,
this.element.nativeElement.children[0],
this.placement, this.appendToBody);
this.top = p.top + 'px';
this.left = p.left + 'px';
this.classMap.in = true;
if (this.animation) {
this.classMap.fade = true;
}
// fix: why time out is really needed here?
setTimeout(() => this.cdr.markForCheck());
}
}
20 changes: 5 additions & 15 deletions components/tooltip/tooltip.directive.ts
Original file line number Diff line number Diff line change
@@ -1,24 +1,14 @@
import {
Directive,
OnInit, Input, HostListener,
ElementRef, EventEmitter,
DynamicComponentLoader, ComponentRef,
Provider,
Injectable, forwardRef, ResolvedBinding, Injector
} from 'angular2/core';
import {NgClass, NgStyle} from 'angular2/common';

import {Directive, OnInit, Input, HostListener, ElementRef, DynamicComponentLoader, ComponentRef, Provider, Injector} from 'angular2/core';
import {TooltipOptions} from './tooltip-options.class';
import {TooltipContainer} from './tooltip-container.component';

import {IAttribute} from '../common';

@Directive({selector: '[tooltip]'})
export class Tooltip implements OnInit {
@Input('tooltip') public content:string;
@Input('tooltipPlacement') public placement:string = 'top';
@Input('tooltipIsOpen') public isOpen:boolean;
@Input('tooltipEnable') public enable:boolean;
@Input('tooltipAnimation') public animation:boolean = true;
@Input('tooltipAppendToBody') public appendToBody:boolean;

private visible:boolean = false;
Expand All @@ -40,10 +30,11 @@ export class Tooltip implements OnInit {
return;
}
this.visible = true;

let options = new TooltipOptions({
content: this.content,
placement: this.placement
placement: this.placement,
animation: this.animation,
hostEl: this.element
});

let binding = Injector.resolve([
Expand All @@ -53,7 +44,6 @@ export class Tooltip implements OnInit {
this.tooltip = this.loader
.loadNextToLocation(TooltipContainer, this.element, binding)
.then((componentRef:ComponentRef) => {
componentRef.instance.position(this.element);
return componentRef;
});
}
Expand Down
2 changes: 1 addition & 1 deletion demo/components/tooltip/tooltip-demo.html
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
nunc sed velit dignissim sodales ut eu sem integer vitae. Turpis egestas
<a href="#" tooltipPlacement="bottom" tooltip="On the Bottom!">bottom</a>
pharetra convallis posuere morbi leo urna,
<a href="#" tooltipAnimation="false" tooltip="I don't fade. :-(">fading</a>
<a href="#" [tooltipAnimation]="false" tooltip="I don't fade. :-(">fading</a>
at elementum eu, facilisis sed odio morbi quis commodo odio. In cursus
<a href="#" tooltipPopupDelay='1000' tooltip='appears with delay'>delayed</a> turpis massa tincidunt dui ut.
nunc sed velit dignissim sodales ut eu sem integer vitae. Turpis egestas
Expand Down
3 changes: 2 additions & 1 deletion demo/components/tooltip/tooltip-demo.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import {Component} from 'angular2/core';
import {Component, ChangeDetectionStrategy} from 'angular2/core';
import {CORE_DIRECTIVES, FORM_DIRECTIVES} from 'angular2/common';
import {TOOLTIP_DIRECTIVES} from '../../../ng2-bootstrap';

Expand All @@ -9,6 +9,7 @@ let template = require('./tooltip-demo.html');
selector: 'tooltip-demo',
template: template,
directives: [TOOLTIP_DIRECTIVES, CORE_DIRECTIVES, FORM_DIRECTIVES],
changeDetection: ChangeDetectionStrategy.OnPush,
styles: [`
/* Specify styling for tooltip contents */
.tooltip.customClass .tooltip-inner {
Expand Down

0 comments on commit 0c223f6

Please sign in to comment.