ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
314 lines • 24.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, TemplateRef, HostBinding } from '@angular/core';
var GridComponent = /** @class */ (function () {
function GridComponent() {
this.wrapCls = {};
this.itemCls = {};
this.carouselProps = {
dots: false,
dragging: false
};
this.defaultProps = {
data: [],
hasLine: true,
isCarousel: false,
columnNum: 4,
carouselMaxRow: 2,
prefixCls: 'am-grid',
square: true,
itemStyle: {}
};
this.carouselData = [];
this.carouselDataTmp = [];
this.gridData = [];
this._data = [];
this.columnNum = 4;
this.carouselMaxRow = 2;
this.itemStyle = {};
this.square = true;
this.hasLine = true;
this.activeStyle = true;
this.onClick = new EventEmitter();
this.amGrid = true;
}
Object.defineProperty(GridComponent.prototype, "isCarousel", {
get: /**
* @return {?}
*/
function () {
return this.defaultProps.isCarousel;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.defaultProps.isCarousel = value;
this.init();
},
enumerable: true,
configurable: true
});
Object.defineProperty(GridComponent.prototype, "data", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._data = value;
this.init();
},
enumerable: true,
configurable: true
});
Object.defineProperty(GridComponent.prototype, "amGridSquare", {
get: /**
* @return {?}
*/
function () {
return true === this.square;
},
enumerable: true,
configurable: true
});
Object.defineProperty(GridComponent.prototype, "amGridLine", {
get: /**
* @return {?}
*/
function () {
return true === this.hasLine;
},
enumerable: true,
configurable: true
});
Object.defineProperty(GridComponent.prototype, "amGridCarousel", {
get: /**
* @return {?}
*/
function () {
return true === this.isCarousel;
},
enumerable: true,
configurable: true
});
/**
* @param {?} value
* @return {?}
*/
GridComponent.prototype.getContentType = /**
* @param {?} value
* @return {?}
*/
function (value) {
if ((value.indexOf('http') >= 0 || value.indexOf('assets') >= 0) && value.indexOf('<') < 0) {
return 'url';
}
else if (value.indexOf('<') >= 0) {
return 'innerHTML';
}
else if (value instanceof TemplateRef) {
return 'TemplateRef';
}
else {
return 'icon';
}
};
/**
* @return {?}
*/
GridComponent.prototype.init = /**
* @return {?}
*/
function () {
/** @type {?} */
var dataLength = (this._data && this._data.length) || 0;
/** @type {?} */
var rowCount = Math.ceil(dataLength / this.columnNum);
/** @type {?} */
var rowsArr;
if (this.defaultProps.isCarousel) {
if (rowCount % this.carouselMaxRow !== 0) {
rowCount = rowCount + this.carouselMaxRow - (rowCount % this.carouselMaxRow);
}
/** @type {?} */
var pageCount = Math.ceil(rowCount / this.carouselMaxRow);
rowsArr = this.getRows(rowCount, dataLength);
if (pageCount <= 1) {
this.carouselProps = {
dots: false,
dragging: false
};
}
else {
this.carouselProps = {
dots: true,
dragging: true
};
}
this.carouselDataTmp = this.getCarouselData(rowsArr, pageCount, rowCount);
}
else {
this.gridData = this.getRows(rowCount, dataLength);
}
};
/**
* @param {?} rowsArr
* @param {?} pageCount
* @param {?} rowCount
* @return {?}
*/
GridComponent.prototype.getCarouselData = /**
* @param {?} rowsArr
* @param {?} pageCount
* @param {?} rowCount
* @return {?}
*/
function (rowsArr, pageCount, rowCount) {
/** @type {?} */
var pagesArr = [];
for (var pageIndex = 0; pageIndex < pageCount; pageIndex++) {
/** @type {?} */
var pageRows = [];
for (var ii = 0; ii < this.carouselMaxRow; ii++) {
/** @type {?} */
var rowIndex = pageIndex * this.carouselMaxRow + ii;
if (rowIndex < rowCount) {
pageRows.push(rowsArr[rowIndex]);
}
else {
// 空节点为了确保末尾页的最后未到底的行有底线(样式中last-child会没线)
pageRows.push(null);
}
}
pagesArr.push(pageRows);
}
return pagesArr;
};
/**
* @param {?} rowCount
* @param {?} dataLength
* @return {?}
*/
GridComponent.prototype.getRows = /**
* @param {?} rowCount
* @param {?} dataLength
* @return {?}
*/
function (rowCount, dataLength) {
/** @type {?} */
var columnNum = this.columnNum;
/** @type {?} */
var rowArr = new Array();
for (var i = 0; i < rowCount; i++) {
rowArr[i] = new Array();
for (var j = 0; j < columnNum; j++) {
/** @type {?} */
var dataIndex = i * columnNum + j;
if (dataIndex < dataLength) {
rowArr[i][j] = this._data[dataIndex];
}
else {
rowArr[i][j] = null;
}
}
}
return rowArr;
};
/**
* @param {?} data
* @param {?} index
* @return {?}
*/
GridComponent.prototype.click = /**
* @param {?} data
* @param {?} index
* @return {?}
*/
function (data, index) {
/** @type {?} */
var outputData = {
data: data,
index: index
};
this.onClick.emit(outputData);
};
/**
* @return {?}
*/
GridComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _a;
this.itemCls = (_a = {},
_a[this.defaultProps.prefixCls + "-item"] = true,
_a[this.defaultProps.prefixCls + "-active-item"] = false,
_a);
};
GridComponent.decorators = [
{ type: Component, args: [{
selector: 'Grid, nzm-grid',
template: "<ng-container *ngIf=\"!isCarousel\">\n <Flex *ngFor=\"let item of gridData; let i = index\" [justify]=\"'center'\" [align]=\"'stretch'\">\n <FlexItem\n TouchFeedbackDirective\n *ngFor=\"let subItem of item; let j = index\"\n [ngClass]=\"itemCls\"\n [ngStyle]=\"itemStyle\"\n [className]=\"['am-grid-item-active']\"\n [activeStyle]=\"activeStyle\"\n >\n <div\n *ngIf=\"subItem !== null\"\n class=\"{{ defaultProps.prefixCls }}-item-content\"\n (click)=\"click(subItem, i * columnNum + j)\"\n >\n <div class=\"{{ defaultProps.prefixCls }}-item-inner-content column-num-{{ columnNum }}\">\n <img\n *ngIf=\"subItem.icon && getContentType(subItem.icon) === 'url'\"\n src=\"{{ subItem.icon }}\"\n class=\"{{ defaultProps.prefixCls }}-icon\"\n />\n <Icon\n *ngIf=\"subItem.icon && getContentType(subItem.icon) === 'icon'\"\n [type]=\"subItem.icon\"\n [size]=\"subItem.size\"\n ></Icon>\n <div\n *ngIf=\"subItem.icon && getContentType(subItem.icon) === 'innerHTML'\"\n [innerHTML]=\"subItem.icon | safeHTML\"\n ></div>\n <ng-template\n *ngIf=\"subItem.icon && getContentType(subItem.icon) === 'TemplateRef'\"\n [ngTemplateOutlet]=\"subItem.icon\"\n ></ng-template>\n <div class=\"{{ defaultProps.prefixCls }}-text\">{{ subItem.text }}</div>\n </div>\n </div>\n <div *ngIf=\"subItem === null\" class=\"{{ defaultProps.prefixCls }}-null-item\"></div>\n </FlexItem>\n </Flex>\n <ng-content></ng-content>\n</ng-container>\n\n<Carousel\n *ngIf=\"isCarousel && carouselDataTmp.length > 0\"\n [autoplay]=\"false\"\n [infinite]=\"true\"\n [selectedIndex]=\"0\"\n [autoplayInterval]=\"3000\"\n [dots]=\"carouselProps.dots\"\n [dragging]=\"carouselProps.dragging\"\n>\n <CarouselSlide\n *ngFor=\"let gridData of carouselDataTmp\"\n class=\"{{ defaultProps.prefixCls }}-carousel-page\"\n style=\"display: block;\"\n >\n <Flex *ngFor=\"let item of gridData; let i = index\" [justify]=\"'center'\" [align]=\"'stretch'\">\n <FlexItem\n TouchFeedbackDirective\n *ngFor=\"let subItem of item; let j = index\"\n class=\"{{ defaultProps.prefixCls }}-item\"\n [ngStyle]=\"itemStyle\"\n [className]=\"['am-grid-item-active']\"\n >\n <div\n *ngIf=\"subItem !== null\"\n class=\"{{ defaultProps.prefixCls }}-item-content\"\n (click)=\"click(subItem, i * columnNum + j)\"\n >\n <div class=\"{{ defaultProps.prefixCls }}-item-inner-content column-num-4\">\n <img class=\"{{ defaultProps.prefixCls }}-icon\" src=\"{{ subItem.icon }}\" />\n <div class=\"{{ defaultProps.prefixCls }}-text\">{{ subItem.text }}</div>\n </div>\n </div>\n <div *ngIf=\"subItem === null\" class=\"{{ defaultProps.prefixCls }}-null-item\"></div>\n </FlexItem>\n </Flex>\n </CarouselSlide>\n</Carousel>\n"
}] }
];
/** @nocollapse */
GridComponent.ctorParameters = function () { return []; };
GridComponent.propDecorators = {
columnNum: [{ type: Input }],
carouselMaxRow: [{ type: Input }],
itemStyle: [{ type: Input }],
square: [{ type: Input }],
hasLine: [{ type: Input }],
isCarousel: [{ type: Input }],
activeStyle: [{ type: Input }],
data: [{ type: Input }],
onClick: [{ type: Output }],
amGrid: [{ type: HostBinding, args: ['class.am-grid',] }],
amGridSquare: [{ type: HostBinding, args: ['class.am-grid-square',] }],
amGridLine: [{ type: HostBinding, args: ['class.am-grid-line',] }],
amGridCarousel: [{ type: HostBinding, args: ['class.am-grid-carousel',] }]
};
return GridComponent;
}());
export { GridComponent };
if (false) {
/** @type {?} */
GridComponent.prototype.wrapCls;
/** @type {?} */
GridComponent.prototype.itemCls;
/** @type {?} */
GridComponent.prototype.carouselProps;
/** @type {?} */
GridComponent.prototype.defaultProps;
/** @type {?} */
GridComponent.prototype.carouselData;
/** @type {?} */
GridComponent.prototype.carouselDataTmp;
/** @type {?} */
GridComponent.prototype.gridData;
/**
* @type {?}
* @private
*/
GridComponent.prototype._data;
/** @type {?} */
GridComponent.prototype.columnNum;
/** @type {?} */
GridComponent.prototype.carouselMaxRow;
/** @type {?} */
GridComponent.prototype.itemStyle;
/** @type {?} */
GridComponent.prototype.square;
/** @type {?} */
GridComponent.prototype.hasLine;
/** @type {?} */
GridComponent.prototype.activeStyle;
/** @type {?} */
GridComponent.prototype.onClick;
/** @type {?} */
GridComponent.prototype.amGrid;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["grid/grid.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, TemplateRef, HostBinding } from '@angular/core';\n\n@Component({\n  selector: 'Grid, nzm-grid',\n  templateUrl: './grid.component.html'\n})\nexport class GridComponent implements OnInit {\n  wrapCls = {};\n  itemCls = {};\n  carouselProps = {\n    dots: false,\n    dragging: false\n  };\n  defaultProps = {\n    data: [],\n    hasLine: true,\n    isCarousel: false,\n    columnNum: 4,\n    carouselMaxRow: 2,\n    prefixCls: 'am-grid',\n    square: true,\n    itemStyle: {}\n  };\n  carouselData = [];\n  carouselDataTmp = [];\n  gridData = [];\n\n  private _data = [];\n\n  @Input()\n  columnNum: number = 4;\n  @Input()\n  carouselMaxRow: number = 2;\n  @Input()\n  itemStyle: object = {};\n  @Input()\n  square: boolean = true;\n  @Input()\n  hasLine: boolean = true;\n  @Input()\n  get isCarousel(): boolean {\n    return this.defaultProps.isCarousel;\n  }\n  set isCarousel(value: boolean) {\n    this.defaultProps.isCarousel = value;\n    this.init();\n  }\n  @Input()\n  activeStyle: boolean = true;\n  @Input()\n  set data(value: Array<any>) {\n    this._data = value;\n    this.init();\n  }\n  @Output()\n  onClick: EventEmitter<any> = new EventEmitter();\n\n  @HostBinding('class.am-grid')\n  amGrid: boolean = true;\n  @HostBinding('class.am-grid-square')\n  get amGridSquare(): boolean {\n    return true === this.square;\n  }\n  @HostBinding('class.am-grid-line')\n  get amGridLine(): boolean {\n    return true === this.hasLine;\n  }\n  @HostBinding('class.am-grid-carousel')\n  get amGridCarousel(): boolean {\n    return true === this.isCarousel;\n  }\n\n  constructor() {}\n\n  getContentType(value: any): string {\n    if ((value.indexOf('http') >= 0 || value.indexOf('assets') >= 0) && value.indexOf('<') < 0) {\n      return 'url';\n    } else if (value.indexOf('<') >= 0) {\n      return 'innerHTML';\n    } else if (value instanceof TemplateRef) {\n      return 'TemplateRef';\n    } else {\n      return 'icon';\n    }\n  }\n\n  init() {\n    const dataLength = (this._data && this._data.length) || 0;\n    let rowCount = Math.ceil(dataLength / this.columnNum);\n    let rowsArr;\n    if (this.defaultProps.isCarousel) {\n      if (rowCount % this.carouselMaxRow !== 0) {\n        rowCount = rowCount + this.carouselMaxRow - (rowCount % this.carouselMaxRow);\n      }\n      const pageCount = Math.ceil(rowCount / this.carouselMaxRow);\n      rowsArr = this.getRows(rowCount, dataLength);\n      if (pageCount <= 1) {\n        this.carouselProps = {\n          dots: false,\n          dragging: false\n        };\n      } else {\n        this.carouselProps = {\n          dots: true,\n          dragging: true\n        };\n      }\n      this.carouselDataTmp = this.getCarouselData(rowsArr, pageCount, rowCount);\n    } else {\n      this.gridData = this.getRows(rowCount, dataLength);\n    }\n  }\n\n  getCarouselData(rowsArr: any[], pageCount: number, rowCount: number) {\n    const pagesArr: any[] = [];\n    for (let pageIndex = 0; pageIndex < pageCount; pageIndex++) {\n      const pageRows: any[] = [];\n      for (let ii = 0; ii < this.carouselMaxRow; ii++) {\n        const rowIndex = pageIndex * this.carouselMaxRow + ii;\n        if (rowIndex < rowCount) {\n          pageRows.push(rowsArr[rowIndex]);\n        } else {\n          // 空节点为了确保末尾页的最后未到底的行有底线(样式中last-child会没线)\n          pageRows.push(null);\n        }\n      }\n      pagesArr.push(pageRows);\n    }\n    return pagesArr;\n  }\n\n  getRows(rowCount: number, dataLength: number) {\n    const columnNum = this.columnNum;\n    const rowArr = new Array();\n    for (let i = 0; i < rowCount; i++) {\n      rowArr[i] = new Array();\n      for (let j = 0; j < columnNum; j++) {\n        const dataIndex = i * columnNum + j;\n        if (dataIndex < dataLength) {\n          rowArr[i][j] = this._data[dataIndex];\n        } else {\n          rowArr[i][j] = null;\n        }\n      }\n    }\n    return rowArr;\n  }\n\n  click(data, index) {\n    const outputData = {\n      data: data,\n      index: index\n    };\n    this.onClick.emit(outputData);\n  }\n\n  ngOnInit() {\n    this.itemCls = {\n      [`${this.defaultProps.prefixCls}-item`]: true,\n      [`${this.defaultProps.prefixCls}-active-item`]: false\n    };\n  }\n}\n"]}