moar test
This commit is contained in:
parent
adcbcd589a
commit
dd55aadaf5
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@poweredsoft/data",
|
"name": "@poweredsoft/data",
|
||||||
"version": "0.0.23",
|
"version": "0.0.24",
|
||||||
"peerDependencies": {
|
"peerDependencies": {
|
||||||
"rxjs": "^6.5.3"
|
"rxjs": "^6.5.3"
|
||||||
}
|
}
|
||||||
|
@ -1,108 +1,130 @@
|
|||||||
import { Component, OnInit, Pipe } from '@angular/core';
|
import { Component, OnInit, Pipe } from '@angular/core';
|
||||||
import { IDataSource } from 'projects/poweredsoft/data/src/lib/IDataSource';
|
import { IDataSource } from 'projects/poweredsoft/data/src/lib/IDataSource';
|
||||||
import { IDataSourceNotifyMessage } from 'projects/poweredsoft/data/src/lib/IDataSourceNotifyMessage';
|
import { IDataSourceNotifyMessage } from 'projects/poweredsoft/data/src/lib/IDataSourceNotifyMessage';
|
||||||
import { DataSource, IDataSourceTransportOptions, IDataSourceQueryAdapterOptions, IQueryCriteria, IQueryExecutionResult, IQueryExecutionGroupResult, IDataSourceCommandAdapterOptions } from 'projects/poweredsoft/data/src/public-api';
|
import { DataSource, IDataSourceTransportOptions, IDataSourceQueryAdapterOptions, IQueryCriteria, IQueryExecutionResult, IQueryExecutionGroupResult, IDataSourceCommandAdapterOptions, IDataSourceValidationError } from 'projects/poweredsoft/data/src/public-api';
|
||||||
import { HttpClient } from '@angular/common/http';
|
import { HttpClient } from '@angular/common/http';
|
||||||
import { of } from 'rxjs';
|
import { of, throwError } from 'rxjs';
|
||||||
|
|
||||||
export interface MyModel {
|
export interface MyModel {
|
||||||
id: number;
|
id: number;
|
||||||
name: string;
|
name: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-root',
|
selector: 'app-root',
|
||||||
templateUrl: './app.component.html',
|
templateUrl: './app.component.html',
|
||||||
styleUrls: ['./app.component.css']
|
styleUrls: ['./app.component.css']
|
||||||
})
|
})
|
||||||
|
|
||||||
export class AppComponent implements OnInit {
|
export class AppComponent implements OnInit {
|
||||||
title = 'data';
|
title = 'data';
|
||||||
message: string = '';
|
message: string = '';
|
||||||
type: string = '';
|
type: string = '';
|
||||||
|
|
||||||
dataSource: IDataSource<any>;
|
dataSource: IDataSource<any>;
|
||||||
createCommand: IDataSourceCommandAdapterOptions<MyModel>;
|
createCommand: IDataSourceCommandAdapterOptions<MyModel>;
|
||||||
|
|
||||||
public constructor(private http: HttpClient) {
|
|
||||||
|
|
||||||
}
|
public constructor(private http: HttpClient) {
|
||||||
|
|
||||||
ngOnInit(): void {
|
}
|
||||||
const keyResolver = (m: MyModel) => m.id;
|
|
||||||
let route = 'http://localhost:9999';
|
|
||||||
|
|
||||||
const query: IDataSourceQueryAdapterOptions<MyModel> = {
|
ngOnInit(): void {
|
||||||
adapter: {
|
const keyResolver = (m: MyModel) => m.id;
|
||||||
handle: (criteria: IQueryCriteria) => {
|
let route = 'http://localhost:9999';
|
||||||
const queryRoute = `${route}/read`;
|
|
||||||
return this.http.post<IQueryExecutionResult<MyModel> & IQueryExecutionGroupResult<MyModel>>(queryRoute, criteria);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
this.createCommand = {
|
const query: IDataSourceQueryAdapterOptions<MyModel> = {
|
||||||
adapter: {
|
adapter: {
|
||||||
handle: (command: MyModel) => {
|
handle: (criteria: IQueryCriteria) => {
|
||||||
return of(command);
|
const queryRoute = `${route}/read`;
|
||||||
//return this.http.post<MyModel>(route, command);
|
return this.http.post<IQueryExecutionResult<MyModel> & IQueryExecutionGroupResult<MyModel>>(queryRoute, criteria);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const updateCommand: IDataSourceCommandAdapterOptions<MyModel> = {
|
this.createCommand = {
|
||||||
adapter: {
|
adapter: {
|
||||||
handle: (command: MyModel) => {
|
handle: (command: MyModel) => {
|
||||||
const key = keyResolver(command);
|
return of(command);
|
||||||
const updateRoute = `${route}/${encodeURIComponent(key as any)}`;
|
//return this.http.post<MyModel>(route, command);
|
||||||
return of(command);
|
}
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
};
|
|
||||||
|
|
||||||
const deleteCommand: IDataSourceCommandAdapterOptions<MyModel> = {
|
const updateCommand: IDataSourceCommandAdapterOptions<MyModel> = {
|
||||||
adapter: {
|
adapter: {
|
||||||
handle: (command: MyModel) => {
|
handle: (command: MyModel) => {
|
||||||
const key = keyResolver(command);
|
const key = keyResolver(command);
|
||||||
const updateRoute = `${route}/${encodeURIComponent(key as any)}`;
|
const updateRoute = `${route}/${encodeURIComponent(key as any)}`;
|
||||||
return of(command);
|
return throwError(<IDataSourceValidationError>{
|
||||||
}
|
type: 'validation',
|
||||||
}
|
errors: {
|
||||||
};
|
'name': [
|
||||||
|
'David is not unique'
|
||||||
|
]
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
const transportOptions : IDataSourceTransportOptions<MyModel> = {
|
const deleteCommand: IDataSourceCommandAdapterOptions<MyModel> = {
|
||||||
query: query,
|
adapter: {
|
||||||
commands: {
|
handle: (command: MyModel) => {
|
||||||
'create': this.createCommand,
|
const key = keyResolver(command);
|
||||||
'update': updateCommand,
|
const updateRoute = `${route}/${encodeURIComponent(key as any)}`;
|
||||||
'delete': deleteCommand
|
return of(command);
|
||||||
}
|
}
|
||||||
};
|
}
|
||||||
this.dataSource = new DataSource<MyModel>({
|
};
|
||||||
manageNotificationMessage: false,
|
|
||||||
transport: transportOptions,
|
|
||||||
defaultCriteria: {
|
|
||||||
page: 1,
|
|
||||||
pageSize: 5,
|
|
||||||
groups: [
|
|
||||||
{ path: 'name' }
|
|
||||||
]
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
this.dataSource.notifyMessage$.subscribe((notifyMessage: IDataSourceNotifyMessage) => {
|
const transportOptions: IDataSourceTransportOptions<MyModel> = {
|
||||||
this.handleNotification(notifyMessage);
|
query: query,
|
||||||
});
|
commands: {
|
||||||
}
|
'create': this.createCommand,
|
||||||
|
'update': updateCommand,
|
||||||
|
'delete': deleteCommand
|
||||||
|
}
|
||||||
|
};
|
||||||
|
this.dataSource = new DataSource<MyModel>({
|
||||||
|
manageNotificationMessage: false,
|
||||||
|
transport: transportOptions,
|
||||||
|
defaultCriteria: {
|
||||||
|
page: 1,
|
||||||
|
pageSize: 5,
|
||||||
|
groups: [
|
||||||
|
{ path: 'name' }
|
||||||
|
]
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
handleNotification(notification: IDataSourceNotifyMessage) {
|
this.dataSource.notifyMessage$.subscribe((notifyMessage) => {
|
||||||
this.message = notification.message;
|
this.handleNotification(notifyMessage);
|
||||||
}
|
});
|
||||||
|
|
||||||
onDoSomething() {
|
this.dataSource.validationError$.subscribe((t) => {
|
||||||
this.dataSource.executeCommandByName('create', this.createCommand).subscribe(() => {
|
|
||||||
console.log('hey we did it!');
|
let message = '';
|
||||||
});
|
for (var key in t.errors)
|
||||||
//this.dataSource.refresh();
|
t.errors[key].forEach(error => message += `\n${error}`);
|
||||||
}
|
|
||||||
|
this.handleNotification({
|
||||||
|
type: 'error',
|
||||||
|
message: message
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
handleNotification(notification: IDataSourceNotifyMessage) {
|
||||||
|
this.message = notification.message;
|
||||||
|
}
|
||||||
|
|
||||||
|
onDoSomething() {
|
||||||
|
this.dataSource.executeCommandByName('create', {}).subscribe(() => {
|
||||||
|
console.log('hey we did it!');
|
||||||
|
});
|
||||||
|
this.dataSource.executeCommandByName('update', {}).subscribe(() => {
|
||||||
|
|
||||||
|
});
|
||||||
|
//this.dataSource.refresh();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user