@banta/sdk 5.2.0 → 5.2.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.
@@ -31,14 +31,6 @@ import * as i1 from "./chat-backend-base";
31
31
  import * as i2 from "./common/common.module";
32
32
  export class BantaSdkModule {
33
33
  constructor(chatBackend) {
34
- if (typeof window !== 'undefined') {
35
- if (!document.querySelector('script[src="https://platform.twitter.com/widgets.js"]')) {
36
- let script = document.createElement('script');
37
- script.src = 'https://platform.twitter.com/widgets.js';
38
- script.async = true;
39
- document.body.appendChild(script);
40
- }
41
- }
42
34
  chatBackend.registerAttachmentScraper(new UrlAttachmentScraper());
43
35
  chatBackend.registerAttachmentResolver(new GiphyAttachmentResolver());
44
36
  chatBackend.registerAttachmentResolver(new YouTubeAttachmentResolver());
@@ -140,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
140
132
  ]
141
133
  }]
142
134
  }], ctorParameters: () => [{ type: i1.ChatBackendBase }] });
143
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"banta-sdk.module.js","sourceRoot":"","sources":["../../../../projects/sdk/src/lib/banta-sdk.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { ModuleWithProviders, NgModule } from '@angular/core';\r\nimport { CommentsModule } from './comments';\r\nimport { ChatModule } from './chat';\r\nimport { EmojiModule } from './emoji';\r\nimport { BantaComponent } from './banta/banta.component';\r\nimport { BantaLogoComponent } from './banta-logo.component';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { BantaCommonModule } from './common/common.module';\r\nimport { LiveMessageComponent } from './live-message.component';\r\nimport { MatButtonModule } from \"@angular/material/button\";\r\nimport { MatIconModule } from \"@angular/material/icon\";\r\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { MatDialogModule } from \"@angular/material/dialog\";\r\nimport { MatSnackBarModule } from \"@angular/material/snack-bar\";\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatInputModule } from \"@angular/material/input\";\r\nimport { MatProgressSpinnerModule } from \"@angular/material/progress-spinner\";\r\nimport { ChatBackend } from './chat-backend';\r\nimport { SdkOptions } from './sdk-options';\r\nimport { BANTA_SDK_OPTIONS } from './sdk-options';\r\nimport { ChatBackendBase } from './chat-backend-base';\r\nimport { OverlayModule } from '@angular/cdk/overlay';\r\nimport { PortalModule } from '@angular/cdk/portal';\r\nimport { UrlAttachmentResolver, UrlAttachmentScraper } from './url-attachments';\r\nimport { YouTubeAttachmentResolver } from './youtube-attachments';\r\nimport { GiphyAttachmentResolver } from './giphy-attachments';\r\nimport { TweetAttachmentResolver } from './tweet-attachments';\r\n\r\n@NgModule({\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        BantaCommonModule.forRoot(),\r\n        CommentsModule,\r\n        ChatModule,\r\n        EmojiModule,\r\n        \r\n        MatIconModule,\r\n        MatButtonModule,\r\n        MatTooltipModule,\r\n        MatMenuModule,\r\n        MatDialogModule,\r\n        MatFormFieldModule,\r\n        MatInputModule,\r\n        MatProgressSpinnerModule,\r\n        MatSnackBarModule,\r\n        OverlayModule,\r\n        PortalModule\r\n    ],\r\n    declarations: [\r\n        BantaComponent,\r\n        BantaLogoComponent,\r\n        LiveMessageComponent\r\n    ],\r\n    exports: [\r\n        BantaComponent,\r\n        BantaLogoComponent,\r\n        LiveMessageComponent,\r\n        BantaCommonModule,\r\n        ChatModule,\r\n        CommentsModule,\r\n        EmojiModule\r\n    ]\r\n})\r\nexport class BantaSdkModule {\r\n    constructor(\r\n        chatBackend: ChatBackendBase\r\n    ) {\r\n        if (typeof window !== 'undefined') {\r\n            if (!document.querySelector('script[src=\"https://platform.twitter.com/widgets.js\"]')) {\r\n                let script = document.createElement('script');\r\n                script.src = 'https://platform.twitter.com/widgets.js';\r\n                script.async = true;\r\n                document.body.appendChild(script);\r\n            }\r\n        }\r\n\r\n        chatBackend.registerAttachmentScraper(new UrlAttachmentScraper());\r\n        chatBackend.registerAttachmentResolver(new GiphyAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new YouTubeAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new TweetAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new UrlAttachmentResolver(chatBackend));\r\n    }\r\n    \r\n    static configure(options?: SdkOptions): ModuleWithProviders<BantaSdkModule> {\r\n        return {\r\n            ngModule: BantaSdkModule,\r\n            providers: [\r\n                { \r\n                    provide: BANTA_SDK_OPTIONS, \r\n                    useValue: options || {}\r\n                },\r\n                { provide: ChatBackendBase, useClass: ChatBackend }\r\n            ]\r\n        }\r\n    }\r\n}"]}
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"banta-sdk.module.js","sourceRoot":"","sources":["../../../../projects/sdk/src/lib/banta-sdk.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { ModuleWithProviders, NgModule } from '@angular/core';\r\nimport { CommentsModule } from './comments';\r\nimport { ChatModule } from './chat';\r\nimport { EmojiModule } from './emoji';\r\nimport { BantaComponent } from './banta/banta.component';\r\nimport { BantaLogoComponent } from './banta-logo.component';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { BantaCommonModule } from './common/common.module';\r\nimport { LiveMessageComponent } from './live-message.component';\r\nimport { MatButtonModule } from \"@angular/material/button\";\r\nimport { MatIconModule } from \"@angular/material/icon\";\r\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { MatDialogModule } from \"@angular/material/dialog\";\r\nimport { MatSnackBarModule } from \"@angular/material/snack-bar\";\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatInputModule } from \"@angular/material/input\";\r\nimport { MatProgressSpinnerModule } from \"@angular/material/progress-spinner\";\r\nimport { ChatBackend } from './chat-backend';\r\nimport { SdkOptions } from './sdk-options';\r\nimport { BANTA_SDK_OPTIONS } from './sdk-options';\r\nimport { ChatBackendBase } from './chat-backend-base';\r\nimport { OverlayModule } from '@angular/cdk/overlay';\r\nimport { PortalModule } from '@angular/cdk/portal';\r\nimport { UrlAttachmentResolver, UrlAttachmentScraper } from './url-attachments';\r\nimport { YouTubeAttachmentResolver } from './youtube-attachments';\r\nimport { GiphyAttachmentResolver } from './giphy-attachments';\r\nimport { TweetAttachmentResolver } from './tweet-attachments';\r\n\r\n@NgModule({\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        BantaCommonModule.forRoot(),\r\n        CommentsModule,\r\n        ChatModule,\r\n        EmojiModule,\r\n        \r\n        MatIconModule,\r\n        MatButtonModule,\r\n        MatTooltipModule,\r\n        MatMenuModule,\r\n        MatDialogModule,\r\n        MatFormFieldModule,\r\n        MatInputModule,\r\n        MatProgressSpinnerModule,\r\n        MatSnackBarModule,\r\n        OverlayModule,\r\n        PortalModule\r\n    ],\r\n    declarations: [\r\n        BantaComponent,\r\n        BantaLogoComponent,\r\n        LiveMessageComponent\r\n    ],\r\n    exports: [\r\n        BantaComponent,\r\n        BantaLogoComponent,\r\n        LiveMessageComponent,\r\n        BantaCommonModule,\r\n        ChatModule,\r\n        CommentsModule,\r\n        EmojiModule\r\n    ]\r\n})\r\nexport class BantaSdkModule {\r\n    constructor(\r\n        chatBackend: ChatBackendBase\r\n    ) {\r\n        chatBackend.registerAttachmentScraper(new UrlAttachmentScraper());\r\n        chatBackend.registerAttachmentResolver(new GiphyAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new YouTubeAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new TweetAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new UrlAttachmentResolver(chatBackend));\r\n    }\r\n    \r\n    static configure(options?: SdkOptions): ModuleWithProviders<BantaSdkModule> {\r\n        return {\r\n            ngModule: BantaSdkModule,\r\n            providers: [\r\n                { \r\n                    provide: BANTA_SDK_OPTIONS, \r\n                    useValue: options || {}\r\n                },\r\n                { provide: ChatBackendBase, useClass: ChatBackend }\r\n            ]\r\n        }\r\n    }\r\n}"]}
@@ -7,6 +7,7 @@ import * as i3 from "@angular/cdk/bidi";
7
7
  import * as i4 from "@angular/material/progress-spinner";
