UNPKG

ng-zorro-antd-mobile

Version:

An enterprise-class mobile UI components based on Ant Design and Angular

203 lines 32.3 kB
import { Component, Input, Output, EventEmitter, TemplateRef, HostBinding } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "ng-zorro-antd-mobile/flex"; import * as i2 from "ng-zorro-antd-mobile/icon"; import * as i3 from "@angular/common"; import * as i4 from "ng-zorro-antd-mobile/carousel"; import * as i5 from "ng-zorro-antd-mobile/core"; import * as i6 from "ng-zorro-antd-mobile/pipes"; export class GridComponent { get columnNum() { return this.defaultProps.columnNum; } set columnNum(value) { if (typeof value === 'number') { this.defaultProps.columnNum = value; this.init(); } } get carouselMaxRow() { return this.defaultProps.carouselMaxRow; } set carouselMaxRow(value) { if (typeof value === 'number') { this.defaultProps.carouselMaxRow = value; this.init(); } } get isCarousel() { return this.defaultProps.isCarousel; } set isCarousel(value) { this.defaultProps.isCarousel = value; this.init(); } set data(value) { this._data = value; this.init(); } get amGridSquare() { return true === this.square; } get amGridLine() { return true === this.hasLine; } get amGridCarousel() { return true === this.isCarousel; } constructor() { 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.itemStyle = {}; this.square = true; this.hasLine = true; this.activeStyle = true; this.onClick = new EventEmitter(); this.amGrid = true; } getContentType(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'; } } init() { const dataLength = (this._data && this._data.length) || 0; let rowCount = Math.ceil(dataLength / this.columnNum); let rowsArr; if (this.defaultProps.isCarousel) { if (rowCount % this.carouselMaxRow !== 0) { rowCount = rowCount + this.carouselMaxRow - (rowCount % this.carouselMaxRow); } const 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); } } getCarouselData(rowsArr, pageCount, rowCount) { const pagesArr = []; for (let pageIndex = 0; pageIndex < pageCount; pageIndex++) { const pageRows = []; for (let ii = 0; ii < this.carouselMaxRow; ii++) { const rowIndex = pageIndex * this.carouselMaxRow + ii; if (rowIndex < rowCount) { pageRows.push(rowsArr[rowIndex]); } else { // 空节点为了确保末尾页的最后未到底的行有底线(样式中last-child会没线) pageRows.push(null); } } pagesArr.push(pageRows); } return pagesArr; } getRows(rowCount, dataLength) { const columnNum = this.columnNum; const rowArr = new Array(); for (let i = 0; i < rowCount; i++) { rowArr[i] = new Array(); for (let j = 0; j < columnNum; j++) { const dataIndex = i * columnNum + j; if (dataIndex < dataLength) { rowArr[i][j] = this._data[dataIndex]; } else { rowArr[i][j] = null; } } } return rowArr; } click(data, index) { const outputData = { data: data, index: index }; this.onClick.emit(outputData); } ngOnInit() { this.itemCls = { [`${this.defaultProps.prefixCls}-item`]: true, [`${this.defaultProps.prefixCls}-active-item`]: false }; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: GridComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: GridComponent, selector: "Grid, nzm-grid", inputs: { columnNum: "columnNum", carouselMaxRow: "carouselMaxRow", itemStyle: "itemStyle", square: "square", hasLine: "hasLine", isCarousel: "isCarousel", activeStyle: "activeStyle", data: "data" }, outputs: { onClick: "onClick" }, host: { properties: { "class.am-grid": "this.amGrid", "class.am-grid-square": "this.amGridSquare", "class.am-grid-line": "this.amGridLine", "class.am-grid-carousel": "this.amGridCarousel" } }, ngImport: i0, 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", dependencies: [{ kind: "component", type: i1.FlexComponent, selector: "Flex, nzm-flex", inputs: ["direction", "wrap", "justify", "align", "alignContent"] }, { kind: "component", type: i1.FlexItemComponent, selector: "FlexItem, nzm-flex-item" }, { kind: "component", type: i2.IconComponent, selector: "Icon, nzm-icon", inputs: ["color", "type", "src", "size"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i4.CarouselComponent, selector: "Carousel, nzm-carousel", inputs: ["speed", "dots", "vertical", "autoplay", "autoplayInterval", "infinite", "dotStyle", "dotActiveStyle", "frameOverflow", "cellSpacing", "slideWidth", "swipeSpeed", "dragging", "selectedIndex"], outputs: ["afterChange", "beforeChange"] }, { kind: "component", type: i4.CarouselSlideComponent, selector: "CarouselSlide, nzm-carousel-slide" }, { kind: "directive", type: i5.TouchFeedbackDirective, selector: "[TouchFeedbackDirective]", inputs: ["className", "activeStyle"], outputs: ["clickStart", "clickEnd"] }, { kind: "pipe", type: i6.SafeHTMLPipe, name: "safeHTML" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: 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" }] }], ctorParameters: () => [], 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'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.component.js","sourceRoot":"","sources":["../../../components/grid/grid.component.ts","../../../components/grid/grid.component.html"],"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  get columnNum(): number {\n    return this.defaultProps.columnNum;\n  }\n  set columnNum(value: number) {\n    if (typeof value === 'number') {\n      this.defaultProps.columnNum = value;\n      this.init();\n    }\n  }\n  @Input()\n  get carouselMaxRow(): number {\n    return this.defaultProps.carouselMaxRow;\n  }\n  set carouselMaxRow(value: number) {\n    if (typeof value === 'number') {\n      this.defaultProps.carouselMaxRow = value;\n      this.init();\n    }\n  }\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","<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"]}