UNPKG

@knora/viewer

Version:
181 lines 27.1 kB
import * as tslib_1 from "tslib"; import { Component, Inject, Input, ViewChild } from '@angular/core'; import { ActivatedRoute, Router } from '@angular/router'; import { ApiResponseError, Constants, IHasProperty, KnoraApiConnection, ReadResource, ReadValue, ResourcePropertyDefinition } from '@knora/api'; import { KnoraApiConnectionToken } from '@knora/core'; import { StillImageComponent } from '../../representation'; // list of file value iris; TODO: not yet well done. It should be defined in global knora constants in knora-api-js-lib var FileRepresentation = /** @class */ (function () { function FileRepresentation() { } FileRepresentation.list = [ Constants.KnoraApiV2 + Constants.Delimiter + 'hasAudioFileValue', Constants.KnoraApiV2 + Constants.Delimiter + 'hasDDDFileValue', Constants.KnoraApiV2 + Constants.Delimiter + 'hasMovingImageFileValue', Constants.KnoraApiV2 + Constants.Delimiter + 'hasStillImageFileValue', Constants.KnoraApiV2 + Constants.Delimiter + 'hasTextFileValue' ]; return FileRepresentation; }()); export { FileRepresentation }; var jsonld = require('jsonld'); var ResourceViewComponent = /** @class */ (function () { function ResourceViewComponent(knoraApiConnection, _route, _router) { this.knoraApiConnection = knoraApiConnection; this._route = _route; this._router = _router; /** * Show all properties, even they don't have a value. * * @param {boolean} [allProps] */ this.allProps = false; /** * Show toolbar with project info and some action tools on top of properties if true. * * @param {boolean} [toolbar] */ this.toolbar = false; this.propArray = []; this.Constants = Constants; } ResourceViewComponent.prototype.ngOnInit = function () { // this.getResource(this.iri); }; ResourceViewComponent.prototype.ngOnChanges = function () { this.getResource(this.iri); // console.log(this.kuiStillImage.k; }; /** * Get a read resource sequence with ontology information and incoming resources. * * @param {string} id Resource iri */ ResourceViewComponent.prototype.getResource = function (id) { var _this = this; this.loading = true; this.error = undefined; this.knoraApiConnection.v2.res.getResource(id).subscribe(function (response) { var e_1, _a; _this.resource = response; // console.log(response); // get list of all properties var hasProps = _this.resource.entityInfo.classes[_this.resource.type].propertiesList; var i = 0; try { for (var hasProps_1 = tslib_1.__values(hasProps), hasProps_1_1 = hasProps_1.next(); !hasProps_1_1.done; hasProps_1_1 = hasProps_1.next()) { var hasProp = hasProps_1_1.value; var index = hasProp.propertyIndex; if (FileRepresentation.list.includes(index)) { // property value is of type hasFileRepresentations _this.fileRepresentation = _this.resource.properties[index]; } else { // filter all properties by type ResourcePropertyDefinition if (_this.resource.entityInfo.properties[index] && _this.resource.entityInfo.properties[index] instanceof ResourcePropertyDefinition) { var tempProp = { guiDef: hasProp, propDef: _this.resource.entityInfo.properties[index], values: _this.resource.properties[index] }; _this.propArray.push(tempProp); } } i++; } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (hasProps_1_1 && !hasProps_1_1.done && (_a = hasProps_1.return)) _a.call(hasProps_1); } finally { if (e_1) throw e_1.error; } } // sort properties by guiOrder _this.propArray.sort(function (a, b) { return (a.guiDef.guiOrder > b.guiDef.guiOrder) ? 1 : -1; }); // console.log(this.propArray); // TODO: get info about file representation to load corresponding media view _this.loading = false; // setTimeout(() => { // }); }, function (error) { console.error(error); _this.loading = false; }); }; /** * Get incoming links for a resource. * * @param offset * @param callback */ // getIncomingLinks(offset: number, callback?: (numberOfResources: number) => void): void { // this.loading = true; // this._incomingService.getIncomingLinksForResource(this.sequence.resources[0].id, offset).subscribe( // (incomingResources: ReadResourcesSequence) => { // // update ontology information // this.ontologyInfo.updateOntologyInformation(incomingResources.ontologyInformation); // // Append elements incomingResources to this.sequence.incomingLinks // Array.prototype.push.apply(this.sequence.resources[0].incomingLinks, incomingResources.resources); // // if callback is given, execute function with the amount of incoming resources as the parameter // if (callback !== undefined) { // callback(incomingResources.resources.length); // } // this.loading = false; // }, // (error: any) => { // console.error(error); // this.loading = false; // } // ); // } ResourceViewComponent.prototype.openLink = function (id) { this.loading = true; // this.routeChanged.emit(id); this._router.navigate(['/resource/' + encodeURIComponent(id)]); }; ResourceViewComponent.prototype.refreshProperties = function (index) { // console.log('from still-image-component: ', index); // TODO: commented for knora-api-js-lib: // this.currentResource = this.sequence.resources[0].incomingFileRepresentations[index]; }; ResourceViewComponent.prototype.toggleProps = function (show) { this.allProps = !this.allProps; }; ResourceViewComponent.ctorParameters = function () { return [ { type: KnoraApiConnection, decorators: [{ type: Inject, args: [KnoraApiConnectionToken,] }] }, { type: ActivatedRoute }, { type: Router } ]; }; tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", String) ], ResourceViewComponent.prototype, "iri", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Boolean) ], ResourceViewComponent.prototype, "allProps", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Boolean) ], ResourceViewComponent.prototype, "toolbar", void 0); tslib_1.__decorate([ ViewChild('kuiStillImage', { static: false }), tslib_1.__metadata("design:type", StillImageComponent) ], ResourceViewComponent.prototype, "kuiStillImage", void 0); ResourceViewComponent = tslib_1.__decorate([ Component({ selector: 'kui-resource-view', template: "<kui-progress-indicator *ngIf=\"loading\"></kui-progress-indicator>\n<div class=\"resource-view\" *ngIf=\"!error && !loading && resource\">\n\n <!-- media: show file representation -->\n <div *ngIf=\"fileRepresentation\">\n <div [ngSwitch]=\"fileRepresentation[0].type\" class=\"media\">\n\n <kui-still-image *ngSwitchCase=\"Constants.StillImageFileValue\" #kuiStillImage class=\"osd-viewer\"\n [images]=\"fileRepresentation\">\n </kui-still-image>\n\n <!-- TODO: switch through all other media type --\n <kui-moving-image></kui-moving-image>\n <kui-audio></kui-audio>\n <kui-ddd></kui-ddd>\n <kui-document></kui-document>\n\n <kui-collection></kui-collection>\n\n <kui-annotation></kui-annotation>\n <kui-link-obj></kui-link-obj>\n <kui-object></kui-object>\n <kui-region></kui-region>\n <kui-text></kui-text>\n -->\n\n <kui-message *ngSwitchDefault [medium]=\"true\"\n [message]=\"{status: 501, statusMsg: 'Not yet implemented', statusText: fileRepresentation[0].type + ' is not yet implemented'}\">\n </kui-message>\n\n </div>\n </div>\n\n <!-- properties / meta data -->\n <!-- tabs with header toolbar and properties -->\n <mat-tab-group animationDuration=\"0ms\" class=\"full-width data\">\n <!-- first tab for the main resource e.g. book -->\n <mat-tab [label]=\"resource.entityInfo?.classes[resource.type].label\">\n <!-- header with project / ontology / resource class info / ark url -->\n <kui-properties-toolbar *ngIf=\"toolbar\" [projectiri]=\"resource.attachedToProject\" [allProps]=\"allProps\"\n (toggleProps)=\"toggleProps($event)\">\n </kui-properties-toolbar>\n\n <kui-properties-view [propArray]=\"propArray\" [toolbar]=\"toolbar\" [allProps]=\"allProps\">\n </kui-properties-view>\n\n </mat-tab>\n\n <!-- TODO: second tab for a \"part-of\"-resource e.g. book page -->\n <!-- TODO: knora-api-js-lib: incoming file representations is empty; can't test it -->\n <!-- <mat-tab *ngIf=\"resource.incomingReferences.length > 0 && activeResource\"\n [label]=\"sequence.ontologyInformation.getLabelForResourceClass(activeResource.type)\">\n </mat-tab> -->\n\n <!-- TODO: third tab for a \"region\"-resource e.g. region on book page -->\n <!-- <mat-tab></mat-tab> -->\n </mat-tab-group>\n</div>\n\n<!-- in case of an error show the following message -->\n<div class=\"resource-view error content large middle\" *ngIf=\"error\">\n <kui-message *ngIf=\"error\" [message]=\"error\" [medium]=\"true\"></kui-message>\n</div>\n", styles: [".mat-form-field{width:320px}.fill-remaining-space{-webkit-box-flex:1;flex:1 1 auto}.center{text-align:center}a{text-decoration:none;color:inherit}.kui-link{cursor:pointer;border-bottom:2px solid rgba(0,105,92,.25)}.lv-prop-label{color:rgba(0,0,0,.54)}.lv-html-text{position:relative;overflow:hidden}.resource-view{max-width:960px;margin:0 auto}.resource-view .media{height:500px;display:block;margin:0 auto}.resource-view .data{min-height:700px;padding:24px 36px}.hidden{display:none}.property{margin-bottom:12px}.property .property-value-item{min-height:48px;height:auto}.property .property-value-item li{list-style-type:none}.property .property-value-item li.list:before{content:\"- \"}.property .property-value-item li.lastItem{margin-bottom:12px}@media (max-width:576px){.resource-view .resource .media{width:auto}}"] }), tslib_1.__param(0, Inject(KnoraApiConnectionToken)), tslib_1.__metadata("design:paramtypes", [KnoraApiConnection, ActivatedRoute, Router]) ], ResourceViewComponent); return ResourceViewComponent; }()); export { ResourceViewComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-view.component.js","sourceRoot":"ng://@knora/viewer/","sources":["lib/view/resource-view/resource-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnChanges, OnInit, ViewChild } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { KuiMessageData } from '@knora/action';\nimport { ApiResponseError, Constants, IHasProperty, KnoraApiConnection, ReadResource, ReadValue, ResourcePropertyDefinition } from '@knora/api';\nimport { PropertyDefinition } from '@knora/api/src/models/v2/ontologies/property-definition';\nimport { GuiOrder, KnoraApiConnectionToken, OntologyInformation } from '@knora/core';\n\nimport { StillImageComponent } from '../../representation';\n\n// object of property information from ontology class, properties and property values\nexport interface TempProperty {\n    guiDef: IHasProperty;\n    propDef: PropertyDefinition;\n    values: ReadValue[];\n}\n\n// list of file value iris; TODO: not yet well done. It should be defined in global knora constants in knora-api-js-lib\nexport class FileRepresentation {\n    static list: string[] = [\n        Constants.KnoraApiV2 + Constants.Delimiter + 'hasAudioFileValue',\n        Constants.KnoraApiV2 + Constants.Delimiter + 'hasDDDFileValue',\n        Constants.KnoraApiV2 + Constants.Delimiter + 'hasMovingImageFileValue',\n        Constants.KnoraApiV2 + Constants.Delimiter + 'hasStillImageFileValue',\n        Constants.KnoraApiV2 + Constants.Delimiter + 'hasTextFileValue'\n    ];\n}\n// import { Region, StillImageRepresentation } from '../../resource';\n\ndeclare let require: any;\nconst jsonld = require('jsonld');\n\n@Component({\n    selector: 'kui-resource-view',\n    templateUrl: './resource-view.component.html',\n    styleUrls: ['./resource-view.component.scss']\n})\nexport class ResourceViewComponent implements OnInit, OnChanges {\n\n    /**\n     * Resource iri\n     *\n     * @param {string} [iri] Resource iri\n     */\n    @Input() iri?: string;\n\n    /**\n     * Show all properties, even they don't have a value.\n     *\n     * @param  {boolean} [allProps]\n     */\n    @Input() allProps?: boolean = false;\n\n    /**\n     * Show toolbar with project info and some action tools on top of properties if true.\n     *\n     * @param  {boolean} [toolbar]\n     */\n    @Input() toolbar?: boolean = false;\n\n\n    // TODO: needs probably general fileRepresentation container to watch on\n    @ViewChild('kuiStillImage', { static: false }) kuiStillImage: StillImageComponent;\n\n    loading: boolean;\n\n    resource: ReadResource;\n\n    // current resource displayed in case of compound object\n    activeResource: ReadResource;\n\n    propArray: TempProperty[] = [];\n\n    // does the resource has a file representation (media file)?\n    fileRepresentation: ReadValue[]; // TODO: expand with following types: | ReadMovingImageFileValue | ReadAudioFileValue | ReadDocumentFileValue | ReadTextFileValue;\n\n    Constants = Constants;\n\n    // TODO: clean up following unused variables\n    ontologyInfo: OntologyInformation;\n    sequence: ReadResource[];\n    guiOrder: GuiOrder[];\n    error: KuiMessageData;\n\n    constructor(\n        @Inject(KnoraApiConnectionToken) private knoraApiConnection: KnoraApiConnection,\n        protected _route: ActivatedRoute,\n        protected _router: Router\n    ) {\n\n    }\n\n    ngOnInit() {\n        // this.getResource(this.iri);\n    }\n\n    ngOnChanges() {\n        this.getResource(this.iri);\n\n        // console.log(this.kuiStillImage.k;\n    }\n\n    /**\n     * Get a read resource sequence with ontology information and incoming resources.\n     *\n     * @param {string} id Resource iri\n     */\n    getResource(id: string) {\n        this.loading = true;\n        this.error = undefined;\n\n        this.knoraApiConnection.v2.res.getResource(id).subscribe(\n            (response: ReadResource) => {\n                this.resource = response;\n                // console.log(response);\n\n                // get list of all properties\n                const hasProps: IHasProperty[] = this.resource.entityInfo.classes[this.resource.type].propertiesList;\n\n                let i = 0;\n                for (const hasProp of hasProps) {\n\n                    const index = hasProp.propertyIndex;\n\n\n\n                    if (FileRepresentation.list.includes(index)) {\n                        // property value is of type hasFileRepresentations\n                        this.fileRepresentation = this.resource.properties[index];\n                    } else {\n                        // filter all properties by type ResourcePropertyDefinition\n                        if (this.resource.entityInfo.properties[index] &&\n                            this.resource.entityInfo.properties[index] instanceof ResourcePropertyDefinition) {\n\n                            const tempProp: TempProperty = {\n                                guiDef: hasProp,\n                                propDef: this.resource.entityInfo.properties[index],\n                                values: this.resource.properties[index]\n                            };\n\n                            this.propArray.push(tempProp);\n                        }\n                    }\n\n                    i++;\n                }\n\n                // sort properties by guiOrder\n                this.propArray.sort((a, b) => (a.guiDef.guiOrder > b.guiDef.guiOrder) ? 1 : -1);\n\n                // console.log(this.propArray);\n\n                // TODO: get info about file representation to load corresponding media view\n\n\n\n                this.loading = false;\n                // setTimeout(() => {\n                // });\n            },\n            (error: ApiResponseError) => {\n                console.error(error);\n                this.loading = false;\n            }\n        );\n\n    }\n\n\n    /**\n     * Get incoming links for a resource.\n     *\n     * @param offset\n     * @param callback\n     */\n    // getIncomingLinks(offset: number, callback?: (numberOfResources: number) => void): void {\n\n    //     this.loading = true;\n\n    //     this._incomingService.getIncomingLinksForResource(this.sequence.resources[0].id, offset).subscribe(\n    //         (incomingResources: ReadResourcesSequence) => {\n    //             // update ontology information\n    //             this.ontologyInfo.updateOntologyInformation(incomingResources.ontologyInformation);\n\n    //             // Append elements incomingResources to this.sequence.incomingLinks\n    //             Array.prototype.push.apply(this.sequence.resources[0].incomingLinks, incomingResources.resources);\n\n    //             // if callback is given, execute function with the amount of incoming resources as the parameter\n    //             if (callback !== undefined) {\n    //                 callback(incomingResources.resources.length);\n    //             }\n\n    //             this.loading = false;\n    //         },\n    //         (error: any) => {\n    //             console.error(error);\n    //             this.loading = false;\n    //         }\n    //     );\n    // }\n\n    openLink(id: string) {\n\n        this.loading = true;\n        // this.routeChanged.emit(id);\n        this._router.navigate(['/resource/' + encodeURIComponent(id)]);\n\n    }\n\n    refreshProperties(index: number) {\n        // console.log('from still-image-component: ', index);\n\n        // TODO: commented for knora-api-js-lib:\n        // this.currentResource = this.sequence.resources[0].incomingFileRepresentations[index];\n\n    }\n\n\n    toggleProps(show: boolean) {\n        this.allProps = !this.allProps;\n    }\n}\n"]}