8
8
  import * as i5 from "@angular/material/button";
9
9
  import * as i6 from "../trust-resource-url.pipe";
10
+ let TWITTER_LOADED = false;
10
11
  export class BantaAttachmentComponent {
11
12
  constructor(elementRef) {
12
13
  this.elementRef = elementRef;
@@ -24,20 +25,33 @@ export class BantaAttachmentComponent {
24
25
  set attachment(value) {
25
26
  this._attachment = value;
26
27
  this.checkLoad();
27
- }
28
- ngOnInit() {
29
- if (typeof window !== 'undefined') {
30
- setTimeout(() => {
31
- if (!window['twttr'])
32
- return;
33
- window['twttr'].widgets.load();
34
- }, 100);
35
- }
28
+ this.loadPlatformSpecific();
36
29
  }
37
30
  ngAfterViewInit() {
38
31
  this._viewLoaded = true;
39
32
  this.checkLoad();
40
33
  }
34
+ loadTwitterWidgets() {
35
+ if (typeof window !== 'undefined')
36
+ window['twttr']?.widgets.load();
37
+ }
38
+ loadPlatformSpecific() {
39
+ if (this._attachment?.type === 'tweet') {
40
+ if (!TWITTER_LOADED && document.querySelector('script[src="https://platform.twitter.com/widgets.js"]'))
41
+ TWITTER_LOADED = true;
42
+ if (typeof window !== 'undefined' && !TWITTER_LOADED) {
43
+ TWITTER_LOADED = true;
44
+ let script = document.createElement('script');
45
+ script.src = 'https://platform.twitter.com/widgets.js';
46
+ script.async = true;
47
+ script.addEventListener('load', () => setTimeout(() => this.loadTwitterWidgets()));
48
+ document.body.appendChild(script);
49
+ }
50
+ else {
51
+ setTimeout(() => this.loadTwitterWidgets());
52
+ }
53
+ }
54
+ }
41
55
  checkLoad() {
42
56
  if (!this._attachment || !this._viewLoaded || !this.elementRef?.nativeElement)
43
57
  return;
@@ -109,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
109
123
  type: HostBinding,
110
124
  args: ['class.loading']
111
125
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment.component.js","sourceRoot":"","sources":["../../../../../../projects/sdk/src/lib/common/attachment/attachment.component.ts","../../../../../../projects/sdk/src/lib/common/attachment/attachment.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, Input, Output } from \"@angular/core\";\r\nimport { ChatMessageAttachment } from \"@banta/common\";\r\nimport { Subject } from \"rxjs\";\r\n\r\n@Component({\r\n    selector: 'banta-attachment',\r\n    templateUrl: './attachment.component.html',\r\n    styleUrls: ['./attachment.component.scss']\r\n})\r\nexport class BantaAttachmentComponent {\r\n    constructor(\r\n        private elementRef: ElementRef<HTMLElement>\r\n    ) {\r\n\r\n    }\r\n\r\n    private _attachment: ChatMessageAttachment;\r\n    @Input() get attachment() { return this._attachment; }\r\n    set attachment(value) {\r\n        this._attachment = value;\r\n        this.checkLoad();\r\n    }\r\n    @Input() loading = false;\r\n    @Input() editing = false;\r\n    @Input() loadingMessage: string = 'Please wait...';\r\n    @Input() error = false;\r\n    @Input() errorMessage: string = 'An error has occurred';\r\n    @Output() removed = new Subject<void>();\r\n    @Output() activated = new Subject<void>();\r\n    @Output() loaded = new Subject<void>();\r\n\r\n    ngOnInit() {\r\n        if (typeof window !== 'undefined') {\r\n            setTimeout(() => {\r\n                if (!window['twttr'])\r\n                    return;\r\n                window['twttr'].widgets.load();\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    private _viewLoaded = false;\r\n    ngAfterViewInit() {\r\n        this._viewLoaded = true;\r\n        this.checkLoad();\r\n    }\r\n\r\n    private checkLoad() {\r\n        if (!this._attachment || !this._viewLoaded || !this.elementRef?.nativeElement)\r\n            return;\r\n\r\n        if (typeof window === 'undefined')\r\n            this.loaded.next();\r\n        else\r\n            setTimeout(() => this.loaded.next(), 250);\r\n    }\r\n\r\n    activate() {\r\n        this.activated.next();\r\n    }\r\n\r\n    remove() {\r\n        this.removed.next();\r\n    }\r\n\r\n    get isError() {\r\n        return this.error || this.attachment?.transientState?.error;\r\n    }\r\n\r\n    get theErrorMessage() {\r\n        return this.errorMessage || this.attachment?.transientState?.errorMessage;\r\n    }\r\n\r\n    @HostBinding('class.loading')\r\n    get isLoading() {\r\n        return this.editing && (\r\n            this.loading || !this.attachment || this.attachment.transientState?.loading \r\n            || !this.attachment.url\r\n        );\r\n    }\r\n\r\n    get isImageAttachment() {\r\n        return this.attachment?.type?.startsWith('image/');\r\n    }\r\n\r\n    get hasFrame() {\r\n        if (!this.attachment)\r\n            return false;\r\n\r\n        return this.attachment.type === 'iframe' || (\r\n            this.attachment.type === 'card' \r\n            && this.attachment.card?.player\r\n        );\r\n    }\r\n\r\n    get frameUrl() {\r\n        if (!this.attachment)\r\n            return undefined;\r\n        \r\n        if (this.attachment.type === 'iframe') {\r\n            return this.attachment.url;\r\n        } else if (this.attachment.type === 'card') {\r\n            return this.attachment.card.player;\r\n        }\r\n    }\r\n}","<button type=\"button\" (click)=\"remove()\" mat-mini-fab color=\"primary\" class=\"remove-button\" *ngIf=\"editing\">\r\n    <mat-icon>close</mat-icon>\r\n</button>\r\n\r\n<ng-container *ngIf=\"isError\">\r\n    <mat-icon class=\"error\">close</mat-icon>\r\n    <em class=\"error\">{{theErrorMessage}}</em>\r\n</ng-container>\r\n<ng-container *ngIf=\"!isError\">\r\n    <ng-container *ngIf=\"isLoading\">\r\n        <mat-spinner></mat-spinner>\r\n        <em>{{loadingMessage}}</em>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"!isLoading && attachment\">\r\n        <iframe *ngIf=\"hasFrame\"\r\n            sandbox=\"allow-scripts allow-popups allow-same-origin allow-presentation\" \r\n            [src]=\"frameUrl | trustResourceUrl\"></iframe>\r\n        <a *ngIf=\"attachment.type === 'card'\" class=\"card-attachment\" [href]=\"attachment.url\" target=\"_blank\" [class.has-image]=\"attachment.card.image\">\r\n            <img \r\n                *ngIf=\"attachment.card.image\"\r\n                class=\"thumbnail\" \r\n                [src]=\"attachment.card.image\"\r\n                />\r\n            <div class=\"description\">\r\n                <h1>{{attachment.card.title}}</h1>\r\n                <div class=\"summary\">\r\n                    {{attachment.card.description}}\r\n                </div>\r\n                <cite>{{attachment.card.url}}</cite>\r\n            </div>\r\n        </a>\r\n        <a class=\"image-attachment\" *ngIf=\"isImageAttachment && attachment.url\" href=\"javascript:;\" (click)=\"activate()\">\r\n            <img [src]=\"attachment.url\" alt=\"Image Attachment\">\r\n        </a>\r\n        <blockquote *ngIf=\"attachment.type === 'tweet'\" \r\n            class=\"twitter-tweet\">\r\n                <p lang=\"en\" dir=\"ltr\"></p>\r\n                <a [href]=\"attachment.url\"></a>\r\n        </blockquote>\r\n    </ng-container>\r\n</ng-container>"]}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment.component.js","sourceRoot":"","sources":["../../../../../../projects/sdk/src/lib/common/attachment/attachment.component.ts","../../../../../../projects/sdk/src/lib/common/attachment/attachment.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, Input, Output } from \"@angular/core\";\r\nimport { ChatMessageAttachment } from \"@banta/common\";\r\nimport { Subject } from \"rxjs\";\r\n\r\nlet TWITTER_LOADED = false;\r\n\r\n@Component({\r\n    selector: 'banta-attachment',\r\n    templateUrl: './attachment.component.html',\r\n    styleUrls: ['./attachment.component.scss']\r\n})\r\nexport class BantaAttachmentComponent {\r\n    constructor(\r\n        private elementRef: ElementRef<HTMLElement>\r\n    ) {\r\n\r\n    }\r\n\r\n    private _attachment: ChatMessageAttachment;\r\n    @Input() get attachment() { return this._attachment; }\r\n    set attachment(value) {\r\n        this._attachment = value;\r\n        this.checkLoad();\r\n        this.loadPlatformSpecific();\r\n    }\r\n    \r\n    @Input() loading = false;\r\n    @Input() editing = false;\r\n    @Input() loadingMessage: string = 'Please wait...';\r\n    @Input() error = false;\r\n    @Input() errorMessage: string = 'An error has occurred';\r\n    @Output() removed = new Subject<void>();\r\n    @Output() activated = new Subject<void>();\r\n    @Output() loaded = new Subject<void>();\r\n\r\n    private _viewLoaded = false;\r\n    ngAfterViewInit() {\r\n        this._viewLoaded = true;\r\n        this.checkLoad();\r\n    }\r\n\r\n    private loadTwitterWidgets() {\r\n        if (typeof window !== 'undefined')\r\n            window['twttr']?.widgets.load();\r\n    }\r\n\r\n    private loadPlatformSpecific() {\r\n        if (this._attachment?.type === 'tweet') {\r\n            if (!TWITTER_LOADED && document.querySelector('script[src=\"https://platform.twitter.com/widgets.js\"]'))\r\n                TWITTER_LOADED = true;\r\n\r\n            if (typeof window !== 'undefined' && !TWITTER_LOADED) {\r\n                TWITTER_LOADED = true;\r\n                let script = document.createElement('script');\r\n                script.src = 'https://platform.twitter.com/widgets.js';\r\n                script.async = true;\r\n                script.addEventListener('load', () => setTimeout(() => this.loadTwitterWidgets()));\r\n                document.body.appendChild(script);\r\n            } else {\r\n                setTimeout(() => this.loadTwitterWidgets());\r\n            }\r\n        }\r\n    }\r\n    \r\n    private checkLoad() {\r\n        if (!this._attachment || !this._viewLoaded || !this.elementRef?.nativeElement)\r\n            return;\r\n\r\n        if (typeof window === 'undefined')\r\n            this.loaded.next();\r\n        else\r\n            setTimeout(() => this.loaded.next(), 250);\r\n    }\r\n\r\n    activate() {\r\n        this.activated.next();\r\n    }\r\n\r\n    remove() {\r\n        this.removed.next();\r\n    }\r\n\r\n    get isError() {\r\n        return this.error || this.attachment?.transientState?.error;\r\n    }\r\n\r\n    get theErrorMessage() {\r\n        return this.errorMessage || this.attachment?.transientState?.errorMessage;\r\n    }\r\n\r\n    @HostBinding('class.loading')\r\n    get isLoading() {\r\n        return this.editing && (\r\n            this.loading || !this.attachment || this.attachment.transientState?.loading \r\n            || !this.attachment.url\r\n        );\r\n    }\r\n\r\n    get isImageAttachment() {\r\n        return this.attachment?.type?.startsWith('image/');\r\n    }\r\n\r\n    get hasFrame() {\r\n        if (!this.attachment)\r\n            return false;\r\n\r\n        return this.attachment.type === 'iframe' || (\r\n            this.attachment.type === 'card' \r\n            && this.attachment.card?.player\r\n        );\r\n    }\r\n\r\n    get frameUrl() {\r\n        if (!this.attachment)\r\n            return undefined;\r\n        \r\n        if (this.attachment.type === 'iframe') {\r\n            return this.attachment.url;\r\n        } else if (this.attachment.type === 'card') {\r\n            return this.attachment.card.player;\r\n        }\r\n    }\r\n}","<button type=\"button\" (click)=\"remove()\" mat-mini-fab color=\"primary\" class=\"remove-button\" *ngIf=\"editing\">\r\n    <mat-icon>close</mat-icon>\r\n</button>\r\n\r\n<ng-container *ngIf=\"isError\">\r\n    <mat-icon class=\"error\">close</mat-icon>\r\n    <em class=\"error\">{{theErrorMessage}}</em>\r\n</ng-container>\r\n<ng-container *ngIf=\"!isError\">\r\n    <ng-container *ngIf=\"isLoading\">\r\n        <mat-spinner></mat-spinner>\r\n        <em>{{loadingMessage}}</em>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"!isLoading && attachment\">\r\n        <iframe *ngIf=\"hasFrame\"\r\n            sandbox=\"allow-scripts allow-popups allow-same-origin allow-presentation\" \r\n            [src]=\"frameUrl | trustResourceUrl\"></iframe>\r\n        <a *ngIf=\"attachment.type === 'card'\" class=\"card-attachment\" [href]=\"attachment.url\" target=\"_blank\" [class.has-image]=\"attachment.card.image\">\r\n            <img \r\n                *ngIf=\"attachment.card.image\"\r\n                class=\"thumbnail\" \r\n                [src]=\"attachment.card.image\"\r\n                />\r\n            <div class=\"description\">\r\n                <h1>{{attachment.card.title}}</h1>\r\n                <div class=\"summary\">\r\n                    {{attachment.card.description}}\r\n                </div>\r\n                <cite>{{attachment.card.url}}</cite>\r\n            </div>\r\n        </a>\r\n        <a class=\"image-attachment\" *ngIf=\"isImageAttachment && attachment.url\" href=\"javascript:;\" (click)=\"activate()\">\r\n            <img [src]=\"attachment.url\" alt=\"Image Attachment\">\r\n        </a>\r\n        <blockquote *ngIf=\"attachment.type === 'tweet'\" \r\n            class=\"twitter-tweet\">\r\n                <p lang=\"en\" dir=\"ltr\"></p>\r\n                <a [href]=\"attachment.url\"></a>\r\n        </blockquote>\r\n    </ng-container>\r\n</ng-container>"]}
@@ -1,6 +1,6 @@
1
1
  export class TweetAttachmentResolver {
2
2
  async resolveFragment(message, fragment) {
3
- if (fragment.type === 'url' && fragment.text.startsWith('https://twitter.com/')) {
3
+ if (fragment.type === 'url' && (fragment.text.startsWith('https://twitter.com/') || fragment.text.startsWith('https://x.com/'))) {
4
4
  return {
5
5
  type: 'tweet',
6
6
  url: fragment.text,
@@ -10,4 +10,4 @@ export class TweetAttachmentResolver {
10
10
  return null;
11
11
  }
12
12
  }
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHdlZXQtYXR0YWNobWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zZGsvc3JjL2xpYi90d2VldC1hdHRhY2htZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sdUJBQXVCO0lBQ2hDLEtBQUssQ0FBQyxlQUFlLENBQUMsT0FBb0IsRUFBRSxRQUE0QjtRQUNwRSxJQUFJLFFBQVEsQ0FBQyxJQUFJLEtBQUssS0FBSyxJQUFJLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLHNCQUFzQixDQUFDLEVBQUUsQ0FBQztZQUM5RSxPQUFPO2dCQUNILElBQUksRUFBRSxPQUFPO2dCQUNiLEdBQUcsRUFBRSxRQUFRLENBQUMsSUFBSTtnQkFDbEIsS0FBSyxFQUFFLE9BQU87YUFDakIsQ0FBQztRQUNOLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGF0TWVzc2FnZSwgQ2hhdE1lc3NhZ2VBdHRhY2htZW50IH0gZnJvbSBcIkBiYW50YS9jb21tb25cIjtcclxuaW1wb3J0IHsgQXR0YWNobWVudEZyYWdtZW50LCBBdHRhY2htZW50UmVzb2x2ZXIgfSBmcm9tIFwiLi9hdHRhY2htZW50LXNjcmFwZXJcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBUd2VldEF0dGFjaG1lbnRSZXNvbHZlciBpbXBsZW1lbnRzIEF0dGFjaG1lbnRSZXNvbHZlciB7XHJcbiAgICBhc3luYyByZXNvbHZlRnJhZ21lbnQobWVzc2FnZTogQ2hhdE1lc3NhZ2UsIGZyYWdtZW50OiBBdHRhY2htZW50RnJhZ21lbnQpOiBQcm9taXNlPENoYXRNZXNzYWdlQXR0YWNobWVudD4ge1xyXG4gICAgICAgIGlmIChmcmFnbWVudC50eXBlID09PSAndXJsJyAmJiBmcmFnbWVudC50ZXh0LnN0YXJ0c1dpdGgoJ2h0dHBzOi8vdHdpdHRlci5jb20vJykpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgICAgIHR5cGU6ICd0d2VldCcsXHJcbiAgICAgICAgICAgICAgICB1cmw6IGZyYWdtZW50LnRleHQsXHJcbiAgICAgICAgICAgICAgICBzdHlsZTogJ2Jsb2NrJ1xyXG4gICAgICAgICAgICB9O1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbn0iXX0=
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHdlZXQtYXR0YWNobWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zZGsvc3JjL2xpYi90d2VldC1hdHRhY2htZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sdUJBQXVCO0lBQ2hDLEtBQUssQ0FBQyxlQUFlLENBQUMsT0FBb0IsRUFBRSxRQUE0QjtRQUNwRSxJQUFJLFFBQVEsQ0FBQyxJQUFJLEtBQUssS0FBSyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsc0JBQXNCLENBQUMsSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLEVBQUUsQ0FBQztZQUM5SCxPQUFPO2dCQUNILElBQUksRUFBRSxPQUFPO2dCQUNiLEdBQUcsRUFBRSxRQUFRLENBQUMsSUFBSTtnQkFDbEIsS0FBSyxFQUFFLE9BQU87YUFDakIsQ0FBQztRQUNOLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGF0TWVzc2FnZSwgQ2hhdE1lc3NhZ2VBdHRhY2htZW50IH0gZnJvbSBcIkBiYW50YS9jb21tb25cIjtcclxuaW1wb3J0IHsgQXR0YWNobWVudEZyYWdtZW50LCBBdHRhY2htZW50UmVzb2x2ZXIgfSBmcm9tIFwiLi9hdHRhY2htZW50LXNjcmFwZXJcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBUd2VldEF0dGFjaG1lbnRSZXNvbHZlciBpbXBsZW1lbnRzIEF0dGFjaG1lbnRSZXNvbHZlciB7XHJcbiAgICBhc3luYyByZXNvbHZlRnJhZ21lbnQobWVzc2FnZTogQ2hhdE1lc3NhZ2UsIGZyYWdtZW50OiBBdHRhY2htZW50RnJhZ21lbnQpOiBQcm9taXNlPENoYXRNZXNzYWdlQXR0YWNobWVudD4ge1xyXG4gICAgICAgIGlmIChmcmFnbWVudC50eXBlID09PSAndXJsJyAmJiAoZnJhZ21lbnQudGV4dC5zdGFydHNXaXRoKCdodHRwczovL3R3aXR0ZXIuY29tLycpIHx8IGZyYWdtZW50LnRleHQuc3RhcnRzV2l0aCgnaHR0cHM6Ly94LmNvbS8nKSkpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgICAgIHR5cGU6ICd0d2VldCcsXHJcbiAgICAgICAgICAgICAgICB1cmw6IGZyYWdtZW50LnRleHQsXHJcbiAgICAgICAgICAgICAgICBzdHlsZTogJ2Jsb2NrJ1xyXG4gICAgICAgICAgICB9O1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbn0iXX0=
@@ -420,6 +420,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
420
420
  }]
421
421
  }] });
