UNPKG

@knora/action

Version:
207 lines 27 kB
import * as tslib_1 from "tslib"; import { Component, Input } from '@angular/core'; import { Location } from '@angular/common'; import { ActivatedRoute, Router } from '@angular/router'; // import defaultMsgs from '../../assets/i18n/statusMsg.json'; import { StatusMsg } from '../../assets/i18n/statusMsg'; /** * @ignore * Data type for messages */ export class KuiMessageData { } /** * Message component to handle notes, warning and error messages. * If you set the paramater `[short]="true"` it shows a smaller message. It can be used to give feedbacks in a form e.g. update process: show success or error message. * */ let MessageComponent = class MessageComponent { constructor(_router, _location, _activatedRoute, _status) { this._router = _router; this._location = _location; this._activatedRoute = _activatedRoute; this._status = _status; /** * Message type: KuiMessageData or ApiServiceError * * @param {KuiMessageData | ApiServiceError} message This type needs at least a status number (0-511). In this case, or if type is ApiServiceError, it takes the default status messages from the list of HTTP status codes (https://en.wikipedia.org/wiki/List_of_HTTP_status_codes) */ this.message = new KuiMessageData(); /** * Show short message only: it can be used in form to show if a post was successfull or not. * * @param {boolean} [short] */ this.short = false; /** * Show medium message: a message box without footnote and withou links. * * @param {boolean} [medium] */ this.medium = false; this.isLoading = true; this.showLinks = false; // disable message this.disable = false; /* * @ignore * default link list, which will be used in message content to give a user some possibilities * what he can do in the case of an error * */ this.links = { title: 'You have the following possibilities now', list: [ { label: 'go to the start page', route: '/', icon: 'keyboard_arrow_right' }, { label: 'try to login', route: '/login', icon: 'keyboard_arrow_right' }, { label: 'go back', route: '<--', icon: 'keyboard_arrow_left' } ] }; this.footnote = { text: 'If you think it\'s a mistake, please', team: { dasch: '<a href=\'https://discuss.dasch.swiss\' target=\'_blank\'> inform the DaSCH developer team.</a>' } }; } ngOnInit() { this.statusMsg = this._status.default; if (!this.message) { this._activatedRoute.data.subscribe((data) => { this.message.status = data.status; }); } this.message = this.setMessage(this.message); this.isLoading = false; } setMessage(msg) { const tmpMsg = {}; const s = msg.status === 0 ? 503 : msg.status; tmpMsg.status = s; tmpMsg.route = msg.route; tmpMsg.statusMsg = msg.statusMsg; tmpMsg.statusText = msg.statusText; tmpMsg.route = msg.route; tmpMsg.footnote = msg.footnote; switch (true) { case s > 0 && s < 300: // the message is a note tmpMsg.type = 'note'; tmpMsg.statusMsg = msg.statusMsg !== undefined ? msg.statusMsg : this.statusMsg[s].message; tmpMsg.statusText = msg.statusText !== undefined ? msg.statusText : this.statusMsg[s].description; // console.log('the message is a note'); break; case s >= 300 && s < 400: // the message is a warning tmpMsg.type = 'warning'; tmpMsg.statusMsg = msg.statusMsg !== undefined ? msg.statusMsg : this.statusMsg[s].message; tmpMsg.statusText = msg.statusText !== undefined ? msg.statusText : this.statusMsg[s].description; // console.log('the message is a warning'); break; case s >= 400 && s < 500: // the message is a client side (app) error // console.error('the message is a client side (app) error', s); tmpMsg.type = 'error'; tmpMsg.statusMsg = msg.statusMsg !== undefined ? msg.statusMsg : this.statusMsg[s].message; tmpMsg.statusText = msg.statusText !== undefined ? msg.statusText : this.statusMsg[s].description; tmpMsg.footnote = msg.footnote !== undefined ? msg.footnote : this.footnote.text + ' ' + this.footnote.team.dasch; this.showLinks = !this.medium; break; case s >= 500 && s < 600: // the message is a server side (api) error // console.error('the message is a server side (api) error'); tmpMsg.type = 'error'; tmpMsg.statusMsg = msg.statusMsg !== undefined ? msg.statusMsg : this.statusMsg[s].message; tmpMsg.statusText = msg.statusText !== undefined ? msg.statusText : this.statusMsg[s].description; tmpMsg.footnote = this.footnote.text + ' ' + this.footnote.team.dasch; this.showLinks = false; break; default: // no default configuration? break; } return tmpMsg; } goToLocation(route) { if (route === '<--') { this._location.back(); } else { this._router.navigate([route]); } } closeMessage() { this.disable = !this.disable; } }; MessageComponent.ctorParameters = () => [ { type: Router }, { type: Location }, { type: ActivatedRoute }, { type: StatusMsg } ]; tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", KuiMessageData) ], MessageComponent.prototype, "message", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Boolean) ], MessageComponent.prototype, "short", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", Boolean) ], MessageComponent.prototype, "medium", void 0); MessageComponent = tslib_1.__decorate([ Component({ selector: 'kui-message', template: "<mat-card *ngIf=\"!short\" class=\"fix-width kui-message\" [ngClass]=\"'kui-' + message?.type\">\n\n <mat-card-subtitle class=\"message-subtitle\">\n <span class=\"left\">{{message?.type | uppercase }} {{message?.status}} | {{message?.statusMsg}}</span>\n <!-- <mat-icon class=\"right\">{{message?.type}}</mat-icon> -->\n </mat-card-subtitle>\n\n <mat-card-title class=\"message-title\" [innerHtml]=\"message?.statusText\"></mat-card-title>\n\n <mat-card-content class=\"message-content\">\n <mat-list *ngIf=\"message?.route\">\n <mat-list-item>\n <a [href]=\"message?.route\" target=\"_blank\">\n &rarr; {{message?.route}}\n </a>\n </mat-list-item>\n </mat-list>\n\n <mat-list *ngIf=\"showLinks\">\n <p>{{links.title}}</p>\n <mat-list-item *ngFor=\"let item of links.list\" class=\"link\" (click)=\"goToLocation(item.route)\">\n <mat-icon mat-list-icon>{{item.icon}}</mat-icon>\n <p mat-line>{{item.label}}</p>\n </mat-list-item>\n </mat-list>\n\n </mat-card-content>\n\n <mat-card-footer *ngIf=\"!medium\" class=\"message-footnote\" [innerHtml]=\"message?.footnote\"></mat-card-footer>\n\n</mat-card>\n\n<mat-card *ngIf=\"short && !disable\" class=\"fix-width kui-short-message\" [ngClass]=\"'kui-' + message?.type\"\n (click)=\"closeMessage()\">\n\n <div class=\"kui-panel\">\n <span class=\"kui-short-message-text\">\n {{message?.statusText}}\n </span>\n <span class=\"fill-remaining-space\"></span>\n <!-- <button mat-icon-button (click)=\"closeMessage()\">\n <mat-icon>close</mat-icon>\n </button> -->\n </div>\n\n</mat-card>\n", styles: [".kui-panel{display:-webkit-box;display:flex;box-sizing:border-box;-webkit-box-orient:horizontal;-webkit-box-direction:normal;flex-direction:row;white-space:nowrap}.fill-remaining-space{flex-basis:auto;-webkit-box-flex:1;flex-grow:1;flex-shrink:1}.kui-error{background-color:rgba(244,67,54,.5)}.kui-warning{background-color:rgba(255,196,0,.5)}.kui-hint,.kui-note{background-color:rgba(0,105,92,.4)}.kui-error,.kui-hint,.kui-note,.kui-warning{margin:12px auto;max-width:640px}.kui-error .message-subtitle,.kui-hint .message-subtitle,.kui-note .message-subtitle,.kui-warning .message-subtitle{padding-bottom:12px}.kui-error .message-subtitle .left,.kui-hint .message-subtitle .left,.kui-note .message-subtitle .left,.kui-warning .message-subtitle .left{float:left;left:16px;position:absolute;text-align:left}.kui-error .message-subtitle .right,.kui-hint .message-subtitle .right,.kui-note .message-subtitle .right,.kui-warning .message-subtitle .right{float:right;right:16px;position:absolute;text-align:right}.kui-error .message-title,.kui-hint .message-title,.kui-note .message-title,.kui-warning .message-title{padding-top:12px}.kui-error .message-content,.kui-hint .message-content,.kui-note .message-content,.kui-warning .message-content{margin-bottom:48px;margin-top:48px}.kui-error .message-content .link,.kui-hint .message-content .link,.kui-note .message-content .link,.kui-warning .message-content .link{cursor:pointer}.kui-error .message-footnote,.kui-hint .message-footnote,.kui-note .message-footnote,.kui-warning .message-footnote{padding:24px}.kui-short-message .kui-short-message-text{font-weight:bolder;text-align:center}@media (max-width:576px){.kui-panel{white-space:normal}.kui-short-message .kui-short-message-text{text-align:left}}"] }), tslib_1.__metadata("design:paramtypes", [Router, Location, ActivatedRoute, StatusMsg]) ], MessageComponent); export { MessageComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.component.js","sourceRoot":"ng://@knora/action/","sources":["lib/message/message.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { Location } from '@angular/common';\nimport { ActivatedRoute, Router } from '@angular/router';\n\n// import defaultMsgs from '../../assets/i18n/statusMsg.json';\nimport { StatusMsg } from '../../assets/i18n/statusMsg';\n\n/**\n * @ignore\n * Data type for messages\n */\nexport class KuiMessageData {\n    status: number;\n    statusMsg?: string;\n    statusText?: string;\n    type?: string;\n    route?: string;\n    footnote?: string;\n    errorInfo?: string;\n    url?: string;\n}\n\n/**\n * Message component to handle notes, warning and error messages.\n * If you set the paramater `[short]=\"true\"` it shows a smaller message. It can be used to give feedbacks in a form e.g. update process: show success or error message.\n *\n */\n@Component({\n    selector: 'kui-message',\n    templateUrl: './message.component.html',\n    styleUrls: ['./message.component.scss']\n})\nexport class MessageComponent implements OnInit {\n    /**\n     * Message type: KuiMessageData or ApiServiceError\n     *\n     * @param  {KuiMessageData | ApiServiceError} message This type needs at least a status number (0-511). In this case, or if type is ApiServiceError, it takes the default status messages from the list of HTTP status codes (https://en.wikipedia.org/wiki/List_of_HTTP_status_codes)\n     */\n    @Input() message: KuiMessageData = new KuiMessageData();\n\n    /**\n     * Show short message only: it can be used in form to show if a post was successfull or not.\n     *\n     * @param  {boolean} [short]\n     */\n    @Input() short?: boolean = false;\n\n    /**\n     * Show medium message: a message box without footnote and withou links.\n     *\n     * @param  {boolean} [medium]\n     */\n    @Input() medium?: boolean = false;\n\n    //    message: MessageData;\n\n    // statusMsg: any = defaultMsgs;\n    statusMsg: any;\n\n    isLoading: boolean = true;\n\n    showLinks: boolean = false;\n\n    // disable message\n    disable: boolean = false;\n\n    /*\n     * @ignore\n     * default link list, which will be used in message content to give a user some possibilities\n     * what he can do in the case of an error\n     *\n     */\n    links: any = {\n        title: 'You have the following possibilities now',\n        list: [\n            {\n                label: 'go to the start page',\n                route: '/',\n                icon: 'keyboard_arrow_right'\n            },\n            {\n                label: 'try to login',\n                route: '/login',\n                icon: 'keyboard_arrow_right'\n            },\n            {\n                label: 'go back',\n                route: '<--',\n                icon: 'keyboard_arrow_left'\n            }\n        ]\n    };\n\n    footnote: any = {\n        text: 'If you think it\\'s a mistake, please',\n        team: {\n            dasch:\n                '<a href=\\'https://discuss.dasch.swiss\\' target=\\'_blank\\'> inform the DaSCH developer team.</a>'\n        }\n    };\n\n    constructor (\n        private _router: Router,\n        private _location: Location,\n        private _activatedRoute: ActivatedRoute,\n        private _status: StatusMsg\n    ) { }\n\n    ngOnInit() {\n        this.statusMsg = this._status.default;\n\n        if (!this.message) {\n            this._activatedRoute.data.subscribe((data: any) => {\n                this.message.status = data.status;\n            });\n        }\n\n        this.message = this.setMessage(this.message);\n        this.isLoading = false;\n\n    }\n\n    setMessage(msg: KuiMessageData) {\n        const tmpMsg: KuiMessageData = <KuiMessageData>{};\n\n        const s: number = msg.status === 0 ? 503 : msg.status;\n\n        tmpMsg.status = s;\n        tmpMsg.route = msg.route;\n        tmpMsg.statusMsg = msg.statusMsg;\n        tmpMsg.statusText = msg.statusText;\n        tmpMsg.route = msg.route;\n        tmpMsg.footnote = msg.footnote;\n\n        switch (true) {\n            case s > 0 && s < 300:\n                // the message is a note\n                tmpMsg.type = 'note';\n                tmpMsg.statusMsg =\n                    msg.statusMsg !== undefined\n                        ? msg.statusMsg\n                        : this.statusMsg[s].message;\n                tmpMsg.statusText =\n                    msg.statusText !== undefined\n                        ? msg.statusText\n                        : this.statusMsg[s].description;\n                // console.log('the message is a note');\n                break;\n            case s >= 300 && s < 400:\n                // the message is a warning\n                tmpMsg.type = 'warning';\n                tmpMsg.statusMsg =\n                    msg.statusMsg !== undefined\n                        ? msg.statusMsg\n                        : this.statusMsg[s].message;\n                tmpMsg.statusText =\n                    msg.statusText !== undefined\n                        ? msg.statusText\n                        : this.statusMsg[s].description;\n                // console.log('the message is a warning');\n\n                break;\n            case s >= 400 && s < 500:\n                // the message is a client side (app) error\n                // console.error('the message is a client side (app) error', s);\n                tmpMsg.type = 'error';\n                tmpMsg.statusMsg =\n                    msg.statusMsg !== undefined\n                        ? msg.statusMsg\n                        : this.statusMsg[s].message;\n                tmpMsg.statusText =\n                    msg.statusText !== undefined\n                        ? msg.statusText\n                        : this.statusMsg[s].description;\n                tmpMsg.footnote =\n                    msg.footnote !== undefined\n                        ? msg.footnote\n                        : this.footnote.text + ' ' + this.footnote.team.dasch;\n                this.showLinks = !this.medium;\n\n                break;\n            case s >= 500 && s < 600:\n                // the message is a server side (api) error\n                // console.error('the message is a server side (api) error');\n                tmpMsg.type = 'error';\n                tmpMsg.statusMsg =\n                    msg.statusMsg !== undefined\n                        ? msg.statusMsg\n                        : this.statusMsg[s].message;\n                tmpMsg.statusText =\n                    msg.statusText !== undefined\n                        ? msg.statusText\n                        : this.statusMsg[s].description;\n                tmpMsg.footnote =\n                    this.footnote.text + ' ' + this.footnote.team.dasch;\n                this.showLinks = false;\n                break;\n            default:\n                // no default configuration?\n                break;\n        }\n\n        return tmpMsg;\n    }\n\n    goToLocation(route: string) {\n        if (route === '<--') {\n            this._location.back();\n        } else {\n            this._router.navigate([route]);\n        }\n    }\n\n    closeMessage() {\n        this.disable = !this.disable;\n    }\n}\n"]}