mirror of https://github.com/Squidex/squidex.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
91 lines
2.2 KiB
91 lines
2.2 KiB
/*
|
|
* Squidex Headless CMS
|
|
*
|
|
* @license
|
|
* Copyright (c) Sebastian Stehle. All rights reserved
|
|
*/
|
|
|
|
// tslint:disable:prefer-for-of
|
|
|
|
import { Component, OnInit } from '@angular/core';
|
|
import { FormControl } from '@angular/forms';
|
|
|
|
import {
|
|
AppComponentBase,
|
|
AppsStoreService,
|
|
AssetDto,
|
|
AssetsService,
|
|
fadeAnimation,
|
|
ImmutableArray,
|
|
NotificationService,
|
|
Pager,
|
|
UsersProviderService
|
|
} from 'shared';
|
|
|
|
@Component({
|
|
selector: 'sqx-assets-page',
|
|
styleUrls: ['./assets-page.component.scss'],
|
|
templateUrl: './assets-page.component.html',
|
|
animations: [
|
|
fadeAnimation
|
|
]
|
|
})
|
|
export class AssetsPageComponent extends AppComponentBase implements OnInit {
|
|
public newFiles = ImmutableArray.empty<File>();
|
|
|
|
public assetsItems = ImmutableArray.empty<AssetDto>();
|
|
public assetsPager = new Pager(0, 0, 12);
|
|
public assetsFilter = new FormControl();
|
|
public assertQuery = '';
|
|
|
|
constructor(apps: AppsStoreService, notifications: NotificationService, users: UsersProviderService,
|
|
private readonly assetsService: AssetsService
|
|
) {
|
|
super(notifications, users, apps);
|
|
}
|
|
|
|
public ngOnInit() {
|
|
this.load();
|
|
}
|
|
|
|
public search() {
|
|
this.assetsPager = new Pager(0, 0, 12);
|
|
this.assertQuery = this.assetsFilter.value;
|
|
|
|
this.load();
|
|
}
|
|
|
|
private load() {
|
|
this.appName()
|
|
.switchMap(app => this.assetsService.getAssets(app, this.assetsPager.pageSize, this.assetsPager.skip, this.assertQuery, null))
|
|
.subscribe(dtos => {
|
|
this.assetsItems = ImmutableArray.of(dtos.items);
|
|
this.assetsPager = this.assetsPager.setCount(dtos.total);
|
|
}, error => {
|
|
this.notifyError(error);
|
|
});
|
|
}
|
|
|
|
public goNext() {
|
|
this.assetsPager = this.assetsPager.goNext();
|
|
|
|
this.load();
|
|
}
|
|
|
|
public goPrev() {
|
|
this.assetsPager = this.assetsPager.goPrev();
|
|
|
|
this.load();
|
|
}
|
|
|
|
public removeFile(file: File) {
|
|
this.newFiles = this.newFiles.remove(file);
|
|
}
|
|
|
|
public addFiles(files: FileList) {
|
|
for (let i = 0; i < files.length; i++) {
|
|
this.newFiles = this.newFiles.pushFront(files[i]);
|
|
}
|
|
}
|
|
}
|
|
|
|
|