@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
187 lines • 15.4 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, Input, TemplateRef, HostBinding } from '@angular/core';
import { TicksOrientation, TickLabelsOrientation } from '../slider.common';
/**
* @hidden
*/
var IgxTicksComponent = /** @class */ (function () {
function IgxTicksComponent() {
/**
* @hidden
*/
this.ticksClass = true;
}
Object.defineProperty(IgxTicksComponent.prototype, "ticksTopClass", {
/**
* @hidden
*/
get: function () {
return this.ticksOrientation === TicksOrientation.Top;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTicksComponent.prototype, "hasPrimaryClass", {
/**
* @hidden
*/
get: function () {
return this.primaryTicks > 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTicksComponent.prototype, "labelsTopToBottomClass", {
/**
* @hidden
*/
get: function () {
return this.tickLabelsOrientation === TickLabelsOrientation.TopToBottom;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxTicksComponent.prototype, "labelsBottomToTopClass", {
/**
* @hidden
*/
get: function () {
return this.tickLabelsOrientation === TickLabelsOrientation.BottomToTop;
},
enumerable: true,
configurable: true
});
/**
* Returns the template context corresponding to
* {@link IgxTickLabelTemplateDirective}
*
* ```typescript
* return {
* $implicit //returns the value per each tick label.
* isPrimery //returns if the tick is primary.
* labels // returns the {@link labels} collection.
* index // returns the index per each tick of the whole sequence.
* }
* ```
*
* @param idx the index per each tick label.
*/
IgxTicksComponent.prototype.context = function (idx) {
return {
$implicit: this.tickLabel(idx),
isPrimary: this.isPrimary(idx),
labels: this.labels,
index: idx
};
};
Object.defineProperty(IgxTicksComponent.prototype, "ticksLength", {
/**
* @hidden
*/
get: function () {
return this.primaryTicks > 0 ?
((this.primaryTicks - 1) * this.secondaryTicks) + this.primaryTicks :
this.secondaryTicks > 0 ? this.secondaryTicks : 0;
},
enumerable: true,
configurable: true
});
IgxTicksComponent.prototype.hiddenTickLabels = function (idx) {
return this.isPrimary(idx) ? this.primaryTickLabels : this.secondaryTickLabels;
};
/**
* @hidden
*/
IgxTicksComponent.prototype.isPrimary = function (idx) {
return this.primaryTicks <= 0 ? false :
idx % (this.secondaryTicks + 1) === 0;
};
/**
* @hidden
*/
IgxTicksComponent.prototype.tickLabel = function (idx) {
if (this.labelsViewEnabled) {
return this.labels[idx];
}
var labelStep = (Math.max(this.minValue, this.maxValue) - Math.min(this.minValue, this.maxValue)) / (this.ticksLength - 1);
var labelVal = labelStep * idx;
return (this.minValue + labelVal).toFixed(2);
};
__decorate([
Input(),
__metadata("design:type", Number)
], IgxTicksComponent.prototype, "primaryTicks", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], IgxTicksComponent.prototype, "secondaryTicks", void 0);
__decorate([
Input(),
__metadata("design:type", Boolean)
], IgxTicksComponent.prototype, "primaryTickLabels", void 0);
__decorate([
Input(),
__metadata("design:type", Boolean)
], IgxTicksComponent.prototype, "secondaryTickLabels", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], IgxTicksComponent.prototype, "ticksOrientation", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], IgxTicksComponent.prototype, "tickLabelsOrientation", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], IgxTicksComponent.prototype, "maxValue", void 0);
__decorate([
Input(),
__metadata("design:type", Number)
], IgxTicksComponent.prototype, "minValue", void 0);
__decorate([
Input(),
__metadata("design:type", Boolean)
], IgxTicksComponent.prototype, "labelsViewEnabled", void 0);
__decorate([
Input(),
__metadata("design:type", Array)
], IgxTicksComponent.prototype, "labels", void 0);
__decorate([
Input(),
__metadata("design:type", TemplateRef)
], IgxTicksComponent.prototype, "tickLabelTemplateRef", void 0);
__decorate([
HostBinding('class.igx-slider__ticks'),
__metadata("design:type", Object)
], IgxTicksComponent.prototype, "ticksClass", void 0);
__decorate([
HostBinding('class.igx-slider__ticks--top'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxTicksComponent.prototype, "ticksTopClass", null);
__decorate([
HostBinding('class.igx-slider__ticks--tall'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxTicksComponent.prototype, "hasPrimaryClass", null);
__decorate([
HostBinding('class.igx-slider__tick-labels--top-bottom'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxTicksComponent.prototype, "labelsTopToBottomClass", null);
__decorate([
HostBinding('class.igx-slider__tick-labels--bottom-top'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxTicksComponent.prototype, "labelsBottomToTopClass", null);
IgxTicksComponent = __decorate([
Component({
selector: 'igx-ticks',
template: "<div class=\"igx-slider__ticks-group\" *ngFor=\"let n of [].constructor(ticksLength); let idx=index\" [ngClass]=\"{ 'igx-slider__ticks-group--tall': isPrimary(idx)}\">\n <div class=\"igx-slider__ticks-tick\">\n <span class=\"igx-slider__ticks-label\" [ngClass]=\"{ 'igx-slider__tick-label--hidden': !hiddenTickLabels(idx)}\">\n <ng-container *ngTemplateOutlet=\"tickLabelTemplateRef ? tickLabelTemplateRef : tickLabelDefaultTemplate; context: context(idx)\"></ng-container>\n </span>\n </div>\n</div>\n\n<ng-template #tickLabelDefaultTemplate let-value>\n {{ value }}\n</ng-template>\n"
})
], IgxTicksComponent);
return IgxTicksComponent;
}());
export { IgxTicksComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ticks.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/slider/ticks/ticks.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, TemplateRef, HostBinding } from '@angular/core';\nimport { TicksOrientation, TickLabelsOrientation } from '../slider.common';\n\n/**\n * @hidden\n */\n@Component({\n    selector: 'igx-ticks',\n    templateUrl: 'ticks.component.html',\n})\nexport class IgxTicksComponent {\n    @Input()\n    public primaryTicks: number;\n\n    @Input()\n    public secondaryTicks: number;\n\n    @Input()\n    public primaryTickLabels: boolean;\n\n    @Input()\n    public secondaryTickLabels: boolean;\n\n    @Input()\n    public ticksOrientation: TicksOrientation;\n\n    @Input()\n    public tickLabelsOrientation: TickLabelsOrientation;\n\n    @Input()\n    public maxValue: number;\n\n    @Input()\n    public minValue: number;\n\n    @Input()\n    public labelsViewEnabled: boolean;\n\n    @Input()\n    public labels: Array<number | string | boolean | null | undefined>;\n\n    @Input()\n    public tickLabelTemplateRef: TemplateRef<any>;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-slider__ticks')\n    public ticksClass = true;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-slider__ticks--top')\n    public get ticksTopClass() {\n        return this.ticksOrientation === TicksOrientation.Top;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-slider__ticks--tall')\n    public get hasPrimaryClass() {\n        return this.primaryTicks > 0;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-slider__tick-labels--top-bottom')\n    public get labelsTopToBottomClass() {\n        return this.tickLabelsOrientation === TickLabelsOrientation.TopToBottom;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-slider__tick-labels--bottom-top')\n    public get labelsBottomToTopClass() {\n        return this.tickLabelsOrientation === TickLabelsOrientation.BottomToTop;\n    }\n\n    /**\n     * Returns the template context corresponding to\n     * {@link IgxTickLabelTemplateDirective}\n     *\n     * ```typescript\n     * return {\n     *  $implicit //returns the value per each tick label.\n     *  isPrimery //returns if the tick is primary.\n     *  labels // returns the {@link labels} collection.\n     *  index // returns the index per each tick of the whole sequence.\n     * }\n     * ```\n     *\n     * @param idx the index per each tick label.\n     */\n    public context(idx: number): any {\n        return {\n            $implicit: this.tickLabel(idx),\n            isPrimary: this.isPrimary(idx),\n            labels: this.labels,\n            index: idx\n        };\n    }\n\n    /**\n     * @hidden\n     */\n    public get ticksLength() {\n        return this.primaryTicks > 0 ?\n                ((this.primaryTicks - 1) * this.secondaryTicks) + this.primaryTicks :\n                this.secondaryTicks > 0 ? this.secondaryTicks : 0;\n    }\n\n    public hiddenTickLabels(idx: number) {\n        return this.isPrimary(idx) ? this.primaryTickLabels : this.secondaryTickLabels;\n    }\n\n    /**\n     * @hidden\n     */\n    public isPrimary(idx: number) {\n        return this.primaryTicks <= 0 ? false :\n            idx % (this.secondaryTicks + 1) === 0;\n    }\n\n    /**\n     * @hidden\n     */\n    public tickLabel(idx: number) {\n        if (this.labelsViewEnabled) {\n            return this.labels[idx];\n        }\n\n        const labelStep = (Math.max(this.minValue, this.maxValue) - Math.min(this.minValue, this.maxValue)) / (this.ticksLength - 1);\n        const labelVal = labelStep * idx;\n\n        return (this.minValue + labelVal).toFixed(2);\n    }\n}\n"]}