@playpilot/tpi 8.12.0 → 8.12.1
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/dist/editorial.mount.js +9 -9
- package/dist/link-injections.js +1 -1
- package/dist/mount.js +5 -5
- package/package.json +1 -1
- package/src/lib/data/translations.ts +1 -1
- package/src/routes/components/Explore/ExploreLayout.svelte +18 -9
- package/src/routes/components/Modals/TitleModal.svelte +3 -1
- package/src/routes/components/Title.svelte +10 -4
- package/src/routes/components/YouTubeEmbed.svelte +2 -2
- package/src/routes/components/YouTubeEmbedBackground.svelte +1 -5
package/package.json
CHANGED
|
@@ -166,7 +166,7 @@ export const translations = {
|
|
|
166
166
|
[Language.Swedish]: 'Streaming Guide',
|
|
167
167
|
[Language.Danish]: 'Streaming Guide',
|
|
168
168
|
},
|
|
169
|
-
'Streaming Guide
|
|
169
|
+
'Streaming Guide Subheading': {
|
|
170
170
|
[Language.English]: 'Discover and search all movies and tv-shows',
|
|
171
171
|
[Language.Swedish]: 'Upptäck och sök bland alla filmer och tv-serier',
|
|
172
172
|
[Language.Danish]: 'Opdag og søg i alle film og tv-serier',
|
|
@@ -45,7 +45,11 @@
|
|
|
45
45
|
<div class="divider"></div>
|
|
46
46
|
|
|
47
47
|
<div class="heading" use:heading>
|
|
48
|
-
{t('Streaming Guide
|
|
48
|
+
{t('Streaming Guide')}
|
|
49
|
+
</div>
|
|
50
|
+
|
|
51
|
+
<div class="subheading" use:heading={2}>
|
|
52
|
+
{t('Streaming Guide Subheading')}
|
|
49
53
|
</div>
|
|
50
54
|
|
|
51
55
|
{#if !useExploreRouter()}
|
|
@@ -101,11 +105,6 @@
|
|
|
101
105
|
gap: margin(0.5);
|
|
102
106
|
margin: theme(explore-header-margin, 0 0 margin(1));
|
|
103
107
|
width: 100%;
|
|
104
|
-
max-width: margin(12);
|
|
105
|
-
|
|
106
|
-
@include desktop {
|
|
107
|
-
max-width: margin(20);
|
|
108
|
-
}
|
|
109
108
|
}
|
|
110
109
|
|
|
111
110
|
.divider {
|
|
@@ -115,15 +114,25 @@
|
|
|
115
114
|
background: theme(explore-divider-background, text-color);
|
|
116
115
|
}
|
|
117
116
|
|
|
118
|
-
.heading
|
|
119
|
-
|
|
117
|
+
.heading,
|
|
118
|
+
.subheading {
|
|
120
119
|
color: theme(text-color);
|
|
121
|
-
font-size: theme(explore-heading-size, clamp(margin(1),
|
|
120
|
+
font-size: theme(explore-heading-size, clamp(margin(1.5), 5vw, margin(2)));
|
|
122
121
|
font-weight: theme(explore-heading-font-weight, font-bold);
|
|
123
122
|
text-transform: theme(explore-heading-text-transform, normal);
|
|
124
123
|
line-height: theme(explore-heading-line-height, 1.5);
|
|
125
124
|
}
|
|
126
125
|
|
|
126
|
+
.subheading {
|
|
127
|
+
margin-top: margin(0.5);
|
|
128
|
+
max-width: margin(15);
|
|
129
|
+
font-size: theme(explore-subheading-size, clamp(margin(1), 2.5vw, margin(1.25)));
|
|
130
|
+
|
|
131
|
+
@include desktop {
|
|
132
|
+
max-width: 100%;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
|
|
127
136
|
.description {
|
|
128
137
|
max-width: theme(explore-header-max-width, 600px);
|
|
129
138
|
margin: 0;
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
import type { TitleData } from '$lib/types/title'
|
|
5
5
|
import { getFirstAdOfType } from '$lib/api/ads'
|
|
6
6
|
import { exploreParentSelector } from '$lib/explore'
|
|
7
|
-
import { onMount } from 'svelte'
|
|
7
|
+
import { onMount, setContext } from 'svelte'
|
|
8
8
|
import { isPixelAllowed } from '$lib/pixel'
|
|
9
9
|
import { trackViaPixel } from '@playpilot/retargeting-tracking'
|
|
10
10
|
import Modal from './Modal.svelte'
|
|
@@ -20,6 +20,8 @@
|
|
|
20
20
|
|
|
21
21
|
const { title, initialScrollPosition = 0, ...restProps }: Props = $props()
|
|
22
22
|
|
|
23
|
+
setContext('modal', 'title')
|
|
24
|
+
|
|
23
25
|
const topScrollAd = getFirstAdOfType('top_scroll')
|
|
24
26
|
const displayAd = getFirstAdOfType('card')
|
|
25
27
|
const insertExploreCta = window.PlayPilotLinkInjections?.config?.explore_insert_cta_in_tpi
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
import { heading } from '$lib/actions/heading'
|
|
15
15
|
import { removeImageUrlPrefix } from '$lib/image'
|
|
16
16
|
import { titleUrl } from '$lib/routes'
|
|
17
|
-
import { setContext } from 'svelte'
|
|
17
|
+
import { getContext, setContext } from 'svelte'
|
|
18
18
|
import { track } from '$lib/tracking'
|
|
19
19
|
import { TrackingEvent } from '$lib/enums/TrackingEvent'
|
|
20
20
|
import { isYouTubeVideoAvailableInRegion } from '$lib/api/youtubeAvailability'
|
|
@@ -32,6 +32,7 @@
|
|
|
32
32
|
|
|
33
33
|
setContext('title', title)
|
|
34
34
|
|
|
35
|
+
const modal = getContext('modal')
|
|
35
36
|
const showDescription = $derived((!small || noAffiliate) && title.description)
|
|
36
37
|
|
|
37
38
|
let posterLoaded = $state(false)
|
|
@@ -96,7 +97,7 @@
|
|
|
96
97
|
</div>
|
|
97
98
|
</div>
|
|
98
99
|
|
|
99
|
-
<div class="background" class:small>
|
|
100
|
+
<div class="background" class:small class:offset-mute={modal === 'title'}>
|
|
100
101
|
{#if useVideoBackground && hasYouTubeVideoAvailable}
|
|
101
102
|
<YouTubeEmbedBackground embeddable_url={title.embeddable_url!} />
|
|
102
103
|
{:else}
|
|
@@ -131,7 +132,6 @@
|
|
|
131
132
|
}
|
|
132
133
|
|
|
133
134
|
.content {
|
|
134
|
-
z-index: 1;
|
|
135
135
|
position: relative;
|
|
136
136
|
padding: margin(1);
|
|
137
137
|
color: theme(detail-text-color, text-color);
|
|
@@ -179,6 +179,8 @@
|
|
|
179
179
|
}
|
|
180
180
|
|
|
181
181
|
.poster {
|
|
182
|
+
z-index: 1;
|
|
183
|
+
position: relative;
|
|
182
184
|
grid-area: poster;
|
|
183
185
|
display: block;
|
|
184
186
|
width: $poster-width;
|
|
@@ -244,7 +246,6 @@
|
|
|
244
246
|
overflow: hidden;
|
|
245
247
|
background: theme(detail-background, lighter);
|
|
246
248
|
mask-image: linear-gradient(to bottom, black 40%, transparent);
|
|
247
|
-
z-index: 0;
|
|
248
249
|
|
|
249
250
|
@include desktop() {
|
|
250
251
|
height: margin(12);
|
|
@@ -263,6 +264,11 @@
|
|
|
263
264
|
}
|
|
264
265
|
}
|
|
265
266
|
|
|
267
|
+
&.offset-mute {
|
|
268
|
+
--mute-top: #{margin(3)};
|
|
269
|
+
--mute-right: #{margin(0.25)};
|
|
270
|
+
}
|
|
271
|
+
|
|
266
272
|
img {
|
|
267
273
|
width: 100%;
|
|
268
274
|
height: 100%;
|
|
@@ -74,8 +74,8 @@
|
|
|
74
74
|
align-items: center;
|
|
75
75
|
justify-content: center;
|
|
76
76
|
position: absolute;
|
|
77
|
-
top: margin(0.5);
|
|
78
|
-
right: margin(0.5);
|
|
77
|
+
top: calc(margin(0.5) + var(--mute-top, 0px));
|
|
78
|
+
right: calc(margin(0.5) + var(--mute-right, 0px));
|
|
79
79
|
padding: margin(0.25);
|
|
80
80
|
border: 0;
|
|
81
81
|
border-radius: 50%;
|
|
@@ -14,15 +14,11 @@
|
|
|
14
14
|
</script>
|
|
15
15
|
|
|
16
16
|
<div class="video-background" style="--height: {height}px; --width: {clientWidth}px;" bind:clientWidth bind:clientHeight data-testid="video-background">
|
|
17
|
-
<YouTubeEmbed {embeddable_url} muted loop />
|
|
17
|
+
<YouTubeEmbed {embeddable_url} muted loop showMuteControls />
|
|
18
18
|
</div>
|
|
19
19
|
|
|
20
20
|
<style lang="scss">
|
|
21
21
|
.video-background {
|
|
22
|
-
width: 100%;
|
|
23
|
-
height: 100%;
|
|
24
|
-
margin-left: 50%;
|
|
25
|
-
transform: translateX(-50%);
|
|
26
22
|
background: black;
|
|
27
23
|
|
|
28
24
|
:global(iframe) {
|