ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
99 lines • 16.1 kB
JavaScript
import { Component, Input, Output, ContentChildren, QueryList, HostBinding, EventEmitter } from '@angular/core';
import { TabBarItemComponent } from './tab-bar-item.component';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "ng-zorro-antd-mobile/tabs";
export class TabBarComponent {
get activeTab() {
return this._activeTab;
}
set activeTab(tab) {
this._activeTab = tab;
if (this.tabBarItems && this.tabBarItems.length > 0) {
this.selectTabBarItem(tab);
}
}
get tintColor() {
return this._tintColor;
}
set tintColor(color) {
this._tintColor = color;
if (this.tabBarItems && this.tabBarItems.length > 0) {
this.tabBarItems.forEach((tabBarItem) => {
tabBarItem.tintColor = this._tintColor;
});
}
}
get unselectedTintColor() {
return this._unselectedTintColor;
}
set unselectedTintColor(color) {
this._unselectedTintColor = color;
if (this.tabBarItems && this.tabBarItems.length > 0) {
this.tabBarItems.forEach((tabBarItem) => {
tabBarItem.unselectedTintColor = this._unselectedTintColor;
});
}
}
constructor() {
this.prefixCls = 'am-tab-bar';
this._activeTab = 0;
this._tintColor = '#108ee9';
this._unselectedTintColor = '#888';
this.hidden = false;
this.prerenderingSiblingsNumber = -1;
this.barTintColor = 'white';
this.tabBarPosition = 'bottom';
this.onPress = new EventEmitter();
this.tabBar = true;
}
selectTabBarItem(index) {
if (this.tabBarItems && this.tabBarItems.length > 0) {
this.tabBarItems.forEach((tabBarItem) => {
tabBarItem.selected = false;
});
this.tabBarItems.toArray()[index].selected = true;
}
}
tabBarTabOnPress(pressParam) {
this.onPress.emit(pressParam);
}
ngAfterContentInit() {
if (this.tabBarItems && this.tabBarItems.length > 0) {
this.tabBarItems.forEach((tabBarItem) => {
tabBarItem.tintColor = this._tintColor;
tabBarItem.unselectedTintColor = this._unselectedTintColor;
});
}
this.selectTabBarItem(this.activeTab);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: TabBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: TabBarComponent, selector: "TabBar, nzm-tab-bar", inputs: { hidden: "hidden", prerenderingSiblingsNumber: "prerenderingSiblingsNumber", activeTab: "activeTab", barTintColor: "barTintColor", tabBarPosition: "tabBarPosition", tintColor: "tintColor", unselectedTintColor: "unselectedTintColor" }, outputs: { onPress: "onPress" }, host: { properties: { "class.am-tab-bar": "this.tabBar" } }, queries: [{ propertyName: "tabBarItems", predicate: TabBarItemComponent, descendants: true }], ngImport: i0, template: "<Tabs\n [animated]=\"false\"\n [useOnPan]=\"false\"\n [swipeable]=\"false\"\n [activeTab]=\"activeTab\"\n [renderTabBar]=\"TabBarBar\"\n [tabDirection]=\"'horizontal'\"\n [tabPanesContent]=\"tabBarItems\"\n [tabBarPosition]=\"tabBarPosition\"\n [prerenderingSiblingsNumber]=\"prerenderingSiblingsNumber\"\n></Tabs>\n\n<ng-template #TabBarBar>\n <div class=\"am-tabs-tab-bar-wrap\">\n <div\n class=\"{{ prefixCls }}-bar\"\n [ngClass]=\"{\n 'am-tab-bar-bar-hidden-top': 'top' === tabBarPosition && hidden,\n 'am-tab-bar-bar-hidden-bottom': 'bottom' === tabBarPosition && hidden\n }\"\n [style.background-color]=\"barTintColor\"\n >\n <div\n class=\"am-tab-bar-tab\"\n *ngFor=\"let tabBarItem of tabBarItems; let i = index\"\n (click)=\"tabBarTabOnPress({ index: i, key: tabBarItem.key, title: tabBarItem.title })\"\n >\n <ng-container [ngTemplateOutlet]=\"tabBarItem.tabBarTab\"></ng-container>\n </div>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.TabsComponent, selector: "Tabs, nzm-tabs", inputs: ["page", "swipeable", "useOnPan", "animated", "tabBarUnderlineStyle", "distanceToChangeTab", "tabTitleSize", "tabBarActiveTextColor", "tabBarInactiveTextColor", "renderTabBar", "tabBarBackgroundColor", "prerenderingSiblingsNumber", "tabBarTextStyle", "tabPanesContent", "activeTab", "tabBarPosition", "tabDirection"], outputs: ["onChange", "onTabClick"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: TabBarComponent, decorators: [{
type: Component,
args: [{ selector: 'TabBar, nzm-tab-bar', template: "<Tabs\n [animated]=\"false\"\n [useOnPan]=\"false\"\n [swipeable]=\"false\"\n [activeTab]=\"activeTab\"\n [renderTabBar]=\"TabBarBar\"\n [tabDirection]=\"'horizontal'\"\n [tabPanesContent]=\"tabBarItems\"\n [tabBarPosition]=\"tabBarPosition\"\n [prerenderingSiblingsNumber]=\"prerenderingSiblingsNumber\"\n></Tabs>\n\n<ng-template #TabBarBar>\n <div class=\"am-tabs-tab-bar-wrap\">\n <div\n class=\"{{ prefixCls }}-bar\"\n [ngClass]=\"{\n 'am-tab-bar-bar-hidden-top': 'top' === tabBarPosition && hidden,\n 'am-tab-bar-bar-hidden-bottom': 'bottom' === tabBarPosition && hidden\n }\"\n [style.background-color]=\"barTintColor\"\n >\n <div\n class=\"am-tab-bar-tab\"\n *ngFor=\"let tabBarItem of tabBarItems; let i = index\"\n (click)=\"tabBarTabOnPress({ index: i, key: tabBarItem.key, title: tabBarItem.title })\"\n >\n <ng-container [ngTemplateOutlet]=\"tabBarItem.tabBarTab\"></ng-container>\n </div>\n </div>\n </div>\n</ng-template>\n" }]
}], ctorParameters: () => [], propDecorators: { tabBarItems: [{
type: ContentChildren,
args: [TabBarItemComponent, { descendants: true }]
}], hidden: [{
type: Input
}], prerenderingSiblingsNumber: [{
type: Input
}], activeTab: [{
type: Input
}], barTintColor: [{
type: Input
}], tabBarPosition: [{
type: Input
}], tintColor: [{
type: Input
}], unselectedTintColor: [{
type: Input
}], onPress: [{
type: Output
}], tabBar: [{
type: HostBinding,
args: ['class.am-tab-bar']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-bar.component.js","sourceRoot":"","sources":["../../../components/tab-bar/tab-bar.component.ts","../../../components/tab-bar/tab-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  AfterContentInit,\n  Input,\n  Output,\n  ContentChildren,\n  QueryList,\n  HostBinding,\n  EventEmitter\n} from '@angular/core';\nimport { TabBarItemComponent } from './tab-bar-item.component';\n\nexport type TabBarTabPositionType = 'top' | 'bottom';\nexport interface TabBarOnPressEvent {\n  index: number;\n  title: string;\n  key: string;\n}\n\n@Component({\n  selector: 'TabBar, nzm-tab-bar',\n  templateUrl: './tab-bar.component.html'\n})\nexport class TabBarComponent implements AfterContentInit {\n  prefixCls: string = 'am-tab-bar';\n  private _activeTab: number = 0;\n  private _tintColor: string = '#108ee9';\n  private _unselectedTintColor: string = '#888';\n\n  @ContentChildren(TabBarItemComponent, { descendants: true })\n  tabBarItems: QueryList<TabBarItemComponent>;\n\n  @Input()\n  hidden: boolean = false;\n  @Input()\n  prerenderingSiblingsNumber: number = -1;\n  @Input()\n  get activeTab(): number {\n    return this._activeTab;\n  }\n  set activeTab(tab: number) {\n    this._activeTab = tab;\n    if (this.tabBarItems && this.tabBarItems.length > 0) {\n      this.selectTabBarItem(tab);\n    }\n  }\n  @Input()\n  barTintColor: string = 'white';\n  @Input()\n  tabBarPosition: TabBarTabPositionType = 'bottom';\n  @Input()\n  get tintColor(): string {\n    return this._tintColor;\n  }\n  set tintColor(color: string) {\n    this._tintColor = color;\n    if (this.tabBarItems && this.tabBarItems.length > 0) {\n      this.tabBarItems.forEach((tabBarItem: TabBarItemComponent) => {\n        tabBarItem.tintColor = this._tintColor;\n      });\n    }\n  }\n  @Input()\n  get unselectedTintColor(): string {\n    return this._unselectedTintColor;\n  }\n  set unselectedTintColor(color: string) {\n    this._unselectedTintColor = color;\n    if (this.tabBarItems && this.tabBarItems.length > 0) {\n      this.tabBarItems.forEach((tabBarItem: TabBarItemComponent) => {\n        tabBarItem.unselectedTintColor = this._unselectedTintColor;\n      });\n    }\n  }\n  @Output()\n  onPress: EventEmitter<TabBarOnPressEvent> = new EventEmitter<TabBarOnPressEvent>();\n\n  @HostBinding('class.am-tab-bar')\n  tabBar: boolean = true;\n\n  constructor() {}\n\n  selectTabBarItem(index: number) {\n    if (this.tabBarItems && this.tabBarItems.length > 0) {\n      this.tabBarItems.forEach((tabBarItem: TabBarItemComponent) => {\n        tabBarItem.selected = false;\n      });\n      this.tabBarItems.toArray()[index].selected = true;\n    }\n  }\n\n  tabBarTabOnPress(pressParam: TabBarOnPressEvent) {\n    this.onPress.emit(pressParam);\n  }\n\n  ngAfterContentInit() {\n    if (this.tabBarItems && this.tabBarItems.length > 0) {\n      this.tabBarItems.forEach((tabBarItem: TabBarItemComponent) => {\n        tabBarItem.tintColor = this._tintColor;\n        tabBarItem.unselectedTintColor = this._unselectedTintColor;\n      });\n    }\n    this.selectTabBarItem(this.activeTab);\n  }\n}\n","<Tabs\n  [animated]=\"false\"\n  [useOnPan]=\"false\"\n  [swipeable]=\"false\"\n  [activeTab]=\"activeTab\"\n  [renderTabBar]=\"TabBarBar\"\n  [tabDirection]=\"'horizontal'\"\n  [tabPanesContent]=\"tabBarItems\"\n  [tabBarPosition]=\"tabBarPosition\"\n  [prerenderingSiblingsNumber]=\"prerenderingSiblingsNumber\"\n></Tabs>\n\n<ng-template #TabBarBar>\n  <div class=\"am-tabs-tab-bar-wrap\">\n    <div\n      class=\"{{ prefixCls }}-bar\"\n      [ngClass]=\"{\n        'am-tab-bar-bar-hidden-top': 'top' === tabBarPosition && hidden,\n        'am-tab-bar-bar-hidden-bottom': 'bottom' === tabBarPosition && hidden\n      }\"\n      [style.background-color]=\"barTintColor\"\n    >\n      <div\n        class=\"am-tab-bar-tab\"\n        *ngFor=\"let tabBarItem of tabBarItems; let i = index\"\n        (click)=\"tabBarTabOnPress({ index: i, key: tabBarItem.key, title: tabBarItem.title })\"\n      >\n        <ng-container [ngTemplateOutlet]=\"tabBarItem.tabBarTab\"></ng-container>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}