Files
2015-12-16 10:49:24 -06:00

90 lines
1.8 KiB
TypeScript

import {Injectable} from 'angular2/core';
/**
* The Input component is used to focus text input elements.
*
* @usage
* ```html
* <ion-input>
* <ion-label>Name</ion-label>
* <input value="Name" type="text">
* </ion-input>
* ```
*/
@Injectable()
export class Form {
constructor() {
this._inputs = [];
this._ids = -1;
this._focused = null;
this.focusCtrl(document);
}
register(input) {
this._inputs.push(input);
}
deregister(input) {
let index = this._inputs.indexOf(input);
if (index > -1) {
this._inputs.splice(index, 1);
}
if (input === this._focused) {
this._focused = null;
}
}
focusCtrl(document) {
// raw DOM fun
let focusCtrl = document.createElement('focus-ctrl');
focusCtrl.setAttribute('aria-hidden', true);
this._blur = document.createElement('button');
this._blur.tabIndex = -1;
focusCtrl.appendChild(this._blur);
document.body.appendChild(focusCtrl);
}
focusOut() {
console.debug('focusOut');
document.activeElement && document.activeElement.blur();
this._blur.focus();
}
setAsFocused(input) {
this._focused = input;
}
/**
* Focuses the next input element, if it exists.
*/
focusNext(currentInput) {
console.debug('focusNext');
let index = this._inputs.indexOf(currentInput);
if (index > -1 && (index + 1) < this._inputs.length) {
let nextInput = this._inputs[index + 1];
if (nextInput !== this._focused) {
return nextInput.initFocus();
}
}
index = this._inputs.indexOf(this._focused);
if (index > 0) {
let previousInput = this._inputs[index - 1];
if (previousInput) {
previousInput.initFocus();
}
}
}
nextId() {
return ++this._ids;
}
}