aboutsummaryrefslogtreecommitdiffhomepage
path: root/client/src/app/shared/shared-share-modal
diff options
context:
space:
mode:
Diffstat (limited to 'client/src/app/shared/shared-share-modal')
-rw-r--r--client/src/app/shared/shared-share-modal/video-share.component.html30
-rw-r--r--client/src/app/shared/shared-share-modal/video-share.component.ts25
2 files changed, 41 insertions, 14 deletions
diff --git a/client/src/app/shared/shared-share-modal/video-share.component.html b/client/src/app/shared/shared-share-modal/video-share.component.html
index ecd36dd5a..7ff62e128 100644
--- a/client/src/app/shared/shared-share-modal/video-share.component.html
+++ b/client/src/app/shared/shared-share-modal/video-share.component.html
@@ -47,7 +47,7 @@
47 <ng-template ngbNavContent> 47 <ng-template ngbNavContent>
48 <div class="nav-content"> 48 <div class="nav-content">
49 <my-input-toggle-hidden 49 <my-input-toggle-hidden
50 [value]="getPlaylistIframeCode()" (change)="updateEmbedCode()" 50 [value]="customizations.onlyEmbedUrl ? getPlaylistEmbedUrl() : getPlaylistIframeCode()" (change)="updateEmbedCode()"
51 [withToggle]="false" [withCopy]="true" [show]="true" [readonly]="true" 51 [withToggle]="false" [withCopy]="true" [show]="true" [readonly]="true"
52 ></my-input-toggle-hidden> 52 ></my-input-toggle-hidden>
53 53
@@ -67,8 +67,18 @@
67 <div class="filters"> 67 <div class="filters">
68 68
69 <div class="form-group" *ngIf="video"> 69 <div class="form-group" *ngIf="video">
70 <my-peertube-checkbox inputName="includeVideoInPlaylist" [(ngModel)]="includeVideoInPlaylist" i18n-labelText 70 <my-peertube-checkbox
71 labelText="Share the playlist at this video position"></my-peertube-checkbox> 71 inputName="includeVideoInPlaylist" [(ngModel)]="includeVideoInPlaylist"
72 i18n-labelText labelText="Share the playlist at this video position"
73 ></my-peertube-checkbox>
74 </div>
75
76 <div class="form-group">
77 <my-peertube-checkbox
78 *ngIf="isInPlaylistEmbedTab()"
79 inputName="onlyEmbedUrl" [(ngModel)]="customizations.onlyEmbedUrl"
80 i18n-labelText labelText="Only display embed URL"
81 ></my-peertube-checkbox>
72 </div> 82 </div>
73 83
74 </div> 84 </div>
@@ -114,7 +124,7 @@
114 <ng-template ngbNavContent> 124 <ng-template ngbNavContent>
115 <div class="nav-content"> 125 <div class="nav-content">
116 <my-input-toggle-hidden 126 <my-input-toggle-hidden
117 [value]="getVideoIframeCode()" (ngModelChange)="updateEmbedCode()" 127 [value]="customizations.onlyEmbedUrl ? getVideoEmbedUrl() : getVideoIframeCode()" (ngModelChange)="updateEmbedCode()"
118 [withToggle]="false" [withCopy]="true" [show]="true" [readonly]="true" 128 [withToggle]="false" [withCopy]="true" [show]="true" [readonly]="true"
119 ></my-input-toggle-hidden> 129 ></my-input-toggle-hidden>
120 130
@@ -160,6 +170,14 @@
160 </select> 170 </select>
161 </div> 171 </div>
162 </div> 172 </div>
173
174 <div class="form-group">
175 <my-peertube-checkbox
176 *ngIf="isInVideoEmbedTab()"
177 inputName="onlyEmbedUrl" [(ngModel)]="customizations.onlyEmbedUrl"
178 i18n-labelText labelText="Only display embed URL"
179 ></my-peertube-checkbox>
180 </div>
163 </div> 181 </div>
164 182
165 <div class="advanced-filters collapse-transition" [ngbCollapse]="isAdvancedCustomizationCollapsed"> 183 <div class="advanced-filters collapse-transition" [ngbCollapse]="isAdvancedCustomizationCollapsed">
@@ -200,7 +218,7 @@
200 ></my-peertube-checkbox> 218 ></my-peertube-checkbox>
201 </div> 219 </div>
202 220
203 <div *ngIf="!isLocalVideo() && !isVideoInEmbedTab()" class="form-group"> 221 <div *ngIf="!isLocalVideo() && !isInVideoEmbedTab()" class="form-group">
204 <my-peertube-checkbox 222 <my-peertube-checkbox
205 inputName="originUrl" [(ngModel)]="customizations.originUrl" 223 inputName="originUrl" [(ngModel)]="customizations.originUrl"
206 i18n-labelText labelText="Use origin instance URL" 224 i18n-labelText labelText="Use origin instance URL"
@@ -208,7 +226,7 @@
208 </div> 226 </div>
209 </div> 227 </div>
210 228
211 <ng-container *ngIf="isVideoInEmbedTab()"> 229 <ng-container *ngIf="isInVideoEmbedTab()">
212 <div class="form-group"> 230 <div class="form-group">
213 <my-peertube-checkbox 231 <my-peertube-checkbox
214 inputName="title" [(ngModel)]="customizations.title" 232 inputName="title" [(ngModel)]="customizations.title"
diff --git a/client/src/app/shared/shared-share-modal/video-share.component.ts b/client/src/app/shared/shared-share-modal/video-share.component.ts
index 2346f03e4..6c0d4a039 100644
--- a/client/src/app/shared/shared-share-modal/video-share.component.ts
+++ b/client/src/app/shared/shared-share-modal/video-share.component.ts
@@ -24,6 +24,7 @@ type Customizations = {
24 muted: boolean 24 muted: boolean
25 25
26 embedP2P: boolean 26 embedP2P: boolean
27 onlyEmbedUrl: boolean
27 title: boolean 28 title: boolean
28 warningTitle: boolean 29 warningTitle: boolean
29 controls: boolean 30 controls: boolean
@@ -82,9 +83,9 @@ export class VideoShareComponent {
82 autoplay: false, 83 autoplay: false,
83 muted: false, 84 muted: false,
84 85
85 embedP2P: this.server.getHTMLConfig().defaults.p2p.embed.enabled,
86
87 // Embed options 86 // Embed options
87 embedP2P: this.server.getHTMLConfig().defaults.p2p.embed.enabled,
88 onlyEmbedUrl: false,
88 title: true, 89 title: true,
89 warningTitle: true, 90 warningTitle: true,
90 controls: true, 91 controls: true,
@@ -112,15 +113,19 @@ export class VideoShareComponent {
112 } 113 }
113 114
114 getVideoIframeCode () { 115 getVideoIframeCode () {
115 const embedUrl = decorateVideoLink({ url: this.video.embedUrl, ...this.getVideoOptions(true) }) 116 return buildVideoOrPlaylistEmbed(this.getVideoEmbedUrl(), this.video.name)
117 }
116 118
117 return buildVideoOrPlaylistEmbed(embedUrl, this.video.name) 119 getVideoEmbedUrl () {
120 return decorateVideoLink({ url: this.video.embedUrl, ...this.getVideoOptions(true) })
118 } 121 }
119 122
120 getPlaylistIframeCode () { 123 getPlaylistEmbedUrl () {
121 const embedUrl = decoratePlaylistLink({ url: this.playlist.embedUrl, ...this.getPlaylistOptions() }) 124 return decoratePlaylistLink({ url: this.playlist.embedUrl, ...this.getPlaylistOptions() })
125 }
122 126
123 return buildVideoOrPlaylistEmbed(embedUrl, this.playlist.displayName) 127 getPlaylistIframeCode () {
128 return buildVideoOrPlaylistEmbed(this.getPlaylistEmbedUrl(), this.playlist.displayName)
124 } 129 }
125 130
126 getVideoUrl () { 131 getVideoUrl () {
@@ -152,10 +157,14 @@ export class VideoShareComponent {
152 return window.location.protocol === 'http:' 157 return window.location.protocol === 'http:'
153 } 158 }
154 159
155 isVideoInEmbedTab () { 160 isInVideoEmbedTab () {
156 return this.activeVideoId === 'embed' 161 return this.activeVideoId === 'embed'
157 } 162 }
158 163
164 isInPlaylistEmbedTab () {
165 return this.activePlaylistId === 'embed'
166 }
167
159 isLocalVideo () { 168 isLocalVideo () {
160 return this.video.isLocal 169 return this.video.isLocal
161 } 170 }