Merge branch 'develop' of https://git.akkerweb.nl/FarmMaps/FarmMapsLib into develop
All checks were successful
FarmMaps.Develop/FarmMapsLib/pipeline/head This commit looks good
All checks were successful
FarmMaps.Develop/FarmMapsLib/pipeline/head This commit looks good
This commit is contained in:
commit
4130e0a796
@ -9,6 +9,7 @@ import { OAuthModule, OAuthService, OAuthStorage } from 'angular-oauth2-oidc';
|
|||||||
|
|
||||||
//components
|
//components
|
||||||
import { ItemTypeService } from './services/itemtype.service';
|
import { ItemTypeService } from './services/itemtype.service';
|
||||||
|
import { SchemaService } from './services/schema.service';
|
||||||
import { FolderService } from './services/folder.service';
|
import { FolderService } from './services/folder.service';
|
||||||
import { TimespanService } from './services/timespan.service';
|
import { TimespanService } from './services/timespan.service';
|
||||||
import { ItemService } from './services/item.service';
|
import { ItemService } from './services/item.service';
|
||||||
@ -47,7 +48,8 @@ export {
|
|||||||
AuthCallbackGuard,
|
AuthCallbackGuard,
|
||||||
ResumableFileUploadService,
|
ResumableFileUploadService,
|
||||||
NgbDateNativeAdapter,
|
NgbDateNativeAdapter,
|
||||||
StateSerializerService
|
StateSerializerService,
|
||||||
|
SchemaService
|
||||||
};
|
};
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
|
@ -4,5 +4,6 @@ export interface IItemType {
|
|||||||
editor?: string;
|
editor?: string;
|
||||||
isFolder?: boolean;
|
isFolder?: boolean;
|
||||||
iconColor?: string;
|
iconColor?: string;
|
||||||
|
schema?: string;
|
||||||
extraAttributes?: string;
|
extraAttributes?: string;
|
||||||
}
|
}
|
||||||
|
@ -31,6 +31,12 @@ export class ItemTypeService {
|
|||||||
return extraAttributes;
|
return extraAttributes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getSchema(itemType: string): string {
|
||||||
|
let schema = null;
|
||||||
|
if (this.itemTypes[itemType]) schema = this.itemTypes[itemType].schema;
|
||||||
|
return schema;
|
||||||
|
}
|
||||||
|
|
||||||
hasViewer(item: IItem) {
|
hasViewer(item: IItem) {
|
||||||
let itemType: string = item.itemType;
|
let itemType: string = item.itemType;
|
||||||
if (this.itemTypes[itemType]) return this.itemTypes[itemType].viewer !== undefined;
|
if (this.itemTypes[itemType]) return this.itemTypes[itemType].viewer !== undefined;
|
||||||
|
32
projects/common/src/fm/services/schema.service.ts
Normal file
32
projects/common/src/fm/services/schema.service.ts
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import {Injectable} from '@angular/core';
|
||||||
|
import {HttpClient} from '@angular/common/http';
|
||||||
|
import {AppConfig} from '../shared/app.config';
|
||||||
|
import {Observable} from 'rxjs';
|
||||||
|
|
||||||
|
@Injectable({
|
||||||
|
providedIn: 'root',
|
||||||
|
})
|
||||||
|
export class SchemaService {
|
||||||
|
constructor(private httpClient: HttpClient, private appConfig: AppConfig) {
|
||||||
|
}
|
||||||
|
|
||||||
|
ApiEndpoint() {
|
||||||
|
return this.appConfig.getConfig('apiEndPoint');
|
||||||
|
}
|
||||||
|
|
||||||
|
public getSchemaIdFromSchemaUrl(schemaUrl): string {
|
||||||
|
const url = new URL(schemaUrl);
|
||||||
|
const pathSplit = url.pathname.split('/');
|
||||||
|
|
||||||
|
return pathSplit[pathSplit.length - 1].replace('.json', '');
|
||||||
|
}
|
||||||
|
|
||||||
|
public getSchemaWithUrl(schemaUrl): Observable<string> {
|
||||||
|
const id = this.getSchemaIdFromSchemaUrl(schemaUrl);
|
||||||
|
return this.httpClient.get<any>(`${this.ApiEndpoint()}/api/v1/schema/${id}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public getSchemaWithId(schemaId): Observable<string> {
|
||||||
|
return this.httpClient.get<any>(`${this.ApiEndpoint()}/api/v1/schema/${schemaId}`);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user