ionic-framework
Version:
An advanced HTML5 mobile app framework built on Angular2
88 lines (87 loc) • 3.04 kB
JavaScript
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var core_1 = require('angular2/core');
var util_1 = require('../../util/util');
/**
* @name Option
* @description
* `ion-option` is a child component of `ion-select`. Similar to the native option element, `ion-option` can take a value and a checked property.
*
* @demo /docs/v2/demos/item-sliding/
*/
var Option = (function () {
function Option(_elementRef) {
this._elementRef = _elementRef;
this._checked = false;
/**
* @input {any} Event to evaluate when option has changed
*/
this.select = new core_1.EventEmitter();
}
Object.defineProperty(Option.prototype, "checked", {
/**
* @input {boolean} Whether or not the option is already checked and selected
*/
get: function () {
return this._checked;
},
set: function (val) {
this._checked = util_1.isTrueProperty(val);
},
enumerable: true,
configurable: true
});
Object.defineProperty(Option.prototype, "value", {
/**
* @input {any} The value of the option
*/
get: function () {
if (util_1.isDefined(this._value)) {
return this._value;
}
return this.text;
},
set: function (val) {
this._value = val;
},
enumerable: true,
configurable: true
});
Object.defineProperty(Option.prototype, "text", {
/**
* @private
*/
get: function () {
return this._elementRef.nativeElement.textContent;
},
enumerable: true,
configurable: true
});
__decorate([
core_1.Output(),
__metadata('design:type', core_1.EventEmitter)
], Option.prototype, "select", void 0);
__decorate([
core_1.Input(),
__metadata('design:type', Object)
], Option.prototype, "checked", null);
__decorate([
core_1.Input(),
__metadata('design:type', Object)
], Option.prototype, "value", null);
Option = __decorate([
core_1.Directive({
selector: 'ion-option'
}),
__metadata('design:paramtypes', [core_1.ElementRef])
], Option);
return Option;
})();
exports.Option = Option;