nx-primeng-sakai-v17/src/app/components/list/list.component.html

89 lines
4.1 KiB
HTML
Raw Normal View History

2021-12-22 13:06:49 +00:00
<div class="grid">
2021-12-09 14:24:42 +00:00
<div class="col-12">
<div class="card">
<h5>DataView</h5>
2021-12-22 13:06:49 +00:00
<p-dataView #dv [value]="products" [paginator]="true" [rows]="9" filterBy="name" [sortField]="sortField" [sortOrder]="sortOrder" layout="grid">
2021-12-09 14:24:42 +00:00
<ng-template pTemplate="header">
2022-01-31 11:24:59 +00:00
<div class="grid grid-nogutter flex-column md:flex-row justify-content-between">
<p-dropdown [options]="sortOptions" [(ngModel)]="sortKey" placeholder="Sort By Price" (onChange)="onSortChange($event)"></p-dropdown>
<span class="p-input-icon-left mb-2 md:mb-0">
<i class="pi pi-search"></i>
<input type="search" pInputText placeholder="Search by Name" (input)="dv.filter($event.target.value)">
</span>
<p-dataViewLayoutOptions></p-dataViewLayoutOptions>
2021-12-09 14:24:42 +00:00
</div>
</ng-template>
2021-12-22 13:06:49 +00:00
2021-12-09 14:24:42 +00:00
<ng-template let-product pTemplate="listItem">
<div class="col-12">
2021-12-22 13:06:49 +00:00
<div class="flex flex-column md:flex-row align-items-center p-3 w-full">
<img [src]="'assets/demo/images/product/' + product.image" [alt]="product.name" class="my-4 md:my-0 w-9 md:w-10rem shadow-2 mr-5"/>
<div class="flex-1 text-center md:text-left">
<div class="font-bold text-2xl">{{product.name}}</div>
<div class="mb-3">{{product.description}}</div>
2021-12-09 14:24:42 +00:00
<p-rating [ngModel]="product.rating" [readonly]="true" [cancel]="false"></p-rating>
2021-12-22 13:06:49 +00:00
<div class="flex align-items-center mt-2">
<i class="pi pi-tag mr-2"></i>
<span class="font-semibold">{{product.category}}</span>
</div>
2021-12-09 14:24:42 +00:00
</div>
2021-12-22 13:06:49 +00:00
<div class="flex flex-row md:flex-column justify-content-between w-full md:w-auto align-items-center md:align-items-end mt-5 md:mt-0">
<span class="text-2xl font-semibold mb-2 align-self-center md:align-self-end">${{product.price}}</span>
<p-button icon="pi pi-shopping-cart" label="Add to Cart" [disabled]="product.inventoryStatus === 'OUTOFSTOCK'" class="mb-2"></p-button>
2021-12-09 14:24:42 +00:00
<span [class]="'product-badge status-' + product.inventoryStatus.toLowerCase()">{{product.inventoryStatus}}</span>
</div>
</div>
</div>
</ng-template>
2021-12-22 13:06:49 +00:00
2021-12-09 14:24:42 +00:00
<ng-template let-product pTemplate="gridItem">
<div class="col-12 md:col-4">
2021-12-22 13:06:49 +00:00
<div class="card m-3 border-1 surface-border">
<div class="flex align-items-center justify-content-between">
<div class="flex align-items-center">
<i class="pi pi-tag mr-2"></i>
<span class="font-semibold">{{product.category}}</span>
2021-12-09 14:24:42 +00:00
</div>
2021-12-22 13:06:49 +00:00
<span [class]="'sm:ml-2 product-badge status-' + product.inventoryStatus.toLowerCase()">{{product.inventoryStatus}}</span>
2021-12-09 14:24:42 +00:00
</div>
2021-12-22 13:06:49 +00:00
<div class="text-center">
<img [src]="'assets/demo/images/product/' + product.image" [alt]="product.name" class="w-9 shadow-2 my-3 mx-0"/>
<div class="text-2xl font-bold">{{product.name}}</div>
<div class="mb-3">{{product.description}}</div>
2021-12-09 14:24:42 +00:00
<p-rating [ngModel]="product.rating" [readonly]="true" [cancel]="false"></p-rating>
</div>
2021-12-22 13:06:49 +00:00
<div class="flex align-items-center justify-content-between">
<span class="text-2xl font-semibold">${{product.price}}</span>
2021-12-09 14:24:42 +00:00
<p-button icon="pi pi-shopping-cart" [disabled]="product.inventoryStatus === 'OUTOFSTOCK'"></p-button>
</div>
</div>
</div>
</ng-template>
</p-dataView>
</div>
</div>
<div class="col-12 lg:col-8">
<div class="card">
<h5>PickList</h5>
<p-pickList [source]="sourceCities" [target]="targetCities" sourceHeader="From" targetHeader="To" dragdrop="true"
2021-12-28 10:37:17 +00:00
[responsive]="true" [sourceStyle]="{'height':'250px'}" [targetStyle]="{'height':'250px'}">
2021-12-09 14:24:42 +00:00
<ng-template let-city pTemplate="item">
<div>{{city.name}}</div>
</ng-template>
</p-pickList>
</div>
</div>
<div class="col-12 lg:col-4">
<div class="card">
<h5>OrderList</h5>
2021-12-28 10:37:17 +00:00
<p-orderList [value]="orderCities" header="Cities" dragdrop="true" [listStyle]="{'height':'250px'}">
2021-12-09 14:24:42 +00:00
<ng-template let-city pTemplate="item">
<div>{{city.name}}</div>
</ng-template>
</p-orderList>
</div>
</div>
</div>