422
422
 
423
+ let TWITTER_LOADED = false;
423
424
  class BantaAttachmentComponent {
424
425
  constructor(elementRef) {
425
426
  this.elementRef = elementRef;
@@ -437,20 +438,33 @@ class BantaAttachmentComponent {
437
438
  set attachment(value) {
438
439
  this._attachment = value;
439
440
  this.checkLoad();
440
- }
441
- ngOnInit() {
442
- if (typeof window !== 'undefined') {
443
- setTimeout(() => {
444
- if (!window['twttr'])
445
- return;
446
- window['twttr'].widgets.load();
447
- }, 100);
448
- }
441
+ this.loadPlatformSpecific();
449
442
  }
450
443
  ngAfterViewInit() {
451
444
  this._viewLoaded = true;
452
445
  this.checkLoad();
453
446
  }
447
+ loadTwitterWidgets() {
448
+ if (typeof window !== 'undefined')
449
+ window['twttr']?.widgets.load();
450
+ }
451
+ loadPlatformSpecific() {
452
+ if (this._attachment?.type === 'tweet') {
453
+ if (!TWITTER_LOADED && document.querySelector('script[src="https://platform.twitter.com/widgets.js"]'))
454
+ TWITTER_LOADED = true;
455
+ if (typeof window !== 'undefined' && !TWITTER_LOADED) {
456
+ TWITTER_LOADED = true;
457
+ let script = document.createElement('script');
458
+ script.src = 'https://platform.twitter.com/widgets.js';
459
+ script.async = true;
460
+ script.addEventListener('load', () => setTimeout(() => this.loadTwitterWidgets()));
461
+ document.body.appendChild(script);
462
+ }
463
+ else {
464
+ setTimeout(() => this.loadTwitterWidgets());
465
+ }
466
+ }
467
+ }
454
468
  checkLoad() {
455
469
  if (!this._attachment || !this._viewLoaded || !this.elementRef?.nativeElement)
456
470
  return;
@@ -10871,7 +10885,7 @@ class GiphyAttachmentResolver {
10871
10885
 
10872
10886
  class TweetAttachmentResolver {
10873
10887
  async resolveFragment(message, fragment) {
10874
- if (fragment.type === 'url' && fragment.text.startsWith('https://twitter.com/')) {
10888
+ if (fragment.type === 'url' && (fragment.text.startsWith('https://twitter.com/') || fragment.text.startsWith('https://x.com/'))) {
10875
10889
  return {
10876
10890
  type: 'tweet',
10877
10891
  url: fragment.text,
@@ -10884,14 +10898,6 @@ class TweetAttachmentResolver {
10884
10898
 
10885
10899
  class BantaSdkModule {
10886
10900
  constructor(chatBackend) {
10887
- if (typeof window !== 'undefined') {
10888
- if (!document.querySelector('script[src="https://platform.twitter.com/widgets.js"]')) {
10889
- let script = document.createElement('script');
10890
- script.src = 'https://platform.twitter.com/widgets.js';
10891
- script.async = true;
10892
- document.body.appendChild(script);
10893
- }
10894
- }
10895
10901
  chatBackend.registerAttachmentScraper(new UrlAttachmentScraper());
10896
10902
  chatBackend.registerAttachmentResolver(new GiphyAttachmentResolver());
10897
10903
  chatBackend.registerAttachmentResolver(new YouTubeAttachmentResolver());