UNPKG

@harbor/ui

Version:

Harbor shared UI components based on Clarity and Angular6

200 lines (199 loc) 21.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, Input } from '@angular/core'; import { AccessLogService, RequestQueryParams } from '../service/index'; import { ErrorHandler } from '../error-handler/index'; import { toPromise, CustomComparator } from '../utils'; import { DEFAULT_PAGE_SIZE, calculatePage, doFiltering, doSorting } from '../utils'; export class RecentLogComponent { /** * @param {?} logService * @param {?} errorHandler */ constructor(logService, errorHandler) { this.logService = logService; this.errorHandler = errorHandler; this.recentLogs = []; this.loading = true; this.defaultFilter = "username"; this.withTitle = false; this.pageSize = DEFAULT_PAGE_SIZE; this.currentPage = 1; this.currentPagePvt = 0; this.opTimeComparator = new CustomComparator('op_time', 'date'); } /** * @return {?} */ ngOnInit() { } /** * @return {?} */ get totalCount() { return this.logsCache && this.logsCache.metadata ? this.logsCache.metadata.xTotalCount : 0; } /** * @return {?} */ get inProgress() { return this.loading; } /** * @param {?} terms * @return {?} */ doFilter(terms) { if (!terms) { return; } this.currentTerm = terms.trim(); // Trigger data loading and start from first page this.loading = true; this.currentPage = 1; if (this.currentPagePvt === 1) { /** @type {?} */ let st = this.currentState; if (!st) { st = { page: {} }; } st.page.from = 0; st.page.to = this.pageSize - 1; st.page.size = this.pageSize; this.currentPagePvt = 0; // Reset pvt this.load(st); } } /** * @return {?} */ refresh() { this.doFilter(""); } /** * @param {?} isOpen * @return {?} */ openFilter(isOpen) { if (isOpen) { this.isOpenFilterTag = true; } else { this.isOpenFilterTag = false; } } /** * @param {?} $event * @return {?} */ selectFilterKey($event) { this.defaultFilter = $event['target'].value; this.doFilter(this.currentTerm); } /** * @param {?} state * @return {?} */ load(state) { // Keep it for future filter this.currentState = state; /** @type {?} */ let pageNumber = calculatePage(state); if (pageNumber !== this.currentPagePvt) { /** @type {?} */ let params = new RequestQueryParams(); params.set("page", '' + pageNumber); params.set("page_size", '' + this.pageSize); if (this.currentTerm && this.currentTerm !== "") { params.set(this.defaultFilter, this.currentTerm); } this.loading = true; toPromise(this.logService.getRecentLogs(params)) .then(response => { this.logsCache = response; // Keep the data this.recentLogs = this.logsCache.data.filter(log => log.username !== ""); // To display // Do customized filter this.recentLogs = doFiltering(this.recentLogs, state); // Do customized sorting this.recentLogs = doSorting(this.recentLogs, state); this.currentPagePvt = pageNumber; this.loading = false; }) .catch(error => { this.loading = false; this.errorHandler.error(error); }); } else { // Column sorting and filtering this.recentLogs = this.logsCache.data.filter(log => log.username !== ""); // Reset data // Do customized filter this.recentLogs = doFiltering(this.recentLogs, state); // Do customized sorting this.recentLogs = doSorting(this.recentLogs, state); } } /** * @param {?} terms * @param {?} log * @return {?} */ isMatched(terms, log) { /** @type {?} */ let reg = new RegExp('.*' + terms + '.*', 'i'); return reg.test(log.username) || reg.test(log.repo_name) || reg.test(log.operation) || reg.test(log.repo_tag); } } RecentLogComponent.decorators = [ { type: Component, args: [{ selector: 'hbr-log', template: "<div>\n <h2 class=\"h2-log-override\" *ngIf=\"withTitle\">{{'SIDE_NAV.LOGS' | translate}}</h2>\n <div class=\"row flex-items-xs-between flex-items-xs-bottom\">\n <div></div>\n <div class=\"action-head-pos rightPos\">\n <div class=\"select filterTag\" [hidden]=\"!isOpenFilterTag\">\n <select id=\"selectKey\" (change)=\"selectFilterKey($event)\">\n <option value=\"username\">{{\"AUDIT_LOG.USERNAME\" | translate | lowercase}}</option>\n <option value=\"repository\">{{\"CONFIG.REPOSITORY\" | translate | lowercase}}</option>\n <option value=\"tag\">{{\"REPOSITORY.TAG\" | translate | lowercase}}</option>\n <option value=\"operation\">{{\"AUDIT_LOG.OPERATION\" | translate | lowercase}}</option>\n </select>\n </div>\n <hbr-filter [withDivider]=\"true\" filterPlaceholder='{{\"AUDIT_LOG.FILTER_PLACEHOLDER\" | translate}}' (filterEvt)=\"doFilter($event)\"\n (openFlag)=\"openFilter($event)\" [currentValue]=\"currentTerm\"></hbr-filter>\n <span (click)=\"refresh()\" class=\"refresh-btn\">\n <clr-icon shape=\"refresh\" [hidden]=\"inProgress\" ng-disabled=\"inProgress\"></clr-icon>\n <span class=\"spinner spinner-inline\" [hidden]=\"!inProgress\"></span>\n </span>\n </div>\n </div>\n <div>\n <clr-datagrid (clrDgRefresh)=\"load($event)\" [clrDgLoading]=\"loading\">\n <clr-dg-column [clrDgField]=\"'username'\">{{'AUDIT_LOG.USERNAME' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'repo_name'\">{{'AUDIT_LOG.REPOSITORY_NAME' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'repo_tag'\">{{'AUDIT_LOG.TAGS' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgField]=\"'operation'\">{{'AUDIT_LOG.OPERATION' | translate}}</clr-dg-column>\n <clr-dg-column [clrDgSortBy]=\"opTimeComparator\">{{'AUDIT_LOG.TIMESTAMP' | translate}}</clr-dg-column>\n <clr-dg-placeholder>We couldn't find any logs!</clr-dg-placeholder>\n <clr-dg-row *ngFor=\"let l of recentLogs\">\n <clr-dg-cell>{{l.username}}</clr-dg-cell>\n <clr-dg-cell>{{l.repo_name}}</clr-dg-cell>\n <clr-dg-cell>{{l.repo_tag}}</clr-dg-cell>\n <clr-dg-cell>{{l.operation}}</clr-dg-cell>\n <clr-dg-cell>{{l.op_time | date: 'short'}}</clr-dg-cell>\n </clr-dg-row>\n <clr-dg-footer>\n {{pagination.firstItem + 1}} - {{pagination.lastItem + 1}} {{'AUDIT_LOG.OF' | translate}} {{pagination.totalItems}} {{'AUDIT_LOG.ITEMS'\n | translate}}\n <clr-dg-pagination #pagination [(clrDgPage)]=\"currentPage\" [clrDgPageSize]=\"pageSize\" [clrDgTotalItems]=\"totalCount\"></clr-dg-pagination>\n </clr-dg-footer>\n </clr-datagrid>\n </div>\n</div>", styles: [".h2-log-override{margin-top:0!important}.action-head-pos{padding-right:18px;height:24px}.refresh-btn{cursor:pointer}.refresh-btn:hover{color:#007cbb}.custom-lines-button{padding:0!important;min-width:25px!important}.lines-button-toggole{font-size:16px;text-decoration:underline}.log-select{width:130px;display:inline-block;top:1px}.item-divider{height:24px;display:inline-block;width:1px;background-color:#ccc;opacity:.55;margin-left:12px;top:8px;position:relative}.rightPos{position:absolute;z-index:100;right:35px;margin-top:4px}.filterTag{float:left;margin-top:8px}"] }] } ]; /** @nocollapse */ RecentLogComponent.ctorParameters = () => [ { type: AccessLogService }, { type: ErrorHandler } ]; RecentLogComponent.propDecorators = { withTitle: [{ type: Input }] }; if (false) { /** @type {?} */ RecentLogComponent.prototype.recentLogs; /** @type {?} */ RecentLogComponent.prototype.logsCache; /** @type {?} */ RecentLogComponent.prototype.loading; /** @type {?} */ RecentLogComponent.prototype.currentTerm; /** @type {?} */ RecentLogComponent.prototype.defaultFilter; /** @type {?} */ RecentLogComponent.prototype.isOpenFilterTag; /** @type {?} */ RecentLogComponent.prototype.withTitle; /** @type {?} */ RecentLogComponent.prototype.pageSize; /** @type {?} */ RecentLogComponent.prototype.currentPage; /** @type {?} */ RecentLogComponent.prototype.currentPagePvt; /** @type {?} */ RecentLogComponent.prototype.currentState; /** @type {?} */ RecentLogComponent.prototype.opTimeComparator; /** @type {?} */ RecentLogComponent.prototype.logService; /** @type {?} */ RecentLogComponent.prototype.errorHandler; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recent-log.component.js","sourceRoot":"ng://@harbor/ui/","sources":["src/log/recent-log.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) 2017 VMware, Inc. All Rights Reserved.\n//\n// Licensed under the Apache License, Version 2.0 (the \"License\");\n// you may not use this file except in compliance with the License.\n// You may obtain a copy of the License at\n//\n//    http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing, software\n// distributed under the License is distributed on an \"AS IS\" BASIS,\n// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n// See the License for the specific language governing permissions and\n// limitations under the License.\nimport { Component, OnInit, Input } from '@angular/core';\nimport { Comparator, State } from '@clr/angular';\n\nimport {\n    AccessLogService,\n    AccessLog,\n    AccessLogItem,\n    RequestQueryParams\n} from '../service/index';\nimport { ErrorHandler } from '../error-handler/index';\nimport { toPromise, CustomComparator } from '../utils';\nimport {\n    DEFAULT_PAGE_SIZE,\n    calculatePage,\n    doFiltering,\n    doSorting\n} from '../utils';\n\n@Component({\n    selector: 'hbr-log',\n    templateUrl: './recent-log.component.html',\n    styleUrls: ['./recent-log.component.scss']\n})\n\nexport class RecentLogComponent implements OnInit {\n    recentLogs: AccessLogItem[] = [];\n    logsCache: AccessLog;\n    loading: boolean = true;\n    currentTerm: string;\n    defaultFilter = \"username\";\n    isOpenFilterTag: boolean;\n    @Input() withTitle: boolean = false;\n\n    pageSize: number = DEFAULT_PAGE_SIZE;\n    currentPage: number = 1; // Double bound to pagination component\n    currentPagePvt: number = 0; // Used to confirm whether page is changed\n    currentState: State;\n\n    opTimeComparator: Comparator<AccessLogItem> = new CustomComparator<AccessLogItem>('op_time', 'date');\n\n    constructor(\n        private logService: AccessLogService,\n        private errorHandler: ErrorHandler) { }\n\n    ngOnInit(): void {\n    }\n\n    public get totalCount(): number {\n        return this.logsCache && this.logsCache.metadata ? this.logsCache.metadata.xTotalCount : 0;\n    }\n\n    public get inProgress(): boolean {\n        return this.loading;\n    }\n\n    public doFilter(terms: string): void {\n        if (!terms) {\n            return;\n        }\n        this.currentTerm = terms.trim();\n        // Trigger data loading and start from first page\n        this.loading = true;\n        this.currentPage = 1;\n        if (this.currentPagePvt === 1) {\n            // Force reloading\n            let st: State = this.currentState;\n            if (!st) {\n                st = {\n                    page: {}\n                };\n            }\n            st.page.from = 0;\n            st.page.to = this.pageSize - 1;\n            st.page.size = this.pageSize;\n\n            this.currentPagePvt = 0; // Reset pvt\n\n            this.load(st);\n        }\n    }\n\n    public refresh(): void {\n        this.doFilter(\"\");\n    }\n\n    openFilter(isOpen: boolean): void {\n        if (isOpen) {\n            this.isOpenFilterTag = true;\n        } else {\n            this.isOpenFilterTag = false;\n        }\n    }\n\n    selectFilterKey($event: any): void {\n        this.defaultFilter = $event['target'].value;\n        this.doFilter(this.currentTerm);\n    }\n\n    load(state: State) {\n        // Keep it for future filter\n        this.currentState = state;\n\n        let pageNumber: number = calculatePage(state);\n        if (pageNumber !== this.currentPagePvt) {\n            // load data\n            let params: RequestQueryParams = new RequestQueryParams();\n            params.set(\"page\", '' + pageNumber);\n            params.set(\"page_size\", '' + this.pageSize);\n            if (this.currentTerm && this.currentTerm !== \"\") {\n                params.set(this.defaultFilter, this.currentTerm);\n            }\n\n            this.loading = true;\n            toPromise<AccessLog>(this.logService.getRecentLogs(params))\n                .then(response => {\n                    this.logsCache = response; // Keep the data\n                    this.recentLogs = this.logsCache.data.filter(log => log.username !== \"\"); // To display\n\n                    // Do customized filter\n                    this.recentLogs = doFiltering<AccessLogItem>(this.recentLogs, state);\n\n                    // Do customized sorting\n                    this.recentLogs = doSorting<AccessLogItem>(this.recentLogs, state);\n\n                    this.currentPagePvt = pageNumber;\n\n                    this.loading = false;\n                })\n                .catch(error => {\n                    this.loading = false;\n                    this.errorHandler.error(error);\n                });\n        } else {\n            // Column sorting and filtering\n\n            this.recentLogs = this.logsCache.data.filter(log => log.username !== \"\"); // Reset data\n\n            // Do customized filter\n            this.recentLogs = doFiltering<AccessLogItem>(this.recentLogs, state);\n\n            // Do customized sorting\n            this.recentLogs = doSorting<AccessLogItem>(this.recentLogs, state);\n        }\n    }\n\n    isMatched(terms: string, log: AccessLogItem): boolean {\n        let reg = new RegExp('.*' + terms + '.*', 'i');\n        return reg.test(log.username) ||\n            reg.test(log.repo_name) ||\n            reg.test(log.operation) ||\n            reg.test(log.repo_tag);\n    }\n}\n"]}