UNPKG

@material-git/grid-list

Version:
88 lines (86 loc) 5.49 kB
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); }; import { Component, ViewEncapsulation, Renderer, ElementRef, Input, ContentChildren, QueryList } from '@angular/core'; import { MdLine, MdLineSetter } from '@material-git/core'; import { coerceToNumber } from './grid-list-measure'; export var MdGridTile = (function () { function MdGridTile(_renderer, _element) { this._renderer = _renderer; this._element = _element; this._rowspan = 1; this._colspan = 1; } Object.defineProperty(MdGridTile.prototype, "rowspan", { get: function () { return this._rowspan; }, set: function (value) { this._rowspan = coerceToNumber(value); }, enumerable: true, configurable: true }); Object.defineProperty(MdGridTile.prototype, "colspan", { get: function () { return this._colspan; }, set: function (value) { this._colspan = coerceToNumber(value); }, enumerable: true, configurable: true }); /** * Sets the style of the grid-tile element. Needs to be set manually to avoid * "Changed after checked" errors that would occur with HostBinding. */ MdGridTile.prototype._setStyle = function (property, value) { this._renderer.setElementStyle(this._element.nativeElement, property, value); }; __decorate([ Input(), __metadata('design:type', Object) ], MdGridTile.prototype, "rowspan", null); __decorate([ Input(), __metadata('design:type', Object) ], MdGridTile.prototype, "colspan", null); MdGridTile = __decorate([ Component({selector: 'md-grid-tile', host: { 'role': 'listitem' }, template: "<!-- TODO(kara): Revisit why this is a figure.--> <figure> <ng-content></ng-content> </figure>", styles: ["md-grid-list { display: block; position: relative; } md-grid-tile { display: block; position: absolute; } md-grid-tile figure { display: flex; position: absolute; align-items: center; justify-content: center; height: 100%; top: 0; right: 0; bottom: 0; left: 0; padding: 0; margin: 0; } md-grid-tile md-grid-tile-header, md-grid-tile md-grid-tile-footer { display: flex; align-items: center; height: 48px; color: #fff; background: rgba(0, 0, 0, 0.18); overflow: hidden; padding: 0 16px; font-size: 16px; position: absolute; left: 0; right: 0; } md-grid-tile md-grid-tile-header [md-line], md-grid-tile md-grid-tile-footer [md-line] { white-space: nowrap; overflow-x: hidden; text-overflow: ellipsis; display: block; box-sizing: border-box; } md-grid-tile md-grid-tile-header [md-line]:nth-child(n+2), md-grid-tile md-grid-tile-footer [md-line]:nth-child(n+2) { font-size: 12px; } md-grid-tile md-grid-tile-header > *, md-grid-tile md-grid-tile-footer > * { margin: 0; padding: 0; font-weight: normal; font-size: inherit; } md-grid-tile md-grid-tile-header.md-2-line, md-grid-tile md-grid-tile-footer.md-2-line { height: 68px; } md-grid-tile .md-grid-list-text { display: flex; flex-direction: column; width: 100%; box-sizing: border-box; overflow: hidden; } md-grid-tile .md-grid-list-text > * { margin: 0; padding: 0; font-weight: normal; font-size: inherit; } md-grid-tile .md-grid-list-text:empty { display: none; } md-grid-tile md-grid-tile-header { top: 0; } md-grid-tile md-grid-tile-footer { bottom: 0; } md-grid-tile [md-grid-avatar] { padding-right: 16px; } [dir='rtl'] md-grid-tile [md-grid-avatar] { padding-right: 0; padding-left: 16px; } md-grid-tile [md-grid-avatar]:empty { display: none; } /*# sourceMappingURL=grid-list.css.map */ "], encapsulation: ViewEncapsulation.None, }), __metadata('design:paramtypes', [Renderer, ElementRef]) ], MdGridTile); return MdGridTile; }()); export var MdGridTileText = (function () { function MdGridTileText(_renderer, _element) { this._renderer = _renderer; this._element = _element; } MdGridTileText.prototype.ngAfterContentInit = function () { this._lineSetter = new MdLineSetter(this._lines, this._renderer, this._element); }; __decorate([ ContentChildren(MdLine), __metadata('design:type', QueryList) ], MdGridTileText.prototype, "_lines", void 0); MdGridTileText = __decorate([ Component({selector: 'md-grid-tile-header, md-grid-tile-footer', template: "<ng-content select=\"[md-grid-avatar]\"></ng-content> <div class=\"md-grid-list-text\"><ng-content select=\"[md-line]\"></ng-content></div> <ng-content></ng-content>" }), __metadata('design:paramtypes', [Renderer, ElementRef]) ], MdGridTileText); return MdGridTileText; }()); //# sourceMappingURL=grid-tile.js.map