asap-feed-beta 12.2.1-dev.1 → 12.2.1-dev.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/asap-feed-beta.metadata.json +1 -1
- package/bundles/asap-feed-beta.umd.js +1 -1
- package/bundles/asap-feed-beta.umd.js.map +1 -1
- package/bundles/asap-feed-beta.umd.min.js +1 -1
- package/bundles/asap-feed-beta.umd.min.js.map +1 -1
- package/esm2015/lib/feed-item/feed-item.component.js +2 -2
- package/esm5/lib/feed-item/feed-item.component.js +2 -2
- package/fesm2015/asap-feed-beta.js +1 -1
- package/fesm2015/asap-feed-beta.js.map +1 -1
- package/fesm5/asap-feed-beta.js +1 -1
- package/fesm5/asap-feed-beta.js.map +1 -1
- package/package.json +1 -1
|
@@ -286,7 +286,7 @@ export class FeedItemComponent {
|
|
|
286
286
|
FeedItemComponent.decorators = [
|
|
287
287
|
{ type: Component, args: [{
|
|
288
288
|
selector: 'app-feed-item',
|
|
289
|
-
template: "<ng-container *ngIf=\"item && item.status && !item.deleted\">\r\n <mat-card #visibleControl class=\"feed-card\" id=\"{{ item.id +'#'+ item.type}}\">\r\n <mat-card-header class=\"feed-header ml-2\">\r\n <popover-content #myPopover placement=\"auto right\" [closeOnClickOutside]=\"false\" [closeOnMouseOutside]=\"false\"\r\n [animation]=\"true\">\r\n <div class='minibio'>\r\n <img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\" alt=\"{{ item?.user_info?.name }}\">\r\n <div class=\"info\"><b>{{ item?.user_info?.name }}</b><br />\r\n <!-- <span class=\"location\"><i class=\"icon fa fa-globe\" aria-hidden=\"true\"></i> Fortaleza/CE</span> -->\r\n </div>\r\n </div>\r\n </popover-content>\r\n <div mat-card-avatar>\r\n <a [routerLink]=\"['/profile',item.user_info?.id]\"><img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n class=\"feed-avatar mr-1\" (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\"\r\n alt=\"{{ item?.user_info?.name }}\" [popover]=\"myPopover\" [popoverOnHover]=\"true\"></a>\r\n </div>\r\n\r\n <mat-card-title>\r\n <h4 class=\"ml-2\"><b><a [routerLink]=\"['/profile',item.user_info?.id]\">{{ item?.user_info?.name }}</a> <i\r\n *ngIf=\"item?.channel_id\" class=\"material-icons text-primary\" matTooltip=\"Este \u00E9 um post Institucional\"\r\n matTooltipClass=\"tooltip-primary\">done_all</i></b>\r\n </h4>\r\n <p class=\"ml-2\"> {{ 'SharedPublication' | translate }}\r\n <!-- <a [routerLink]=\"['/portal',item.id]\">{{ item?.updated_at | amTimeAgo }}</a></p> -->\r\n <a [routerLink]=\"['/portal',item.id]\">{{ item?.updated_at | amCalendar | amDateFormat: 'DD/MM/YYYY' }}</a>\r\n </mat-card-title>\r\n\r\n <ng-container *ngIf=\"global.loggedUser()\">\r\n <div class=\"feed-buttom-option\" *ngIf=\"item.user_info.id === global.loggedUser().id\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\" [disabled]=\"!item.status\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"onEditItem()\" [disabled]=\"!item.status\">\r\n <mat-icon>create</mat-icon>\r\n <span>{{ 'Edit' | translate }}</span>\r\n </button>\r\n <button mat-menu-item (click)=\"onRemoveItem(item)\" [disabled]=\"!item.status\">\r\n <mat-icon>delete</mat-icon>\r\n <span>{{ 'Remove' | translate }}</span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n <div *ngIf=\"item.isHighlighted\" matTooltip=\"Post destacado\" class=\"feed-buttom-option pinned-feed\">\r\n <i class=\"fa fa-thumb-tack fa-lg\"></i>\r\n </div>\r\n </ng-container>\r\n\r\n </mat-card-header>\r\n\r\n <ng-container *ngIf=\"item.type != 'announce'\">\r\n <!-- <code>{{item.additional_data | json}}</code> -->\r\n <ng-container *ngIf=\"!(item.files && item.files.length > 0)\">\r\n <div class=\"card card-file mt-0 pointer\">\r\n <!-- <div class=\"card-cover\"> -->\r\n <ng-container *ngIf=\"item.additional_data && item.additional_data.image\">\r\n <img style=\"display: none;\" [src]=\"item.additional_data.image\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"imageLoaded\">\r\n <img class=\"bg-mat-card\" [src]=\"item.additional_data.image\">\r\n <img mat-card-image [src]=\"item.additional_data.image\">\r\n </div>\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"!imageLoaded\">\r\n <img mat-card-image [src]=\"'assets/img/background-blur-' + blurBackgroundIndex + '.png'\">\r\n </div>\r\n </ng-container>\r\n <!-- </div> -->\r\n <a *ngIf=\"item.additional_data && item.additional_data.file_id\"\r\n [routerLink]=\"['/channel/files/' + item.channel_id +'/'+ item.additional_data.file_id]\" class=\"circle\">\r\n <i class=\"fa fa-file-text-o\"></i>\r\n </a>\r\n <div *ngIf=\"item.additional_data && item.additional_data.description\" class=\"card-content\">\r\n <div class=\"clearfix\"></div>\r\n <p class=\"description m-3\" [innerHTML]=\"linkify(item.additional_data.description)\"></p>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"item.files && item.files.length > 0\">\r\n\r\n <ng-container *ngIf=\"item.files.length === 1\">\r\n <ng-container *ngFor=\"let file of item.files\">\r\n <ng-container *ngIf=\"file.type == 'image'\">\r\n\r\n <img style=\"display: none;\" [src]=\"file.name || file.url\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"imageLoaded\">\r\n <img class=\"bg-mat-card\" [src]=\"file.name || file.url\">\r\n <img mat-card-image [src]=\"file.name || file.url\">\r\n </div>\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"!imageLoaded\">\r\n <img mat-card-image [src]=\"'assets/img/background-blur-' + blurBackgroundIndex + '.png'\">\r\n </div>\r\n\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'video'\">\r\n <div class=\"carousel custom-carrousel\">\r\n <div class=\"content\">\r\n <div class=\"item\">\r\n <div class=\"video-overlay cloudinary-true\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\"></div>\r\n\r\n <div class=\"video-overlay youtube-true\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\"></div>\r\n\r\n <div class=\"video-overlay not-cloudinary-youtube\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\"></div>\r\n\r\n <video attr.type='stream' #videoPlayer *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video not-cloudinary-youtube\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer *ngIf=\"file.isCloudinary == true\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video cloudinary-true\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube == true\">\r\n <iframe attr.type='youtube' #videoPlayer [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'pdf' || file.type == 'txt'\">\r\n <div class=\"container-mat-card px-3\">\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id + '/' + file.file_id]\" class=\"w-100\">\r\n\r\n <div class=\"card card-file mt-0 pointer\">\r\n <div class=\"card-cover\">\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id +'/'+ file.file_id]\">\r\n <ng-container *ngIf=\"file.image\">\r\n <img [src]=\"file.image\" alt=\"\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!file.image || file.image == null\">\r\n <h4 class=\"title\" [innerHTML]=\"linkify(file.title)\"></h4>\r\n </ng-container>\r\n </a>\r\n </div>\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id +'/'+ file.file_id]\" class=\"circle\">\r\n <i *ngIf=\"file.type == 'pdf'\" class=\"fa fa-file-pdf-o\"></i>\r\n <i *ngIf=\"file.type == 'txt'\" class=\"fa fa-file-text-o\"></i>\r\n </a>\r\n <div class=\"card-content\">\r\n <div class=\"clearfix\"></div>\r\n <p class=\"description mb-3\" [innerHTML]=\"linkify(file.description)\"></p>\r\n </div>\r\n </div>\r\n\r\n </a>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'embed'\">\r\n <iframe class=\"video\" style=\"height: 280px; width: 100%;margin-top: 15px;\"\r\n [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\" allowfullscreen></iframe>\r\n </ng-container>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngIf=\"item.files.length > 1\">\r\n\r\n <!-- Carrosel de Imavens e v\u00EDdeos -->\r\n\r\n <div class=\"swiper-stage\">\r\n <swiper [config]=\"global.swiperConfig(false)\">\r\n <div swiperSlide *ngFor=\"let file of item.files; let i = index\">\r\n <div class=\"swiper-carousel-custom\">\r\n\r\n <!-- Imagem -->\r\n\r\n <ng-container *ngIf=\"file.type === 'image'\">\r\n <ng-container *ngIf=\"file.url\">\r\n <div class=\"swiper-container-img\">\r\n <div class=\"swiper-bg-blur\" [style.backgroundImage]=\"'url('+file.url+')'\">\r\n </div>\r\n <img class=\"img\" [src]=\"file.url\" alt=\"\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.name\">\r\n <div class=\"swiper-container-img\" [style.backgroundImage]=\"'url('+file.name+')'\">\r\n <div class=\"swiper-bg-blur\" [style.backgroundImage]=\"'url('+file.name+')'\">\r\n </div>\r\n <img class=\"img\" [src]=\"file.name\" alt=\"\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <!-- Video -->\r\n\r\n <ng-container *ngIf=\"file.type === 'video'\">\r\n\r\n <ng-container>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <video attr.type='stream' #videoPlayer *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\"\r\n width=\"100%\" controls=\"false\" preload=\"metadata\" poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer *ngIf=\"file.isCloudinary == true\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\"\r\n width=\"100%\" controls=\"false\" preload=\"metadata\" poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube == true\">\r\n <iframe attr.type='youtube' #videoPlayer [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n <!-- Verifica se o V\u00EDdeo \u00E9 a primeira posi\u00E7\u00E3o do Slide -->\r\n <!-- <ng-container *ngIf=\" i === 0\">\r\n\r\n <div class=\"video-overlay\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <video attr.type='stream' #videoPlayer\r\n *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer\r\n *ngIf=\"file.isCloudinary === true\" (click)=\"playVideo($event)\"\r\n (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\" width=\"100%\"\r\n controls=\"false\" preload=\"metadata\" poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube === true\">\r\n <iframe attr.type='youtube' #videoPlayer\r\n [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </ng-container> -->\r\n\r\n </ng-container>\r\n\r\n <ng-template #infiniteContainer></ng-template>\r\n </div>\r\n </div>\r\n </swiper>\r\n </div>\r\n\r\n <!-- Fim Carrosel de Imagens e V\u00EDdeos -->\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"item.type == 'announce'\">\r\n <div class=\"ribbon ribbon-top-right\"><span>An\u00FAncio</span></div>\r\n\r\n <div class=\"swiper-stage\">\r\n <swiper [config]=\"global.swiperConfig(false)\">\r\n <div swiperSlide *ngFor=\"let file of item.files; let i = index\">\r\n <div class=\"swiper-carousel-custom\">\r\n <ng-container *ngIf=\"file.type === 'image'\">\r\n <div class=\"img\" [style.backgroundImage]=\"'url('+file.name+')'\" *ngIf=\"file.name\">\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type === 'video'\">\r\n\r\n <ng-container>\r\n\r\n <div class=\"video-overlay\" [style.background-image]=\"file.url | stream:'styleThumbUrl'\">\r\n </div>\r\n\r\n <video class=\"video\" width=\"100%\" preload=\"metadata\" poster=\"{{ file.url | stream:'thumb' }}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n </ng-container>\r\n\r\n <!-- Verifica se o V\u00EDdeo \u00E9 a primeira posi\u00E7\u00E3o do Slide -->\r\n <!-- <ng-container *ngIf=\" i === 0\">\r\n\r\n <div class=\"video-overlay\"\r\n [style.background-image]=\"file.url | stream:'styleThumbUrl'\">\r\n </div>\r\n\r\n <video class=\"video\" width=\"100%\" preload=\"metadata\"\r\n poster=\"{{ file.url | stream:'thumb' }}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n </ng-container> -->\r\n\r\n </ng-container>\r\n </div>\r\n </div>\r\n <ng-template #infiniteContainer></ng-template>\r\n </swiper>\r\n </div>\r\n\r\n <div class=\"pull-right mt-3\" [routerLink]=\"['/market/product/', item.product.id]\">\r\n <button class=\"btn btn-primary\">\r\n <i class=\"fa fa-shopping-cart\"></i>\r\n {{ preConvertNumber(item.product.valorDe) | currency:'BRL':true}} -\r\n {{ preConvertNumber(item.product.valorAte) | currency:'BRL':true}}\r\n </button>\r\n </div>\r\n <p *ngIf=\"item?.product?.data?.descr\" [innerHTML]=\"item.product.descr\"></p>\r\n </ng-container>\r\n\r\n <div class=\"mat-card-content\">\r\n <span class=\"ws-pre-wrap post-text mt-1 mb-4\" [innerHTML]=\"linkify(item.title)\"></span>\r\n <feed-actions [item]=\"item\"></feed-actions>\r\n <feed-comments [feed_id]=\"item.id\" [user]=\"item.user_info\"></feed-comments>\r\n </div>\r\n\r\n </mat-card>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"item && !item.status\">\r\n <ng-container *ngIf=\"global.loggedUser()\">\r\n <ng-container *ngIf=\"item.user_info.id === global.loggedUser().id\">\r\n <ng-container *ngIf=\"item\">\r\n <mat-card #visibleControl class=\"feed-card\" id=\"{{ item.id +'#'+ item.type}}\">\r\n <mat-card-header class=\"feed-header ml-2\">\r\n <div mat-card-avatar>\r\n <img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n class=\"feed-avatar\" (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\"\r\n alt=\"{{ item?.user_info?.name }}\">\r\n </div>\r\n <mat-card-title>\r\n <h4><b>{{ item?.user_info?.name }}</b></h4>\r\n <!-- <p> {{ 'SharedPublication' | translate }} <a>{{ item?.updated_at | amTimeAgo }}</a></p> -->\r\n <p> {{ 'SharedAPostOn' | translate }}\r\n <a>{{ item?.updated_at | amCalendar | amDateFormat: 'DD/MM/YYYY' }}</a>\r\n </p>\r\n </mat-card-title>\r\n\r\n <div class=\"feed-buttom-option\" *ngIf=\"false\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"false\">\r\n <mat-icon>create</mat-icon>\r\n <span>{{ 'Edit' | translate }}</span>\r\n </button>\r\n <button mat-menu-item (click)=\"false\">\r\n <mat-icon>delete</mat-icon>\r\n <span>{{ 'Remove' | translate }}</span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n\r\n </mat-card-header>\r\n\r\n <ng-container>\r\n <div class=\"col-sm-12 mx-auto text-center post-processing-section\">\r\n <img src=\"https://image.flaticon.com/icons/svg/2654/2654464.svg\" width=\"30%\">\r\n <h4>Estamos processando os dados do seu Post!</h4>\r\n <p>No momento ele est\u00E1 vis\u00EDvel apenas para voc\u00EA, mas logo estar\u00E1 dispon\u00EDvel para todos!</p>\r\n </div>\r\n </ng-container>\r\n\r\n <span class=\"ws-pre-wrap post-text mt-1 mb-4\" [innerHTML]=\"linkify(item.title)\"></span>\r\n <feed-actions prefix=\"prefix\" [item]=\"item\"></feed-actions>\r\n <feed-comments prefix=\"prefix\" [feed_id]=\"item.id\" [user]=\"item.user_info\"></feed-comments>\r\n </mat-card>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>\r\n",
|
|
289
|
+
template: "<ng-container *ngIf=\"item && item.status && !item.deleted\">\r\n <mat-card #visibleControl class=\"feed-card\" id=\"{{ item.id +'#'+ item.type}}\">\r\n <mat-card-header class=\"feed-header ml-2\">\r\n <popover-content #myPopover placement=\"auto right\" [closeOnClickOutside]=\"false\" [closeOnMouseOutside]=\"false\"\r\n [animation]=\"true\">\r\n <div class='minibio'>\r\n <img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\" alt=\"{{ item?.user_info?.name }}\">\r\n <div class=\"info\"><b>{{ item?.user_info?.name }}</b><br />\r\n <!-- <span class=\"location\"><i class=\"icon fa fa-globe\" aria-hidden=\"true\"></i> Fortaleza/CE</span> -->\r\n </div>\r\n </div>\r\n </popover-content>\r\n <div mat-card-avatar>\r\n <a [routerLink]=\"['/profile',item.user_info?.id]\"><img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n class=\"feed-avatar mr-1\" (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\"\r\n alt=\"{{ item?.user_info?.name }}\" [popover]=\"myPopover\" [popoverOnHover]=\"true\"></a>\r\n </div>\r\n\r\n <mat-card-title>\r\n <h4 class=\"ml-2\"><b><a [routerLink]=\"['/profile',item.user_info?.id]\">{{ item?.user_info?.name }}</a> <i\r\n *ngIf=\"item?.channel_id\" class=\"material-icons text-primary\" matTooltip=\"Este \u00E9 um post Institucional\"\r\n matTooltipClass=\"tooltip-primary\">done_all</i></b>\r\n </h4>\r\n <p class=\"ml-2\"> {{ 'SharedAPostOn' | translate }}\r\n <!-- <a [routerLink]=\"['/portal',item.id]\">{{ item?.updated_at | amTimeAgo }}</a></p> -->\r\n <a [routerLink]=\"['/portal',item.id]\">{{ item?.updated_at | amCalendar | amDateFormat: 'DD/MM/YYYY' }}</a>\r\n </mat-card-title>\r\n\r\n <ng-container *ngIf=\"global.loggedUser()\">\r\n <div class=\"feed-buttom-option\" *ngIf=\"item.user_info.id === global.loggedUser().id\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\" [disabled]=\"!item.status\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"onEditItem()\" [disabled]=\"!item.status\">\r\n <mat-icon>create</mat-icon>\r\n <span>{{ 'Edit' | translate }}</span>\r\n </button>\r\n <button mat-menu-item (click)=\"onRemoveItem(item)\" [disabled]=\"!item.status\">\r\n <mat-icon>delete</mat-icon>\r\n <span>{{ 'Remove' | translate }}</span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n <div *ngIf=\"item.isHighlighted\" matTooltip=\"Post destacado\" class=\"feed-buttom-option pinned-feed\">\r\n <i class=\"fa fa-thumb-tack fa-lg\"></i>\r\n </div>\r\n </ng-container>\r\n\r\n </mat-card-header>\r\n\r\n <ng-container *ngIf=\"item.type != 'announce'\">\r\n <!-- <code>{{item.additional_data | json}}</code> -->\r\n <ng-container *ngIf=\"!(item.files && item.files.length > 0)\">\r\n <div class=\"card card-file mt-0 pointer\">\r\n <!-- <div class=\"card-cover\"> -->\r\n <ng-container *ngIf=\"item.additional_data && item.additional_data.image\">\r\n <img style=\"display: none;\" [src]=\"item.additional_data.image\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"imageLoaded\">\r\n <img class=\"bg-mat-card\" [src]=\"item.additional_data.image\">\r\n <img mat-card-image [src]=\"item.additional_data.image\">\r\n </div>\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"!imageLoaded\">\r\n <img mat-card-image [src]=\"'assets/img/background-blur-' + blurBackgroundIndex + '.png'\">\r\n </div>\r\n </ng-container>\r\n <!-- </div> -->\r\n <a *ngIf=\"item.additional_data && item.additional_data.file_id\"\r\n [routerLink]=\"['/channel/files/' + item.channel_id +'/'+ item.additional_data.file_id]\" class=\"circle\">\r\n <i class=\"fa fa-file-text-o\"></i>\r\n </a>\r\n <div *ngIf=\"item.additional_data && item.additional_data.description\" class=\"card-content\">\r\n <div class=\"clearfix\"></div>\r\n <p class=\"description m-3\" [innerHTML]=\"linkify(item.additional_data.description)\"></p>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"item.files && item.files.length > 0\">\r\n\r\n <ng-container *ngIf=\"item.files.length === 1\">\r\n <ng-container *ngFor=\"let file of item.files\">\r\n <ng-container *ngIf=\"file.type == 'image'\">\r\n\r\n <img style=\"display: none;\" [src]=\"file.name || file.url\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"imageLoaded\">\r\n <img class=\"bg-mat-card\" [src]=\"file.name || file.url\">\r\n <img mat-card-image [src]=\"file.name || file.url\">\r\n </div>\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"!imageLoaded\">\r\n <img mat-card-image [src]=\"'assets/img/background-blur-' + blurBackgroundIndex + '.png'\">\r\n </div>\r\n\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'video'\">\r\n <div class=\"carousel custom-carrousel\">\r\n <div class=\"content\">\r\n <div class=\"item\">\r\n <div class=\"video-overlay cloudinary-true\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\"></div>\r\n\r\n <div class=\"video-overlay youtube-true\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\"></div>\r\n\r\n <div class=\"video-overlay not-cloudinary-youtube\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\"></div>\r\n\r\n <video attr.type='stream' #videoPlayer *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video not-cloudinary-youtube\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer *ngIf=\"file.isCloudinary == true\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video cloudinary-true\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube == true\">\r\n <iframe attr.type='youtube' #videoPlayer [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'pdf' || file.type == 'txt'\">\r\n <div class=\"container-mat-card px-3\">\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id + '/' + file.file_id]\" class=\"w-100\">\r\n\r\n <div class=\"card card-file mt-0 pointer\">\r\n <div class=\"card-cover\">\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id +'/'+ file.file_id]\">\r\n <ng-container *ngIf=\"file.image\">\r\n <img [src]=\"file.image\" alt=\"\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!file.image || file.image == null\">\r\n <h4 class=\"title\" [innerHTML]=\"linkify(file.title)\"></h4>\r\n </ng-container>\r\n </a>\r\n </div>\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id +'/'+ file.file_id]\" class=\"circle\">\r\n <i *ngIf=\"file.type == 'pdf'\" class=\"fa fa-file-pdf-o\"></i>\r\n <i *ngIf=\"file.type == 'txt'\" class=\"fa fa-file-text-o\"></i>\r\n </a>\r\n <div class=\"card-content\">\r\n <div class=\"clearfix\"></div>\r\n <p class=\"description mb-3\" [innerHTML]=\"linkify(file.description)\"></p>\r\n </div>\r\n </div>\r\n\r\n </a>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'embed'\">\r\n <iframe class=\"video\" style=\"height: 280px; width: 100%;margin-top: 15px;\"\r\n [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\" allowfullscreen></iframe>\r\n </ng-container>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngIf=\"item.files.length > 1\">\r\n\r\n <!-- Carrosel de Imavens e v\u00EDdeos -->\r\n\r\n <div class=\"swiper-stage\">\r\n <swiper [config]=\"global.swiperConfig(false)\">\r\n <div swiperSlide *ngFor=\"let file of item.files; let i = index\">\r\n <div class=\"swiper-carousel-custom\">\r\n\r\n <!-- Imagem -->\r\n\r\n <ng-container *ngIf=\"file.type === 'image'\">\r\n <ng-container *ngIf=\"file.url\">\r\n <div class=\"swiper-container-img\">\r\n <div class=\"swiper-bg-blur\" [style.backgroundImage]=\"'url('+file.url+')'\">\r\n </div>\r\n <img class=\"img\" [src]=\"file.url\" alt=\"\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.name\">\r\n <div class=\"swiper-container-img\" [style.backgroundImage]=\"'url('+file.name+')'\">\r\n <div class=\"swiper-bg-blur\" [style.backgroundImage]=\"'url('+file.name+')'\">\r\n </div>\r\n <img class=\"img\" [src]=\"file.name\" alt=\"\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <!-- Video -->\r\n\r\n <ng-container *ngIf=\"file.type === 'video'\">\r\n\r\n <ng-container>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <video attr.type='stream' #videoPlayer *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\"\r\n width=\"100%\" controls=\"false\" preload=\"metadata\" poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer *ngIf=\"file.isCloudinary == true\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\"\r\n width=\"100%\" controls=\"false\" preload=\"metadata\" poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube == true\">\r\n <iframe attr.type='youtube' #videoPlayer [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n <!-- Verifica se o V\u00EDdeo \u00E9 a primeira posi\u00E7\u00E3o do Slide -->\r\n <!-- <ng-container *ngIf=\" i === 0\">\r\n\r\n <div class=\"video-overlay\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <video attr.type='stream' #videoPlayer\r\n *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer\r\n *ngIf=\"file.isCloudinary === true\" (click)=\"playVideo($event)\"\r\n (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\" width=\"100%\"\r\n controls=\"false\" preload=\"metadata\" poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube === true\">\r\n <iframe attr.type='youtube' #videoPlayer\r\n [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </ng-container> -->\r\n\r\n </ng-container>\r\n\r\n <ng-template #infiniteContainer></ng-template>\r\n </div>\r\n </div>\r\n </swiper>\r\n </div>\r\n\r\n <!-- Fim Carrosel de Imagens e V\u00EDdeos -->\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"item.type == 'announce'\">\r\n <div class=\"ribbon ribbon-top-right\"><span>An\u00FAncio</span></div>\r\n\r\n <div class=\"swiper-stage\">\r\n <swiper [config]=\"global.swiperConfig(false)\">\r\n <div swiperSlide *ngFor=\"let file of item.files; let i = index\">\r\n <div class=\"swiper-carousel-custom\">\r\n <ng-container *ngIf=\"file.type === 'image'\">\r\n <div class=\"img\" [style.backgroundImage]=\"'url('+file.name+')'\" *ngIf=\"file.name\">\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type === 'video'\">\r\n\r\n <ng-container>\r\n\r\n <div class=\"video-overlay\" [style.background-image]=\"file.url | stream:'styleThumbUrl'\">\r\n </div>\r\n\r\n <video class=\"video\" width=\"100%\" preload=\"metadata\" poster=\"{{ file.url | stream:'thumb' }}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n </ng-container>\r\n\r\n <!-- Verifica se o V\u00EDdeo \u00E9 a primeira posi\u00E7\u00E3o do Slide -->\r\n <!-- <ng-container *ngIf=\" i === 0\">\r\n\r\n <div class=\"video-overlay\"\r\n [style.background-image]=\"file.url | stream:'styleThumbUrl'\">\r\n </div>\r\n\r\n <video class=\"video\" width=\"100%\" preload=\"metadata\"\r\n poster=\"{{ file.url | stream:'thumb' }}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n </ng-container> -->\r\n\r\n </ng-container>\r\n </div>\r\n </div>\r\n <ng-template #infiniteContainer></ng-template>\r\n </swiper>\r\n </div>\r\n\r\n <div class=\"pull-right mt-3\" [routerLink]=\"['/market/product/', item.product.id]\">\r\n <button class=\"btn btn-primary\">\r\n <i class=\"fa fa-shopping-cart\"></i>\r\n {{ preConvertNumber(item.product.valorDe) | currency:'BRL':true}} -\r\n {{ preConvertNumber(item.product.valorAte) | currency:'BRL':true}}\r\n </button>\r\n </div>\r\n <p *ngIf=\"item?.product?.data?.descr\" [innerHTML]=\"item.product.descr\"></p>\r\n </ng-container>\r\n\r\n <div class=\"mat-card-content\">\r\n <span class=\"ws-pre-wrap post-text mt-1 mb-4\" [innerHTML]=\"linkify(item.title)\"></span>\r\n <feed-actions [item]=\"item\"></feed-actions>\r\n <feed-comments [feed_id]=\"item.id\" [user]=\"item.user_info\"></feed-comments>\r\n </div>\r\n\r\n </mat-card>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"item && !item.status\">\r\n <ng-container *ngIf=\"global.loggedUser()\">\r\n <ng-container *ngIf=\"item.user_info.id === global.loggedUser().id\">\r\n <ng-container *ngIf=\"item\">\r\n <mat-card #visibleControl class=\"feed-card\" id=\"{{ item.id +'#'+ item.type}}\">\r\n <mat-card-header class=\"feed-header ml-2\">\r\n <div mat-card-avatar>\r\n <img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n class=\"feed-avatar\" (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\"\r\n alt=\"{{ item?.user_info?.name }}\">\r\n </div>\r\n <mat-card-title>\r\n <h4><b>{{ item?.user_info?.name }}</b></h4>\r\n <!-- <p> {{ 'SharedPublication' | translate }} <a>{{ item?.updated_at | amTimeAgo }}</a></p> -->\r\n <p> {{ 'SharedAPostOn' | translate }}\r\n <a>{{ item?.updated_at | amCalendar | amDateFormat: 'DD/MM/YYYY' }}</a>\r\n </p>\r\n </mat-card-title>\r\n\r\n <div class=\"feed-buttom-option\" *ngIf=\"false\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"false\">\r\n <mat-icon>create</mat-icon>\r\n <span>{{ 'Edit' | translate }}</span>\r\n </button>\r\n <button mat-menu-item (click)=\"false\">\r\n <mat-icon>delete</mat-icon>\r\n <span>{{ 'Remove' | translate }}</span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n\r\n </mat-card-header>\r\n\r\n <ng-container>\r\n <div class=\"col-sm-12 mx-auto text-center post-processing-section\">\r\n <img src=\"https://image.flaticon.com/icons/svg/2654/2654464.svg\" width=\"30%\">\r\n <h4>Estamos processando os dados do seu Post!</h4>\r\n <p>No momento ele est\u00E1 vis\u00EDvel apenas para voc\u00EA, mas logo estar\u00E1 dispon\u00EDvel para todos!</p>\r\n </div>\r\n </ng-container>\r\n\r\n <span class=\"ws-pre-wrap post-text mt-1 mb-4\" [innerHTML]=\"linkify(item.title)\"></span>\r\n <feed-actions prefix=\"prefix\" [item]=\"item\"></feed-actions>\r\n <feed-comments prefix=\"prefix\" [feed_id]=\"item.id\" [user]=\"item.user_info\"></feed-comments>\r\n </mat-card>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>\r\n",
|
|
290
290
|
providers: [StreamService],
|
|
291
291
|
styles: ["li,ul{list-style:none!important}a,a:hover{text-decoration:none}.text-primary{color:var(--main-color)}.card{border-radius:6px;box-shadow:1px 1px 10px rgba(201,191,187,.7);-moz-box-shadow:1px 1px 10px rgba(201,191,187,.7);-webkit-box-shadow:1px 1px 10px rgba(201,191,187,.7);border:none;margin-bottom:30px;margin-top:0}.card .card-content{flex:1 1 auto;padding:1.25rem}.comments{margin:30px -15px}.comments h4{font-size:16px;color:#414141;margin-bottom:0;font-weight:600}.comments p{margin:5px 15px 5px 65px;font-size:14px;word-break:break-all}.post-text{white-space:pre-wrap!important;font-size:14px}.form-feed{width:100%;margin:0 0 25px!important;padding:10px 15px!important;border-radius:8px;box-shadow:1px 1px 15px rgba(201,191,187,.7);-moz-box-shadow:1px 1px 15px rgba(201,191,187,.7);-webkit-box-shadow:1px 1px 15px rgba(201,191,187,.7);background-color:var(--bg-card)!important}.form-feed .title{font-size:16px;margin-bottom:10px;border-bottom:1px solid #eee;padding-bottom:10px}.form-feed textarea{float:left;width:calc(100% - 50px);border-bottom:1px solid #eee;border-top:transparent;border-left:transparent;border-right:transparent;box-shadow:none;padding:5px 10px;outline:0!important}.form-input-btn a{float:right;border:none!important;box-shadow:none!important;background:0 0;padding:0;margin-top:12px;position:relative;right:0;left:0;margin-bottom:0;color:#8e8994}.form-input-btn a .material-icons{font-size:18px}.mat-dialog-container{padding:0!important}.form-comment{width:100%;margin:0!important;padding:15px 0 0!important;border-top:1px solid #eee}.form-comment input[type=text]{float:left;width:calc(100% - 50px);border:1px solid #eee;box-shadow:none;border-radius:30px;padding:5px 10px;outline:0}input::-webkit-input-placeholder{color:#ccc}input::-moz-placeholder{color:#ccc}input:-ms-input-placeholder{color:#ccc}input::-ms-input-placeholder{color:#ccc}input::placeholder{color:#ccc}.avatar-30{float:left;width:30px;height:30px;margin-right:10px;border-radius:50%}.avatar-30-null{display:flex;align-items:center;justify-content:center;float:left;width:30px;height:30px;margin-right:10px;border-radius:50%;background:#fafafa;color:#bbb}.comment-time{position:absolute;right:15px}.avatar-45{float:left;width:40px;height:40px;margin-right:10px;border-radius:50%}.avatar-45-null{display:flex;align-items:center;justify-content:center;float:left;width:40px;height:40px;margin-right:10px;border-radius:50%;background:#fafafa;color:#bbb;border:1.3px solid var(--main-color)}.super-post{position:absolute;right:15px;top:10px;font-size:1.8em;color:#888}.icons-comments{margin:10px 0 0;padding:10px 20px;border-top:1px solid #eee;border-bottom:1px solid #eee}.icons-comments li{display:inline-block;margin-right:30px;font-size:14px}.icons-comments li:last-child{margin-right:0;position:absolute;right:20px}.icons-comments li a{color:#4a4a4a;cursor:pointer}.icons-comments li a.active,.icons-comments li a:hover{color:var(--main-color)}.icons-comments .fa{font-size:16px}.card-file{width:100%;margin:0 auto 30px;box-shadow:0 0 30px rgba(204,204,204,.4);border:none;border-radius:12px;transition:.5s}.card-file:hover{box-shadow:0 0 30px rgba(204,204,204,.8)}.card-file .card-cover{display:flex;align-items:center;justify-content:center;padding:15px;position:relative;width:100%;height:160px;border-top-left-radius:16px;border-top-right-radius:12px;-o-object-fit:cover;object-fit:cover;background-size:cover;background-position:center;z-index:1;background:var(--main-color);color:#fff!important}.card-file .card-content{height:auto;padding:0 15px}.card-file .card-content .description{color:#888}.card-file .title{color:#fff;margin-bottom:0;font-size:18px;text-shadow:2px 2px 2px #101010}.btn-feed{width:auto;font-size:12px;padding:2px 5px;border-radius:30px;font-weight:600;text-transform:capitalize}.btn-group-xs>.btn,.btn-xs{padding:2px 15px 3px;font-size:13px;line-height:1;border-radius:30px}.btn-primary,.btn-primary:hover{color:var(--text-btn)!important;background-color:var(--bg-btn);border-color:var(--bg-btn)}.btn-primary.focus,.btn-primary:focus{background-color:var(--bg-btn);border-color:var(--bg-btn);box-shadow:0 0 0 .2rem rgba(0,0,0,.5)}.btn-primary.disabled,.btn-primary:disabled,.btn-primary:not(:disabled):not(.disabled).active,.btn-primary:not(:disabled):not(.disabled):active,.show>.btn-primary.dropdown-toggle{color:var(--text-btn)!important;background-color:var(--bg-btn);border-color:var(--bg-btn)}.btn-primary:not(:disabled):not(.disabled).active:focus,.btn-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,0,0,.5)}.btn-secondary{color:#fff;background-color:#111;border-color:#111}.btn-secondary:hover{color:#fff;background-color:#333;border-color:#333}.btn-secondary.focus,.btn-secondary:focus{background-color:#333;border-color:#333;box-shadow:0 0 0 .2rem rgba(0,0,0,.5)}.btn-secondary.disabled,.btn-secondary:disabled{color:#fff;background-color:#111;border-color:#111}.btn-secondary:not(:disabled):not(.disabled).active,.btn-secondary:not(:disabled):not(.disabled):active,.show>.btn-secondary.dropdown-toggle{color:#fff;background-color:#333;border-color:#333}.btn-secondary:not(:disabled):not(.disabled).active:focus,.btn-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,0,0,.5)}.ribbon{width:150px;height:150px;overflow:hidden;position:absolute;z-index:1}.ribbon::after,.ribbon::before{position:absolute;z-index:-1;content:\"\";display:block;border:5px solid var(--bg-btn)}.ribbon span{position:absolute;display:block;width:225px;padding:15px 0;background-color:var(--bg-btn);box-shadow:0 5px 10px rgba(0,0,0,.1);color:#fff;font:700 18px/1 Lato,sans-serif;text-shadow:0 1px 1px rgba(0,0,0,.2);text-transform:uppercase;text-align:center}.ribbon-top-left{top:-10px;left:-10px;background:0 0}.ribbon-top-left::after,.ribbon-top-left::before{border-top-color:transparent;border-left-color:transparent}.ribbon-top-left::before{top:0;right:0}.ribbon-top-left::after{bottom:0;left:0}.ribbon-top-left span{right:-25px;top:30px;transform:rotate(-45deg)}.ribbon-top-right{top:-10px;right:-10px;background:0 0!important}.ribbon-top-right::after,.ribbon-top-right::before{border-top-color:transparent;border-right-color:transparent}.ribbon-top-right::before{top:0;left:0}.ribbon-top-right::after{bottom:0;right:0}.ribbon-top-right span{left:-25px;top:30px;transform:rotate(45deg)}.ribbon-bottom-left{bottom:-10px;left:-10px}.ribbon-bottom-left::after,.ribbon-bottom-left::before{border-bottom-color:transparent;border-left-color:transparent}.ribbon-bottom-left::before{bottom:0;right:0}.ribbon-bottom-left::after{top:0;left:0}.ribbon-bottom-left span{right:-25px;bottom:30px;transform:rotate(225deg)}.ribbon-bottom-right{bottom:-10px;right:-10px}.ribbon-bottom-right::after,.ribbon-bottom-right::before{border-bottom-color:transparent;border-right-color:transparent}.ribbon-bottom-right::before{bottom:0;left:0}.ribbon-bottom-right::after{top:0;right:0}.ribbon-bottom-right span{left:-25px;bottom:30px;transform:rotate(-225deg)}.video-container{min-height:200px}.video-container img{width:100%;-o-object-fit:cover;object-fit:cover;-webkit-filter:blur(10px);filter:blur(10px)}.video-player{top:0;left:1px;width:calc(100% - 2px)}.tmp-file-buttons-overlay{opacity:1}.overlayed{opacity:1!important;visibility:visible}.tmp-file-status-overlay{position:absolute;background:rgba(0,0,0,.5);text-align:center;z-index:9999999999;color:#fff;width:156px;height:120px;padding:20px}.tmp-file-status-overlay p{color:#fff}.tmp-file-buttons-overlay{background:rgba(0,0,0,.5);width:156px;height:120px;position:absolute;z-index:99999;visibility:visible;opacity:1;transition:opacity .5s ease-out}.tmp-file-remove-button{position:absolute;right:5px;text-align:right;width:10px;color:#fff;padding:0 1px;border-radius:0}.tmp-file-content{width:156px;height:120px;overflow:hidden}.tmp-upload-video{-o-object-fit:contain;object-fit:contain}.tmp-file-wrapper{position:relative}.tmp-upload{-o-object-fit:cover;object-fit:cover;width:156px;height:120px}.tmp-file-wrapper-container{padding:20px 0 0;margin:20px -15px;border-width:1px 0;border-color:#ccc;border-style:solid}.hide{display:none}.masonry{display:flex;flex-flow:row wrap;margin:20px 0 -2px}.masonry-brick{flex:auto;height:250px;min-width:150px;margin:2px;position:relative;cursor:pointer}.masonry-img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.masonry-brick:nth-child(4n+1){width:50%}.masonry-brick:nth-child(4n+2){width:40%}.masonry-brick:nth-child(4n+3){width:20%}.masonry-brick:nth-child(4n+4){width:30%}.masonry-brick-full{width:100%!important;height:291px!important;overflow:hidden;outline:rgba(0,0,0,.2) solid 1px;outline-offset:-1px}.card-body{border-bottom-left-radius:16px;border-bottom-right-radius:16px}.card .circle{float:left;position:relative;display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;margin:-30px 10px 15px 15px;background:#eee;z-index:1;font-size:1.5em;color:#414141!important}.card-team .card-content{width:100%;height:160px;margin-bottom:10px}.card-classroom{padding:15px;box-shadow:1px 1px 5px rgba(201,191,187,.7);-moz-box-shadow:1px 1px 5px rgba(201,191,187,.7);-webkit-box-shadow:1px 1px 5px rgba(201,191,187,.7);margin-bottom:20px}.play-overlay{position:absolute;top:0;left:0;width:100%;text-align:center;height:291px;line-height:291px;background:rgba(0,0,0,.05)}.play-overlay img{width:80px;height:80px}.preview-wrapper{position:relative;margin-top:30px}.preview-image img{outline:rgba(0,0,0,.2) solid 1px;outline-offset:-1px}.preview-button{position:absolute;top:0;right:0;color:#fff}.preview-text{position:relative;background:#f9f9f9;border:1px solid #ccc;padding:11px;margin-top:-7px}.img-with-outline{outline:rgba(0,0,0,.2) solid 1px;outline-offset:-1px}.mt-5{margin-top:2em}.feed-card{width:100%;margin-bottom:30px;box-shadow:1px 1px 15px rgba(201,191,187,.7);-moz-box-shadow:1px 1px 15px rgba(201,191,187,.7);-webkit-box-shadow:1px 1px 15px rgba(201,191,187,.7)}.feed-card .feed-header{margin-bottom:10px}.feed-card .feed-header .feed-avatar{float:left;width:40px;height:40px;margin-right:5px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #e6e5e5}.feed-card .feed-header .feed-buttom-option{position:absolute;top:5px;right:0;z-index:21}.mat-card{padding:15px 0 10px!important}.mat-card .mat-card-header .mat-card-title h4{font-size:16px;margin-bottom:0}.mat-card .mat-card-header .mat-card-title p{font-size:13px;color:#aaa}.container-mat-card{display:flex;align-items:flex-end;justify-content:flex-end;position:relative;overflow:hidden;margin:0 0 10px}.bg-mat-card{display:block;position:absolute;z-index:15;width:100%;height:calc(100% - 30px);-webkit-filter:blur(40px) brightness(80%);filter:blur(40px) brightness(80%);background-size:cover;background-repeat:no-repeat;background-position:center}.mat-card-image{position:relative;z-index:20;margin:0!important;-o-object-fit:contain;object-fit:contain;height:auto;max-height:540px;display:block;width:100%}.feed-comment-option{float:right;margin-top:-10px;margin-left:0}.clickable{cursor:pointer;color:var(--main-color)}.scroll-to-top{position:fixed;bottom:15px;right:15px;opacity:0;transition:.2s ease-in-out}.show-scroll{opacity:1;transition:.2s ease-in-out}.feed-actions{color:#ccc;font-size:16px;margin-right:10px;margin-bottom:5px;margin-left:10px}.feed-actions span{margin-left:5px}.feed-actions .btn{background:0 0!important;border:none!important}.feed-likes{font-size:13px;margin-top:10px}a.is-liked{color:var(--main-color)!important}a.disabled-like{color:#ccc!important;cursor:not-allowed;text-decoration:none;pointer-events:none}.carousel{margin-bottom:10px;margin-left:0;margin-right:0}.carousel-item{-o-object-fit:cover!important;object-fit:cover!important;max-height:400px;-o-object-position:center;object-position:center}.video-player{position:initial!important}::ng-deep .ws-pre-wrap h4{font-size:18px!important}::ng-deep .ws-pre-wrap a{color:var(--main-color)}.SeeMore{display:block;color:var(--main-color)!important;text-align:center;cursor:pointer}.carousel-stage{position:relative;z-index:0;min-height:100px}.carousel-stage .progress{height:8px;border-radius:30px}.carousel-stage .progress .progress-bar{background:var(--main-color)}.carousel-stage .courses-image-item{border-radius:5%;-o-object-fit:cover;object-fit:cover}.carousel-stage .courses-item{padding:15px}.carousel-stage .courses-title{text-align:center}.carousel-stage .courses-title a{color:#000!important;font-weight:400!important}.customNavigation a{display:flex;justify-content:center;align-items:center;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.8);color:var(--main-color)!important;text-align:center}.customNavigation a:hover{background:#fff;color:var(--main-color)}.prev{position:absolute;width:100%;top:50%;left:-15px;margin-top:-15px;z-index:10}.next{position:absolute;width:100%;top:50%;right:-15px;margin-top:-15px;z-index:10}.owl-dots{position:absolute;top:-40px;right:15px;outline:0!important}.owl-dots .owl-dot{background:#ccc!important;border-radius:50%;height:10px;width:10px;padding:0!important;border:none;margin:0 2px;outline:0!important}.owl-dots .owl-dot.active{background:var(--main-color)!important;outline:0!important}::ng-deep .owl-carousel-o-stories .owl-next,::ng-deep .owl-carousel-o-stories .owl-prev{position:absolute!important;top:50%!important;transform:translateY(-50%)!important;display:block!important;border-radius:50%!important;margin-top:-5px!important}::ng-deep .owl-carousel-o-stories .owl-prev{left:5px!important}::ng-deep .owl-carousel-o-stories .owl-next{right:5px!important}::ng-deep .swiper-stage .swiper-container{padding:0}::ng-deep .swiper-stage .swiper-button-next,::ng-deep .swiper-stage .swiper-button-prev{display:flex;align-items:center;justify-content:center;margin-top:0!important;width:25px;height:25px;border-radius:50%;background-color:var(--main-color)!important;opacity:.7!important}::ng-deep .swiper-stage .swiper-button-prev{left:10px;right:auto!important}::ng-deep .swiper-stage .swiper-button-next{right:10px;left:auto!important}::ng-deep .swiper-stage .swiper-button-next:after,::ng-deep .swiper-stage .swiper-button-prev:after{font-size:13px!important;color:#fff}::ng-deep .swiper-stage .swiper-button-disabled{opacity:0!important}.carousel-stories{display:inline-block;width:100%;height:145px;margin:0;border-radius:6px;text-transform:uppercase;font-size:1em;font-weight:500;background-repeat:no-repeat;background-size:cover;cursor:pointer;background-position:center!important}.carousel-stories .item:focus{outline:0}.carousel-stories .stories-body{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;text-align:center;height:100%;padding:0}.carousel-stories .stories-body a{font-size:12px;color:#fff;margin-bottom:10px;text-shadow:0 1px 1px rgba(0,0,0,.6)}.carousel-stories .stories-body a:hover{color:#ccc}.mat-button,.mat-flat-button,.mat-icon-button,.mat-stroked-button{outline:0!important}::ng-deep .mat-menu-panel{border-radius:6px!important;outline:0!important}::ng-deep .mat-menu-panel .mat-menu-content:not(:empty){padding-top:0!important;padding-bottom:0!important}::ng-deep .mat-menu-panel .mat-menu-item{color:#414141;font-size:15px;font-style:normal;font-weight:400;letter-spacing:1px;outline:0!important}.progress-bar-custom span{display:inline-block;height:100%;border-radius:3px;box-shadow:0 1px 0 rgba(37,21,21,.5) inset;transition:width .4s ease-in-out}.green-progress span{background-image:linear-gradient(to bottom,#fff,var(--main-color))}.stripes span{background-size:30px 30px;background-image:linear-gradient(135deg,#ff4e4ef3 25%,transparent 25%,transparent 50%,rgba(236,47,47,.972) 50%,rgba(240,0,0,.15) 75%,transparent 75%,transparent);-webkit-animation:3s linear infinite animate-stripes;animation:3s linear infinite animate-stripes}.container-stipes{width:100%;padding:0 10px;font-weight:700}.keep-logged{position:relative;height:150px;background:var(--main-color);top:0;color:#fff!important;z-index:99;opacity:.9;width:100%;border:0;left:0;right:0}.keep-logged button{background:#fff!important;color:var(--main-color)!important}.scrollable{overflow-y:scroll;height:100vh}.alert-primary{color:#fff;background-color:var(--main-color)!important;background:var(--main-color)!important}.mat-progress-bar{height:17px;border-radius:5px}@-webkit-keyframes animate-stripes{0%{background-position:0 0}100%{background-position:60px 0}}@keyframes animate-stripes{0%{background-position:0 0}100%{background-position:60px 0}}.p-channel{color:#3c4858;font-weight:500;margin-bottom:0!important}@media (max-width:767px){.form-feed textarea{font-size:12px}.btn-feed{width:auto;font-size:11px;padding:2px 5px;border-radius:30px;font-weight:600;text-transform:capitalize}.carousel-stories{width:120px;height:120px}.keep-logged{height:175px}.keep-logged h3{font-size:1.1rem}.keep-logged button{font-size:1rem}.btn-group-xs>.btn,.btn-xs{padding:2px 5px;font-size:11px;line-height:1;border-radius:30px}}::ng-deep .mat-card-header-text{width:100%!important;margin:0}::ng-deep .popover{background:#fff!important;border:0!important;box-shadow:1px 1px 15px rgba(201,191,187,.7)!important;-moz-box-shadow:1px 1px 15px rgba(201,191,187,.7)!important;-webkit-box-shadow:1px 1px 15px rgba(201,191,187,.7)!important}.minibio{padding:10px;border-radius:10px}.minibio img{width:30%;max-width:100px;display:inline-block;padding-right:10px}.minibio .info{display:inline-block;vertical-align:top}.minibio .info .icon{color:#d4d4d4}.minibio .info ul{list-style:none}.minibio .info li{display:inline-block}", "@charset \"UTF-8\";.pinned-feed{background-color:var(--bg-btn);color:var(--text-btn);padding:5px;height:40px;width:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;position:absolute;margin-top:60px;margin-right:5px;opacity:1}.mat-card-video{-o-object-fit:cover;object-fit:cover;width:calc(100% + 31px);margin:0 0 10px}.mat-card-content{word-break:break-word;padding:0 15px}::ng-deep .tooltip-primary{background:var(--main-color);opacity:.85;font-size:13px}.no-click{pointer-events:none}.modal-feed-publication{border-radius:24px!important}.share-social{max-width:185px}.mat-card-actions{min-height:40px}.post-processing-section{padding:12px;border:3px dotted gray;border-radius:8px;background-color:#f4f4f4}.carousel{color:#fff}.carousel .content{display:flex}.carousel .content .item{width:100%;display:block;transition:opacity 295ms linear .2s}.carousel .content .item.visible{opacity:1}.carousel .content .item .img{width:100%;height:500px;display:block;-o-object-fit:cover;object-fit:cover;background-size:cover;background-position:center}.carousel .content .item .video{width:100%;height:500px!important;display:block;background-size:cover;background-position:center}.carousel .content .item .video-overlay{background:rgba(0,0,0,.5);width:100%;height:500px!important;position:absolute;z-index:-1;transition:opacity .5s ease-out;filter:blur(8px);-webkit-filter:blur(8px)}.carousel .content .wraper-video{background-color:#000}.carousel .ball{width:10px;height:10px;border-radius:50%;background:#000;border:2px solid;opacity:.5}.carousel .ball.visible{opacity:1}.carousel .click-area{width:50px;text-align:center}.carousel .click-area i{font-size:2em;background:rgba(255,255,255,.8);color:#000;border-radius:100%}.custom-carrousel{z-index:1;overflow:hidden}.card-file{box-shadow:0 0 30px rgba(204,204,204,.4);border:none;border-radius:16px;transition:.5s;margin-bottom:30px;cursor:pointer}.card-file .card-cover{display:flex;align-items:center;justify-content:center;text-align:center;padding:0;width:100%;height:250px;border-top-left-radius:10px;border-top-right-radius:10px;background:var(--main-color);color:#fff!important;overflow:hidden}.card-file .card-cover img{position:absolute;z-index:0;top:0;left:0;width:100%;height:inherit;-o-object-fit:cover;object-fit:cover;border-top-left-radius:10px;border-top-right-radius:10px}.card-file .card-cover .title{position:relative;z-index:3;color:#fff;margin-bottom:0;height:60px;padding:0 15px;font-size:18px}.card-file .circle{float:left;position:relative;display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;margin:-30px 10px 15px 15px;background:#eee;z-index:20;font-size:1.5em;color:#3c4858!important}.card-file .card-body{height:125px;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.card-file .card-body .edit-file{float:right!important;margin-top:-60px;margin-right:-15px}.card-file .card-body h5{height:60px}.card-file .card-body .description{color:#888;height:65px;overflow:hidden}::ng-deep owl-carousel-o .owl-theme .owl-next,::ng-deep owl-carousel-o .owl-theme .owl-prev{position:absolute;top:50%;transform:translateY(-50%);display:flex!important;align-items:center!important;justify-content:center!important;width:30px!important;height:30px!important;border-radius:50%!important;margin:20px 0;background:rgba(255,255,255,.8)!important;color:#414141!important;border:none!important;font-size:20px!important;font-weight:600!important}::ng-deep owl-carousel-o .owl-theme .owl-prev{left:5px;transition:.3s!important}::ng-deep owl-carousel-o .owl-theme .owl-prev:hover{transition:.3s!important}::ng-deep owl-carousel-o .owl-theme .owl-next{right:5px;transition:.3s!important}::ng-deep owl-carousel-o .owl-theme .owl-next:hover{transition:.3s}::ng-deep owl-carousel-o .owl-carousel .owl-dot,::ng-deep owl-carousel-o .owl-carousel .owl-nav .owl-next,::ng-deep owl-carousel-o .owl-carousel .owl-nav .owl-prev{font-family:fontAwesome}::ng-deep owl-carousel-o .owl-carousel .owl-nav .owl-prev:before{content:\"\uF104\"}::ng-deep owl-carousel-o .owl-carousel .owl-nav .owl-next:after{content:\"\uF105\"}.swiper-carousel-custom .swiper-container-img{display:flex;align-items:center;justify-content:center;width:100%;height:500px}.swiper-carousel-custom .swiper-bg-blur{position:absolute;z-index:10;width:100%;height:500px;-webkit-filter:blur(30px) brightness(80%);filter:blur(30px) brightness(80%);background-size:cover;background-repeat:no-repeat;background-position:center}.swiper-carousel-custom .img{position:relative;z-index:20;max-width:100%;max-height:500px!important;display:block;-o-object-fit:contain;object-fit:contain;background-size:cover;background-position:center}.swiper-carousel-custom .video{width:100%;height:500px!important;display:block;background-size:cover;background-position:center}.swiper-carousel-custom .video-overlay{background:rgba(0,0,0,.5);width:100%;height:500px!important;position:absolute;z-index:-1;transition:opacity .5s ease-out;filter:blur(8px);-webkit-filter:blur(8px)}"]
|
|
292
292
|
}] }
|
|
@@ -344,4 +344,4 @@ if (false) {
|
|
|
344
344
|
/** @type {?} */
|
|
345
345
|
FeedItemComponent.prototype.service;
|
|
346
346
|
}
|
|
347
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVlZC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FzYXAtZmVlZC1iZXRhLyIsInNvdXJjZXMiOlsibGliL2ZlZWQtaXRlbS9mZWVkLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQTRCLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEksT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDbkMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seUVBQXlFLENBQUM7QUFDckgsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzlDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFckQsT0FBTyxVQUFVLEVBQUUsRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQzVELFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxVQUFVLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQztBQVF6QyxNQUFNLE9BQU8saUJBQWlCOzs7Ozs7OztJQW9CNUIsWUFDUyxhQUE0QixFQUM1QixFQUFvQixFQUNwQixNQUFjLEVBQ2QsTUFBaUIsRUFDakIsT0FBcUI7UUFKckIsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDNUIsT0FBRSxHQUFGLEVBQUUsQ0FBa0I7UUFDcEIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLFdBQU0sR0FBTixNQUFNLENBQVc7UUFDakIsWUFBTyxHQUFQLE9BQU8sQ0FB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ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCwgVmlld0NoaWxkLCBFbGVtZW50UmVmLCBPbkRlc3Ryb3ksIEFmdGVyVmlld0luaXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFN0cmVhbVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9zdHJlYW0uc2VydmljZSc7XHJcbmltcG9ydCB7IEFuZ3VsYXJGaXJlc3RvcmUgfSBmcm9tICdAYW5ndWxhci9maXJlL2ZpcmVzdG9yZSc7XHJcbmltcG9ydCB7IEdsb2JhbCB9IGZyb20gJ2FzYXAtY3J1ZCc7XHJcbmltcG9ydCB7IEZlZWRNb2RhbEl0ZW1FZGl0Q29tcG9uZW50IH0gZnJvbSAnLi4vZmVlZC1wdWJsaWNhdGlvbi9mZWVkLW1vZGFsLWl0ZW0tZWRpdC9mZWVkLW1vZGFsLWl0ZW0tZWRpdC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBwYXRoIH0gZnJvbSAnLi4vY29uc3RhbnRzL2NvbnN0YW50cyc7XHJcbmltcG9ydCB7IFV0aWxzU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3V0aWxzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2cgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5cclxuaW1wb3J0IFN3aXBlckNvcmUsIHsgTmF2aWdhdGlvbiwgUGFnaW5hdGlvbiB9IGZyb20gJ3N3aXBlcic7XHJcblN3aXBlckNvcmUudXNlKFtOYXZpZ2F0aW9uLCBQYWdpbmF0aW9uXSk7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1mZWVkLWl0ZW0nLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9mZWVkLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuLi9hc2FwLWZlZWQuYmV0YS5jb21wb25lbnRlLnNjc3MnLCAnLi9mZWVkLWl0ZW0uY29tcG9uZW50LnNjc3MnXSxcclxuICBwcm92aWRlcnM6IFtTdHJlYW1TZXJ2aWNlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRmVlZEl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XHJcblxyXG4gIEBJbnB1dCgpIGl0ZW07XHJcbiAgQElucHV0KCkgb3duZXI7XHJcblxyXG4gIEBPdXRwdXQoKSBpc1Zpc2libGUgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIEBWaWV3Q2hpbGQoJ3ZpZGVvUGxheWVyJywgeyBzdGF0aWM6IHRydWUgfSkgdmlkZW9wbGF5ZXI6IEVsZW1lbnRSZWZcclxuICBAVmlld0NoaWxkKCd2aXNpYmxlQ29udHJvbCcsIHsgc3RhdGljOiBmYWxzZSwgcmVhZDogRWxlbWVudFJlZiB9KSB2aXNpYmxlQ29udHJvbDtcclxuXHJcbiAgcHVibGljIGN1cnJlbnRJbmRleDtcclxuICBwdWJsaWMgaW1hZ2VMb2FkZWQgPSBmYWxzZTtcclxuICBwdWJsaWMgaW1hZ2VEYXRhTG9hZGVkID0gZmFsc2U7XHJcbiAgcHVibGljIGN1cnJlbnRDYXJyb3VzZWxJbmRleDtcclxuICBwdWJsaWMgYmx1ckJhY2tncm91bmRJbmRleCA9IE1hdGguZmxvb3IoKE1hdGgucmFuZG9tKCkgKiA1KSArIDEpO1xyXG5cclxuICBwdWJsaWMgb2JzZXJ2ZXI7XHJcbiAgcHVibGljIHZpc2libGVUaW1lcjtcclxuICBwdWJsaWMgc2hvdFRpbWVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBzdHJlYW1TZXJ2aWNlOiBTdHJlYW1TZXJ2aWNlLFxyXG4gICAgcHVibGljIGRiOiBBbmd1bGFyRmlyZXN0b3JlLFxyXG4gICAgcHVibGljIGdsb2JhbDogR2xvYmFsLFxyXG4gICAgcHVibGljIGRpYWxvZzogTWF0RGlhbG9nLFxyXG4gICAgcHVibGljIHNlcnZpY2U6IFV0aWxzU2VydmljZVxyXG4gICkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5sb2FkVmlzaWJpbGl0eUNvbnRyb2xzKCk7XHJcblxyXG4gICAgaWYgKHRoaXMuaXRlbS5maWxlcyAmJiB0aGlzLml0ZW0uZmlsZXMubGVuZ3RoID4gMCkge1xyXG4gICAgICB0aGlzLml0ZW0uZmlsZXMubWFwKGZlZWQgPT4ge1xyXG4gICAgICAgIGlmIChmZWVkLnVybCAmJiBmZWVkLnVybC5pbmNsdWRlcygneW91dHViZScpKSB7XHJcbiAgICAgICAgICBmZWVkLmlzWW91dHViZSA9IHRydWU7XHJcbiAgICAgICAgICBsZXQgeW91dHViZUlEID0gdGhpcy5nZXRZb3V0dWJlSUQoZmVlZC51cmwpO1xyXG4gICAgICAgICAgZmVlZC51cmwgPSBgaHR0cHM6Ly93d3cueW91dHViZS5jb20vZW1iZWQvJHt5b3V0dWJlSUR9YDtcclxuICAgICAgICB9XHJcbiAgICAgIH0pXHJcbiAgICB9XHJcblxyXG4gICAgLy8gY29uc29sZS5sb2coJ0lURU0gLT4nLCB0aGlzLml0ZW0pO1xyXG4gIH1cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5vYnNlcnZlci5vYnNlcnZlKHRoaXMudmlzaWJsZUNvbnRyb2wubmF0aXZlRWxlbWVudCk7XHJcbiAgfVxyXG5cclxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMub2JzZXJ2ZXIuZGlzY29ubmVjdCgpO1xyXG4gICAgY2xlYXJJbnRlcnZhbCh0aGlzLnZpc2libGVUaW1lcik7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbG9hZFZpc2liaWxpdHlDb250cm9scygpIHtcclxuICAgIHRoaXMudmlzaWJsZVRpbWVyID0gc2V0SW50ZXJ2YWwoKCkgPT4ge1xyXG4gICAgICB0aGlzLnNob3RUaW1lci0tO1xyXG4gICAgICBpZiAodGhpcy5zaG90VGltZXIgPT0gMCkge1xyXG4gICAgICAgIHRoaXMuaXNWaXNpYmxlLmVtaXQodGhpcy5pdGVtKTtcclxuICAgICAgICBjbGVhckludGVydmFsKHRoaXMudmlzaWJsZVRpbWVyKTtcclxuICAgICAgICB0aGlzLm9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcclxuICAgICAgfVxyXG4gICAgfSwgMTAwMCk7XHJcblxyXG4gICAgY29uc3Qgb3B0aW9ucyA9IHtcclxuICAgICAgcm9vdE1hcmdpbjogJzBweCcsXHJcbiAgICAgIHRocmVzaG9sZDogWzAsIDAuMSwgMC4yLCAwLjMsIDAuNCwgMC41LCAwLjYsIDAuNywgMC44LCAwLjksIDEuMF1cclxuICAgIH07XHJcblxyXG4gICAgdGhpcy5vYnNlcnZlciA9IG5ldyBJbnRlcnNlY3Rpb25PYnNlcnZlcigoZW50cmllcywgb2JzZXJ2ZXIpID0+IHtcclxuICAgICAgZW50cmllcy5mb3JFYWNoKGVudHJ5ID0+IHtcclxuICAgICAgICB0aGlzLnNob3RUaW1lciA9IC0xO1xyXG4gICAgICAgIHRoaXMuaXRlbS5hY3RpdmUgPSBmYWxzZTtcclxuICAgICAgICBpZiAoZW50cnkuaW50ZXJzZWN0aW9uUmF0aW8gPT0gMSkge1xyXG4gICAgICAgICAgdGhpcy5zaG90VGltZXIgPSA1O1xyXG4gICAgICAgIH1cclxuICAgICAgfSk7XHJcbiAgICB9LCBvcHRpb25zKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbmxvYWRJbWFnZShldmVudCkge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ0V2ZW50IG9ubG9hZEltYWdlIC0+JywgZXZlbnQpO1xyXG4gICAgdGhpcy5pbWFnZUxvYWRlZCA9IHRydWU7XHJcbiAgICB0aGlzLmltYWdlRGF0YUxvYWRlZCA9IHRydWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25FcnJvckltYWdlKGV2ZW50KSB7XHJcbiAgICAvLyBjb25zb2xlLmxvZygnRXZlbnQgb25FcnJvckltYWdlIC0+JywgZXZlbnQpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHBsYXlWaWRlbyhldmVudCkge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ0V2ZW50IC0+JywgZXZlbnQpO1xyXG4gICAgaWYgKHRoaXMudmlkZW9wbGF5ZXIpIHtcclxuICAgICAgdGhpcy52aWRlb3BsYXllci5uYXRpdmVFbGVtZW50LnBsYXkoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBsaW5raWZ5KHN0cikge1xyXG4gICAgdmFyIHJlOiBhbnk7XHJcbiAgICByZSA9IFtcclxuICAgICAgXCJcXFxcYigoPzpodHRwcz98ZnRwKTovL1teXFxcXHNcXFwiJzw+XSspXFxcXGJcIixcclxuICAgICAgXCJcXFxcYih3d3dcXFxcLlteXFxcXHNcXFwiJzw+XSspXFxcXGJcIixcclxuICAgICAgXCJcXFxcYihcXFxcd1tcXFxcdy4rLV0qQFtcXFxcdy4tXStcXFxcLlthLXpdezIsNn0pXFxcXGJcIixcclxuICAgICAgXCIjKFthLXowLTldKylcIl07XHJcbiAgICByZSA9IG5ldyBSZWdFeHAocmUuam9pbignfCcpLCBcImdpXCIpO1xyXG5cclxuICAgIGlmIChzdHIpIHtcclxuICAgICAgcmV0dXJuIHN0ci5yZXBsYWNlKHJlLCBmdW5jdGlvbiAobWF0Y2gsIHVybCwgd3d3LCBtYWlsLCB0d2l0bGVyKSB7XHJcbiAgICAgICAgaWYgKHVybClcclxuICAgICAgICAgIHJldHVybiBcIjxhIGNsYXNzPSd0ZXh0LXByaW1hcnknIHRhcmdldD0nX2JsYW5rJyAoY2xpY2spPSdyZWRpcmVjdE5ld0xpbmsodXJsKScgaHJlZj1cXFwiXCIgKyB1cmwgKyBcIlxcXCI+XCIgKyB1cmwgKyBcIjwvYT5cIjtcclxuICAgICAgICBpZiAod3d3KVxyXG4gICAgICAgICAgcmV0dXJuIFwiPGEgY2xhc3M9J3RleHQtcHJpbWFyeScgaHJlZj1cXFwiaHR0cDovL1wiICsgd3d3ICsgXCJcXFwiPlwiICsgd3d3ICsgXCI8L2E+XCI7XHJcbiAgICAgICAgaWYgKG1haWwpXHJcbiAgICAgICAgICByZXR1cm4gXCI8YSBjbGFzcz0ndGV4dC1wcmltYXJ5JyBocmVmPVxcXCIjPC9hPlwiO1xyXG4gICAgICAgIGlmICh0d2l0bGVyKVxyXG4gICAgICAgICAgcmV0dXJuIFwiPGEgY2xhc3M9J3RleHQtcHJpbWFyeScgaHJlZj1cXFwicG9ydGFsL3NlYXJjaC9cIiArIGVuY29kZVVSSUNvbXBvbmVudCgnIycgKyB0d2l0bGVyKSArIFwiXFxcIj4jXCIgKyB0d2l0bGVyICsgXCI8L2E+XCI7XHJcbiAgICAgICAgLy8gcmV0dXJuIFwiPGEgY2xhc3M9J3RleHQtcHJpbWFyeScgaHJlZj1cXFwiI1xcXCI+I1wiICsgdHdpdGxlciArIFwiPC9hPlwiO1xyXG5cclxuICAgICAgICAvLyBzaG91bGRudCBnZXQgaGVyZSwgYnV0IGp1c3QgaW4gY2FzZVxyXG4gICAgICAgIHJldHVybiBtYXRjaDtcclxuICAgICAgfSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY2hlY2tWaWRlb1JlbmRlcihpdGVtKSB7XHJcblxyXG4gICAgY29uc29sZS5sb2coJ3ZpZGVvUmVuZGVyIC0+JywgaXRlbSk7XHJcbiAgICB0aGlzLnN0cmVhbVNlcnZpY2Uuc3RhdHVzKGl0ZW0pLnN1YnNjcmliZSgocmVzOiBhbnkpID0+IHtcclxuICAgICAgY29uc29sZS5sb2coJ2NoZWNrVmlkZW9SZW5kZXInLCByZXMpO1xyXG4gICAgfSlcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbkVkaXRJdGVtKCkge1xyXG4gICAgLy8gIFByZXBhcmFyIGZlZWQgcGFyYSBlZGl0YXJcclxuICAgIGxldCBmZWVkO1xyXG4gICAgZmVlZCA9IHRoaXMuaXRlbTtcclxuICAgIGRlbGV0ZSBmZWVkLmNvbW1lbnRzO1xyXG4gICAgZGVsZXRlIGZlZWQubGlrZXM7XHJcblxyXG4gICAgZmVlZC5maWxlcy5tYXAoZmlsZSA9PiB7XHJcbiAgICAgIGZpbGUubmV3ID0gZmFsc2U7XHJcbiAgICB9KTtcclxuXHJcbiAgICB0aGlzLmRpYWxvZy5vcGVuKEZlZWRNb2RhbEl0ZW1FZGl0Q29tcG9uZW50LCB7XHJcbiAgICAgIHdpZHRoOiAnNjAwcHgnLFxyXG4gICAgICBkYXRhOiBmZWVkLFxyXG4gICAgICBwYW5lbENsYXNzOiAnbW9kYWwtZmVlZC1wdWJsaWNhdGlvbidcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBwcmVDb252ZXJ0TnVtYmVyKHZhbHVlKSB7XHJcbiAgICByZXR1cm4gcGFyc2VGbG9hdCh2YWx1ZSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25SZW1vdmVJdGVtKGl0ZW0pIHtcclxuICAgIHRoaXMuZ2xvYmFsLnN3YWwoe1xyXG4gICAgICB0aXRsZTogJ1ZvY8OqIHJlYWxtZW50ZSBkZXNlamEgcmVtb3ZlciBlc3RlIFBvc3Q/JyxcclxuICAgICAgdGV4dDogJ1ZvY8OqIG7Do28gcG9kZXLDoSByZXZlcnRlciBlc3NhIGHDp8OjbyBkZXBvaXMgZGUgY29uZmlybWFkbycsXHJcbiAgICAgIHR5cGU6IFwid2FybmluZ1wiLFxyXG4gICAgICBzaG93Q2FuY2VsQnV0dG9uOiB0cnVlLFxyXG4gICAgICBjb25maXJtQnV0dG9uVGV4dDogXCJTaW1cIixcclxuICAgICAgY2FuY2VsQnV0dG9uVGV4dDogXCJOw6NvXCJcclxuICAgIH0pLnRoZW4oYXN5bmMgY29uZmlybSA9PiB7XHJcbiAgICAgIGlmIChjb25maXJtLnZhbHVlKSB7XHJcbiAgICAgICAgY29uc3QgY29sbGVjdGlvbiA9IHRoaXMuZGIuY29sbGVjdGlvbihwYXRoKCkuZmVlZCkuZG9jKGl0ZW0uaWQpO1xyXG5cclxuICAgICAgICBpZiAoaXRlbS5maWxlcyAmJiBpdGVtLmZpbGVzLmxlbmd0aCA+IDApIHtcclxuICAgICAgICAgIGZvciAoY29uc3QgZmlsZSBvZiBpdGVtLmZpbGVzKSB7XHJcbiAgICAgICAgICAgIGlmIChmaWxlLnR5cGUgPT09ICdpbWFnZScpIHtcclxuICAgICAgICAgICAgICBpZiAoZmlsZS5uYW1lKSB7XHJcbiAgICAgICAgICAgICAgICB0cnkge1xyXG4gICAgICAgICAgICAgICAgICBhd2FpdCB0aGlzLnNlcnZpY2UuZGVsZXRlRmlyZVN0b3JhZ2UoYCR7cGF0aCgpLmltYWdlc30vJHtmaWxlLm5hbWV9YCk7XHJcbiAgICAgICAgICAgICAgICB9IGNhdGNoIChlcnJvcikge1xyXG4gICAgICAgICAgICAgICAgICBjb25zb2xlLmxvZygnUmVtb3ZlbmRvIHVtIHBvc3QgY29tIGltYWdlbSBuw6NvIHJlZmVyZW5jaWFkYScsIGVycm9yKTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgIH1cclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGNvbGxlY3Rpb24uZGVsZXRlKCk7XHJcbiAgICAgICAgaXRlbS5kZWxldGVkID0gdHJ1ZTtcclxuICAgICAgICB0aGlzLmdsb2JhbC50b2FzdCgnUG9zdCByZW1vdmlkbyBjb20gU3VjZXNzbycpO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGNoZWNrRmlsZU9yaWdpbihmaWxlKSB7XHJcblxyXG4gIH1cclxuXHJcbiAgaXNZb3V0dWJlKGZpbGUpIHtcclxuICAgIGNvbnNvbGUubG9nKCdJc1lvdXR1YmUgLT4nLCBmaWxlKTtcclxuICAgIGlmIChmaWxlLmluY2x1ZGVzKCd5b3V0dWJlJykpIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gZmFsc2U7XHJcbiAgfVxyXG5cclxuICBnZXRZb3V0dWJlSUQodXJsKSB7XHJcbiAgICB2YXIgcmVnRXhwID0gL14uKigoeW91dHUuYmVcXC8pfCh2XFwvKXwoXFwvdVxcL1xcd1xcLyl8KGVtYmVkXFwvKXwod2F0Y2hcXD8pKVxcPz92Pz0/KFteIyY/XSopLiovO1xyXG4gICAgdmFyIG1hdGNoID0gdXJsLm1hdGNoKHJlZ0V4cCk7XHJcbiAgICByZXR1cm4gKG1hdGNoICYmIG1hdGNoWzddLmxlbmd0aCA9PSAxMSkgPyBtYXRjaFs3XSA6IGZhbHNlO1xyXG4gIH1cclxuXHJcblxyXG59XHJcbiJdfQ==
|
|
347
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVlZC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FzYXAtZmVlZC1iZXRhLyIsInNvdXJjZXMiOlsibGliL2ZlZWQtaXRlbS9mZWVkLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQTRCLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEksT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDbkMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seUVBQXlFLENBQUM7QUFDckgsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzlDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFckQsT0FBTyxVQUFVLEVBQUUsRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQzVELFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxVQUFVLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQztBQVF6QyxNQUFNLE9BQU8saUJBQWlCOzs7Ozs7OztJQW9CNUIsWUFDUyxhQUE0QixFQUM1QixFQUFvQixFQUNwQixNQUFjLEVBQ2QsTUFBaUIsRUFDakIsT0FBcUI7UUFKckIsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDNUIsT0FBRSxHQUFGLEVBQUUsQ0FBa0I7UUFDcEIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLFdBQU0sR0FBTixNQUFNLENBQVc7UUFDakIsWUFBTyxHQUFQLE9BQU8sQ0FBYztRQXBCcEIsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFNbEMsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFDcEIsb0JBQWUsR0FBRyxLQUFLLENBQUM7UUFFeEIsd0JBQW1CLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQVk3RCxDQUFDOzs7O0lBRUwsUUFBUTtRQUNOLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO1FBRTlCLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUNqRCxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHOzs7O1lBQUMsSUFBSSxDQUFDLEVBQUU7Z0JBQ3pCLElBQUksSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRTtvQkFDNUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7O3dCQUNsQixTQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO29CQUMzQyxJQUFJLENBQUMsR0FBRyxHQUFHLGlDQUFpQyxTQUFTLEVBQUUsQ0FBQztpQkFDekQ7WUFDSCxDQUFDLEVBQUMsQ0FBQTtTQUNIO1FBRUQscUNBQXFDO0lBQ3ZDLENBQUM7Ozs7SUFFRCxlQUFlO1FBQ2IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUMzRCxDQUFDOzs7O0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDM0IsYUFBYSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNuQyxDQUFDOzs7O0lBRU0sc0JBQXNCO1FBQzNCLElBQUksQ0FBQyxZQUFZLEdBQUcsV0FBVzs7O1FBQUMsR0FBRyxFQUFFO1lBQ25DLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNqQixJQUFJLElBQUksQ0FBQyxTQUFTLElBQUksQ0FBQyxFQUFFO2dCQUN2QixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQy9CLGFBQWEsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7Z0JBQ2pDLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxFQUFFLENBQUM7YUFDNUI7UUFDSCxDQUFDLEdBQUUsSUFBSSxDQUFDLENBQUM7O2NBRUgsT0FBTyxHQUFHO1lBQ2QsVUFBVSxFQUFFLEtBQUs7WUFDakIsU0FBUyxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsQ0FBQztTQUNqRTtRQUVELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxvQkFBb0I7Ozs7O1FBQUMsQ0FBQyxPQUFPLEVBQUUsUUFBUSxFQUFFLEVBQUU7WUFDN0QsT0FBTyxDQUFDLE9BQU87Ozs7WUFBQyxLQUFLLENBQUMsRUFBRTtnQkFDdEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLENBQUMsQ0FBQztnQkFDcEIsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO2dCQUN6QixJQUFJLEtBQUssQ0FBQyxpQkFBaUIsSUFBSSxDQUFDLEVBQUU7b0JBQ2hDLElBQUksQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFDO2lCQUNwQjtZQUNILENBQUMsRUFBQyxDQUFDO1FBQ0wsQ0FBQyxHQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ2QsQ0FBQzs7Ozs7SUFFTSxXQUFXLENBQUMsS0FBSztRQUN0Qiw4Q0FBOEM7UUFDOUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUM7UUFDeEIsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUM7SUFDOUIsQ0FBQzs7Ozs7SUFFTSxZQUFZLENBQUMsS0FBSztRQUN2QiwrQ0FBK0M7SUFDakQsQ0FBQzs7Ozs7SUFFTSxTQUFTLENBQUMsS0FBSztRQUNwQixrQ0FBa0M7UUFDbEMsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3BCLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQ3ZDO0lBQ0gsQ0FBQzs7Ozs7SUFFTSxPQUFPLENBQUMsR0FBRzs7WUFDWixFQUFPO1FBQ1gsRUFBRSxHQUFHO1lBQ0gsdUNBQXVDO1lBQ3ZDLDRCQUE0QjtZQUM1Qiw0Q0FBNEM7WUFDNUMsY0FBYztTQUFDLENBQUM7UUFDbEIsRUFBRSxHQUFHLElBQUksTUFBTSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFFcEMsSUFBSSxHQUFHLEVBQUU7WUFDUCxPQUFPLEdBQUcsQ0FBQyxPQUFPLENBQUMsRUFBRTs7Ozs7Ozs7WUFBRSxVQUFVLEtBQUssRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxPQUFPO2dCQUM3RCxJQUFJLEdBQUc7b0JBQ0wsT0FBTyxnRkFBZ0YsR0FBRyxHQUFHLEdBQUcsS0FBSyxHQUFHLEdBQUcsR0FBRyxNQUFNLENBQUM7Z0JBQ3ZILElBQUksR0FBRztvQkFDTCxPQUFPLHdDQUF3QyxHQUFHLEdBQUcsR0FBRyxLQUFLLEdBQUcsR0FBRyxHQUFHLE1BQU0sQ0FBQztnQkFDL0UsSUFBSSxJQUFJO29CQUNOLE9BQU8sc0NBQXNDLENBQUM7Z0JBQ2hELElBQUksT0FBTztvQkFDVCxPQUFPLCtDQUErQyxHQUFHLGtCQUFrQixDQUFDLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxNQUFNLEdBQUcsT0FBTyxHQUFHLE1BQU0sQ0FBQztnQkFDekgsb0VBQW9FO2dCQUVwRSxzQ0FBc0M7Z0JBQ3RDLE9BQU8sS0FBSyxDQUFDO1lBQ2YsQ0FBQyxFQUFDLENBQUM7U0FDSjtJQUNILENBQUM7Ozs7O0lBRU0sZ0JBQWdCLENBQUMsSUFBSTtRQUUxQixPQUFPLENBQUMsR0FBRyxDQUFDLGdCQUFnQixFQUFFLElBQUksQ0FBQyxDQUFDO1FBQ3BDLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVM7Ozs7UUFBQyxDQUFDLEdBQVEsRUFBRSxFQUFFO1lBQ3JELE9BQU8sQ0FBQyxHQUFHLENBQUMsa0JBQWtCLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDdkMsQ0FBQyxFQUFDLENBQUE7SUFDSixDQUFDOzs7O0lBRU0sVUFBVTs7O1lBRVgsSUFBSTtRQUNSLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUNyQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7UUFFbEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHOzs7O1FBQUMsSUFBSSxDQUFDLEVBQUU7WUFDcEIsSUFBSSxDQUFDLEdBQUcsR0FBRyxLQUFLLENBQUM7UUFDbkIsQ0FBQyxFQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQywwQkFBMEIsRUFBRTtZQUMzQyxLQUFLLEVBQUUsT0FBTztZQUNkLElBQUksRUFBRSxJQUFJO1lBQ1YsVUFBVSxFQUFFLHdCQUF3QjtTQUNyQyxDQUFDLENBQUE7SUFDSixDQUFDOzs7OztJQUVELGdCQUFnQixDQUFDLEtBQUs7UUFDcEIsT0FBTyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsQ0FBQzs7Ozs7SUFFTSxZQUFZLENBQUMsSUFBSTtRQUN0QixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztZQUNmLEtBQUssRUFBRSwwQ0FBMEM7WUFDakQsSUFBSSxFQUFFLHlEQUF5RDtZQUMvRCxJQUFJLEVBQUUsU0FBUztZQUNmLGdCQUFnQixFQUFFLElBQUk7WUFDdEIsaUJBQWlCLEVBQUUsS0FBSztZQUN4QixnQkFBZ0IsRUFBRSxLQUFLO1NBQ3hCLENBQUMsQ0FBQyxJQUFJOzs7O1FBQUMsQ0FBTSxPQUFPLEVBQUMsRUFBRTtZQUN0QixJQUFJLE9BQU8sQ0FBQyxLQUFLLEVBQUU7O3NCQUNYLFVBQVUsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztnQkFFL0QsSUFBSSxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtvQkFDdkMsS0FBSyxNQUFNLElBQUksSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO3dCQUM3QixJQUFJLElBQUksQ0FBQyxJQUFJLEtBQUssT0FBTyxFQUFFOzRCQUN6QixJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUU7Z0NBQ2IsSUFBSTtvQ0FDRixNQUFNLElBQUksQ0FBQyxPQUFPLENBQUMsaUJBQWlCLENBQUMsR0FBRyxJQUFJLEVBQUUsQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7aUNBQ3ZFO2dDQUFDLE9BQU8sS0FBSyxFQUFFO29DQUNkLE9BQU8sQ0FBQyxHQUFHLENBQUMsK0NBQStDLEVBQUUsS0FBSyxDQUFDLENBQUM7aUNBQ3JFOzZCQUNGO3lCQUNGO3FCQUNGO2lCQUNGO2dCQUVELFVBQVUsQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDcEIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7Z0JBQ3BCLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLDJCQUEyQixDQUFDLENBQUM7YUFDaEQ7UUFDSCxDQUFDLENBQUEsRUFBQyxDQUFDO0lBQ0wsQ0FBQzs7Ozs7SUFFRCxlQUFlLENBQUMsSUFBSTtJQUVwQixDQUFDOzs7OztJQUVELFNBQVMsQ0FBQyxJQUFJO1FBQ1osT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDbEMsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQzVCLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7Ozs7O0lBRUQsWUFBWSxDQUFDLEdBQUc7O1lBQ1YsTUFBTSxHQUFHLDJFQUEyRTs7WUFDcEYsS0FBSyxHQUFHLEdBQUcsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDO1FBQzdCLE9BQU8sQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDN0QsQ0FBQzs7O1lBaE5GLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsZUFBZTtnQkFDekIsbW1zQkFBeUM7Z0JBRXpDLFNBQVMsRUFBRSxDQUFDLGFBQWEsQ0FBQzs7YUFDM0I7Ozs7WUFoQlEsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQixNQUFNO1lBSU4sU0FBUztZQURULFlBQVk7OzttQkFjbEIsS0FBSztvQkFDTCxLQUFLO3dCQUVMLE1BQU07MEJBRU4sU0FBUyxTQUFDLGFBQWEsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7NkJBQ3pDLFNBQVMsU0FBQyxnQkFBZ0IsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRTs7OztJQU5oRSxpQ0FBYzs7SUFDZCxrQ0FBZTs7SUFFZixzQ0FBeUM7O0lBRXpDLHdDQUFtRTs7SUFDbkUsMkNBQWlGOztJQUVqRix5Q0FBb0I7O0lBQ3BCLHdDQUEyQjs7SUFDM0IsNENBQStCOztJQUMvQixrREFBNkI7O0lBQzdCLGdEQUFpRTs7SUFFakUscUNBQWdCOztJQUNoQix5Q0FBb0I7O0lBQ3BCLHNDQUFpQjs7SUFHZiwwQ0FBbUM7O0lBQ25DLCtCQUEyQjs7SUFDM0IsbUNBQXFCOztJQUNyQixtQ0FBd0I7O0lBQ3hCLG9DQUE0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCwgVmlld0NoaWxkLCBFbGVtZW50UmVmLCBPbkRlc3Ryb3ksIEFmdGVyVmlld0luaXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFN0cmVhbVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9zdHJlYW0uc2VydmljZSc7XHJcbmltcG9ydCB7IEFuZ3VsYXJGaXJlc3RvcmUgfSBmcm9tICdAYW5ndWxhci9maXJlL2ZpcmVzdG9yZSc7XHJcbmltcG9ydCB7IEdsb2JhbCB9IGZyb20gJ2FzYXAtY3J1ZCc7XHJcbmltcG9ydCB7IEZlZWRNb2RhbEl0ZW1FZGl0Q29tcG9uZW50IH0gZnJvbSAnLi4vZmVlZC1wdWJsaWNhdGlvbi9mZWVkLW1vZGFsLWl0ZW0tZWRpdC9mZWVkLW1vZGFsLWl0ZW0tZWRpdC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBwYXRoIH0gZnJvbSAnLi4vY29uc3RhbnRzL2NvbnN0YW50cyc7XHJcbmltcG9ydCB7IFV0aWxzU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL3V0aWxzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2cgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xyXG5cclxuaW1wb3J0IFN3aXBlckNvcmUsIHsgTmF2aWdhdGlvbiwgUGFnaW5hdGlvbiB9IGZyb20gJ3N3aXBlcic7XHJcblN3aXBlckNvcmUudXNlKFtOYXZpZ2F0aW9uLCBQYWdpbmF0aW9uXSk7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1mZWVkLWl0ZW0nLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9mZWVkLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuLi9hc2FwLWZlZWQuYmV0YS5jb21wb25lbnRlLnNjc3MnLCAnLi9mZWVkLWl0ZW0uY29tcG9uZW50LnNjc3MnXSxcclxuICBwcm92aWRlcnM6IFtTdHJlYW1TZXJ2aWNlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRmVlZEl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XHJcblxyXG4gIEBJbnB1dCgpIGl0ZW07XHJcbiAgQElucHV0KCkgb3duZXI7XHJcblxyXG4gIEBPdXRwdXQoKSBpc1Zpc2libGUgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIEBWaWV3Q2hpbGQoJ3ZpZGVvUGxheWVyJywgeyBzdGF0aWM6IHRydWUgfSkgdmlkZW9wbGF5ZXI6IEVsZW1lbnRSZWZcclxuICBAVmlld0NoaWxkKCd2aXNpYmxlQ29udHJvbCcsIHsgc3RhdGljOiBmYWxzZSwgcmVhZDogRWxlbWVudFJlZiB9KSB2aXNpYmxlQ29udHJvbDtcclxuXHJcbiAgcHVibGljIGN1cnJlbnRJbmRleDtcclxuICBwdWJsaWMgaW1hZ2VMb2FkZWQgPSBmYWxzZTtcclxuICBwdWJsaWMgaW1hZ2VEYXRhTG9hZGVkID0gZmFsc2U7XHJcbiAgcHVibGljIGN1cnJlbnRDYXJyb3VzZWxJbmRleDtcclxuICBwdWJsaWMgYmx1ckJhY2tncm91bmRJbmRleCA9IE1hdGguZmxvb3IoKE1hdGgucmFuZG9tKCkgKiA1KSArIDEpO1xyXG5cclxuICBwdWJsaWMgb2JzZXJ2ZXI7XHJcbiAgcHVibGljIHZpc2libGVUaW1lcjtcclxuICBwdWJsaWMgc2hvdFRpbWVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBzdHJlYW1TZXJ2aWNlOiBTdHJlYW1TZXJ2aWNlLFxyXG4gICAgcHVibGljIGRiOiBBbmd1bGFyRmlyZXN0b3JlLFxyXG4gICAgcHVibGljIGdsb2JhbDogR2xvYmFsLFxyXG4gICAgcHVibGljIGRpYWxvZzogTWF0RGlhbG9nLFxyXG4gICAgcHVibGljIHNlcnZpY2U6IFV0aWxzU2VydmljZVxyXG4gICkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5sb2FkVmlzaWJpbGl0eUNvbnRyb2xzKCk7XHJcblxyXG4gICAgaWYgKHRoaXMuaXRlbS5maWxlcyAmJiB0aGlzLml0ZW0uZmlsZXMubGVuZ3RoID4gMCkge1xyXG4gICAgICB0aGlzLml0ZW0uZmlsZXMubWFwKGZlZWQgPT4ge1xyXG4gICAgICAgIGlmIChmZWVkLnVybCAmJiBmZWVkLnVybC5pbmNsdWRlcygneW91dHViZScpKSB7XHJcbiAgICAgICAgICBmZWVkLmlzWW91dHViZSA9IHRydWU7XHJcbiAgICAgICAgICBsZXQgeW91dHViZUlEID0gdGhpcy5nZXRZb3V0dWJlSUQoZmVlZC51cmwpO1xyXG4gICAgICAgICAgZmVlZC51cmwgPSBgaHR0cHM6Ly93d3cueW91dHViZS5jb20vZW1iZWQvJHt5b3V0dWJlSUR9YDtcclxuICAgICAgICB9XHJcbiAgICAgIH0pXHJcbiAgICB9XHJcblxyXG4gICAgLy8gY29uc29sZS5sb2coJ0lURU0gLT4nLCB0aGlzLml0ZW0pO1xyXG4gIH1cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5vYnNlcnZlci5vYnNlcnZlKHRoaXMudmlzaWJsZUNvbnRyb2wubmF0aXZlRWxlbWVudCk7XHJcbiAgfVxyXG5cclxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMub2JzZXJ2ZXIuZGlzY29ubmVjdCgpO1xyXG4gICAgY2xlYXJJbnRlcnZhbCh0aGlzLnZpc2libGVUaW1lcik7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbG9hZFZpc2liaWxpdHlDb250cm9scygpIHtcclxuICAgIHRoaXMudmlzaWJsZVRpbWVyID0gc2V0SW50ZXJ2YWwoKCkgPT4ge1xyXG4gICAgICB0aGlzLnNob3RUaW1lci0tO1xyXG4gICAgICBpZiAodGhpcy5zaG90VGltZXIgPT0gMCkge1xyXG4gICAgICAgIHRoaXMuaXNWaXNpYmxlLmVtaXQodGhpcy5pdGVtKTtcclxuICAgICAgICBjbGVhckludGVydmFsKHRoaXMudmlzaWJsZVRpbWVyKTtcclxuICAgICAgICB0aGlzLm9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcclxuICAgICAgfVxyXG4gICAgfSwgMTAwMCk7XHJcblxyXG4gICAgY29uc3Qgb3B0aW9ucyA9IHtcclxuICAgICAgcm9vdE1hcmdpbjogJzBweCcsXHJcbiAgICAgIHRocmVzaG9sZDogWzAsIDAuMSwgMC4yLCAwLjMsIDAuNCwgMC41LCAwLjYsIDAuNywgMC44LCAwLjksIDEuMF1cclxuICAgIH07XHJcblxyXG4gICAgdGhpcy5vYnNlcnZlciA9IG5ldyBJbnRlcnNlY3Rpb25PYnNlcnZlcigoZW50cmllcywgb2JzZXJ2ZXIpID0+IHtcclxuICAgICAgZW50cmllcy5mb3JFYWNoKGVudHJ5ID0+IHtcclxuICAgICAgICB0aGlzLnNob3RUaW1lciA9IC0xO1xyXG4gICAgICAgIHRoaXMuaXRlbS5hY3RpdmUgPSBmYWxzZTtcclxuICAgICAgICBpZiAoZW50cnkuaW50ZXJzZWN0aW9uUmF0aW8gPT0gMSkge1xyXG4gICAgICAgICAgdGhpcy5zaG90VGltZXIgPSA1O1xyXG4gICAgICAgIH1cclxuICAgICAgfSk7XHJcbiAgICB9LCBvcHRpb25zKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbmxvYWRJbWFnZShldmVudCkge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ0V2ZW50IG9ubG9hZEltYWdlIC0+JywgZXZlbnQpO1xyXG4gICAgdGhpcy5pbWFnZUxvYWRlZCA9IHRydWU7XHJcbiAgICB0aGlzLmltYWdlRGF0YUxvYWRlZCA9IHRydWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25FcnJvckltYWdlKGV2ZW50KSB7XHJcbiAgICAvLyBjb25zb2xlLmxvZygnRXZlbnQgb25FcnJvckltYWdlIC0+JywgZXZlbnQpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHBsYXlWaWRlbyhldmVudCkge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ0V2ZW50IC0+JywgZXZlbnQpO1xyXG4gICAgaWYgKHRoaXMudmlkZW9wbGF5ZXIpIHtcclxuICAgICAgdGhpcy52aWRlb3BsYXllci5uYXRpdmVFbGVtZW50LnBsYXkoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBsaW5raWZ5KHN0cikge1xyXG4gICAgdmFyIHJlOiBhbnk7XHJcbiAgICByZSA9IFtcclxuICAgICAgXCJcXFxcYigoPzpodHRwcz98ZnRwKTovL1teXFxcXHNcXFwiJzw+XSspXFxcXGJcIixcclxuICAgICAgXCJcXFxcYih3d3dcXFxcLlteXFxcXHNcXFwiJzw+XSspXFxcXGJcIixcclxuICAgICAgXCJcXFxcYihcXFxcd1tcXFxcdy4rLV0qQFtcXFxcdy4tXStcXFxcLlthLXpdezIsNn0pXFxcXGJcIixcclxuICAgICAgXCIjKFthLXowLTldKylcIl07XHJcbiAgICByZSA9IG5ldyBSZWdFeHAocmUuam9pbignfCcpLCBcImdpXCIpO1xyXG5cclxuICAgIGlmIChzdHIpIHtcclxuICAgICAgcmV0dXJuIHN0ci5yZXBsYWNlKHJlLCBmdW5jdGlvbiAobWF0Y2gsIHVybCwgd3d3LCBtYWlsLCB0d2l0bGVyKSB7XHJcbiAgICAgICAgaWYgKHVybClcclxuICAgICAgICAgIHJldHVybiBcIjxhIGNsYXNzPSd0ZXh0LXByaW1hcnknIHRhcmdldD0nX2JsYW5rJyAoY2xpY2spPSdyZWRpcmVjdE5ld0xpbmsodXJsKScgaHJlZj1cXFwiXCIgKyB1cmwgKyBcIlxcXCI+XCIgKyB1cmwgKyBcIjwvYT5cIjtcclxuICAgICAgICBpZiAod3d3KVxyXG4gICAgICAgICAgcmV0dXJuIFwiPGEgY2xhc3M9J3RleHQtcHJpbWFyeScgaHJlZj1cXFwiaHR0cDovL1wiICsgd3d3ICsgXCJcXFwiPlwiICsgd3d3ICsgXCI8L2E+XCI7XHJcbiAgICAgICAgaWYgKG1haWwpXHJcbiAgICAgICAgICByZXR1cm4gXCI8YSBjbGFzcz0ndGV4dC1wcmltYXJ5JyBocmVmPVxcXCIjPC9hPlwiO1xyXG4gICAgICAgIGlmICh0d2l0bGVyKVxyXG4gICAgICAgICAgcmV0dXJuIFwiPGEgY2xhc3M9J3RleHQtcHJpbWFyeScgaHJlZj1cXFwicG9ydGFsL3NlYXJjaC9cIiArIGVuY29kZVVSSUNvbXBvbmVudCgnIycgKyB0d2l0bGVyKSArIFwiXFxcIj4jXCIgKyB0d2l0bGVyICsgXCI8L2E+XCI7XHJcbiAgICAgICAgLy8gcmV0dXJuIFwiPGEgY2xhc3M9J3RleHQtcHJpbWFyeScgaHJlZj1cXFwiI1xcXCI+I1wiICsgdHdpdGxlciArIFwiPC9hPlwiO1xyXG5cclxuICAgICAgICAvLyBzaG91bGRudCBnZXQgaGVyZSwgYnV0IGp1c3QgaW4gY2FzZVxyXG4gICAgICAgIHJldHVybiBtYXRjaDtcclxuICAgICAgfSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY2hlY2tWaWRlb1JlbmRlcihpdGVtKSB7XHJcblxyXG4gICAgY29uc29sZS5sb2coJ3ZpZGVvUmVuZGVyIC0+JywgaXRlbSk7XHJcbiAgICB0aGlzLnN0cmVhbVNlcnZpY2Uuc3RhdHVzKGl0ZW0pLnN1YnNjcmliZSgocmVzOiBhbnkpID0+IHtcclxuICAgICAgY29uc29sZS5sb2coJ2NoZWNrVmlkZW9SZW5kZXInLCByZXMpO1xyXG4gICAgfSlcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbkVkaXRJdGVtKCkge1xyXG4gICAgLy8gIFByZXBhcmFyIGZlZWQgcGFyYSBlZGl0YXJcclxuICAgIGxldCBmZWVkO1xyXG4gICAgZmVlZCA9IHRoaXMuaXRlbTtcclxuICAgIGRlbGV0ZSBmZWVkLmNvbW1lbnRzO1xyXG4gICAgZGVsZXRlIGZlZWQubGlrZXM7XHJcblxyXG4gICAgZmVlZC5maWxlcy5tYXAoZmlsZSA9PiB7XHJcbiAgICAgIGZpbGUubmV3ID0gZmFsc2U7XHJcbiAgICB9KTtcclxuXHJcbiAgICB0aGlzLmRpYWxvZy5vcGVuKEZlZWRNb2RhbEl0ZW1FZGl0Q29tcG9uZW50LCB7XHJcbiAgICAgIHdpZHRoOiAnNjAwcHgnLFxyXG4gICAgICBkYXRhOiBmZWVkLFxyXG4gICAgICBwYW5lbENsYXNzOiAnbW9kYWwtZmVlZC1wdWJsaWNhdGlvbidcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBwcmVDb252ZXJ0TnVtYmVyKHZhbHVlKSB7XHJcbiAgICByZXR1cm4gcGFyc2VGbG9hdCh2YWx1ZSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25SZW1vdmVJdGVtKGl0ZW0pIHtcclxuICAgIHRoaXMuZ2xvYmFsLnN3YWwoe1xyXG4gICAgICB0aXRsZTogJ1ZvY8OqIHJlYWxtZW50ZSBkZXNlamEgcmVtb3ZlciBlc3RlIFBvc3Q/JyxcclxuICAgICAgdGV4dDogJ1ZvY8OqIG7Do28gcG9kZXLDoSByZXZlcnRlciBlc3NhIGHDp8OjbyBkZXBvaXMgZGUgY29uZmlybWFkbycsXHJcbiAgICAgIHR5cGU6IFwid2FybmluZ1wiLFxyXG4gICAgICBzaG93Q2FuY2VsQnV0dG9uOiB0cnVlLFxyXG4gICAgICBjb25maXJtQnV0dG9uVGV4dDogXCJTaW1cIixcclxuICAgICAgY2FuY2VsQnV0dG9uVGV4dDogXCJOw6NvXCJcclxuICAgIH0pLnRoZW4oYXN5bmMgY29uZmlybSA9PiB7XHJcbiAgICAgIGlmIChjb25maXJtLnZhbHVlKSB7XHJcbiAgICAgICAgY29uc3QgY29sbGVjdGlvbiA9IHRoaXMuZGIuY29sbGVjdGlvbihwYXRoKCkuZmVlZCkuZG9jKGl0ZW0uaWQpO1xyXG5cclxuICAgICAgICBpZiAoaXRlbS5maWxlcyAmJiBpdGVtLmZpbGVzLmxlbmd0aCA+IDApIHtcclxuICAgICAgICAgIGZvciAoY29uc3QgZmlsZSBvZiBpdGVtLmZpbGVzKSB7XHJcbiAgICAgICAgICAgIGlmIChmaWxlLnR5cGUgPT09ICdpbWFnZScpIHtcclxuICAgICAgICAgICAgICBpZiAoZmlsZS5uYW1lKSB7XHJcbiAgICAgICAgICAgICAgICB0cnkge1xyXG4gICAgICAgICAgICAgICAgICBhd2FpdCB0aGlzLnNlcnZpY2UuZGVsZXRlRmlyZVN0b3JhZ2UoYCR7cGF0aCgpLmltYWdlc30vJHtmaWxlLm5hbWV9YCk7XHJcbiAgICAgICAgICAgICAgICB9IGNhdGNoIChlcnJvcikge1xyXG4gICAgICAgICAgICAgICAgICBjb25zb2xlLmxvZygnUmVtb3ZlbmRvIHVtIHBvc3QgY29tIGltYWdlbSBuw6NvIHJlZmVyZW5jaWFkYScsIGVycm9yKTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgIH1cclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGNvbGxlY3Rpb24uZGVsZXRlKCk7XHJcbiAgICAgICAgaXRlbS5kZWxldGVkID0gdHJ1ZTtcclxuICAgICAgICB0aGlzLmdsb2JhbC50b2FzdCgnUG9zdCByZW1vdmlkbyBjb20gU3VjZXNzbycpO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGNoZWNrRmlsZU9yaWdpbihmaWxlKSB7XHJcblxyXG4gIH1cclxuXHJcbiAgaXNZb3V0dWJlKGZpbGUpIHtcclxuICAgIGNvbnNvbGUubG9nKCdJc1lvdXR1YmUgLT4nLCBmaWxlKTtcclxuICAgIGlmIChmaWxlLmluY2x1ZGVzKCd5b3V0dWJlJykpIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gZmFsc2U7XHJcbiAgfVxyXG5cclxuICBnZXRZb3V0dWJlSUQodXJsKSB7XHJcbiAgICB2YXIgcmVnRXhwID0gL14uKigoeW91dHUuYmVcXC8pfCh2XFwvKXwoXFwvdVxcL1xcd1xcLyl8KGVtYmVkXFwvKXwod2F0Y2hcXD8pKVxcPz92Pz0/KFteIyY/XSopLiovO1xyXG4gICAgdmFyIG1hdGNoID0gdXJsLm1hdGNoKHJlZ0V4cCk7XHJcbiAgICByZXR1cm4gKG1hdGNoICYmIG1hdGNoWzddLmxlbmd0aCA9PSAxMSkgPyBtYXRjaFs3XSA6IGZhbHNlO1xyXG4gIH1cclxuXHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -366,7 +366,7 @@ var FeedItemComponent = /** @class */ (function () {
|
|
|
366
366
|
FeedItemComponent.decorators = [
|
|
367
367
|
{ type: Component, args: [{
|
|
368
368
|
selector: 'app-feed-item',
|
|
369
|
-
template: "<ng-container *ngIf=\"item && item.status && !item.deleted\">\r\n <mat-card #visibleControl class=\"feed-card\" id=\"{{ item.id +'#'+ item.type}}\">\r\n <mat-card-header class=\"feed-header ml-2\">\r\n <popover-content #myPopover placement=\"auto right\" [closeOnClickOutside]=\"false\" [closeOnMouseOutside]=\"false\"\r\n [animation]=\"true\">\r\n <div class='minibio'>\r\n <img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\" alt=\"{{ item?.user_info?.name }}\">\r\n <div class=\"info\"><b>{{ item?.user_info?.name }}</b><br />\r\n <!-- <span class=\"location\"><i class=\"icon fa fa-globe\" aria-hidden=\"true\"></i> Fortaleza/CE</span> -->\r\n </div>\r\n </div>\r\n </popover-content>\r\n <div mat-card-avatar>\r\n <a [routerLink]=\"['/profile',item.user_info?.id]\"><img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n class=\"feed-avatar mr-1\" (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\"\r\n alt=\"{{ item?.user_info?.name }}\" [popover]=\"myPopover\" [popoverOnHover]=\"true\"></a>\r\n </div>\r\n\r\n <mat-card-title>\r\n <h4 class=\"ml-2\"><b><a [routerLink]=\"['/profile',item.user_info?.id]\">{{ item?.user_info?.name }}</a> <i\r\n *ngIf=\"item?.channel_id\" class=\"material-icons text-primary\" matTooltip=\"Este \u00E9 um post Institucional\"\r\n matTooltipClass=\"tooltip-primary\">done_all</i></b>\r\n </h4>\r\n <p class=\"ml-2\"> {{ 'SharedPublication' | translate }}\r\n <!-- <a [routerLink]=\"['/portal',item.id]\">{{ item?.updated_at | amTimeAgo }}</a></p> -->\r\n <a [routerLink]=\"['/portal',item.id]\">{{ item?.updated_at | amCalendar | amDateFormat: 'DD/MM/YYYY' }}</a>\r\n </mat-card-title>\r\n\r\n <ng-container *ngIf=\"global.loggedUser()\">\r\n <div class=\"feed-buttom-option\" *ngIf=\"item.user_info.id === global.loggedUser().id\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\" [disabled]=\"!item.status\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"onEditItem()\" [disabled]=\"!item.status\">\r\n <mat-icon>create</mat-icon>\r\n <span>{{ 'Edit' | translate }}</span>\r\n </button>\r\n <button mat-menu-item (click)=\"onRemoveItem(item)\" [disabled]=\"!item.status\">\r\n <mat-icon>delete</mat-icon>\r\n <span>{{ 'Remove' | translate }}</span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n <div *ngIf=\"item.isHighlighted\" matTooltip=\"Post destacado\" class=\"feed-buttom-option pinned-feed\">\r\n <i class=\"fa fa-thumb-tack fa-lg\"></i>\r\n </div>\r\n </ng-container>\r\n\r\n </mat-card-header>\r\n\r\n <ng-container *ngIf=\"item.type != 'announce'\">\r\n <!-- <code>{{item.additional_data | json}}</code> -->\r\n <ng-container *ngIf=\"!(item.files && item.files.length > 0)\">\r\n <div class=\"card card-file mt-0 pointer\">\r\n <!-- <div class=\"card-cover\"> -->\r\n <ng-container *ngIf=\"item.additional_data && item.additional_data.image\">\r\n <img style=\"display: none;\" [src]=\"item.additional_data.image\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"imageLoaded\">\r\n <img class=\"bg-mat-card\" [src]=\"item.additional_data.image\">\r\n <img mat-card-image [src]=\"item.additional_data.image\">\r\n </div>\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"!imageLoaded\">\r\n <img mat-card-image [src]=\"'assets/img/background-blur-' + blurBackgroundIndex + '.png'\">\r\n </div>\r\n </ng-container>\r\n <!-- </div> -->\r\n <a *ngIf=\"item.additional_data && item.additional_data.file_id\"\r\n [routerLink]=\"['/channel/files/' + item.channel_id +'/'+ item.additional_data.file_id]\" class=\"circle\">\r\n <i class=\"fa fa-file-text-o\"></i>\r\n </a>\r\n <div *ngIf=\"item.additional_data && item.additional_data.description\" class=\"card-content\">\r\n <div class=\"clearfix\"></div>\r\n <p class=\"description m-3\" [innerHTML]=\"linkify(item.additional_data.description)\"></p>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"item.files && item.files.length > 0\">\r\n\r\n <ng-container *ngIf=\"item.files.length === 1\">\r\n <ng-container *ngFor=\"let file of item.files\">\r\n <ng-container *ngIf=\"file.type == 'image'\">\r\n\r\n <img style=\"display: none;\" [src]=\"file.name || file.url\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"imageLoaded\">\r\n <img class=\"bg-mat-card\" [src]=\"file.name || file.url\">\r\n <img mat-card-image [src]=\"file.name || file.url\">\r\n </div>\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"!imageLoaded\">\r\n <img mat-card-image [src]=\"'assets/img/background-blur-' + blurBackgroundIndex + '.png'\">\r\n </div>\r\n\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'video'\">\r\n <div class=\"carousel custom-carrousel\">\r\n <div class=\"content\">\r\n <div class=\"item\">\r\n <div class=\"video-overlay cloudinary-true\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\"></div>\r\n\r\n <div class=\"video-overlay youtube-true\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\"></div>\r\n\r\n <div class=\"video-overlay not-cloudinary-youtube\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\"></div>\r\n\r\n <video attr.type='stream' #videoPlayer *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video not-cloudinary-youtube\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer *ngIf=\"file.isCloudinary == true\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video cloudinary-true\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube == true\">\r\n <iframe attr.type='youtube' #videoPlayer [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'pdf' || file.type == 'txt'\">\r\n <div class=\"container-mat-card px-3\">\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id + '/' + file.file_id]\" class=\"w-100\">\r\n\r\n <div class=\"card card-file mt-0 pointer\">\r\n <div class=\"card-cover\">\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id +'/'+ file.file_id]\">\r\n <ng-container *ngIf=\"file.image\">\r\n <img [src]=\"file.image\" alt=\"\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!file.image || file.image == null\">\r\n <h4 class=\"title\" [innerHTML]=\"linkify(file.title)\"></h4>\r\n </ng-container>\r\n </a>\r\n </div>\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id +'/'+ file.file_id]\" class=\"circle\">\r\n <i *ngIf=\"file.type == 'pdf'\" class=\"fa fa-file-pdf-o\"></i>\r\n <i *ngIf=\"file.type == 'txt'\" class=\"fa fa-file-text-o\"></i>\r\n </a>\r\n <div class=\"card-content\">\r\n <div class=\"clearfix\"></div>\r\n <p class=\"description mb-3\" [innerHTML]=\"linkify(file.description)\"></p>\r\n </div>\r\n </div>\r\n\r\n </a>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'embed'\">\r\n <iframe class=\"video\" style=\"height: 280px; width: 100%;margin-top: 15px;\"\r\n [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\" allowfullscreen></iframe>\r\n </ng-container>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngIf=\"item.files.length > 1\">\r\n\r\n <!-- Carrosel de Imavens e v\u00EDdeos -->\r\n\r\n <div class=\"swiper-stage\">\r\n <swiper [config]=\"global.swiperConfig(false)\">\r\n <div swiperSlide *ngFor=\"let file of item.files; let i = index\">\r\n <div class=\"swiper-carousel-custom\">\r\n\r\n <!-- Imagem -->\r\n\r\n <ng-container *ngIf=\"file.type === 'image'\">\r\n <ng-container *ngIf=\"file.url\">\r\n <div class=\"swiper-container-img\">\r\n <div class=\"swiper-bg-blur\" [style.backgroundImage]=\"'url('+file.url+')'\">\r\n </div>\r\n <img class=\"img\" [src]=\"file.url\" alt=\"\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.name\">\r\n <div class=\"swiper-container-img\" [style.backgroundImage]=\"'url('+file.name+')'\">\r\n <div class=\"swiper-bg-blur\" [style.backgroundImage]=\"'url('+file.name+')'\">\r\n </div>\r\n <img class=\"img\" [src]=\"file.name\" alt=\"\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <!-- Video -->\r\n\r\n <ng-container *ngIf=\"file.type === 'video'\">\r\n\r\n <ng-container>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <video attr.type='stream' #videoPlayer *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\"\r\n width=\"100%\" controls=\"false\" preload=\"metadata\" poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer *ngIf=\"file.isCloudinary == true\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\"\r\n width=\"100%\" controls=\"false\" preload=\"metadata\" poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube == true\">\r\n <iframe attr.type='youtube' #videoPlayer [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n <!-- Verifica se o V\u00EDdeo \u00E9 a primeira posi\u00E7\u00E3o do Slide -->\r\n <!-- <ng-container *ngIf=\" i === 0\">\r\n\r\n <div class=\"video-overlay\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <video attr.type='stream' #videoPlayer\r\n *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer\r\n *ngIf=\"file.isCloudinary === true\" (click)=\"playVideo($event)\"\r\n (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\" width=\"100%\"\r\n controls=\"false\" preload=\"metadata\" poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube === true\">\r\n <iframe attr.type='youtube' #videoPlayer\r\n [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </ng-container> -->\r\n\r\n </ng-container>\r\n\r\n <ng-template #infiniteContainer></ng-template>\r\n </div>\r\n </div>\r\n </swiper>\r\n </div>\r\n\r\n <!-- Fim Carrosel de Imagens e V\u00EDdeos -->\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"item.type == 'announce'\">\r\n <div class=\"ribbon ribbon-top-right\"><span>An\u00FAncio</span></div>\r\n\r\n <div class=\"swiper-stage\">\r\n <swiper [config]=\"global.swiperConfig(false)\">\r\n <div swiperSlide *ngFor=\"let file of item.files; let i = index\">\r\n <div class=\"swiper-carousel-custom\">\r\n <ng-container *ngIf=\"file.type === 'image'\">\r\n <div class=\"img\" [style.backgroundImage]=\"'url('+file.name+')'\" *ngIf=\"file.name\">\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type === 'video'\">\r\n\r\n <ng-container>\r\n\r\n <div class=\"video-overlay\" [style.background-image]=\"file.url | stream:'styleThumbUrl'\">\r\n </div>\r\n\r\n <video class=\"video\" width=\"100%\" preload=\"metadata\" poster=\"{{ file.url | stream:'thumb' }}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n </ng-container>\r\n\r\n <!-- Verifica se o V\u00EDdeo \u00E9 a primeira posi\u00E7\u00E3o do Slide -->\r\n <!-- <ng-container *ngIf=\" i === 0\">\r\n\r\n <div class=\"video-overlay\"\r\n [style.background-image]=\"file.url | stream:'styleThumbUrl'\">\r\n </div>\r\n\r\n <video class=\"video\" width=\"100%\" preload=\"metadata\"\r\n poster=\"{{ file.url | stream:'thumb' }}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n </ng-container> -->\r\n\r\n </ng-container>\r\n </div>\r\n </div>\r\n <ng-template #infiniteContainer></ng-template>\r\n </swiper>\r\n </div>\r\n\r\n <div class=\"pull-right mt-3\" [routerLink]=\"['/market/product/', item.product.id]\">\r\n <button class=\"btn btn-primary\">\r\n <i class=\"fa fa-shopping-cart\"></i>\r\n {{ preConvertNumber(item.product.valorDe) | currency:'BRL':true}} -\r\n {{ preConvertNumber(item.product.valorAte) | currency:'BRL':true}}\r\n </button>\r\n </div>\r\n <p *ngIf=\"item?.product?.data?.descr\" [innerHTML]=\"item.product.descr\"></p>\r\n </ng-container>\r\n\r\n <div class=\"mat-card-content\">\r\n <span class=\"ws-pre-wrap post-text mt-1 mb-4\" [innerHTML]=\"linkify(item.title)\"></span>\r\n <feed-actions [item]=\"item\"></feed-actions>\r\n <feed-comments [feed_id]=\"item.id\" [user]=\"item.user_info\"></feed-comments>\r\n </div>\r\n\r\n </mat-card>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"item && !item.status\">\r\n <ng-container *ngIf=\"global.loggedUser()\">\r\n <ng-container *ngIf=\"item.user_info.id === global.loggedUser().id\">\r\n <ng-container *ngIf=\"item\">\r\n <mat-card #visibleControl class=\"feed-card\" id=\"{{ item.id +'#'+ item.type}}\">\r\n <mat-card-header class=\"feed-header ml-2\">\r\n <div mat-card-avatar>\r\n <img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n class=\"feed-avatar\" (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\"\r\n alt=\"{{ item?.user_info?.name }}\">\r\n </div>\r\n <mat-card-title>\r\n <h4><b>{{ item?.user_info?.name }}</b></h4>\r\n <!-- <p> {{ 'SharedPublication' | translate }} <a>{{ item?.updated_at | amTimeAgo }}</a></p> -->\r\n <p> {{ 'SharedAPostOn' | translate }}\r\n <a>{{ item?.updated_at | amCalendar | amDateFormat: 'DD/MM/YYYY' }}</a>\r\n </p>\r\n </mat-card-title>\r\n\r\n <div class=\"feed-buttom-option\" *ngIf=\"false\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"false\">\r\n <mat-icon>create</mat-icon>\r\n <span>{{ 'Edit' | translate }}</span>\r\n </button>\r\n <button mat-menu-item (click)=\"false\">\r\n <mat-icon>delete</mat-icon>\r\n <span>{{ 'Remove' | translate }}</span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n\r\n </mat-card-header>\r\n\r\n <ng-container>\r\n <div class=\"col-sm-12 mx-auto text-center post-processing-section\">\r\n <img src=\"https://image.flaticon.com/icons/svg/2654/2654464.svg\" width=\"30%\">\r\n <h4>Estamos processando os dados do seu Post!</h4>\r\n <p>No momento ele est\u00E1 vis\u00EDvel apenas para voc\u00EA, mas logo estar\u00E1 dispon\u00EDvel para todos!</p>\r\n </div>\r\n </ng-container>\r\n\r\n <span class=\"ws-pre-wrap post-text mt-1 mb-4\" [innerHTML]=\"linkify(item.title)\"></span>\r\n <feed-actions prefix=\"prefix\" [item]=\"item\"></feed-actions>\r\n <feed-comments prefix=\"prefix\" [feed_id]=\"item.id\" [user]=\"item.user_info\"></feed-comments>\r\n </mat-card>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>\r\n",
|
|
369
|
+
template: "<ng-container *ngIf=\"item && item.status && !item.deleted\">\r\n <mat-card #visibleControl class=\"feed-card\" id=\"{{ item.id +'#'+ item.type}}\">\r\n <mat-card-header class=\"feed-header ml-2\">\r\n <popover-content #myPopover placement=\"auto right\" [closeOnClickOutside]=\"false\" [closeOnMouseOutside]=\"false\"\r\n [animation]=\"true\">\r\n <div class='minibio'>\r\n <img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\" alt=\"{{ item?.user_info?.name }}\">\r\n <div class=\"info\"><b>{{ item?.user_info?.name }}</b><br />\r\n <!-- <span class=\"location\"><i class=\"icon fa fa-globe\" aria-hidden=\"true\"></i> Fortaleza/CE</span> -->\r\n </div>\r\n </div>\r\n </popover-content>\r\n <div mat-card-avatar>\r\n <a [routerLink]=\"['/profile',item.user_info?.id]\"><img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n class=\"feed-avatar mr-1\" (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\"\r\n alt=\"{{ item?.user_info?.name }}\" [popover]=\"myPopover\" [popoverOnHover]=\"true\"></a>\r\n </div>\r\n\r\n <mat-card-title>\r\n <h4 class=\"ml-2\"><b><a [routerLink]=\"['/profile',item.user_info?.id]\">{{ item?.user_info?.name }}</a> <i\r\n *ngIf=\"item?.channel_id\" class=\"material-icons text-primary\" matTooltip=\"Este \u00E9 um post Institucional\"\r\n matTooltipClass=\"tooltip-primary\">done_all</i></b>\r\n </h4>\r\n <p class=\"ml-2\"> {{ 'SharedAPostOn' | translate }}\r\n <!-- <a [routerLink]=\"['/portal',item.id]\">{{ item?.updated_at | amTimeAgo }}</a></p> -->\r\n <a [routerLink]=\"['/portal',item.id]\">{{ item?.updated_at | amCalendar | amDateFormat: 'DD/MM/YYYY' }}</a>\r\n </mat-card-title>\r\n\r\n <ng-container *ngIf=\"global.loggedUser()\">\r\n <div class=\"feed-buttom-option\" *ngIf=\"item.user_info.id === global.loggedUser().id\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\" [disabled]=\"!item.status\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"onEditItem()\" [disabled]=\"!item.status\">\r\n <mat-icon>create</mat-icon>\r\n <span>{{ 'Edit' | translate }}</span>\r\n </button>\r\n <button mat-menu-item (click)=\"onRemoveItem(item)\" [disabled]=\"!item.status\">\r\n <mat-icon>delete</mat-icon>\r\n <span>{{ 'Remove' | translate }}</span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n <div *ngIf=\"item.isHighlighted\" matTooltip=\"Post destacado\" class=\"feed-buttom-option pinned-feed\">\r\n <i class=\"fa fa-thumb-tack fa-lg\"></i>\r\n </div>\r\n </ng-container>\r\n\r\n </mat-card-header>\r\n\r\n <ng-container *ngIf=\"item.type != 'announce'\">\r\n <!-- <code>{{item.additional_data | json}}</code> -->\r\n <ng-container *ngIf=\"!(item.files && item.files.length > 0)\">\r\n <div class=\"card card-file mt-0 pointer\">\r\n <!-- <div class=\"card-cover\"> -->\r\n <ng-container *ngIf=\"item.additional_data && item.additional_data.image\">\r\n <img style=\"display: none;\" [src]=\"item.additional_data.image\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"imageLoaded\">\r\n <img class=\"bg-mat-card\" [src]=\"item.additional_data.image\">\r\n <img mat-card-image [src]=\"item.additional_data.image\">\r\n </div>\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"!imageLoaded\">\r\n <img mat-card-image [src]=\"'assets/img/background-blur-' + blurBackgroundIndex + '.png'\">\r\n </div>\r\n </ng-container>\r\n <!-- </div> -->\r\n <a *ngIf=\"item.additional_data && item.additional_data.file_id\"\r\n [routerLink]=\"['/channel/files/' + item.channel_id +'/'+ item.additional_data.file_id]\" class=\"circle\">\r\n <i class=\"fa fa-file-text-o\"></i>\r\n </a>\r\n <div *ngIf=\"item.additional_data && item.additional_data.description\" class=\"card-content\">\r\n <div class=\"clearfix\"></div>\r\n <p class=\"description m-3\" [innerHTML]=\"linkify(item.additional_data.description)\"></p>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"item.files && item.files.length > 0\">\r\n\r\n <ng-container *ngIf=\"item.files.length === 1\">\r\n <ng-container *ngFor=\"let file of item.files\">\r\n <ng-container *ngIf=\"file.type == 'image'\">\r\n\r\n <img style=\"display: none;\" [src]=\"file.name || file.url\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"imageLoaded\">\r\n <img class=\"bg-mat-card\" [src]=\"file.name || file.url\">\r\n <img mat-card-image [src]=\"file.name || file.url\">\r\n </div>\r\n\r\n <div class=\"container-mat-card\" *ngIf=\"!imageLoaded\">\r\n <img mat-card-image [src]=\"'assets/img/background-blur-' + blurBackgroundIndex + '.png'\">\r\n </div>\r\n\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'video'\">\r\n <div class=\"carousel custom-carrousel\">\r\n <div class=\"content\">\r\n <div class=\"item\">\r\n <div class=\"video-overlay cloudinary-true\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\"></div>\r\n\r\n <div class=\"video-overlay youtube-true\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\"></div>\r\n\r\n <div class=\"video-overlay not-cloudinary-youtube\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\"></div>\r\n\r\n <video attr.type='stream' #videoPlayer *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video not-cloudinary-youtube\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer *ngIf=\"file.isCloudinary == true\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video cloudinary-true\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube == true\">\r\n <iframe attr.type='youtube' #videoPlayer [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'pdf' || file.type == 'txt'\">\r\n <div class=\"container-mat-card px-3\">\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id + '/' + file.file_id]\" class=\"w-100\">\r\n\r\n <div class=\"card card-file mt-0 pointer\">\r\n <div class=\"card-cover\">\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id +'/'+ file.file_id]\">\r\n <ng-container *ngIf=\"file.image\">\r\n <img [src]=\"file.image\" alt=\"\">\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!file.image || file.image == null\">\r\n <h4 class=\"title\" [innerHTML]=\"linkify(file.title)\"></h4>\r\n </ng-container>\r\n </a>\r\n </div>\r\n <a [routerLink]=\"['/channel/files/' + file.channel_id +'/'+ file.file_id]\" class=\"circle\">\r\n <i *ngIf=\"file.type == 'pdf'\" class=\"fa fa-file-pdf-o\"></i>\r\n <i *ngIf=\"file.type == 'txt'\" class=\"fa fa-file-text-o\"></i>\r\n </a>\r\n <div class=\"card-content\">\r\n <div class=\"clearfix\"></div>\r\n <p class=\"description mb-3\" [innerHTML]=\"linkify(file.description)\"></p>\r\n </div>\r\n </div>\r\n\r\n </a>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type == 'embed'\">\r\n <iframe class=\"video\" style=\"height: 280px; width: 100%;margin-top: 15px;\"\r\n [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\" allowfullscreen></iframe>\r\n </ng-container>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n\r\n <ng-container *ngIf=\"item.files.length > 1\">\r\n\r\n <!-- Carrosel de Imavens e v\u00EDdeos -->\r\n\r\n <div class=\"swiper-stage\">\r\n <swiper [config]=\"global.swiperConfig(false)\">\r\n <div swiperSlide *ngFor=\"let file of item.files; let i = index\">\r\n <div class=\"swiper-carousel-custom\">\r\n\r\n <!-- Imagem -->\r\n\r\n <ng-container *ngIf=\"file.type === 'image'\">\r\n <ng-container *ngIf=\"file.url\">\r\n <div class=\"swiper-container-img\">\r\n <div class=\"swiper-bg-blur\" [style.backgroundImage]=\"'url('+file.url+')'\">\r\n </div>\r\n <img class=\"img\" [src]=\"file.url\" alt=\"\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.name\">\r\n <div class=\"swiper-container-img\" [style.backgroundImage]=\"'url('+file.name+')'\">\r\n <div class=\"swiper-bg-blur\" [style.backgroundImage]=\"'url('+file.name+')'\">\r\n </div>\r\n <img class=\"img\" [src]=\"file.name\" alt=\"\" (load)=\"onloadImage($event)\"\r\n (error)=\"onErrorImage($event)\">\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <!-- Video -->\r\n\r\n <ng-container *ngIf=\"file.type === 'video'\">\r\n\r\n <ng-container>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <video attr.type='stream' #videoPlayer *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\"\r\n width=\"100%\" controls=\"false\" preload=\"metadata\" poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer *ngIf=\"file.isCloudinary == true\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\"\r\n width=\"100%\" controls=\"false\" preload=\"metadata\" poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube == true\">\r\n <iframe attr.type='youtube' #videoPlayer [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n <!-- Verifica se o V\u00EDdeo \u00E9 a primeira posi\u00E7\u00E3o do Slide -->\r\n <!-- <ng-container *ngIf=\" i === 0\">\r\n\r\n <div class=\"video-overlay\" *ngIf=\"file.isCloudinary == true\"\r\n [style.background-image]=\"file.thumb | stream: 'backgroundImage'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isYoutube == true\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <div class=\"video-overlay\" *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n [style.background-image]=\"file.url | stream: 'styleThumbUrl'\">\r\n </div>\r\n\r\n <video attr.type='stream' #videoPlayer\r\n *ngIf=\"!file.isCloudinary && !file.isYoutube\"\r\n (click)=\"playVideo($event)\" (onloadeddata)=\"checkVideoRender(file.url)\"\r\n class=\"video\" width=\"100%\" controls=\"false\" preload=\"metadata\"\r\n poster=\"{{file.url | stream:'thumb'}}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n <video attr.type='cloudinary' #videoPlayer\r\n *ngIf=\"file.isCloudinary === true\" (click)=\"playVideo($event)\"\r\n (onloadeddata)=\"checkVideoRender(file.url)\" class=\"video\" width=\"100%\"\r\n controls=\"false\" preload=\"metadata\" poster=\"{{file.thumb}}\">\r\n <source [src]=\"file.url\" />\r\n </video>\r\n\r\n <ng-container *ngIf=\"file.isYoutube === true\">\r\n <iframe attr.type='youtube' #videoPlayer\r\n [src]=\"file.url | safe:'resourceUrl'\" frameborder=\"0\"\r\n frameborder=\"0\" width=\"100%\" class=\"video\"></iframe>\r\n </ng-container>\r\n\r\n </ng-container> -->\r\n\r\n </ng-container>\r\n\r\n <ng-template #infiniteContainer></ng-template>\r\n </div>\r\n </div>\r\n </swiper>\r\n </div>\r\n\r\n <!-- Fim Carrosel de Imagens e V\u00EDdeos -->\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"item.type == 'announce'\">\r\n <div class=\"ribbon ribbon-top-right\"><span>An\u00FAncio</span></div>\r\n\r\n <div class=\"swiper-stage\">\r\n <swiper [config]=\"global.swiperConfig(false)\">\r\n <div swiperSlide *ngFor=\"let file of item.files; let i = index\">\r\n <div class=\"swiper-carousel-custom\">\r\n <ng-container *ngIf=\"file.type === 'image'\">\r\n <div class=\"img\" [style.backgroundImage]=\"'url('+file.name+')'\" *ngIf=\"file.name\">\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"file.type === 'video'\">\r\n\r\n <ng-container>\r\n\r\n <div class=\"video-overlay\" [style.background-image]=\"file.url | stream:'styleThumbUrl'\">\r\n </div>\r\n\r\n <video class=\"video\" width=\"100%\" preload=\"metadata\" poster=\"{{ file.url | stream:'thumb' }}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n </ng-container>\r\n\r\n <!-- Verifica se o V\u00EDdeo \u00E9 a primeira posi\u00E7\u00E3o do Slide -->\r\n <!-- <ng-container *ngIf=\" i === 0\">\r\n\r\n <div class=\"video-overlay\"\r\n [style.background-image]=\"file.url | stream:'styleThumbUrl'\">\r\n </div>\r\n\r\n <video class=\"video\" width=\"100%\" preload=\"metadata\"\r\n poster=\"{{ file.url | stream:'thumb' }}\">\r\n <source [src]=\"file.url | stream:'link'\" />\r\n </video>\r\n\r\n </ng-container> -->\r\n\r\n </ng-container>\r\n </div>\r\n </div>\r\n <ng-template #infiniteContainer></ng-template>\r\n </swiper>\r\n </div>\r\n\r\n <div class=\"pull-right mt-3\" [routerLink]=\"['/market/product/', item.product.id]\">\r\n <button class=\"btn btn-primary\">\r\n <i class=\"fa fa-shopping-cart\"></i>\r\n {{ preConvertNumber(item.product.valorDe) | currency:'BRL':true}} -\r\n {{ preConvertNumber(item.product.valorAte) | currency:'BRL':true}}\r\n </button>\r\n </div>\r\n <p *ngIf=\"item?.product?.data?.descr\" [innerHTML]=\"item.product.descr\"></p>\r\n </ng-container>\r\n\r\n <div class=\"mat-card-content\">\r\n <span class=\"ws-pre-wrap post-text mt-1 mb-4\" [innerHTML]=\"linkify(item.title)\"></span>\r\n <feed-actions [item]=\"item\"></feed-actions>\r\n <feed-comments [feed_id]=\"item.id\" [user]=\"item.user_info\"></feed-comments>\r\n </div>\r\n\r\n </mat-card>\r\n</ng-container>\r\n\r\n<ng-container *ngIf=\"item && !item.status\">\r\n <ng-container *ngIf=\"global.loggedUser()\">\r\n <ng-container *ngIf=\"item.user_info.id === global.loggedUser().id\">\r\n <ng-container *ngIf=\"item\">\r\n <mat-card #visibleControl class=\"feed-card\" id=\"{{ item.id +'#'+ item.type}}\">\r\n <mat-card-header class=\"feed-header ml-2\">\r\n <div mat-card-avatar>\r\n <img\r\n [src]=\"(item.user_info?.picture)? item.user_info.picture : 'assets/img/default-avatar.png' || 'assets/img/default-avatar.png'\"\r\n class=\"feed-avatar\" (error)=\"item.user_info.picture = 'assets/img/default-avatar.png'\"\r\n alt=\"{{ item?.user_info?.name }}\">\r\n </div>\r\n <mat-card-title>\r\n <h4><b>{{ item?.user_info?.name }}</b></h4>\r\n <!-- <p> {{ 'SharedPublication' | translate }} <a>{{ item?.updated_at | amTimeAgo }}</a></p> -->\r\n <p> {{ 'SharedAPostOn' | translate }}\r\n <a>{{ item?.updated_at | amCalendar | amDateFormat: 'DD/MM/YYYY' }}</a>\r\n </p>\r\n </mat-card-title>\r\n\r\n <div class=\"feed-buttom-option\" *ngIf=\"false\">\r\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <button mat-menu-item (click)=\"false\">\r\n <mat-icon>create</mat-icon>\r\n <span>{{ 'Edit' | translate }}</span>\r\n </button>\r\n <button mat-menu-item (click)=\"false\">\r\n <mat-icon>delete</mat-icon>\r\n <span>{{ 'Remove' | translate }}</span>\r\n </button>\r\n </mat-menu>\r\n </div>\r\n\r\n </mat-card-header>\r\n\r\n <ng-container>\r\n <div class=\"col-sm-12 mx-auto text-center post-processing-section\">\r\n <img src=\"https://image.flaticon.com/icons/svg/2654/2654464.svg\" width=\"30%\">\r\n <h4>Estamos processando os dados do seu Post!</h4>\r\n <p>No momento ele est\u00E1 vis\u00EDvel apenas para voc\u00EA, mas logo estar\u00E1 dispon\u00EDvel para todos!</p>\r\n </div>\r\n </ng-container>\r\n\r\n <span class=\"ws-pre-wrap post-text mt-1 mb-4\" [innerHTML]=\"linkify(item.title)\"></span>\r\n <feed-actions prefix=\"prefix\" [item]=\"item\"></feed-actions>\r\n <feed-comments prefix=\"prefix\" [feed_id]=\"item.id\" [user]=\"item.user_info\"></feed-comments>\r\n </mat-card>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>\r\n",
|
|
370
370
|
providers: [StreamService],
|
|
371
371
|
styles: ["li,ul{list-style:none!important}a,a:hover{text-decoration:none}.text-primary{color:var(--main-color)}.card{border-radius:6px;box-shadow:1px 1px 10px rgba(201,191,187,.7);-moz-box-shadow:1px 1px 10px rgba(201,191,187,.7);-webkit-box-shadow:1px 1px 10px rgba(201,191,187,.7);border:none;margin-bottom:30px;margin-top:0}.card .card-content{flex:1 1 auto;padding:1.25rem}.comments{margin:30px -15px}.comments h4{font-size:16px;color:#414141;margin-bottom:0;font-weight:600}.comments p{margin:5px 15px 5px 65px;font-size:14px;word-break:break-all}.post-text{white-space:pre-wrap!important;font-size:14px}.form-feed{width:100%;margin:0 0 25px!important;padding:10px 15px!important;border-radius:8px;box-shadow:1px 1px 15px rgba(201,191,187,.7);-moz-box-shadow:1px 1px 15px rgba(201,191,187,.7);-webkit-box-shadow:1px 1px 15px rgba(201,191,187,.7);background-color:var(--bg-card)!important}.form-feed .title{font-size:16px;margin-bottom:10px;border-bottom:1px solid #eee;padding-bottom:10px}.form-feed textarea{float:left;width:calc(100% - 50px);border-bottom:1px solid #eee;border-top:transparent;border-left:transparent;border-right:transparent;box-shadow:none;padding:5px 10px;outline:0!important}.form-input-btn a{float:right;border:none!important;box-shadow:none!important;background:0 0;padding:0;margin-top:12px;position:relative;right:0;left:0;margin-bottom:0;color:#8e8994}.form-input-btn a .material-icons{font-size:18px}.mat-dialog-container{padding:0!important}.form-comment{width:100%;margin:0!important;padding:15px 0 0!important;border-top:1px solid #eee}.form-comment input[type=text]{float:left;width:calc(100% - 50px);border:1px solid #eee;box-shadow:none;border-radius:30px;padding:5px 10px;outline:0}input::-webkit-input-placeholder{color:#ccc}input::-moz-placeholder{color:#ccc}input:-ms-input-placeholder{color:#ccc}input::-ms-input-placeholder{color:#ccc}input::placeholder{color:#ccc}.avatar-30{float:left;width:30px;height:30px;margin-right:10px;border-radius:50%}.avatar-30-null{display:flex;align-items:center;justify-content:center;float:left;width:30px;height:30px;margin-right:10px;border-radius:50%;background:#fafafa;color:#bbb}.comment-time{position:absolute;right:15px}.avatar-45{float:left;width:40px;height:40px;margin-right:10px;border-radius:50%}.avatar-45-null{display:flex;align-items:center;justify-content:center;float:left;width:40px;height:40px;margin-right:10px;border-radius:50%;background:#fafafa;color:#bbb;border:1.3px solid var(--main-color)}.super-post{position:absolute;right:15px;top:10px;font-size:1.8em;color:#888}.icons-comments{margin:10px 0 0;padding:10px 20px;border-top:1px solid #eee;border-bottom:1px solid #eee}.icons-comments li{display:inline-block;margin-right:30px;font-size:14px}.icons-comments li:last-child{margin-right:0;position:absolute;right:20px}.icons-comments li a{color:#4a4a4a;cursor:pointer}.icons-comments li a.active,.icons-comments li a:hover{color:var(--main-color)}.icons-comments .fa{font-size:16px}.card-file{width:100%;margin:0 auto 30px;box-shadow:0 0 30px rgba(204,204,204,.4);border:none;border-radius:12px;transition:.5s}.card-file:hover{box-shadow:0 0 30px rgba(204,204,204,.8)}.card-file .card-cover{display:flex;align-items:center;justify-content:center;padding:15px;position:relative;width:100%;height:160px;border-top-left-radius:16px;border-top-right-radius:12px;-o-object-fit:cover;object-fit:cover;background-size:cover;background-position:center;z-index:1;background:var(--main-color);color:#fff!important}.card-file .card-content{height:auto;padding:0 15px}.card-file .card-content .description{color:#888}.card-file .title{color:#fff;margin-bottom:0;font-size:18px;text-shadow:2px 2px 2px #101010}.btn-feed{width:auto;font-size:12px;padding:2px 5px;border-radius:30px;font-weight:600;text-transform:capitalize}.btn-group-xs>.btn,.btn-xs{padding:2px 15px 3px;font-size:13px;line-height:1;border-radius:30px}.btn-primary,.btn-primary:hover{color:var(--text-btn)!important;background-color:var(--bg-btn);border-color:var(--bg-btn)}.btn-primary.focus,.btn-primary:focus{background-color:var(--bg-btn);border-color:var(--bg-btn);box-shadow:0 0 0 .2rem rgba(0,0,0,.5)}.btn-primary.disabled,.btn-primary:disabled,.btn-primary:not(:disabled):not(.disabled).active,.btn-primary:not(:disabled):not(.disabled):active,.show>.btn-primary.dropdown-toggle{color:var(--text-btn)!important;background-color:var(--bg-btn);border-color:var(--bg-btn)}.btn-primary:not(:disabled):not(.disabled).active:focus,.btn-primary:not(:disabled):not(.disabled):active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,0,0,.5)}.btn-secondary{color:#fff;background-color:#111;border-color:#111}.btn-secondary:hover{color:#fff;background-color:#333;border-color:#333}.btn-secondary.focus,.btn-secondary:focus{background-color:#333;border-color:#333;box-shadow:0 0 0 .2rem rgba(0,0,0,.5)}.btn-secondary.disabled,.btn-secondary:disabled{color:#fff;background-color:#111;border-color:#111}.btn-secondary:not(:disabled):not(.disabled).active,.btn-secondary:not(:disabled):not(.disabled):active,.show>.btn-secondary.dropdown-toggle{color:#fff;background-color:#333;border-color:#333}.btn-secondary:not(:disabled):not(.disabled).active:focus,.btn-secondary:not(:disabled):not(.disabled):active:focus,.show>.btn-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem rgba(0,0,0,.5)}.ribbon{width:150px;height:150px;overflow:hidden;position:absolute;z-index:1}.ribbon::after,.ribbon::before{position:absolute;z-index:-1;content:\"\";display:block;border:5px solid var(--bg-btn)}.ribbon span{position:absolute;display:block;width:225px;padding:15px 0;background-color:var(--bg-btn);box-shadow:0 5px 10px rgba(0,0,0,.1);color:#fff;font:700 18px/1 Lato,sans-serif;text-shadow:0 1px 1px rgba(0,0,0,.2);text-transform:uppercase;text-align:center}.ribbon-top-left{top:-10px;left:-10px;background:0 0}.ribbon-top-left::after,.ribbon-top-left::before{border-top-color:transparent;border-left-color:transparent}.ribbon-top-left::before{top:0;right:0}.ribbon-top-left::after{bottom:0;left:0}.ribbon-top-left span{right:-25px;top:30px;transform:rotate(-45deg)}.ribbon-top-right{top:-10px;right:-10px;background:0 0!important}.ribbon-top-right::after,.ribbon-top-right::before{border-top-color:transparent;border-right-color:transparent}.ribbon-top-right::before{top:0;left:0}.ribbon-top-right::after{bottom:0;right:0}.ribbon-top-right span{left:-25px;top:30px;transform:rotate(45deg)}.ribbon-bottom-left{bottom:-10px;left:-10px}.ribbon-bottom-left::after,.ribbon-bottom-left::before{border-bottom-color:transparent;border-left-color:transparent}.ribbon-bottom-left::before{bottom:0;right:0}.ribbon-bottom-left::after{top:0;left:0}.ribbon-bottom-left span{right:-25px;bottom:30px;transform:rotate(225deg)}.ribbon-bottom-right{bottom:-10px;right:-10px}.ribbon-bottom-right::after,.ribbon-bottom-right::before{border-bottom-color:transparent;border-right-color:transparent}.ribbon-bottom-right::before{bottom:0;left:0}.ribbon-bottom-right::after{top:0;right:0}.ribbon-bottom-right span{left:-25px;bottom:30px;transform:rotate(-225deg)}.video-container{min-height:200px}.video-container img{width:100%;-o-object-fit:cover;object-fit:cover;-webkit-filter:blur(10px);filter:blur(10px)}.video-player{top:0;left:1px;width:calc(100% - 2px)}.tmp-file-buttons-overlay{opacity:1}.overlayed{opacity:1!important;visibility:visible}.tmp-file-status-overlay{position:absolute;background:rgba(0,0,0,.5);text-align:center;z-index:9999999999;color:#fff;width:156px;height:120px;padding:20px}.tmp-file-status-overlay p{color:#fff}.tmp-file-buttons-overlay{background:rgba(0,0,0,.5);width:156px;height:120px;position:absolute;z-index:99999;visibility:visible;opacity:1;transition:opacity .5s ease-out}.tmp-file-remove-button{position:absolute;right:5px;text-align:right;width:10px;color:#fff;padding:0 1px;border-radius:0}.tmp-file-content{width:156px;height:120px;overflow:hidden}.tmp-upload-video{-o-object-fit:contain;object-fit:contain}.tmp-file-wrapper{position:relative}.tmp-upload{-o-object-fit:cover;object-fit:cover;width:156px;height:120px}.tmp-file-wrapper-container{padding:20px 0 0;margin:20px -15px;border-width:1px 0;border-color:#ccc;border-style:solid}.hide{display:none}.masonry{display:flex;flex-flow:row wrap;margin:20px 0 -2px}.masonry-brick{flex:auto;height:250px;min-width:150px;margin:2px;position:relative;cursor:pointer}.masonry-img{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.masonry-brick:nth-child(4n+1){width:50%}.masonry-brick:nth-child(4n+2){width:40%}.masonry-brick:nth-child(4n+3){width:20%}.masonry-brick:nth-child(4n+4){width:30%}.masonry-brick-full{width:100%!important;height:291px!important;overflow:hidden;outline:rgba(0,0,0,.2) solid 1px;outline-offset:-1px}.card-body{border-bottom-left-radius:16px;border-bottom-right-radius:16px}.card .circle{float:left;position:relative;display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;margin:-30px 10px 15px 15px;background:#eee;z-index:1;font-size:1.5em;color:#414141!important}.card-team .card-content{width:100%;height:160px;margin-bottom:10px}.card-classroom{padding:15px;box-shadow:1px 1px 5px rgba(201,191,187,.7);-moz-box-shadow:1px 1px 5px rgba(201,191,187,.7);-webkit-box-shadow:1px 1px 5px rgba(201,191,187,.7);margin-bottom:20px}.play-overlay{position:absolute;top:0;left:0;width:100%;text-align:center;height:291px;line-height:291px;background:rgba(0,0,0,.05)}.play-overlay img{width:80px;height:80px}.preview-wrapper{position:relative;margin-top:30px}.preview-image img{outline:rgba(0,0,0,.2) solid 1px;outline-offset:-1px}.preview-button{position:absolute;top:0;right:0;color:#fff}.preview-text{position:relative;background:#f9f9f9;border:1px solid #ccc;padding:11px;margin-top:-7px}.img-with-outline{outline:rgba(0,0,0,.2) solid 1px;outline-offset:-1px}.mt-5{margin-top:2em}.feed-card{width:100%;margin-bottom:30px;box-shadow:1px 1px 15px rgba(201,191,187,.7);-moz-box-shadow:1px 1px 15px rgba(201,191,187,.7);-webkit-box-shadow:1px 1px 15px rgba(201,191,187,.7)}.feed-card .feed-header{margin-bottom:10px}.feed-card .feed-header .feed-avatar{float:left;width:40px;height:40px;margin-right:5px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #e6e5e5}.feed-card .feed-header .feed-buttom-option{position:absolute;top:5px;right:0;z-index:21}.mat-card{padding:15px 0 10px!important}.mat-card .mat-card-header .mat-card-title h4{font-size:16px;margin-bottom:0}.mat-card .mat-card-header .mat-card-title p{font-size:13px;color:#aaa}.container-mat-card{display:flex;align-items:flex-end;justify-content:flex-end;position:relative;overflow:hidden;margin:0 0 10px}.bg-mat-card{display:block;position:absolute;z-index:15;width:100%;height:calc(100% - 30px);-webkit-filter:blur(40px) brightness(80%);filter:blur(40px) brightness(80%);background-size:cover;background-repeat:no-repeat;background-position:center}.mat-card-image{position:relative;z-index:20;margin:0!important;-o-object-fit:contain;object-fit:contain;height:auto;max-height:540px;display:block;width:100%}.feed-comment-option{float:right;margin-top:-10px;margin-left:0}.clickable{cursor:pointer;color:var(--main-color)}.scroll-to-top{position:fixed;bottom:15px;right:15px;opacity:0;transition:.2s ease-in-out}.show-scroll{opacity:1;transition:.2s ease-in-out}.feed-actions{color:#ccc;font-size:16px;margin-right:10px;margin-bottom:5px;margin-left:10px}.feed-actions span{margin-left:5px}.feed-actions .btn{background:0 0!important;border:none!important}.feed-likes{font-size:13px;margin-top:10px}a.is-liked{color:var(--main-color)!important}a.disabled-like{color:#ccc!important;cursor:not-allowed;text-decoration:none;pointer-events:none}.carousel{margin-bottom:10px;margin-left:0;margin-right:0}.carousel-item{-o-object-fit:cover!important;object-fit:cover!important;max-height:400px;-o-object-position:center;object-position:center}.video-player{position:initial!important}::ng-deep .ws-pre-wrap h4{font-size:18px!important}::ng-deep .ws-pre-wrap a{color:var(--main-color)}.SeeMore{display:block;color:var(--main-color)!important;text-align:center;cursor:pointer}.carousel-stage{position:relative;z-index:0;min-height:100px}.carousel-stage .progress{height:8px;border-radius:30px}.carousel-stage .progress .progress-bar{background:var(--main-color)}.carousel-stage .courses-image-item{border-radius:5%;-o-object-fit:cover;object-fit:cover}.carousel-stage .courses-item{padding:15px}.carousel-stage .courses-title{text-align:center}.carousel-stage .courses-title a{color:#000!important;font-weight:400!important}.customNavigation a{display:flex;justify-content:center;align-items:center;width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.8);color:var(--main-color)!important;text-align:center}.customNavigation a:hover{background:#fff;color:var(--main-color)}.prev{position:absolute;width:100%;top:50%;left:-15px;margin-top:-15px;z-index:10}.next{position:absolute;width:100%;top:50%;right:-15px;margin-top:-15px;z-index:10}.owl-dots{position:absolute;top:-40px;right:15px;outline:0!important}.owl-dots .owl-dot{background:#ccc!important;border-radius:50%;height:10px;width:10px;padding:0!important;border:none;margin:0 2px;outline:0!important}.owl-dots .owl-dot.active{background:var(--main-color)!important;outline:0!important}::ng-deep .owl-carousel-o-stories .owl-next,::ng-deep .owl-carousel-o-stories .owl-prev{position:absolute!important;top:50%!important;transform:translateY(-50%)!important;display:block!important;border-radius:50%!important;margin-top:-5px!important}::ng-deep .owl-carousel-o-stories .owl-prev{left:5px!important}::ng-deep .owl-carousel-o-stories .owl-next{right:5px!important}::ng-deep .swiper-stage .swiper-container{padding:0}::ng-deep .swiper-stage .swiper-button-next,::ng-deep .swiper-stage .swiper-button-prev{display:flex;align-items:center;justify-content:center;margin-top:0!important;width:25px;height:25px;border-radius:50%;background-color:var(--main-color)!important;opacity:.7!important}::ng-deep .swiper-stage .swiper-button-prev{left:10px;right:auto!important}::ng-deep .swiper-stage .swiper-button-next{right:10px;left:auto!important}::ng-deep .swiper-stage .swiper-button-next:after,::ng-deep .swiper-stage .swiper-button-prev:after{font-size:13px!important;color:#fff}::ng-deep .swiper-stage .swiper-button-disabled{opacity:0!important}.carousel-stories{display:inline-block;width:100%;height:145px;margin:0;border-radius:6px;text-transform:uppercase;font-size:1em;font-weight:500;background-repeat:no-repeat;background-size:cover;cursor:pointer;background-position:center!important}.carousel-stories .item:focus{outline:0}.carousel-stories .stories-body{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;text-align:center;height:100%;padding:0}.carousel-stories .stories-body a{font-size:12px;color:#fff;margin-bottom:10px;text-shadow:0 1px 1px rgba(0,0,0,.6)}.carousel-stories .stories-body a:hover{color:#ccc}.mat-button,.mat-flat-button,.mat-icon-button,.mat-stroked-button{outline:0!important}::ng-deep .mat-menu-panel{border-radius:6px!important;outline:0!important}::ng-deep .mat-menu-panel .mat-menu-content:not(:empty){padding-top:0!important;padding-bottom:0!important}::ng-deep .mat-menu-panel .mat-menu-item{color:#414141;font-size:15px;font-style:normal;font-weight:400;letter-spacing:1px;outline:0!important}.progress-bar-custom span{display:inline-block;height:100%;border-radius:3px;box-shadow:0 1px 0 rgba(37,21,21,.5) inset;transition:width .4s ease-in-out}.green-progress span{background-image:linear-gradient(to bottom,#fff,var(--main-color))}.stripes span{background-size:30px 30px;background-image:linear-gradient(135deg,#ff4e4ef3 25%,transparent 25%,transparent 50%,rgba(236,47,47,.972) 50%,rgba(240,0,0,.15) 75%,transparent 75%,transparent);-webkit-animation:3s linear infinite animate-stripes;animation:3s linear infinite animate-stripes}.container-stipes{width:100%;padding:0 10px;font-weight:700}.keep-logged{position:relative;height:150px;background:var(--main-color);top:0;color:#fff!important;z-index:99;opacity:.9;width:100%;border:0;left:0;right:0}.keep-logged button{background:#fff!important;color:var(--main-color)!important}.scrollable{overflow-y:scroll;height:100vh}.alert-primary{color:#fff;background-color:var(--main-color)!important;background:var(--main-color)!important}.mat-progress-bar{height:17px;border-radius:5px}@-webkit-keyframes animate-stripes{0%{background-position:0 0}100%{background-position:60px 0}}@keyframes animate-stripes{0%{background-position:0 0}100%{background-position:60px 0}}.p-channel{color:#3c4858;font-weight:500;margin-bottom:0!important}@media (max-width:767px){.form-feed textarea{font-size:12px}.btn-feed{width:auto;font-size:11px;padding:2px 5px;border-radius:30px;font-weight:600;text-transform:capitalize}.carousel-stories{width:120px;height:120px}.keep-logged{height:175px}.keep-logged h3{font-size:1.1rem}.keep-logged button{font-size:1rem}.btn-group-xs>.btn,.btn-xs{padding:2px 5px;font-size:11px;line-height:1;border-radius:30px}}::ng-deep .mat-card-header-text{width:100%!important;margin:0}::ng-deep .popover{background:#fff!important;border:0!important;box-shadow:1px 1px 15px rgba(201,191,187,.7)!important;-moz-box-shadow:1px 1px 15px rgba(201,191,187,.7)!important;-webkit-box-shadow:1px 1px 15px rgba(201,191,187,.7)!important}.minibio{padding:10px;border-radius:10px}.minibio img{width:30%;max-width:100px;display:inline-block;padding-right:10px}.minibio .info{display:inline-block;vertical-align:top}.minibio .info .icon{color:#d4d4d4}.minibio .info ul{list-style:none}.minibio .info li{display:inline-block}", "@charset \"UTF-8\";.pinned-feed{background-color:var(--bg-btn);color:var(--text-btn);padding:5px;height:40px;width:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;position:absolute;margin-top:60px;margin-right:5px;opacity:1}.mat-card-video{-o-object-fit:cover;object-fit:cover;width:calc(100% + 31px);margin:0 0 10px}.mat-card-content{word-break:break-word;padding:0 15px}::ng-deep .tooltip-primary{background:var(--main-color);opacity:.85;font-size:13px}.no-click{pointer-events:none}.modal-feed-publication{border-radius:24px!important}.share-social{max-width:185px}.mat-card-actions{min-height:40px}.post-processing-section{padding:12px;border:3px dotted gray;border-radius:8px;background-color:#f4f4f4}.carousel{color:#fff}.carousel .content{display:flex}.carousel .content .item{width:100%;display:block;transition:opacity 295ms linear .2s}.carousel .content .item.visible{opacity:1}.carousel .content .item .img{width:100%;height:500px;display:block;-o-object-fit:cover;object-fit:cover;background-size:cover;background-position:center}.carousel .content .item .video{width:100%;height:500px!important;display:block;background-size:cover;background-position:center}.carousel .content .item .video-overlay{background:rgba(0,0,0,.5);width:100%;height:500px!important;position:absolute;z-index:-1;transition:opacity .5s ease-out;filter:blur(8px);-webkit-filter:blur(8px)}.carousel .content .wraper-video{background-color:#000}.carousel .ball{width:10px;height:10px;border-radius:50%;background:#000;border:2px solid;opacity:.5}.carousel .ball.visible{opacity:1}.carousel .click-area{width:50px;text-align:center}.carousel .click-area i{font-size:2em;background:rgba(255,255,255,.8);color:#000;border-radius:100%}.custom-carrousel{z-index:1;overflow:hidden}.card-file{box-shadow:0 0 30px rgba(204,204,204,.4);border:none;border-radius:16px;transition:.5s;margin-bottom:30px;cursor:pointer}.card-file .card-cover{display:flex;align-items:center;justify-content:center;text-align:center;padding:0;width:100%;height:250px;border-top-left-radius:10px;border-top-right-radius:10px;background:var(--main-color);color:#fff!important;overflow:hidden}.card-file .card-cover img{position:absolute;z-index:0;top:0;left:0;width:100%;height:inherit;-o-object-fit:cover;object-fit:cover;border-top-left-radius:10px;border-top-right-radius:10px}.card-file .card-cover .title{position:relative;z-index:3;color:#fff;margin-bottom:0;height:60px;padding:0 15px;font-size:18px}.card-file .circle{float:left;position:relative;display:flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;margin:-30px 10px 15px 15px;background:#eee;z-index:20;font-size:1.5em;color:#3c4858!important}.card-file .card-body{height:125px;border-bottom-left-radius:16px;border-bottom-right-radius:16px}.card-file .card-body .edit-file{float:right!important;margin-top:-60px;margin-right:-15px}.card-file .card-body h5{height:60px}.card-file .card-body .description{color:#888;height:65px;overflow:hidden}::ng-deep owl-carousel-o .owl-theme .owl-next,::ng-deep owl-carousel-o .owl-theme .owl-prev{position:absolute;top:50%;transform:translateY(-50%);display:flex!important;align-items:center!important;justify-content:center!important;width:30px!important;height:30px!important;border-radius:50%!important;margin:20px 0;background:rgba(255,255,255,.8)!important;color:#414141!important;border:none!important;font-size:20px!important;font-weight:600!important}::ng-deep owl-carousel-o .owl-theme .owl-prev{left:5px;transition:.3s!important}::ng-deep owl-carousel-o .owl-theme .owl-prev:hover{transition:.3s!important}::ng-deep owl-carousel-o .owl-theme .owl-next{right:5px;transition:.3s!important}::ng-deep owl-carousel-o .owl-theme .owl-next:hover{transition:.3s}::ng-deep owl-carousel-o .owl-carousel .owl-dot,::ng-deep owl-carousel-o .owl-carousel .owl-nav .owl-next,::ng-deep owl-carousel-o .owl-carousel .owl-nav .owl-prev{font-family:fontAwesome}::ng-deep owl-carousel-o .owl-carousel .owl-nav .owl-prev:before{content:\"\uF104\"}::ng-deep owl-carousel-o .owl-carousel .owl-nav .owl-next:after{content:\"\uF105\"}.swiper-carousel-custom .swiper-container-img{display:flex;align-items:center;justify-content:center;width:100%;height:500px}.swiper-carousel-custom .swiper-bg-blur{position:absolute;z-index:10;width:100%;height:500px;-webkit-filter:blur(30px) brightness(80%);filter:blur(30px) brightness(80%);background-size:cover;background-repeat:no-repeat;background-position:center}.swiper-carousel-custom .img{position:relative;z-index:20;max-width:100%;max-height:500px!important;display:block;-o-object-fit:contain;object-fit:contain;background-size:cover;background-position:center}.swiper-carousel-custom .video{width:100%;height:500px!important;display:block;background-size:cover;background-position:center}.swiper-carousel-custom .video-overlay{background:rgba(0,0,0,.5);width:100%;height:500px!important;position:absolute;z-index:-1;transition:opacity .5s ease-out;filter:blur(8px);-webkit-filter:blur(8px)}"]
|
|
372
372
|
}] }
|
|
@@ -427,4 +427,4 @@ if (false) {
|
|
|
427
427
|
/** @type {?} */
|
|
428
428
|
FeedItemComponent.prototype.service;
|
|
429
429
|
}
|
|
430
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVlZC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FzYXAtZmVlZC1iZXRhLyIsInNvdXJjZXMiOlsibGliL2ZlZWQtaXRlbS9mZWVkLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQTRCLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEksT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDbkMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seUVBQXlFLENBQUM7QUFDckgsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzlDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFckQsT0FBTyxVQUFVLEVBQUUsRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQzVELFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxVQUFVLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUV6QztJQTBCRSwyQkFDUyxhQUE0QixFQUM1QixFQUFvQixFQUNwQixNQUFjLEVBQ2QsTUFBaUIsRUFDakIsT0FBcUI7UUFKckIsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDNUIsT0FBRSxHQUFGLEVBQUUsQ0FBa0I7UUFDcEIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLFdBQU0sR0FBTixNQUFNLENBQVc7UUFDakIsWUFBTyxHQUFQLE9BQU8sQ0FBYztRQXBCcEIsY0FBUyxHQUFHLElBQUks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QUM3QixnREFBaUU7O0lBRWpFLHFDQUFnQjs7SUFDaEIseUNBQW9COztJQUNwQixzQ0FBaUI7O0lBR2YsMENBQW1DOztJQUNuQywrQkFBMkI7O0lBQzNCLG1DQUFxQjs7SUFDckIsbUNBQXdCOztJQUN4QixvQ0FBNEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQsIFZpZXdDaGlsZCwgRWxlbWVudFJlZiwgT25EZXN0cm95LCBBZnRlclZpZXdJbml0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTdHJlYW1TZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvc3RyZWFtLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBBbmd1bGFyRmlyZXN0b3JlIH0gZnJvbSAnQGFuZ3VsYXIvZmlyZS9maXJlc3RvcmUnO1xyXG5pbXBvcnQgeyBHbG9iYWwgfSBmcm9tICdhc2FwLWNydWQnO1xyXG5pbXBvcnQgeyBGZWVkTW9kYWxJdGVtRWRpdENvbXBvbmVudCB9IGZyb20gJy4uL2ZlZWQtcHVibGljYXRpb24vZmVlZC1tb2RhbC1pdGVtLWVkaXQvZmVlZC1tb2RhbC1pdGVtLWVkaXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgcGF0aCB9IGZyb20gJy4uL2NvbnN0YW50cy9jb25zdGFudHMnO1xyXG5pbXBvcnQgeyBVdGlsc1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy91dGlscy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcclxuXHJcbmltcG9ydCBTd2lwZXJDb3JlLCB7IE5hdmlnYXRpb24sIFBhZ2luYXRpb24gfSBmcm9tICdzd2lwZXInO1xyXG5Td2lwZXJDb3JlLnVzZShbTmF2aWdhdGlvbiwgUGFnaW5hdGlvbl0pO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtZmVlZC1pdGVtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZmVlZC1pdGVtLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi4vYXNhcC1mZWVkLmJldGEuY29tcG9uZW50ZS5zY3NzJywgJy4vZmVlZC1pdGVtLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgcHJvdmlkZXJzOiBbU3RyZWFtU2VydmljZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZlZWRJdGVtQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xyXG5cclxuICBASW5wdXQoKSBpdGVtO1xyXG4gIEBJbnB1dCgpIG93bmVyO1xyXG5cclxuICBAT3V0cHV0KCkgaXNWaXNpYmxlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICBAVmlld0NoaWxkKCd2aWRlb1BsYXllcicsIHsgc3RhdGljOiB0cnVlIH0pIHZpZGVvcGxheWVyOiBFbGVtZW50UmVmXHJcbiAgQFZpZXdDaGlsZCgndmlzaWJsZUNvbnRyb2wnLCB7IHN0YXRpYzogZmFsc2UsIHJlYWQ6IEVsZW1lbnRSZWYgfSkgdmlzaWJsZUNvbnRyb2w7XHJcblxyXG4gIHB1YmxpYyBjdXJyZW50SW5kZXg7XHJcbiAgcHVibGljIGltYWdlTG9hZGVkID0gZmFsc2U7XHJcbiAgcHVibGljIGltYWdlRGF0YUxvYWRlZCA9IGZhbHNlO1xyXG4gIHB1YmxpYyBjdXJyZW50Q2Fycm91c2VsSW5kZXg7XHJcbiAgcHVibGljIGJsdXJCYWNrZ3JvdW5kSW5kZXggPSBNYXRoLmZsb29yKChNYXRoLnJhbmRvbSgpICogNSkgKyAxKTtcclxuXHJcbiAgcHVibGljIG9ic2VydmVyO1xyXG4gIHB1YmxpYyB2aXNpYmxlVGltZXI7XHJcbiAgcHVibGljIHNob3RUaW1lcjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgc3RyZWFtU2VydmljZTogU3RyZWFtU2VydmljZSxcclxuICAgIHB1YmxpYyBkYjogQW5ndWxhckZpcmVzdG9yZSxcclxuICAgIHB1YmxpYyBnbG9iYWw6IEdsb2JhbCxcclxuICAgIHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZyxcclxuICAgIHB1YmxpYyBzZXJ2aWNlOiBVdGlsc1NlcnZpY2VcclxuICApIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMubG9hZFZpc2liaWxpdHlDb250cm9scygpO1xyXG5cclxuICAgIGlmICh0aGlzLml0ZW0uZmlsZXMgJiYgdGhpcy5pdGVtLmZpbGVzLmxlbmd0aCA+IDApIHtcclxuICAgICAgdGhpcy5pdGVtLmZpbGVzLm1hcChmZWVkID0+IHtcclxuICAgICAgICBpZiAoZmVlZC51cmwgJiYgZmVlZC51cmwuaW5jbHVkZXMoJ3lvdXR1YmUnKSkge1xyXG4gICAgICAgICAgZmVlZC5pc1lvdXR1YmUgPSB0cnVlO1xyXG4gICAgICAgICAgbGV0IHlvdXR1YmVJRCA9IHRoaXMuZ2V0WW91dHViZUlEKGZlZWQudXJsKTtcclxuICAgICAgICAgIGZlZWQudXJsID0gYGh0dHBzOi8vd3d3LnlvdXR1YmUuY29tL2VtYmVkLyR7eW91dHViZUlEfWA7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KVxyXG4gICAgfVxyXG5cclxuICAgIC8vIGNvbnNvbGUubG9nKCdJVEVNIC0+JywgdGhpcy5pdGVtKTtcclxuICB9XHJcblxyXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMub2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLnZpc2libGVDb250cm9sLm5hdGl2ZUVsZW1lbnQpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICB0aGlzLm9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcclxuICAgIGNsZWFySW50ZXJ2YWwodGhpcy52aXNpYmxlVGltZXIpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGxvYWRWaXNpYmlsaXR5Q29udHJvbHMoKSB7XHJcbiAgICB0aGlzLnZpc2libGVUaW1lciA9IHNldEludGVydmFsKCgpID0+IHtcclxuICAgICAgdGhpcy5zaG90VGltZXItLTtcclxuICAgICAgaWYgKHRoaXMuc2hvdFRpbWVyID09IDApIHtcclxuICAgICAgICB0aGlzLmlzVmlzaWJsZS5lbWl0KHRoaXMuaXRlbSk7XHJcbiAgICAgICAgY2xlYXJJbnRlcnZhbCh0aGlzLnZpc2libGVUaW1lcik7XHJcbiAgICAgICAgdGhpcy5vYnNlcnZlci5kaXNjb25uZWN0KCk7XHJcbiAgICAgIH1cclxuICAgIH0sIDEwMDApO1xyXG5cclxuICAgIGNvbnN0IG9wdGlvbnMgPSB7XHJcbiAgICAgIHJvb3RNYXJnaW46ICcwcHgnLFxyXG4gICAgICB0aHJlc2hvbGQ6IFswLCAwLjEsIDAuMiwgMC4zLCAwLjQsIDAuNSwgMC42LCAwLjcsIDAuOCwgMC45LCAxLjBdXHJcbiAgICB9O1xyXG5cclxuICAgIHRoaXMub2JzZXJ2ZXIgPSBuZXcgSW50ZXJzZWN0aW9uT2JzZXJ2ZXIoKGVudHJpZXMsIG9ic2VydmVyKSA9PiB7XHJcbiAgICAgIGVudHJpZXMuZm9yRWFjaChlbnRyeSA9PiB7XHJcbiAgICAgICAgdGhpcy5zaG90VGltZXIgPSAtMTtcclxuICAgICAgICB0aGlzLml0ZW0uYWN0aXZlID0gZmFsc2U7XHJcbiAgICAgICAgaWYgKGVudHJ5LmludGVyc2VjdGlvblJhdGlvID09IDEpIHtcclxuICAgICAgICAgIHRoaXMuc2hvdFRpbWVyID0gNTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pO1xyXG4gICAgfSwgb3B0aW9ucyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25sb2FkSW1hZ2UoZXZlbnQpIHtcclxuICAgIC8vIGNvbnNvbGUubG9nKCdFdmVudCBvbmxvYWRJbWFnZSAtPicsIGV2ZW50KTtcclxuICAgIHRoaXMuaW1hZ2VMb2FkZWQgPSB0cnVlO1xyXG4gICAgdGhpcy5pbWFnZURhdGFMb2FkZWQgPSB0cnVlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uRXJyb3JJbWFnZShldmVudCkge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ0V2ZW50IG9uRXJyb3JJbWFnZSAtPicsIGV2ZW50KTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBwbGF5VmlkZW8oZXZlbnQpIHtcclxuICAgIC8vIGNvbnNvbGUubG9nKCdFdmVudCAtPicsIGV2ZW50KTtcclxuICAgIGlmICh0aGlzLnZpZGVvcGxheWVyKSB7XHJcbiAgICAgIHRoaXMudmlkZW9wbGF5ZXIubmF0aXZlRWxlbWVudC5wbGF5KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbGlua2lmeShzdHIpIHtcclxuICAgIHZhciByZTogYW55O1xyXG4gICAgcmUgPSBbXHJcbiAgICAgIFwiXFxcXGIoKD86aHR0cHM/fGZ0cCk6Ly9bXlxcXFxzXFxcIic8Pl0rKVxcXFxiXCIsXHJcbiAgICAgIFwiXFxcXGIod3d3XFxcXC5bXlxcXFxzXFxcIic8Pl0rKVxcXFxiXCIsXHJcbiAgICAgIFwiXFxcXGIoXFxcXHdbXFxcXHcuKy1dKkBbXFxcXHcuLV0rXFxcXC5bYS16XXsyLDZ9KVxcXFxiXCIsXHJcbiAgICAgIFwiIyhbYS16MC05XSspXCJdO1xyXG4gICAgcmUgPSBuZXcgUmVnRXhwKHJlLmpvaW4oJ3wnKSwgXCJnaVwiKTtcclxuXHJcbiAgICBpZiAoc3RyKSB7XHJcbiAgICAgIHJldHVybiBzdHIucmVwbGFjZShyZSwgZnVuY3Rpb24gKG1hdGNoLCB1cmwsIHd3dywgbWFpbCwgdHdpdGxlcikge1xyXG4gICAgICAgIGlmICh1cmwpXHJcbiAgICAgICAgICByZXR1cm4gXCI8YSBjbGFzcz0ndGV4dC1wcmltYXJ5JyB0YXJnZXQ9J19ibGFuaycgKGNsaWNrKT0ncmVkaXJlY3ROZXdMaW5rKHVybCknIGhyZWY9XFxcIlwiICsgdXJsICsgXCJcXFwiPlwiICsgdXJsICsgXCI8L2E+XCI7XHJcbiAgICAgICAgaWYgKHd3dylcclxuICAgICAgICAgIHJldHVybiBcIjxhIGNsYXNzPSd0ZXh0LXByaW1hcnknIGhyZWY9XFxcImh0dHA6Ly9cIiArIHd3dyArIFwiXFxcIj5cIiArIHd3dyArIFwiPC9hPlwiO1xyXG4gICAgICAgIGlmIChtYWlsKVxyXG4gICAgICAgICAgcmV0dXJuIFwiPGEgY2xhc3M9J3RleHQtcHJpbWFyeScgaHJlZj1cXFwiIzwvYT5cIjtcclxuICAgICAgICBpZiAodHdpdGxlcilcclxuICAgICAgICAgIHJldHVybiBcIjxhIGNsYXNzPSd0ZXh0LXByaW1hcnknIGhyZWY9XFxcInBvcnRhbC9zZWFyY2gvXCIgKyBlbmNvZGVVUklDb21wb25lbnQoJyMnICsgdHdpdGxlcikgKyBcIlxcXCI+I1wiICsgdHdpdGxlciArIFwiPC9hPlwiO1xyXG4gICAgICAgIC8vIHJldHVybiBcIjxhIGNsYXNzPSd0ZXh0LXByaW1hcnknIGhyZWY9XFxcIiNcXFwiPiNcIiArIHR3aXRsZXIgKyBcIjwvYT5cIjtcclxuXHJcbiAgICAgICAgLy8gc2hvdWxkbnQgZ2V0IGhlcmUsIGJ1dCBqdXN0IGluIGNhc2VcclxuICAgICAgICByZXR1cm4gbWF0Y2g7XHJcbiAgICAgIH0pO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGNoZWNrVmlkZW9SZW5kZXIoaXRlbSkge1xyXG5cclxuICAgIGNvbnNvbGUubG9nKCd2aWRlb1JlbmRlciAtPicsIGl0ZW0pO1xyXG4gICAgdGhpcy5zdHJlYW1TZXJ2aWNlLnN0YXR1cyhpdGVtKS5zdWJzY3JpYmUoKHJlczogYW55KSA9PiB7XHJcbiAgICAgIGNvbnNvbGUubG9nKCdjaGVja1ZpZGVvUmVuZGVyJywgcmVzKTtcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25FZGl0SXRlbSgpIHtcclxuICAgIC8vICBQcmVwYXJhciBmZWVkIHBhcmEgZWRpdGFyXHJcbiAgICBsZXQgZmVlZDtcclxuICAgIGZlZWQgPSB0aGlzLml0ZW07XHJcbiAgICBkZWxldGUgZmVlZC5jb21tZW50cztcclxuICAgIGRlbGV0ZSBmZWVkLmxpa2VzO1xyXG5cclxuICAgIGZlZWQuZmlsZXMubWFwKGZpbGUgPT4ge1xyXG4gICAgICBmaWxlLm5ldyA9IGZhbHNlO1xyXG4gICAgfSk7XHJcblxyXG4gICAgdGhpcy5kaWFsb2cub3BlbihGZWVkTW9kYWxJdGVtRWRpdENvbXBvbmVudCwge1xyXG4gICAgICB3aWR0aDogJzYwMHB4JyxcclxuICAgICAgZGF0YTogZmVlZCxcclxuICAgICAgcGFuZWxDbGFzczogJ21vZGFsLWZlZWQtcHVibGljYXRpb24nXHJcbiAgICB9KVxyXG4gIH1cclxuXHJcbiAgcHJlQ29udmVydE51bWJlcih2YWx1ZSkge1xyXG4gICAgcmV0dXJuIHBhcnNlRmxvYXQodmFsdWUpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uUmVtb3ZlSXRlbShpdGVtKSB7XHJcbiAgICB0aGlzLmdsb2JhbC5zd2FsKHtcclxuICAgICAgdGl0bGU6ICdWb2PDqiByZWFsbWVudGUgZGVzZWphIHJlbW92ZXIgZXN0ZSBQb3N0PycsXHJcbiAgICAgIHRleHQ6ICdWb2PDqiBuw6NvIHBvZGVyw6EgcmV2ZXJ0ZXIgZXNzYSBhw6fDo28gZGVwb2lzIGRlIGNvbmZpcm1hZG8nLFxyXG4gICAgICB0eXBlOiBcIndhcm5pbmdcIixcclxuICAgICAgc2hvd0NhbmNlbEJ1dHRvbjogdHJ1ZSxcclxuICAgICAgY29uZmlybUJ1dHRvblRleHQ6IFwiU2ltXCIsXHJcbiAgICAgIGNhbmNlbEJ1dHRvblRleHQ6IFwiTsOjb1wiXHJcbiAgICB9KS50aGVuKGFzeW5jIGNvbmZpcm0gPT4ge1xyXG4gICAgICBpZiAoY29uZmlybS52YWx1ZSkge1xyXG4gICAgICAgIGNvbnN0IGNvbGxlY3Rpb24gPSB0aGlzLmRiLmNvbGxlY3Rpb24ocGF0aCgpLmZlZWQpLmRvYyhpdGVtLmlkKTtcclxuXHJcbiAgICAgICAgaWYgKGl0ZW0uZmlsZXMgJiYgaXRlbS5maWxlcy5sZW5ndGggPiAwKSB7XHJcbiAgICAgICAgICBmb3IgKGNvbnN0IGZpbGUgb2YgaXRlbS5maWxlcykge1xyXG4gICAgICAgICAgICBpZiAoZmlsZS50eXBlID09PSAnaW1hZ2UnKSB7XHJcbiAgICAgICAgICAgICAgaWYgKGZpbGUubmFtZSkge1xyXG4gICAgICAgICAgICAgICAgdHJ5IHtcclxuICAgICAgICAgICAgICAgICAgYXdhaXQgdGhpcy5zZXJ2aWNlLmRlbGV0ZUZpcmVTdG9yYWdlKGAke3BhdGgoKS5pbWFnZXN9LyR7ZmlsZS5uYW1lfWApO1xyXG4gICAgICAgICAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcclxuICAgICAgICAgICAgICAgICAgY29uc29sZS5sb2coJ1JlbW92ZW5kbyB1bSBwb3N0IGNvbSBpbWFnZW0gbsOjbyByZWZlcmVuY2lhZGEnLCBlcnJvcik7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBjb2xsZWN0aW9uLmRlbGV0ZSgpO1xyXG4gICAgICAgIGl0ZW0uZGVsZXRlZCA9IHRydWU7XHJcbiAgICAgICAgdGhpcy5nbG9iYWwudG9hc3QoJ1Bvc3QgcmVtb3ZpZG8gY29tIFN1Y2Vzc28nKTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBjaGVja0ZpbGVPcmlnaW4oZmlsZSkge1xyXG5cclxuICB9XHJcblxyXG4gIGlzWW91dHViZShmaWxlKSB7XHJcbiAgICBjb25zb2xlLmxvZygnSXNZb3V0dWJlIC0+JywgZmlsZSk7XHJcbiAgICBpZiAoZmlsZS5pbmNsdWRlcygneW91dHViZScpKSB7XHJcbiAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgZ2V0WW91dHViZUlEKHVybCkge1xyXG4gICAgdmFyIHJlZ0V4cCA9IC9eLiooKHlvdXR1LmJlXFwvKXwodlxcLyl8KFxcL3VcXC9cXHdcXC8pfChlbWJlZFxcLyl8KHdhdGNoXFw/KSlcXD8/dj89PyhbXiMmP10qKS4qLztcclxuICAgIHZhciBtYXRjaCA9IHVybC5tYXRjaChyZWdFeHApO1xyXG4gICAgcmV0dXJuIChtYXRjaCAmJiBtYXRjaFs3XS5sZW5ndGggPT0gMTEpID8gbWF0Y2hbN10gOiBmYWxzZTtcclxuICB9XHJcblxyXG5cclxufVxyXG4iXX0=
|
|
430
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmVlZC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2FzYXAtZmVlZC1iZXRhLyIsInNvdXJjZXMiOlsibGliL2ZlZWQtaXRlbS9mZWVkLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsS0FBSyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQTRCLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEksT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzNELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzNELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDbkMsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0seUVBQXlFLENBQUM7QUFDckgsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzlDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFckQsT0FBTyxVQUFVLEVBQUUsRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQzVELFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxVQUFVLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUV6QztJQTBCRSwyQkFDUyxhQUE0QixFQUM1QixFQUFvQixFQUNwQixNQUFjLEVBQ2QsTUFBaUIsRUFDakIsT0FBcUI7UUFKckIsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDNUIsT0FBRSxHQUFGLEVBQUUsQ0FBa0I7UUFDcEIsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLFdBQU0sR0FBTixNQUFNLENBQVc7UUFDakIsWUFBTyxHQUFQLE9BQU8sQ0FBYztRQXBCcEIsY0FBUyxHQUFHLElBQUks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QUM3QixnREFBaUU7O0lBRWpFLHFDQUFnQjs7SUFDaEIseUNBQW9COztJQUNwQixzQ0FBaUI7O0lBR2YsMENBQW1DOztJQUNuQywrQkFBMkI7O0lBQzNCLG1DQUFxQjs7SUFDckIsbUNBQXdCOztJQUN4QixvQ0FBNEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQsIFZpZXdDaGlsZCwgRWxlbWVudFJlZiwgT25EZXN0cm95LCBBZnRlclZpZXdJbml0LCBPdXRwdXQsIEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTdHJlYW1TZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvc3RyZWFtLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBBbmd1bGFyRmlyZXN0b3JlIH0gZnJvbSAnQGFuZ3VsYXIvZmlyZS9maXJlc3RvcmUnO1xyXG5pbXBvcnQgeyBHbG9iYWwgfSBmcm9tICdhc2FwLWNydWQnO1xyXG5pbXBvcnQgeyBGZWVkTW9kYWxJdGVtRWRpdENvbXBvbmVudCB9IGZyb20gJy4uL2ZlZWQtcHVibGljYXRpb24vZmVlZC1tb2RhbC1pdGVtLWVkaXQvZmVlZC1tb2RhbC1pdGVtLWVkaXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgcGF0aCB9IGZyb20gJy4uL2NvbnN0YW50cy9jb25zdGFudHMnO1xyXG5pbXBvcnQgeyBVdGlsc1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy91dGlscy5zZXJ2aWNlJztcclxuaW1wb3J0IHsgTWF0RGlhbG9nIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcclxuXHJcbmltcG9ydCBTd2lwZXJDb3JlLCB7IE5hdmlnYXRpb24sIFBhZ2luYXRpb24gfSBmcm9tICdzd2lwZXInO1xyXG5Td2lwZXJDb3JlLnVzZShbTmF2aWdhdGlvbiwgUGFnaW5hdGlvbl0pO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtZmVlZC1pdGVtJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZmVlZC1pdGVtLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi4vYXNhcC1mZWVkLmJldGEuY29tcG9uZW50ZS5zY3NzJywgJy4vZmVlZC1pdGVtLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgcHJvdmlkZXJzOiBbU3RyZWFtU2VydmljZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIEZlZWRJdGVtQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xyXG5cclxuICBASW5wdXQoKSBpdGVtO1xyXG4gIEBJbnB1dCgpIG93bmVyO1xyXG5cclxuICBAT3V0cHV0KCkgaXNWaXNpYmxlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICBAVmlld0NoaWxkKCd2aWRlb1BsYXllcicsIHsgc3RhdGljOiB0cnVlIH0pIHZpZGVvcGxheWVyOiBFbGVtZW50UmVmXHJcbiAgQFZpZXdDaGlsZCgndmlzaWJsZUNvbnRyb2wnLCB7IHN0YXRpYzogZmFsc2UsIHJlYWQ6IEVsZW1lbnRSZWYgfSkgdmlzaWJsZUNvbnRyb2w7XHJcblxyXG4gIHB1YmxpYyBjdXJyZW50SW5kZXg7XHJcbiAgcHVibGljIGltYWdlTG9hZGVkID0gZmFsc2U7XHJcbiAgcHVibGljIGltYWdlRGF0YUxvYWRlZCA9IGZhbHNlO1xyXG4gIHB1YmxpYyBjdXJyZW50Q2Fycm91c2VsSW5kZXg7XHJcbiAgcHVibGljIGJsdXJCYWNrZ3JvdW5kSW5kZXggPSBNYXRoLmZsb29yKChNYXRoLnJhbmRvbSgpICogNSkgKyAxKTtcclxuXHJcbiAgcHVibGljIG9ic2VydmVyO1xyXG4gIHB1YmxpYyB2aXNpYmxlVGltZXI7XHJcbiAgcHVibGljIHNob3RUaW1lcjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgc3RyZWFtU2VydmljZTogU3RyZWFtU2VydmljZSxcclxuICAgIHB1YmxpYyBkYjogQW5ndWxhckZpcmVzdG9yZSxcclxuICAgIHB1YmxpYyBnbG9iYWw6IEdsb2JhbCxcclxuICAgIHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZyxcclxuICAgIHB1YmxpYyBzZXJ2aWNlOiBVdGlsc1NlcnZpY2VcclxuICApIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpIHtcclxuICAgIHRoaXMubG9hZFZpc2liaWxpdHlDb250cm9scygpO1xyXG5cclxuICAgIGlmICh0aGlzLml0ZW0uZmlsZXMgJiYgdGhpcy5pdGVtLmZpbGVzLmxlbmd0aCA+IDApIHtcclxuICAgICAgdGhpcy5pdGVtLmZpbGVzLm1hcChmZWVkID0+IHtcclxuICAgICAgICBpZiAoZmVlZC51cmwgJiYgZmVlZC51cmwuaW5jbHVkZXMoJ3lvdXR1YmUnKSkge1xyXG4gICAgICAgICAgZmVlZC5pc1lvdXR1YmUgPSB0cnVlO1xyXG4gICAgICAgICAgbGV0IHlvdXR1YmVJRCA9IHRoaXMuZ2V0WW91dHViZUlEKGZlZWQudXJsKTtcclxuICAgICAgICAgIGZlZWQudXJsID0gYGh0dHBzOi8vd3d3LnlvdXR1YmUuY29tL2VtYmVkLyR7eW91dHViZUlEfWA7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KVxyXG4gICAgfVxyXG5cclxuICAgIC8vIGNvbnNvbGUubG9nKCdJVEVNIC0+JywgdGhpcy5pdGVtKTtcclxuICB9XHJcblxyXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMub2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLnZpc2libGVDb250cm9sLm5hdGl2ZUVsZW1lbnQpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICB0aGlzLm9ic2VydmVyLmRpc2Nvbm5lY3QoKTtcclxuICAgIGNsZWFySW50ZXJ2YWwodGhpcy52aXNpYmxlVGltZXIpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGxvYWRWaXNpYmlsaXR5Q29udHJvbHMoKSB7XHJcbiAgICB0aGlzLnZpc2libGVUaW1lciA9IHNldEludGVydmFsKCgpID0+IHtcclxuICAgICAgdGhpcy5zaG90VGltZXItLTtcclxuICAgICAgaWYgKHRoaXMuc2hvdFRpbWVyID09IDApIHtcclxuICAgICAgICB0aGlzLmlzVmlzaWJsZS5lbWl0KHRoaXMuaXRlbSk7XHJcbiAgICAgICAgY2xlYXJJbnRlcnZhbCh0aGlzLnZpc2libGVUaW1lcik7XHJcbiAgICAgICAgdGhpcy5vYnNlcnZlci5kaXNjb25uZWN0KCk7XHJcbiAgICAgIH1cclxuICAgIH0sIDEwMDApO1xyXG5cclxuICAgIGNvbnN0IG9wdGlvbnMgPSB7XHJcbiAgICAgIHJvb3RNYXJnaW46ICcwcHgnLFxyXG4gICAgICB0aHJlc2hvbGQ6IFswLCAwLjEsIDAuMiwgMC4zLCAwLjQsIDAuNSwgMC42LCAwLjcsIDAuOCwgMC45LCAxLjBdXHJcbiAgICB9O1xyXG5cclxuICAgIHRoaXMub2JzZXJ2ZXIgPSBuZXcgSW50ZXJzZWN0aW9uT2JzZXJ2ZXIoKGVudHJpZXMsIG9ic2VydmVyKSA9PiB7XHJcbiAgICAgIGVudHJpZXMuZm9yRWFjaChlbnRyeSA9PiB7XHJcbiAgICAgICAgdGhpcy5zaG90VGltZXIgPSAtMTtcclxuICAgICAgICB0aGlzLml0ZW0uYWN0aXZlID0gZmFsc2U7XHJcbiAgICAgICAgaWYgKGVudHJ5LmludGVyc2VjdGlvblJhdGlvID09IDEpIHtcclxuICAgICAgICAgIHRoaXMuc2hvdFRpbWVyID0gNTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pO1xyXG4gICAgfSwgb3B0aW9ucyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25sb2FkSW1hZ2UoZXZlbnQpIHtcclxuICAgIC8vIGNvbnNvbGUubG9nKCdFdmVudCBvbmxvYWRJbWFnZSAtPicsIGV2ZW50KTtcclxuICAgIHRoaXMuaW1hZ2VMb2FkZWQgPSB0cnVlO1xyXG4gICAgdGhpcy5pbWFnZURhdGFMb2FkZWQgPSB0cnVlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uRXJyb3JJbWFnZShldmVudCkge1xyXG4gICAgLy8gY29uc29sZS5sb2coJ0V2ZW50IG9uRXJyb3JJbWFnZSAtPicsIGV2ZW50KTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBwbGF5VmlkZW8oZXZlbnQpIHtcclxuICAgIC8vIGNvbnNvbGUubG9nKCdFdmVudCAtPicsIGV2ZW50KTtcclxuICAgIGlmICh0aGlzLnZpZGVvcGxheWVyKSB7XHJcbiAgICAgIHRoaXMudmlkZW9wbGF5ZXIubmF0aXZlRWxlbWVudC5wbGF5KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbGlua2lmeShzdHIpIHtcclxuICAgIHZhciByZTogYW55O1xyXG4gICAgcmUgPSBbXHJcbiAgICAgIFwiXFxcXGIoKD86aHR0cHM/fGZ0cCk6Ly9bXlxcXFxzXFxcIic8Pl0rKVxcXFxiXCIsXHJcbiAgICAgIFwiXFxcXGIod3d3XFxcXC5bXlxcXFxzXFxcIic8Pl0rKVxcXFxiXCIsXHJcbiAgICAgIFwiXFxcXGIoXFxcXHdbXFxcXHcuKy1dKkBbXFxcXHcuLV0rXFxcXC5bYS16XXsyLDZ9KVxcXFxiXCIsXHJcbiAgICAgIFwiIyhbYS16MC05XSspXCJdO1xyXG4gICAgcmUgPSBuZXcgUmVnRXhwKHJlLmpvaW4oJ3wnKSwgXCJnaVwiKTtcclxuXHJcbiAgICBpZiAoc3RyKSB7XHJcbiAgICAgIHJldHVybiBzdHIucmVwbGFjZShyZSwgZnVuY3Rpb24gKG1hdGNoLCB1cmwsIHd3dywgbWFpbCwgdHdpdGxlcikge1xyXG4gICAgICAgIGlmICh1cmwpXHJcbiAgICAgICAgICByZXR1cm4gXCI8YSBjbGFzcz0ndGV4dC1wcmltYXJ5JyB0YXJnZXQ9J19ibGFuaycgKGNsaWNrKT0ncmVkaXJlY3ROZXdMaW5rKHVybCknIGhyZWY9XFxcIlwiICsgdXJsICsgXCJcXFwiPlwiICsgdXJsICsgXCI8L2E+XCI7XHJcbiAgICAgICAgaWYgKHd3dylcclxuICAgICAgICAgIHJldHVybiBcIjxhIGNsYXNzPSd0ZXh0LXByaW1hcnknIGhyZWY9XFxcImh0dHA6Ly9cIiArIHd3dyArIFwiXFxcIj5cIiArIHd3dyArIFwiPC9hPlwiO1xyXG4gICAgICAgIGlmIChtYWlsKVxyXG4gICAgICAgICAgcmV0dXJuIFwiPGEgY2xhc3M9J3RleHQtcHJpbWFyeScgaHJlZj1cXFwiIzwvYT5cIjtcclxuICAgICAgICBpZiAodHdpdGxlcilcclxuICAgICAgICAgIHJldHVybiBcIjxhIGNsYXNzPSd0ZXh0LXByaW1hcnknIGhyZWY9XFxcInBvcnRhbC9zZWFyY2gvXCIgKyBlbmNvZGVVUklDb21wb25lbnQoJyMnICsgdHdpdGxlcikgKyBcIlxcXCI+I1wiICsgdHdpdGxlciArIFwiPC9hPlwiO1xyXG4gICAgICAgIC8vIHJldHVybiBcIjxhIGNsYXNzPSd0ZXh0LXByaW1hcnknIGhyZWY9XFxcIiNcXFwiPiNcIiArIHR3aXRsZXIgKyBcIjwvYT5cIjtcclxuXHJcbiAgICAgICAgLy8gc2hvdWxkbnQgZ2V0IGhlcmUsIGJ1dCBqdXN0IGluIGNhc2VcclxuICAgICAgICByZXR1cm4gbWF0Y2g7XHJcbiAgICAgIH0pO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGNoZWNrVmlkZW9SZW5kZXIoaXRlbSkge1xyXG5cclxuICAgIGNvbnNvbGUubG9nKCd2aWRlb1JlbmRlciAtPicsIGl0ZW0pO1xyXG4gICAgdGhpcy5zdHJlYW1TZXJ2aWNlLnN0YXR1cyhpdGVtKS5zdWJzY3JpYmUoKHJlczogYW55KSA9PiB7XHJcbiAgICAgIGNvbnNvbGUubG9nKCdjaGVja1ZpZGVvUmVuZGVyJywgcmVzKTtcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25FZGl0SXRlbSgpIHtcclxuICAgIC8vICBQcmVwYXJhciBmZWVkIHBhcmEgZWRpdGFyXHJcbiAgICBsZXQgZmVlZDtcclxuICAgIGZlZWQgPSB0aGlzLml0ZW07XHJcbiAgICBkZWxldGUgZmVlZC5jb21tZW50cztcclxuICAgIGRlbGV0ZSBmZWVkLmxpa2VzO1xyXG5cclxuICAgIGZlZWQuZmlsZXMubWFwKGZpbGUgPT4ge1xyXG4gICAgICBmaWxlLm5ldyA9IGZhbHNlO1xyXG4gICAgfSk7XHJcblxyXG4gICAgdGhpcy5kaWFsb2cub3BlbihGZWVkTW9kYWxJdGVtRWRpdENvbXBvbmVudCwge1xyXG4gICAgICB3aWR0aDogJzYwMHB4JyxcclxuICAgICAgZGF0YTogZmVlZCxcclxuICAgICAgcGFuZWxDbGFzczogJ21vZGFsLWZlZWQtcHVibGljYXRpb24nXHJcbiAgICB9KVxyXG4gIH1cclxuXHJcbiAgcHJlQ29udmVydE51bWJlcih2YWx1ZSkge1xyXG4gICAgcmV0dXJuIHBhcnNlRmxvYXQodmFsdWUpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIG9uUmVtb3ZlSXRlbShpdGVtKSB7XHJcbiAgICB0aGlzLmdsb2JhbC5zd2FsKHtcclxuICAgICAgdGl0bGU6ICdWb2PDqiByZWFsbWVudGUgZGVzZWphIHJlbW92ZXIgZXN0ZSBQb3N0PycsXHJcbiAgICAgIHRleHQ6ICdWb2PDqiBuw6NvIHBvZGVyw6EgcmV2ZXJ0ZXIgZXNzYSBhw6fDo28gZGVwb2lzIGRlIGNvbmZpcm1hZG8nLFxyXG4gICAgICB0eXBlOiBcIndhcm5pbmdcIixcclxuICAgICAgc2hvd0NhbmNlbEJ1dHRvbjogdHJ1ZSxcclxuICAgICAgY29uZmlybUJ1dHRvblRleHQ6IFwiU2ltXCIsXHJcbiAgICAgIGNhbmNlbEJ1dHRvblRleHQ6IFwiTsOjb1wiXHJcbiAgICB9KS50aGVuKGFzeW5jIGNvbmZpcm0gPT4ge1xyXG4gICAgICBpZiAoY29uZmlybS52YWx1ZSkge1xyXG4gICAgICAgIGNvbnN0IGNvbGxlY3Rpb24gPSB0aGlzLmRiLmNvbGxlY3Rpb24ocGF0aCgpLmZlZWQpLmRvYyhpdGVtLmlkKTtcclxuXHJcbiAgICAgICAgaWYgKGl0ZW0uZmlsZXMgJiYgaXRlbS5maWxlcy5sZW5ndGggPiAwKSB7XHJcbiAgICAgICAgICBmb3IgKGNvbnN0IGZpbGUgb2YgaXRlbS5maWxlcykge1xyXG4gICAgICAgICAgICBpZiAoZmlsZS50eXBlID09PSAnaW1hZ2UnKSB7XHJcbiAgICAgICAgICAgICAgaWYgKGZpbGUubmFtZSkge1xyXG4gICAgICAgICAgICAgICAgdHJ5IHtcclxuICAgICAgICAgICAgICAgICAgYXdhaXQgdGhpcy5zZXJ2aWNlLmRlbGV0ZUZpcmVTdG9yYWdlKGAke3BhdGgoKS5pbWFnZXN9LyR7ZmlsZS5uYW1lfWApO1xyXG4gICAgICAgICAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcclxuICAgICAgICAgICAgICAgICAgY29uc29sZS5sb2coJ1JlbW92ZW5kbyB1bSBwb3N0IGNvbSBpbWFnZW0gbsOjbyByZWZlcmVuY2lhZGEnLCBlcnJvcik7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBjb2xsZWN0aW9uLmRlbGV0ZSgpO1xyXG4gICAgICAgIGl0ZW0uZGVsZXRlZCA9IHRydWU7XHJcbiAgICAgICAgdGhpcy5nbG9iYWwudG9hc3QoJ1Bvc3QgcmVtb3ZpZG8gY29tIFN1Y2Vzc28nKTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBjaGVja0ZpbGVPcmlnaW4oZmlsZSkge1xyXG5cclxuICB9XHJcblxyXG4gIGlzWW91dHViZShmaWxlKSB7XHJcbiAgICBjb25zb2xlLmxvZygnSXNZb3V0dWJlIC0+JywgZmlsZSk7XHJcbiAgICBpZiAoZmlsZS5pbmNsdWRlcygneW91dHViZScpKSB7XHJcbiAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgZ2V0WW91dHViZUlEKHVybCkge1xyXG4gICAgdmFyIHJlZ0V4cCA9IC9eLiooKHlvdXR1LmJlXFwvKXwodlxcLyl8KFxcL3VcXC9cXHdcXC8pfChlbWJlZFxcLyl8KHdhdGNoXFw/KSlcXD8/dj89PyhbXiMmP10qKS4qLztcclxuICAgIHZhciBtYXRjaCA9IHVybC5tYXRjaChyZWdFeHApO1xyXG4gICAgcmV0dXJuIChtYXRjaCAmJiBtYXRjaFs3XS5sZW5ndGggPT0gMTEpID8gbWF0Y2hbN10gOiBmYWxzZTtcclxuICB9XHJcblxyXG5cclxufVxyXG4iXX0=
|