|
1 | 1 | import { Clipboard } from '@angular/cdk/clipboard'; |
2 | 2 | import { inject, Injectable } from '@angular/core'; |
3 | 3 |
|
4 | | -import { ENVIRONMENT } from '@osf/core/provider/environment.provider'; |
5 | 4 | import { embedDynamicJs, embedStaticHtml } from '@shared/constants/file-embed.constants'; |
6 | 5 |
|
7 | 6 | import { FileModel } from '../models/files/file.model'; |
8 | 7 | import { FileShareLink } from '../models/files/file-share-link.model'; |
9 | 8 |
|
| 9 | +import { SocialShareService } from './social-share.service'; |
| 10 | +import { ToastService } from './toast.service'; |
| 11 | + |
10 | 12 | @Injectable({ |
11 | 13 | providedIn: 'root', |
12 | 14 | }) |
13 | 15 | export class FilesShareEmbedService { |
14 | | - private readonly environment = inject(ENVIRONMENT); |
15 | 16 | private readonly clipboard = inject(Clipboard); |
| 17 | + private readonly socialShareService = inject(SocialShareService); |
| 18 | + private readonly toastService = inject(ToastService); |
16 | 19 |
|
17 | 20 | private readonly EMBED_PLACEHOLDER = 'ENCODED_URL'; |
18 | 21 |
|
19 | 22 | getShareLink(file: FileModel, shareType?: string): FileShareLink | null { |
20 | | - const url = file.links?.html; |
21 | | - const name = file.name; |
22 | | - |
23 | | - if (!url || !name) return null; |
| 23 | + const name = file.name ?? ''; |
| 24 | + const url = file.links?.html ?? ''; |
24 | 25 |
|
25 | | - const encodedUrl = encodeURIComponent(url); |
26 | | - const encodedName = encodeURIComponent(name); |
| 26 | + if (!url) { |
| 27 | + return null; |
| 28 | + } |
27 | 29 |
|
28 | 30 | switch (shareType) { |
29 | 31 | case 'email': |
30 | 32 | return { |
31 | | - link: `mailto:?subject=${encodedName}&body=${encodedUrl}`, |
| 33 | + link: this.socialShareService.getEmailLink(name, url), |
32 | 34 | target: '_self', |
33 | 35 | }; |
34 | 36 | case 'twitter': |
35 | 37 | return { |
36 | | - link: `https://x.com/intent/tweet?url=${encodedUrl}&text=${encodedName}&via=OSFramework`, |
| 38 | + link: this.socialShareService.getXLink(name, url), |
37 | 39 | target: '_blank', |
38 | 40 | }; |
39 | | - case 'facebook': { |
40 | | - const appId = this.environment.facebookAppId; |
| 41 | + case 'facebook': |
41 | 42 | return { |
42 | | - link: `https://www.facebook.com/dialog/share?app_id=${appId}&display=popup&href=${encodedUrl}&redirect_uri=${encodedUrl}`, |
| 43 | + link: this.socialShareService.getFacebookLink(url), |
43 | 44 | target: '_blank', |
44 | 45 | }; |
45 | | - } |
46 | 46 | default: |
47 | 47 | return null; |
48 | 48 | } |
49 | 49 | } |
50 | 50 |
|
51 | | - getEmbedHtml(file: FileModel, embedType?: string): string { |
| 51 | + getEmbedHtml(url: string, embedType?: string): string { |
52 | 52 | switch (embedType) { |
53 | 53 | case 'dynamic': |
54 | | - return embedDynamicJs.replace(this.EMBED_PLACEHOLDER, file.links.render); |
| 54 | + return embedDynamicJs.replace(this.EMBED_PLACEHOLDER, url); |
55 | 55 | case 'static': |
56 | | - return embedStaticHtml.replace(this.EMBED_PLACEHOLDER, file.links.render); |
| 56 | + return embedStaticHtml.replace(this.EMBED_PLACEHOLDER, url); |
57 | 57 | default: |
58 | 58 | return ''; |
59 | 59 | } |
60 | 60 | } |
61 | 61 |
|
62 | | - copyToClipboard(value: string): boolean { |
63 | | - return this.clipboard.copy(value); |
| 62 | + copyEmbedToClipboard(url: string, embedType?: string): boolean { |
| 63 | + const embedHtml = this.getEmbedHtml(url, embedType); |
| 64 | + |
| 65 | + if (!embedHtml) { |
| 66 | + return false; |
| 67 | + } |
| 68 | + |
| 69 | + const copied = this.clipboard.copy(embedHtml); |
| 70 | + |
| 71 | + if (copied) { |
| 72 | + this.toastService.showSuccess('files.detail.toast.copiedToClipboard'); |
| 73 | + } |
| 74 | + |
| 75 | + return copied; |
64 | 76 | } |
65 | 77 | } |
0 commit comments