]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - client/src/app/+videos/+video-watch/comment/video-comment-add.component.html
Improve markdown-it emoji list column display (#3253)
[github/Chocobozzz/PeerTube.git] / client / src / app / +videos / +video-watch / comment / video-comment-add.component.html
1 <form novalidate [formGroup]="form" (ngSubmit)="formValidated()">
2 <div class="avatar-and-textarea">
3 <img [src]="getAvatarUrl()" alt="Avatar" />
4
5 <div class="form-group">
6 <textarea i18n-placeholder placeholder="Add comment..." myAutoResize
7 [readonly]="(user === null) ? true : false"
8 (click)="openVisitorModal($event)"
9 formControlName="text" [ngClass]="{ 'input-error': formErrors['text'] }"
10 (keyup.control.enter)="onValidKey()" (keyup.meta.enter)="onValidKey()" #textarea>
11
12 </textarea>
13 <my-help class="markdown-guide" helpType="custom" iconName="markdown" tooltipPlacement="left auto" autoClose="true" i18n-title title="Markdown compatible">
14 <ng-template ptTemplate="customHtml">
15 <span i18n>Markdown compatible that supports:</span>
16
17 <ul>
18 <li><span i18n>Auto generated links</span></li>
19 <li><span i18n>Break lines</span></li>
20 <li><span i18n>Lists</span></li>
21 <li>
22 <span i18n>Emphasis</span>
23 <code>**<strong i18n>bold</strong>** _<i i18n>italic</i>_</code>
24 </li>
25 <li>
26 <span i18n>Emoji shortcuts</span>
27 <code>:) &lt;3</code>
28 </li>
29 <li>
30 <span i18n>Emoji markup</span>
31 <code>:smile:</code>
32 <div><a href="" (click)="openEmojiModal($event)" i18n>See complete list</a></div>
33 </li>
34 </ul>
35 </ng-template>
36 </my-help>
37 <div *ngIf="formErrors.text" class="form-error">
38 {{ formErrors.text }}
39 </div>
40 </div>
41 </div>
42
43 <div class="comment-buttons">
44 <button *ngIf="isAddButtonDisplayed()" class="cancel-button" (click)="cancelCommentReply()" type="button" i18n>
45 Cancel
46 </button>
47 <button *ngIf="isAddButtonDisplayed()" [ngClass]="{ disabled: !form.valid || addingComment }">
48 {{ addingCommentButtonValue }}
49 </button>
50 </div>
51 </form>
52
53 <ng-template #visitorModal let-modal>
54 <div class="modal-header">
55 <h4 class="modal-title" id="modal-basic-title" i18n>You are one step away from commenting</h4>
56 <my-global-icon iconName="cross" aria-label="Close" role="button" (click)="hideModals()"></my-global-icon>
57 </div>
58 <div class="modal-body">
59 <span i18n>
60 You can comment using an account on any ActivityPub-compatible instance.
61 On most platforms, you can find the video by typing its URL in the search bar and then comment it
62 from within the software's interface.
63 </span>
64 <span i18n>
65 If you have an account on Mastodon or Pleroma, you can open it directly in their interface:
66 </span>
67 <my-remote-subscribe [interact]="true" [uri]="getUri()"></my-remote-subscribe>
68 </div>
69 <div class="modal-footer inputs">
70 <input
71 type="button" role="button" i18n-value value="Cancel" class="action-button action-button-cancel"
72 (click)="hideModals()" (key.enter)="hideModals()"
73 >
74
75 <input
76 type="submit" i18n-value value="Login to comment" class="action-button-submit"
77 (click)="gotoLogin()"
78 >
79 </div>
80 </ng-template>
81
82 <ng-template #emojiModal>
83 <div class="modal-header">
84 <h4 class="modal-title" id="modal-basic-title" i18n>Markdown Emoji List</h4>
85 <my-global-icon iconName="cross" aria-label="Close" role="button" (click)="hideModals()"></my-global-icon>
86 </div>
87 <div class="modal-body">
88 <div class="emoji-flex">
89 <div class="emoji-flex-item" *ngFor="let emojiMarkup of emojiMarkupList">
90 {{ emojiMarkup[0] }} <code>:{{ emojiMarkup[1] }}:</code>
91 </div>
92 </div>
93 </div>
94 </ng-template>