nx-primeng-sakai-v17/src/app/components/blockviewer/blockviewer.component.ts
2022-01-06 17:39:33 +03:00

71 lines
2.1 KiB
TypeScript
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import { Component, Input } from '@angular/core';
import { environment } from '../../../environments/environment';
enum BlockView {
PREVIEW,
CODE
}
@Component({
selector: 'block-viewer',
template: `
<div class="block-section">
<div class="block-header">
<span class="block-title">
<span>{{header}}</span>
<span class="badge-free" *ngIf="free">Free</span>
<span class="badge-new" *ngIf="new">New</span>
</span>
<div class="block-actions">
<a tabindex="0" [ngClass]="{'block-action-active': blockView == BlockView.PREVIEW}" (click)="activateView($event, BlockView.PREVIEW)"><span>Preview</span></a>
<a [attr.tabindex]="'0'" [ngClass]="{'block-action-active': blockView == BlockView.CODE}" (click)="activateView($event, BlockView.CODE)">
<span>Code</span>
</a>
<a [attr.tabindex]="'0'" class="block-action-copy" (click)="copyCode($event)"
pTooltip="Copied to clipboard" tooltipEvent="focus" tooltipPosition="bottom"><i class="pi pi-copy"></i></a>
</div>
</div>
<div class="block-content">
<div [class]="containerClass" [ngStyle]="previewStyle" *ngIf="blockView == BlockView.PREVIEW">
<ng-content></ng-content>
</div>
<div *ngIf="blockView == BlockView.CODE">
<app-code lang="markup" ngPreserveWhitespaces>{{code}}
</app-code>
</div>
</div>
</div>
`,
styleUrls: ['./blockviewer.component.scss']
})
export class BlockViewer {
@Input() header: string;
@Input() code: string;
@Input() containerClass: string;
@Input() previewStyle: string;
@Input() free: boolean = true;
@Input() new: boolean = false;
BlockView = BlockView;
blockView: BlockView = BlockView.PREVIEW;
activateView(event: Event, blockView: BlockView) {
this.blockView = blockView;
event.preventDefault();
}
async copyCode(event: Event) {
await navigator.clipboard.writeText(this.code);
event.preventDefault();
}
}