stream-chat-angular 1.3.0 → 2.0.0

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.
Files changed (64) hide show
  1. package/assets/i18n/en.d.ts +1 -0
  2. package/assets/version.d.ts +1 -1
  3. package/bundles/stream-chat-angular.umd.js +1196 -365
  4. package/bundles/stream-chat-angular.umd.js.map +1 -1
  5. package/esm2015/assets/i18n/en.js +2 -1
  6. package/esm2015/assets/version.js +2 -2
  7. package/esm2015/lib/attachment-list/attachment-list.component.js +3 -4
  8. package/esm2015/lib/attachment-preview-list/attachment-preview-list.component.js +38 -0
  9. package/esm2015/lib/attachment.service.js +190 -0
  10. package/esm2015/lib/channel.service.js +53 -4
  11. package/esm2015/lib/chat-client.service.js +16 -1
  12. package/esm2015/lib/injection-tokens.js +3 -0
  13. package/esm2015/lib/is-image-attachment.js +6 -0
  14. package/esm2015/lib/message/highlight-mentions.pipe.js +23 -0
  15. package/esm2015/lib/message/message.component.js +3 -2
  16. package/esm2015/lib/message-actions-box/message-actions-box.component.js +43 -12
  17. package/esm2015/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.js +145 -0
  18. package/esm2015/lib/message-input/message-input-config.service.js +19 -0
  19. package/esm2015/lib/message-input/message-input.component.js +122 -140
  20. package/esm2015/lib/message-input/textarea/textarea.component.js +42 -0
  21. package/esm2015/lib/message-input/textarea.directive.js +69 -0
  22. package/esm2015/lib/message-input/textarea.interface.js +2 -0
  23. package/esm2015/lib/message-list/message-list.component.js +19 -3
  24. package/esm2015/lib/message-preview.js +3 -2
  25. package/esm2015/lib/modal/modal.component.js +63 -0
  26. package/esm2015/lib/notification-list/notification-list.component.js +1 -1
  27. package/esm2015/lib/notification.service.js +1 -1
  28. package/esm2015/lib/stream-autocomplete-textarea.module.js +33 -0
  29. package/esm2015/lib/stream-avatar.module.js +19 -0
  30. package/esm2015/lib/stream-chat.module.js +25 -11
  31. package/esm2015/lib/stream-textarea.module.js +31 -0
  32. package/esm2015/lib/types.js +1 -1
  33. package/esm2015/public-api.js +19 -1
  34. package/fesm2015/stream-chat-angular.js +955 -241
  35. package/fesm2015/stream-chat-angular.js.map +1 -1
  36. package/lib/attachment-preview-list/attachment-preview-list.component.d.ts +14 -0
  37. package/lib/attachment.service.d.ts +25 -0
  38. package/lib/channel.service.d.ts +6 -2
  39. package/lib/chat-client.service.d.ts +1 -0
  40. package/lib/injection-tokens.d.ts +3 -0
  41. package/lib/is-image-attachment.d.ts +2 -0
  42. package/lib/message/highlight-mentions.pipe.d.ts +8 -0
  43. package/lib/message/message.component.d.ts +1 -0
  44. package/lib/message-actions-box/message-actions-box.component.d.ts +11 -4
  45. package/lib/message-input/autocomplete-textarea/autocomplete-textarea.component.d.ts +42 -0
  46. package/lib/message-input/message-input-config.service.d.ts +14 -0
  47. package/lib/message-input/message-input.component.d.ts +30 -20
  48. package/lib/message-input/textarea/textarea.component.d.ts +16 -0
  49. package/lib/message-input/textarea.directive.d.ts +21 -0
  50. package/lib/message-input/textarea.interface.d.ts +12 -0
  51. package/lib/message-list/message-list.component.d.ts +1 -1
  52. package/lib/message-preview.d.ts +1 -1
  53. package/lib/modal/modal.component.d.ts +16 -0
  54. package/lib/notification-list/notification-list.component.d.ts +3 -3
  55. package/lib/notification.service.d.ts +2 -2
  56. package/lib/stream-autocomplete-textarea.module.d.ts +11 -0
  57. package/lib/stream-avatar.module.d.ts +9 -0
  58. package/lib/stream-chat.module.d.ts +23 -19
  59. package/lib/stream-textarea.module.d.ts +9 -0
  60. package/lib/types.d.ts +7 -1
  61. package/package.json +3 -2
  62. package/public-api.d.ts +18 -0
  63. package/src/assets/i18n/en.ts +1 -0
  64. package/src/assets/version.ts +1 -1
@@ -23,6 +23,7 @@ export const en = {
23
23
  'Error unmuting a user ...': 'Error unmuting a user ...',
24
24
  'Error uploading file': 'Error uploading file',
25
25
  'Error uploading image': 'Error uploading image',
26
+ 'Error deleting attachment': 'Error deleting attachment',
26
27
  'Error · Unsent': 'Error · Unsent',
27
28
  'Error: {{ errorMessage }}': 'Error: {{ errorMessage }}',
28
29
  Flag: 'Flag',
@@ -78,4 +79,4 @@ export const en = {
78
79
  test: 'success',
79
80
  },
80
81
  };
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zdHJlYW0tY2hhdC1hbmd1bGFyL3NyYy9hc3NldHMvaTE4bi9lbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUc7SUFDaEIsVUFBVSxFQUFFO1FBQ1YsU0FBUyxFQUFFLFNBQVM7UUFDcEIsY0FBYyxFQUFFLGNBQWM7UUFDOUIsTUFBTSxFQUFFLFFBQVE7UUFDaEIsaUJBQWlCLEVBQUUsaUJBQWlCO1FBQ3BDLEtBQUssRUFBRSxPQUFPO1FBQ2Qsb0JBQW9CLEVBQUUsb0JBQW9CO1FBQzFDLG1CQUFtQixFQUFFLG1CQUFtQjtRQUN4Qyx5Q0FBeUMsRUFDdkMseUNBQXlDO1FBQzNDLE1BQU0sRUFBRSxRQUFRO1FBQ2hCLFNBQVMsRUFBRSxXQUFXO1FBQ3RCLGNBQWMsRUFBRSxjQUFjO1FBQzlCLDZCQUE2QixFQUFFLDZCQUE2QjtRQUM1RCxnQkFBZ0IsRUFBRSxnQkFBZ0I7UUFDbEMsa0JBQWtCLEVBQUUsa0JBQWtCO1FBQ3RDLG1CQUFtQixFQUFFLG1CQUFtQjtRQUN4QywwREFBMEQsRUFDeEQsMERBQTBEO1FBQzVELHdCQUF3QixFQUFFLHdCQUF3QjtRQUNsRCx5QkFBeUIsRUFBRSx5QkFBeUI7UUFDcEQsdUJBQXVCLEVBQUUsdUJBQXVCO1FBQ2hELDRCQUE0QixFQUFFLDRCQUE0QjtRQUMxRCwyQkFBMkIsRUFBRSwyQkFBMkI7UUFDeEQsc0JBQXNCLEVBQUUsc0JBQXNCO1FBQzlDLHVCQUF1QixFQUFFLHVCQUF1QjtRQUNoRCxnQkFBZ0IsRUFBRSxnQkFBZ0I7UUFDbEMsMkJBQTJCLEVBQUUsMkJBQTJCO1FBQ3hELElBQUksRUFBRSxNQUFNO1FBQ1osZ0JBQWdCLEVBQUUsZ0JBQWdCO1FBQ2xDLCtCQUErQixFQUFFLCtCQUErQjtRQUNoRSxpQkFBaUIsRUFBRSxpQkFBaUI7UUFDcEMsdUNBQXVDLEVBQ3JDLHVDQUF1QztRQUN6QyxnQkFBZ0IsRUFBRSxnQkFBZ0I7UUFDbEMsSUFBSSxFQUFFLE1BQU07UUFDWixHQUFHLEVBQUUsS0FBSztRQUNWLGVBQWUsRUFBRSxlQUFlO1FBQ2hDLGtCQUFrQixFQUFFLGtCQUFrQjtRQUN0QyxnQkFBZ0IsRUFBRSxnQkFBZ0I7UUFDbEMscUJBQXFCLEVBQUUscUJBQXFCO1FBQzVDLG1CQUFtQixFQUFFLG1CQUFtQjtRQUN4QyxpQkFBaUIsRUFBRSxpQkFBaUI7UUFDcEMsaUJBQWlCLEVBQUUsaUJBQWlCO1FBQ3BDLEdBQUcsRUFBRSxLQUFLO1FBQ1YsV0FBVyxFQUFFLFdBQVc7UUFDeEIsS0FBSyxFQUFFLE9BQU87UUFDZCxrQkFBa0IsRUFBRSxrQkFBa0I7UUFDdEMsTUFBTSxFQUFFLFFBQVE7UUFDaEIsY0FBYyxFQUFFLGNBQWM7UUFDOUIsSUFBSSxFQUFFLE1BQU07UUFDWiw2QkFBNkIsRUFBRSw2QkFBNkI7UUFDNUQsWUFBWSxFQUFFLFlBQVk7UUFDMUIsY0FBYyxFQUFFLGNBQWM7UUFDOUIsdUJBQXVCLEVBQUUsdUJBQXVCO1FBQ2hELDZCQUE2QixFQUFFLDZCQUE2QjtRQUM1RCxNQUFNLEVBQUUsUUFBUTtRQUNoQixtQkFBbUIsRUFBRSxtQkFBbUI7UUFDeEMsTUFBTSxFQUFFLFFBQVE7UUFDaEIsS0FBSyxFQUFFLE9BQU87UUFDZCwwQ0FBMEMsRUFDeEMsMENBQTBDO1FBQzVDLGdDQUFnQyxFQUFFLGdDQUFnQztRQUNsRSw0Q0FBNEMsRUFDMUMsNENBQTRDO1FBQzlDLElBQUksRUFBRSxNQUFNO1FBQ1oscUNBQXFDLEVBQ25DLHFDQUFxQztRQUN2QyxvREFBb0QsRUFDbEQsb0RBQW9EO1FBQ3RELCtDQUErQyxFQUM3QywrQ0FBK0M7UUFDakQsc0NBQXNDLEVBQ3BDLHNDQUFzQztRQUN4Qyx1QkFBdUIsRUFBRSx1QkFBdUI7UUFDaEQsMkJBQTJCLEVBQUUsMkJBQTJCO1FBQ3hELDBCQUEwQixFQUFFLDBCQUEwQjtRQUN0RCwyQkFBMkIsRUFBRSwyQkFBMkI7UUFDeEQsNkJBQTZCLEVBQUUsNkJBQTZCO1FBQzVELDJCQUEyQixFQUFFLDJCQUEyQjtRQUN4RCxrQkFBa0IsRUFBRSxrQkFBa0I7UUFDdEMsa0JBQWtCLEVBQUUsa0JBQWtCO1FBQ3RDLFdBQVcsRUFBRSxXQUFXO1FBQ3hCLE1BQU0sRUFBRSxRQUFRO1FBQ2hCLEtBQUssRUFBRSxPQUFPO1FBQ2QsSUFBSSxFQUFFLFNBQVM7S0FDaEI7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGVuID0ge1xuICBzdHJlYW1DaGF0OiB7XG4gICAgJzEgcmVwbHknOiAnMSByZXBseScsXG4gICAgJ0F0dGFjaCBmaWxlcyc6ICdBdHRhY2ggZmlsZXMnLFxuICAgIENhbmNlbDogJ0NhbmNlbCcsXG4gICAgJ0NoYW5uZWwgTWlzc2luZyc6ICdDaGFubmVsIE1pc3NpbmcnLFxuICAgIENsb3NlOiAnQ2xvc2UnLFxuICAgICdDbG9zZSBlbW9qaSBwaWNrZXInOiAnQ2xvc2UgZW1vamkgcGlja2VyJyxcbiAgICAnQ29tbWFuZHMgbWF0Y2hpbmcnOiAnQ29tbWFuZHMgbWF0Y2hpbmcnLFxuICAgICdDb25uZWN0aW9uIGZhaWx1cmUsIHJlY29ubmVjdGluZyBub3cuLi4nOlxuICAgICAgJ0Nvbm5lY3Rpb24gZmFpbHVyZSwgcmVjb25uZWN0aW5nIG5vdy4uLicsXG4gICAgRGVsZXRlOiAnRGVsZXRlJyxcbiAgICBEZWxpdmVyZWQ6ICdEZWxpdmVyZWQnLFxuICAgICdFZGl0IE1lc3NhZ2UnOiAnRWRpdCBNZXNzYWdlJyxcbiAgICAnRWRpdCBtZXNzYWdlIHJlcXVlc3QgZmFpbGVkJzogJ0VkaXQgbWVzc2FnZSByZXF1ZXN0IGZhaWxlZCcsXG4gICAgJ0Vtb2ppIG1hdGNoaW5nJzogJ0Vtb2ppIG1hdGNoaW5nJyxcbiAgICAnRW1wdHkgbWVzc2FnZS4uLic6ICdFbXB0eSBtZXNzYWdlLi4uJyxcbiAgICAnRXJyb3IgYWRkaW5nIGZsYWcnOiAnRXJyb3IgYWRkaW5nIGZsYWcnLFxuICAgICdFcnJvciBjb25uZWN0aW5nIHRvIGNoYXQsIHJlZnJlc2ggdGhlIHBhZ2UgdG8gdHJ5IGFnYWluLic6XG4gICAgICAnRXJyb3IgY29ubmVjdGluZyB0byBjaGF0LCByZWZyZXNoIHRoZSBwYWdlIHRvIHRyeSBhZ2Fpbi4nLFxuICAgICdFcnJvciBkZWxldGluZyBtZXNzYWdlJzogJ0Vycm9yIGRlbGV0aW5nIG1lc3NhZ2UnLFxuICAgICdFcnJvciBtdXRpbmcgYSB1c2VyIC4uLic6ICdFcnJvciBtdXRpbmcgYSB1c2VyIC4uLicsXG4gICAgJ0Vycm9yIHBpbm5pbmcgbWVzc2FnZSc6ICdFcnJvciBwaW5uaW5nIG1lc3NhZ2UnLFxuICAgICdFcnJvciByZW1vdmluZyBtZXNzYWdlIHBpbic6ICdFcnJvciByZW1vdmluZyBtZXNzYWdlIHBpbicsXG4gICAgJ0Vycm9yIHVubXV0aW5nIGEgdXNlciAuLi4nOiAnRXJyb3IgdW5tdXRpbmcgYSB1c2VyIC4uLicsXG4gICAgJ0Vycm9yIHVwbG9hZGluZyBmaWxlJzogJ0Vycm9yIHVwbG9hZGluZyBmaWxlJyxcbiAgICAnRXJyb3IgdXBsb2FkaW5nIGltYWdlJzogJ0Vycm9yIHVwbG9hZGluZyBpbWFnZScsXG4gICAgJ0Vycm9yIMK3IFVuc2VudCc6ICdFcnJvciDCtyBVbnNlbnQnLFxuICAgICdFcnJvcjoge3sgZXJyb3JNZXNzYWdlIH19JzogJ0Vycm9yOiB7eyBlcnJvck1lc3NhZ2UgfX0nLFxuICAgIEZsYWc6ICdGbGFnJyxcbiAgICAnTWVzc2FnZSBGYWlsZWQnOiAnTWVzc2FnZSBGYWlsZWQnLFxuICAgICdNZXNzYWdlIEZhaWxlZCDCtyBVbmF1dGhvcml6ZWQnOiAnTWVzc2FnZSBGYWlsZWQgwrcgVW5hdXRob3JpemVkJyxcbiAgICAnTWVzc2FnZSBkZWxldGVkJzogJ01lc3NhZ2UgZGVsZXRlZCcsXG4gICAgJ01lc3NhZ2UgaGFzIGJlZW4gc3VjY2Vzc2Z1bGx5IGZsYWdnZWQnOlxuICAgICAgJ01lc3NhZ2UgaGFzIGJlZW4gc3VjY2Vzc2Z1bGx5IGZsYWdnZWQnLFxuICAgICdNZXNzYWdlIHBpbm5lZCc6ICdNZXNzYWdlIHBpbm5lZCcsXG4gICAgTXV0ZTogJ011dGUnLFxuICAgIE5ldzogJ05ldycsXG4gICAgJ05ldyBNZXNzYWdlcyEnOiAnTmV3IE1lc3NhZ2VzIScsXG4gICAgJ05vIHJlc3VsdHMgZm91bmQnOiAnTm8gcmVzdWx0cyBmb3VuZCcsXG4gICAgJ05vdGhpbmcgeWV0Li4uJzogJ05vdGhpbmcgeWV0Li4uJyxcbiAgICAnT25seSB2aXNpYmxlIHRvIHlvdSc6ICdPbmx5IHZpc2libGUgdG8geW91JyxcbiAgICAnT3BlbiBlbW9qaSBwaWNrZXInOiAnT3BlbiBlbW9qaSBwaWNrZXInLFxuICAgICdQZW9wbGUgbWF0Y2hpbmcnOiAnUGVvcGxlIG1hdGNoaW5nJyxcbiAgICAnUGljayB5b3VyIGVtb2ppJzogJ1BpY2sgeW91ciBlbW9qaScsXG4gICAgUGluOiAnUGluJyxcbiAgICAnUGlubmVkIGJ5JzogJ1Bpbm5lZCBieScsXG4gICAgUmVwbHk6ICdSZXBseScsXG4gICAgJ1JlcGx5IHRvIE1lc3NhZ2UnOiAnUmVwbHkgdG8gTWVzc2FnZScsXG4gICAgU2VhcmNoOiAnU2VhcmNoJyxcbiAgICAnU2VhcmNoaW5nLi4uJzogJ1NlYXJjaGluZy4uLicsXG4gICAgU2VuZDogJ1NlbmQnLFxuICAgICdTZW5kIG1lc3NhZ2UgcmVxdWVzdCBmYWlsZWQnOiAnU2VuZCBtZXNzYWdlIHJlcXVlc3QgZmFpbGVkJyxcbiAgICAnU2VuZGluZy4uLic6ICdTZW5kaW5nLi4uJyxcbiAgICAnU2xvdyBNb2RlIE9OJzogJ1Nsb3cgTW9kZSBPTicsXG4gICAgJ1N0YXJ0IG9mIGEgbmV3IHRocmVhZCc6ICdTdGFydCBvZiBhIG5ldyB0aHJlYWQnLFxuICAgICdUaGlzIG1lc3NhZ2Ugd2FzIGRlbGV0ZWQuLi4nOiAnVGhpcyBtZXNzYWdlIHdhcyBkZWxldGVkLi4uJyxcbiAgICBUaHJlYWQ6ICdUaHJlYWQnLFxuICAgICdUeXBlIHlvdXIgbWVzc2FnZSc6ICdUeXBlIHlvdXIgbWVzc2FnZScsXG4gICAgVW5tdXRlOiAnVW5tdXRlJyxcbiAgICBVbnBpbjogJ1VucGluJyxcbiAgICAnV2FpdCB1bnRpbCBhbGwgYXR0YWNobWVudHMgaGF2ZSB1cGxvYWRlZCc6XG4gICAgICAnV2FpdCB1bnRpbCBhbGwgYXR0YWNobWVudHMgaGF2ZSB1cGxvYWRlZCcsXG4gICAgJ1lvdSBoYXZlIG5vIGNoYW5uZWxzIGN1cnJlbnRseSc6ICdZb3UgaGF2ZSBubyBjaGFubmVscyBjdXJyZW50bHknLFxuICAgIFwiWW91J3ZlIHJlYWNoZWQgdGhlIG1heGltdW0gbnVtYmVyIG9mIGZpbGVzXCI6XG4gICAgICBcIllvdSd2ZSByZWFjaGVkIHRoZSBtYXhpbXVtIG51bWJlciBvZiBmaWxlc1wiLFxuICAgIGxpdmU6ICdsaXZlJyxcbiAgICAndGhpcyBjb250ZW50IGNvdWxkIG5vdCBiZSBkaXNwbGF5ZWQnOlxuICAgICAgJ3RoaXMgY29udGVudCBjb3VsZCBub3QgYmUgZGlzcGxheWVkJyxcbiAgICAne3sgY29tbWFTZXBhcmF0ZWRVc2VycyB9fSBhbmQge3sgbW9yZUNvdW50IH19IG1vcmUnOlxuICAgICAgJ3t7IGNvbW1hU2VwYXJhdGVkVXNlcnMgfX0gYW5kIHt7IG1vcmVDb3VudCB9fSBtb3JlJyxcbiAgICAne3sgY29tbWFTZXBhcmF0ZWRVc2VycyB9fSwgYW5kIHt7IGxhc3RVc2VyIH19JzpcbiAgICAgICd7eyBjb21tYVNlcGFyYXRlZFVzZXJzIH19LCBhbmQge3sgbGFzdFVzZXIgfX0nLFxuICAgICd7eyBmaXJzdFVzZXIgfX0gYW5kIHt7IHNlY29uZFVzZXIgfX0nOlxuICAgICAgJ3t7IGZpcnN0VXNlciB9fSBhbmQge3sgc2Vjb25kVXNlciB9fScsXG4gICAgJ3t7IGltYWdlQ291bnQgfX0gbW9yZSc6ICd7eyBpbWFnZUNvdW50IH19IG1vcmUnLFxuICAgICd7eyBtZW1iZXJDb3VudCB9fSBtZW1iZXJzJzogJ3t7IG1lbWJlckNvdW50IH19IG1lbWJlcnMnLFxuICAgICd7eyByZXBseUNvdW50IH19IHJlcGxpZXMnOiAne3sgcmVwbHlDb3VudCB9fSByZXBsaWVzJyxcbiAgICAne3sgdXNlciB9fSBoYXMgYmVlbiBtdXRlZCc6ICd7eyB1c2VyIH19IGhhcyBiZWVuIG11dGVkJyxcbiAgICAne3sgdXNlciB9fSBoYXMgYmVlbiB1bm11dGVkJzogJ3t7IHVzZXIgfX0gaGFzIGJlZW4gdW5tdXRlZCcsXG4gICAgJ3t7IHdhdGNoZXJDb3VudCB9fSBvbmxpbmUnOiAne3sgd2F0Y2hlckNvdW50IH19IG9ubGluZScsXG4gICAgJ/Cfj5kgQXR0YWNobWVudC4uLic6ICfwn4+ZIEF0dGFjaG1lbnQuLi4nLFxuICAgICdDb25uZWN0aW9uIGVycm9yJzogJ0Nvbm5lY3Rpb24gZXJyb3InLFxuICAgICdMb2FkIG1vcmUnOiAnTG9hZCBtb3JlJyxcbiAgICBmYWlsZWQ6ICdmYWlsZWQnLFxuICAgIHJldHJ5OiAncmV0cnknLFxuICAgIHRlc3Q6ICdzdWNjZXNzJyxcbiAgfSxcbn07XG4iXX0=
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zdHJlYW0tY2hhdC1hbmd1bGFyL3NyYy9hc3NldHMvaTE4bi9lbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxFQUFFLEdBQUc7SUFDaEIsVUFBVSxFQUFFO1FBQ1YsU0FBUyxFQUFFLFNBQVM7UUFDcEIsY0FBYyxFQUFFLGNBQWM7UUFDOUIsTUFBTSxFQUFFLFFBQVE7UUFDaEIsaUJBQWlCLEVBQUUsaUJBQWlCO1FBQ3BDLEtBQUssRUFBRSxPQUFPO1FBQ2Qsb0JBQW9CLEVBQUUsb0JBQW9CO1FBQzFDLG1CQUFtQixFQUFFLG1CQUFtQjtRQUN4Qyx5Q0FBeUMsRUFDdkMseUNBQXlDO1FBQzNDLE1BQU0sRUFBRSxRQUFRO1FBQ2hCLFNBQVMsRUFBRSxXQUFXO1FBQ3RCLGNBQWMsRUFBRSxjQUFjO1FBQzlCLDZCQUE2QixFQUFFLDZCQUE2QjtRQUM1RCxnQkFBZ0IsRUFBRSxnQkFBZ0I7UUFDbEMsa0JBQWtCLEVBQUUsa0JBQWtCO1FBQ3RDLG1CQUFtQixFQUFFLG1CQUFtQjtRQUN4QywwREFBMEQsRUFDeEQsMERBQTBEO1FBQzVELHdCQUF3QixFQUFFLHdCQUF3QjtRQUNsRCx5QkFBeUIsRUFBRSx5QkFBeUI7UUFDcEQsdUJBQXVCLEVBQUUsdUJBQXVCO1FBQ2hELDRCQUE0QixFQUFFLDRCQUE0QjtRQUMxRCwyQkFBMkIsRUFBRSwyQkFBMkI7UUFDeEQsc0JBQXNCLEVBQUUsc0JBQXNCO1FBQzlDLHVCQUF1QixFQUFFLHVCQUF1QjtRQUNoRCwyQkFBMkIsRUFBRSwyQkFBMkI7UUFDeEQsZ0JBQWdCLEVBQUUsZ0JBQWdCO1FBQ2xDLDJCQUEyQixFQUFFLDJCQUEyQjtRQUN4RCxJQUFJLEVBQUUsTUFBTTtRQUNaLGdCQUFnQixFQUFFLGdCQUFnQjtRQUNsQywrQkFBK0IsRUFBRSwrQkFBK0I7UUFDaEUsaUJBQWlCLEVBQUUsaUJBQWlCO1FBQ3BDLHVDQUF1QyxFQUNyQyx1Q0FBdUM7UUFDekMsZ0JBQWdCLEVBQUUsZ0JBQWdCO1FBQ2xDLElBQUksRUFBRSxNQUFNO1FBQ1osR0FBRyxFQUFFLEtBQUs7UUFDVixlQUFlLEVBQUUsZUFBZTtRQUNoQyxrQkFBa0IsRUFBRSxrQkFBa0I7UUFDdEMsZ0JBQWdCLEVBQUUsZ0JBQWdCO1FBQ2xDLHFCQUFxQixFQUFFLHFCQUFxQjtRQUM1QyxtQkFBbUIsRUFBRSxtQkFBbUI7UUFDeEMsaUJBQWlCLEVBQUUsaUJBQWlCO1FBQ3BDLGlCQUFpQixFQUFFLGlCQUFpQjtRQUNwQyxHQUFHLEVBQUUsS0FBSztRQUNWLFdBQVcsRUFBRSxXQUFXO1FBQ3hCLEtBQUssRUFBRSxPQUFPO1FBQ2Qsa0JBQWtCLEVBQUUsa0JBQWtCO1FBQ3RDLE1BQU0sRUFBRSxRQUFRO1FBQ2hCLGNBQWMsRUFBRSxjQUFjO1FBQzlCLElBQUksRUFBRSxNQUFNO1FBQ1osNkJBQTZCLEVBQUUsNkJBQTZCO1FBQzVELFlBQVksRUFBRSxZQUFZO1FBQzFCLGNBQWMsRUFBRSxjQUFjO1FBQzlCLHVCQUF1QixFQUFFLHVCQUF1QjtRQUNoRCw2QkFBNkIsRUFBRSw2QkFBNkI7UUFDNUQsTUFBTSxFQUFFLFFBQVE7UUFDaEIsbUJBQW1CLEVBQUUsbUJBQW1CO1FBQ3hDLE1BQU0sRUFBRSxRQUFRO1FBQ2hCLEtBQUssRUFBRSxPQUFPO1FBQ2QsMENBQTBDLEVBQ3hDLDBDQUEwQztRQUM1QyxnQ0FBZ0MsRUFBRSxnQ0FBZ0M7UUFDbEUsNENBQTRDLEVBQzFDLDRDQUE0QztRQUM5QyxJQUFJLEVBQUUsTUFBTTtRQUNaLHFDQUFxQyxFQUNuQyxxQ0FBcUM7UUFDdkMsb0RBQW9ELEVBQ2xELG9EQUFvRDtRQUN0RCwrQ0FBK0MsRUFDN0MsK0NBQStDO1FBQ2pELHNDQUFzQyxFQUNwQyxzQ0FBc0M7UUFDeEMsdUJBQXVCLEVBQUUsdUJBQXVCO1FBQ2hELDJCQUEyQixFQUFFLDJCQUEyQjtRQUN4RCwwQkFBMEIsRUFBRSwwQkFBMEI7UUFDdEQsMkJBQTJCLEVBQUUsMkJBQTJCO1FBQ3hELDZCQUE2QixFQUFFLDZCQUE2QjtRQUM1RCwyQkFBMkIsRUFBRSwyQkFBMkI7UUFDeEQsa0JBQWtCLEVBQUUsa0JBQWtCO1FBQ3RDLGtCQUFrQixFQUFFLGtCQUFrQjtRQUN0QyxXQUFXLEVBQUUsV0FBVztRQUN4QixNQUFNLEVBQUUsUUFBUTtRQUNoQixLQUFLLEVBQUUsT0FBTztRQUNkLElBQUksRUFBRSxTQUFTO0tBQ2hCO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBlbiA9IHtcbiAgc3RyZWFtQ2hhdDoge1xuICAgICcxIHJlcGx5JzogJzEgcmVwbHknLFxuICAgICdBdHRhY2ggZmlsZXMnOiAnQXR0YWNoIGZpbGVzJyxcbiAgICBDYW5jZWw6ICdDYW5jZWwnLFxuICAgICdDaGFubmVsIE1pc3NpbmcnOiAnQ2hhbm5lbCBNaXNzaW5nJyxcbiAgICBDbG9zZTogJ0Nsb3NlJyxcbiAgICAnQ2xvc2UgZW1vamkgcGlja2VyJzogJ0Nsb3NlIGVtb2ppIHBpY2tlcicsXG4gICAgJ0NvbW1hbmRzIG1hdGNoaW5nJzogJ0NvbW1hbmRzIG1hdGNoaW5nJyxcbiAgICAnQ29ubmVjdGlvbiBmYWlsdXJlLCByZWNvbm5lY3Rpbmcgbm93Li4uJzpcbiAgICAgICdDb25uZWN0aW9uIGZhaWx1cmUsIHJlY29ubmVjdGluZyBub3cuLi4nLFxuICAgIERlbGV0ZTogJ0RlbGV0ZScsXG4gICAgRGVsaXZlcmVkOiAnRGVsaXZlcmVkJyxcbiAgICAnRWRpdCBNZXNzYWdlJzogJ0VkaXQgTWVzc2FnZScsXG4gICAgJ0VkaXQgbWVzc2FnZSByZXF1ZXN0IGZhaWxlZCc6ICdFZGl0IG1lc3NhZ2UgcmVxdWVzdCBmYWlsZWQnLFxuICAgICdFbW9qaSBtYXRjaGluZyc6ICdFbW9qaSBtYXRjaGluZycsXG4gICAgJ0VtcHR5IG1lc3NhZ2UuLi4nOiAnRW1wdHkgbWVzc2FnZS4uLicsXG4gICAgJ0Vycm9yIGFkZGluZyBmbGFnJzogJ0Vycm9yIGFkZGluZyBmbGFnJyxcbiAgICAnRXJyb3IgY29ubmVjdGluZyB0byBjaGF0LCByZWZyZXNoIHRoZSBwYWdlIHRvIHRyeSBhZ2Fpbi4nOlxuICAgICAgJ0Vycm9yIGNvbm5lY3RpbmcgdG8gY2hhdCwgcmVmcmVzaCB0aGUgcGFnZSB0byB0cnkgYWdhaW4uJyxcbiAgICAnRXJyb3IgZGVsZXRpbmcgbWVzc2FnZSc6ICdFcnJvciBkZWxldGluZyBtZXNzYWdlJyxcbiAgICAnRXJyb3IgbXV0aW5nIGEgdXNlciAuLi4nOiAnRXJyb3IgbXV0aW5nIGEgdXNlciAuLi4nLFxuICAgICdFcnJvciBwaW5uaW5nIG1lc3NhZ2UnOiAnRXJyb3IgcGlubmluZyBtZXNzYWdlJyxcbiAgICAnRXJyb3IgcmVtb3ZpbmcgbWVzc2FnZSBwaW4nOiAnRXJyb3IgcmVtb3ZpbmcgbWVzc2FnZSBwaW4nLFxuICAgICdFcnJvciB1bm11dGluZyBhIHVzZXIgLi4uJzogJ0Vycm9yIHVubXV0aW5nIGEgdXNlciAuLi4nLFxuICAgICdFcnJvciB1cGxvYWRpbmcgZmlsZSc6ICdFcnJvciB1cGxvYWRpbmcgZmlsZScsXG4gICAgJ0Vycm9yIHVwbG9hZGluZyBpbWFnZSc6ICdFcnJvciB1cGxvYWRpbmcgaW1hZ2UnLFxuICAgICdFcnJvciBkZWxldGluZyBhdHRhY2htZW50JzogJ0Vycm9yIGRlbGV0aW5nIGF0dGFjaG1lbnQnLFxuICAgICdFcnJvciDCtyBVbnNlbnQnOiAnRXJyb3IgwrcgVW5zZW50JyxcbiAgICAnRXJyb3I6IHt7IGVycm9yTWVzc2FnZSB9fSc6ICdFcnJvcjoge3sgZXJyb3JNZXNzYWdlIH19JyxcbiAgICBGbGFnOiAnRmxhZycsXG4gICAgJ01lc3NhZ2UgRmFpbGVkJzogJ01lc3NhZ2UgRmFpbGVkJyxcbiAgICAnTWVzc2FnZSBGYWlsZWQgwrcgVW5hdXRob3JpemVkJzogJ01lc3NhZ2UgRmFpbGVkIMK3IFVuYXV0aG9yaXplZCcsXG4gICAgJ01lc3NhZ2UgZGVsZXRlZCc6ICdNZXNzYWdlIGRlbGV0ZWQnLFxuICAgICdNZXNzYWdlIGhhcyBiZWVuIHN1Y2Nlc3NmdWxseSBmbGFnZ2VkJzpcbiAgICAgICdNZXNzYWdlIGhhcyBiZWVuIHN1Y2Nlc3NmdWxseSBmbGFnZ2VkJyxcbiAgICAnTWVzc2FnZSBwaW5uZWQnOiAnTWVzc2FnZSBwaW5uZWQnLFxuICAgIE11dGU6ICdNdXRlJyxcbiAgICBOZXc6ICdOZXcnLFxuICAgICdOZXcgTWVzc2FnZXMhJzogJ05ldyBNZXNzYWdlcyEnLFxuICAgICdObyByZXN1bHRzIGZvdW5kJzogJ05vIHJlc3VsdHMgZm91bmQnLFxuICAgICdOb3RoaW5nIHlldC4uLic6ICdOb3RoaW5nIHlldC4uLicsXG4gICAgJ09ubHkgdmlzaWJsZSB0byB5b3UnOiAnT25seSB2aXNpYmxlIHRvIHlvdScsXG4gICAgJ09wZW4gZW1vamkgcGlja2VyJzogJ09wZW4gZW1vamkgcGlja2VyJyxcbiAgICAnUGVvcGxlIG1hdGNoaW5nJzogJ1Blb3BsZSBtYXRjaGluZycsXG4gICAgJ1BpY2sgeW91ciBlbW9qaSc6ICdQaWNrIHlvdXIgZW1vamknLFxuICAgIFBpbjogJ1BpbicsXG4gICAgJ1Bpbm5lZCBieSc6ICdQaW5uZWQgYnknLFxuICAgIFJlcGx5OiAnUmVwbHknLFxuICAgICdSZXBseSB0byBNZXNzYWdlJzogJ1JlcGx5IHRvIE1lc3NhZ2UnLFxuICAgIFNlYXJjaDogJ1NlYXJjaCcsXG4gICAgJ1NlYXJjaGluZy4uLic6ICdTZWFyY2hpbmcuLi4nLFxuICAgIFNlbmQ6ICdTZW5kJyxcbiAgICAnU2VuZCBtZXNzYWdlIHJlcXVlc3QgZmFpbGVkJzogJ1NlbmQgbWVzc2FnZSByZXF1ZXN0IGZhaWxlZCcsXG4gICAgJ1NlbmRpbmcuLi4nOiAnU2VuZGluZy4uLicsXG4gICAgJ1Nsb3cgTW9kZSBPTic6ICdTbG93IE1vZGUgT04nLFxuICAgICdTdGFydCBvZiBhIG5ldyB0aHJlYWQnOiAnU3RhcnQgb2YgYSBuZXcgdGhyZWFkJyxcbiAgICAnVGhpcyBtZXNzYWdlIHdhcyBkZWxldGVkLi4uJzogJ1RoaXMgbWVzc2FnZSB3YXMgZGVsZXRlZC4uLicsXG4gICAgVGhyZWFkOiAnVGhyZWFkJyxcbiAgICAnVHlwZSB5b3VyIG1lc3NhZ2UnOiAnVHlwZSB5b3VyIG1lc3NhZ2UnLFxuICAgIFVubXV0ZTogJ1VubXV0ZScsXG4gICAgVW5waW46ICdVbnBpbicsXG4gICAgJ1dhaXQgdW50aWwgYWxsIGF0dGFjaG1lbnRzIGhhdmUgdXBsb2FkZWQnOlxuICAgICAgJ1dhaXQgdW50aWwgYWxsIGF0dGFjaG1lbnRzIGhhdmUgdXBsb2FkZWQnLFxuICAgICdZb3UgaGF2ZSBubyBjaGFubmVscyBjdXJyZW50bHknOiAnWW91IGhhdmUgbm8gY2hhbm5lbHMgY3VycmVudGx5JyxcbiAgICBcIllvdSd2ZSByZWFjaGVkIHRoZSBtYXhpbXVtIG51bWJlciBvZiBmaWxlc1wiOlxuICAgICAgXCJZb3UndmUgcmVhY2hlZCB0aGUgbWF4aW11bSBudW1iZXIgb2YgZmlsZXNcIixcbiAgICBsaXZlOiAnbGl2ZScsXG4gICAgJ3RoaXMgY29udGVudCBjb3VsZCBub3QgYmUgZGlzcGxheWVkJzpcbiAgICAgICd0aGlzIGNvbnRlbnQgY291bGQgbm90IGJlIGRpc3BsYXllZCcsXG4gICAgJ3t7IGNvbW1hU2VwYXJhdGVkVXNlcnMgfX0gYW5kIHt7IG1vcmVDb3VudCB9fSBtb3JlJzpcbiAgICAgICd7eyBjb21tYVNlcGFyYXRlZFVzZXJzIH19IGFuZCB7eyBtb3JlQ291bnQgfX0gbW9yZScsXG4gICAgJ3t7IGNvbW1hU2VwYXJhdGVkVXNlcnMgfX0sIGFuZCB7eyBsYXN0VXNlciB9fSc6XG4gICAgICAne3sgY29tbWFTZXBhcmF0ZWRVc2VycyB9fSwgYW5kIHt7IGxhc3RVc2VyIH19JyxcbiAgICAne3sgZmlyc3RVc2VyIH19IGFuZCB7eyBzZWNvbmRVc2VyIH19JzpcbiAgICAgICd7eyBmaXJzdFVzZXIgfX0gYW5kIHt7IHNlY29uZFVzZXIgfX0nLFxuICAgICd7eyBpbWFnZUNvdW50IH19IG1vcmUnOiAne3sgaW1hZ2VDb3VudCB9fSBtb3JlJyxcbiAgICAne3sgbWVtYmVyQ291bnQgfX0gbWVtYmVycyc6ICd7eyBtZW1iZXJDb3VudCB9fSBtZW1iZXJzJyxcbiAgICAne3sgcmVwbHlDb3VudCB9fSByZXBsaWVzJzogJ3t7IHJlcGx5Q291bnQgfX0gcmVwbGllcycsXG4gICAgJ3t7IHVzZXIgfX0gaGFzIGJlZW4gbXV0ZWQnOiAne3sgdXNlciB9fSBoYXMgYmVlbiBtdXRlZCcsXG4gICAgJ3t7IHVzZXIgfX0gaGFzIGJlZW4gdW5tdXRlZCc6ICd7eyB1c2VyIH19IGhhcyBiZWVuIHVubXV0ZWQnLFxuICAgICd7eyB3YXRjaGVyQ291bnQgfX0gb25saW5lJzogJ3t7IHdhdGNoZXJDb3VudCB9fSBvbmxpbmUnLFxuICAgICfwn4+ZIEF0dGFjaG1lbnQuLi4nOiAn8J+PmSBBdHRhY2htZW50Li4uJyxcbiAgICAnQ29ubmVjdGlvbiBlcnJvcic6ICdDb25uZWN0aW9uIGVycm9yJyxcbiAgICAnTG9hZCBtb3JlJzogJ0xvYWQgbW9yZScsXG4gICAgZmFpbGVkOiAnZmFpbGVkJyxcbiAgICByZXRyeTogJ3JldHJ5JyxcbiAgICB0ZXN0OiAnc3VjY2VzcycsXG4gIH0sXG59O1xuIl19
@@ -1,2 +1,2 @@
1
- export const version = '1.3.0';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2Fzc2V0cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdmVyc2lvbiA9ICcxLjMuMCc7XG4iXX0=
1
+ export const version = '2.0.0';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2Fzc2V0cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgdmVyc2lvbiA9ICcyLjAuMCc7XG4iXX0=
@@ -1,5 +1,6 @@
1
1
  import { Component, Input } from '@angular/core';
2
2
  import prettybytes from 'pretty-bytes';
3
+ import { isImageAttachment } from '../is-image-attachment';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "../message-list/image-load.service";
5
6
  import * as i2 from "../icon/icon.component";
@@ -21,9 +22,7 @@ export class AttachmentListComponent {
21
22
  return index;
22
23
  }
23
24
  isImage(attachment) {
24
- return (attachment.type === 'image' &&
25
- !attachment.title_link &&
26
- !attachment.og_scrape_url);
25
+ return isImageAttachment(attachment);
27
26
  }
28
27
  isFile(attachment) {
29
28
  return attachment.type === 'file';
@@ -63,4 +62,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
63
62
  }], ctorParameters: function () { return [{ type: i1.ImageLoadService }]; }, propDecorators: { attachments: [{
64
63
  type: Input
65
64
  }] } });
66
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-list.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/attachment-list/attachment-list.component.ts","../../../../../projects/stream-chat-angular/src/lib/attachment-list/attachment-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAa,MAAM,eAAe,CAAC;AAI5D,OAAO,WAAW,MAAM,cAAc,CAAC;;;;;AAOvC,MAAM,OAAO,uBAAuB;IAIlC,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAH7C,gBAAW,GAAwC,EAAE,CAAC;QAC/D,uBAAkB,GAAwC,EAAE,CAAC;IAEJ,CAAC;IAE1D,WAAW;QACT,IAAI,CAAC,kBAAkB,GAAG;YACxB,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAClD,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACjD,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;SAClD,CAAC;IACJ,CAAC;IAED,SAAS,CAAC,KAAa;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,CAAC,UAAsB;QAC5B,OAAO,CACL,UAAU,CAAC,IAAI,KAAK,OAAO;YAC3B,CAAC,UAAU,CAAC,UAAU;YACtB,CAAC,UAAU,CAAC,aAAa,CAC1B,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,UAAsB;QAC3B,OAAO,UAAU,CAAC,IAAI,KAAK,MAAM,CAAC;IACpC,CAAC;IAED,MAAM,CAAC,UAAsB;QAC3B,OAAO,CACL,CAAC,UAAU,CAAC,IAAI;YAChB,CAAC,UAAU,CAAC,IAAI,KAAK,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAC3D,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAC1C,CAAC;IAED,WAAW,CAAC,UAA6C;QACvD,OAAO,CACL,UAAU,CAAC,SAAS,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CACtE,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,UAA6C;QACvD,OAAO,WAAW,CAAC,UAAU,CAAC,SAAU,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,CAAC,GAAmB;QACzB,IAAI,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,IAAI,EAAE;YACrC,MAAM,CAAC,UAAU,CAAC,GAAG,GAAG;iBACrB,OAAO,CAAC,8BAA8B,EAAE,EAAE,CAAC;iBAC3C,KAAK,CAAC,GAAG,CAAC,CAAC;YAEd,OAAO,UAAU,CAAC;SACnB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;;oHA5DU,uBAAuB;wGAAvB,uBAAuB,2HCXpC,o+FAyFA;2FD9Ea,uBAAuB;kBALnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,WAAW,EAAE,kCAAkC;oBAC/C,MAAM,EAAE,EAAE;iBACX;uGAEU,WAAW;sBAAnB,KAAK","sourcesContent":["import { Component, Input, OnChanges } from '@angular/core';\nimport { Attachment } from 'stream-chat';\nimport { ImageLoadService } from '../message-list/image-load.service';\nimport { DefaultAttachmentType } from '../types';\nimport prettybytes from 'pretty-bytes';\n\n@Component({\n  selector: 'stream-attachment-list',\n  templateUrl: './attachment-list.component.html',\n  styles: [],\n})\nexport class AttachmentListComponent implements OnChanges {\n  @Input() attachments: Attachment<DefaultAttachmentType>[] = [];\n  orderedAttachments: Attachment<DefaultAttachmentType>[] = [];\n\n  constructor(private imageLoadService: ImageLoadService) {}\n\n  ngOnChanges(): void {\n    this.orderedAttachments = [\n      ...this.attachments.filter((a) => this.isImage(a)),\n      ...this.attachments.filter((a) => this.isFile(a)),\n      ...this.attachments.filter((a) => this.isCard(a)),\n    ];\n  }\n\n  trackById(index: number) {\n    return index;\n  }\n\n  isImage(attachment: Attachment) {\n    return (\n      attachment.type === 'image' &&\n      !attachment.title_link &&\n      !attachment.og_scrape_url\n    );\n  }\n\n  isFile(attachment: Attachment) {\n    return attachment.type === 'file';\n  }\n\n  isCard(attachment: Attachment) {\n    return (\n      !attachment.type ||\n      (attachment.type === 'image' && !this.isImage(attachment))\n    );\n  }\n\n  imageLoaded() {\n    this.imageLoadService.imageLoad$.next();\n  }\n\n  hasFileSize(attachment: Attachment<DefaultAttachmentType>) {\n    return (\n      attachment.file_size && Number.isFinite(Number(attachment.file_size))\n    );\n  }\n\n  getFileSize(attachment: Attachment<DefaultAttachmentType>) {\n    return prettybytes(attachment.file_size!);\n  }\n\n  trimUrl(url?: string | null) {\n    if (url !== undefined && url !== null) {\n      const [trimmedUrl] = url\n        .replace(/^(?:https?:\\/\\/)?(?:www\\.)?/i, '')\n        .split('/');\n\n      return trimmedUrl;\n    }\n    return null;\n  }\n}\n","<ng-container *ngFor=\"let attachment of orderedAttachments; trackBy: trackById\">\n  <div\n    data-testclass=\"attachment-container\"\n    class=\"str-chat__message-attachment str-chat__message-attachment--{{\n      attachment.type\n    }}\"\n    [class.str-chat__message-attachment--card]=\"isCard(attachment)\"\n    [class.str-chat-angular__message-attachment-file-single]=\"\n      isFile(attachment)\n    \"\n  >\n    <img\n      *ngIf=\"isImage(attachment)\"\n      class=\"str-chat__message-attachment--img\"\n      data-testclass=\"image\"\n      [src]=\"attachment.img_url || attachment.thumb_url || attachment.image_url\"\n      [alt]=\"attachment?.fallback\"\n      (load)=\"imageLoaded()\"\n    />\n    <div\n      *ngIf=\"isFile(attachment)\"\n      class=\"\n        str-chat__message-attachment-file--item\n        str-chat-angular__message-attachment-file-single\n      \"\n    >\n      <stream-icon icon=\"file\" [size]=\"30\"></stream-icon>\n      <div class=\"str-chat__message-attachment-file--item-text\">\n        <a\n          data-testclass=\"file-link\"\n          download\n          href=\"{{ attachment.asset_url }}\"\n          target=\"_blank\"\n        >\n          {{ attachment.title }}\n        </a>\n        <span data-testclass=\"size\" *ngIf=\"hasFileSize(attachment)\">{{\n          getFileSize(attachment)\n        }}</span>\n      </div>\n    </div>\n    <div\n      *ngIf=\"isCard(attachment)\"\n      class=\"str-chat__message-attachment-card str-chat__message-attachment-card--{{\n        attachment.type\n      }}\"\n    >\n      <div\n        *ngIf=\"attachment.image_url || attachment.thumb_url\"\n        class=\"str-chat__message-attachment-card--header\"\n      >\n        <img\n          data-testclass=\"card-img\"\n          alt=\"{{ attachment.image_url || attachment.thumb_url }}\"\n          src=\"{{ attachment.image_url || attachment.thumb_url }}\"\n        />\n      </div>\n      <div class=\"str-chat__message-attachment-card--content\">\n        <div class=\"str-chat__message-attachment-card--flex\">\n          <div\n            *ngIf=\"attachment.title\"\n            data-testclass=\"card-title\"\n            class=\"str-chat__message-attachment-card--title\"\n          >\n            {{ attachment.title }}\n          </div>\n          <div\n            *ngIf=\"attachment.text\"\n            class=\"str-chat__message-attachment-card--text\"\n            data-testclass=\"card-text\"\n          >\n            {{ attachment.text }}\n          </div>\n          <a\n            class=\"str-chat__message-attachment-card--url\"\n            *ngIf=\"attachment.title_link || attachment.og_scrape_url\"\n            data-testclass=\"url-link\"\n            noopener\n            noreferrer\n            href=\"{{ attachment.title_link || attachment.og_scrape_url }}\"\n            target=\"_blank\"\n          >\n            {{ trimUrl(attachment.title_link || attachment.og_scrape_url) }}\n          </a>\n        </div>\n      </div>\n    </div>\n  </div>\n</ng-container>\n"]}
65
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-list.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/attachment-list/attachment-list.component.ts","../../../../../projects/stream-chat-angular/src/lib/attachment-list/attachment-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAa,MAAM,eAAe,CAAC;AAI5D,OAAO,WAAW,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;;;;;AAO3D,MAAM,OAAO,uBAAuB;IAIlC,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAH7C,gBAAW,GAAwC,EAAE,CAAC;QAC/D,uBAAkB,GAAwC,EAAE,CAAC;IAEJ,CAAC;IAE1D,WAAW;QACT,IAAI,CAAC,kBAAkB,GAAG;YACxB,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAClD,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YACjD,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;SAClD,CAAC;IACJ,CAAC;IAED,SAAS,CAAC,KAAa;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO,CAAC,UAAsB;QAC5B,OAAO,iBAAiB,CAAC,UAAU,CAAC,CAAC;IACvC,CAAC;IAED,MAAM,CAAC,UAAsB;QAC3B,OAAO,UAAU,CAAC,IAAI,KAAK,MAAM,CAAC;IACpC,CAAC;IAED,MAAM,CAAC,UAAsB;QAC3B,OAAO,CACL,CAAC,UAAU,CAAC,IAAI;YAChB,CAAC,UAAU,CAAC,IAAI,KAAK,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAC3D,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAC1C,CAAC;IAED,WAAW,CAAC,UAA6C;QACvD,OAAO,CACL,UAAU,CAAC,SAAS,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CACtE,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,UAA6C;QACvD,OAAO,WAAW,CAAC,UAAU,CAAC,SAAU,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,CAAC,GAAmB;QACzB,IAAI,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,IAAI,EAAE;YACrC,MAAM,CAAC,UAAU,CAAC,GAAG,GAAG;iBACrB,OAAO,CAAC,8BAA8B,EAAE,EAAE,CAAC;iBAC3C,KAAK,CAAC,GAAG,CAAC,CAAC;YAEd,OAAO,UAAU,CAAC;SACnB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;;oHAxDU,uBAAuB;wGAAvB,uBAAuB,2HCZpC,o+FAyFA;2FD7Ea,uBAAuB;kBALnC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,WAAW,EAAE,kCAAkC;oBAC/C,MAAM,EAAE,EAAE;iBACX;uGAEU,WAAW;sBAAnB,KAAK","sourcesContent":["import { Component, Input, OnChanges } from '@angular/core';\nimport { Attachment } from 'stream-chat';\nimport { ImageLoadService } from '../message-list/image-load.service';\nimport { DefaultAttachmentType } from '../types';\nimport prettybytes from 'pretty-bytes';\nimport { isImageAttachment } from '../is-image-attachment';\n\n@Component({\n  selector: 'stream-attachment-list',\n  templateUrl: './attachment-list.component.html',\n  styles: [],\n})\nexport class AttachmentListComponent implements OnChanges {\n  @Input() attachments: Attachment<DefaultAttachmentType>[] = [];\n  orderedAttachments: Attachment<DefaultAttachmentType>[] = [];\n\n  constructor(private imageLoadService: ImageLoadService) {}\n\n  ngOnChanges(): void {\n    this.orderedAttachments = [\n      ...this.attachments.filter((a) => this.isImage(a)),\n      ...this.attachments.filter((a) => this.isFile(a)),\n      ...this.attachments.filter((a) => this.isCard(a)),\n    ];\n  }\n\n  trackById(index: number) {\n    return index;\n  }\n\n  isImage(attachment: Attachment) {\n    return isImageAttachment(attachment);\n  }\n\n  isFile(attachment: Attachment) {\n    return attachment.type === 'file';\n  }\n\n  isCard(attachment: Attachment) {\n    return (\n      !attachment.type ||\n      (attachment.type === 'image' && !this.isImage(attachment))\n    );\n  }\n\n  imageLoaded() {\n    this.imageLoadService.imageLoad$.next();\n  }\n\n  hasFileSize(attachment: Attachment<DefaultAttachmentType>) {\n    return (\n      attachment.file_size && Number.isFinite(Number(attachment.file_size))\n    );\n  }\n\n  getFileSize(attachment: Attachment<DefaultAttachmentType>) {\n    return prettybytes(attachment.file_size!);\n  }\n\n  trimUrl(url?: string | null) {\n    if (url !== undefined && url !== null) {\n      const [trimmedUrl] = url\n        .replace(/^(?:https?:\\/\\/)?(?:www\\.)?/i, '')\n        .split('/');\n\n      return trimmedUrl;\n    }\n    return null;\n  }\n}\n","<ng-container *ngFor=\"let attachment of orderedAttachments; trackBy: trackById\">\n  <div\n    data-testclass=\"attachment-container\"\n    class=\"str-chat__message-attachment str-chat__message-attachment--{{\n      attachment.type\n    }}\"\n    [class.str-chat__message-attachment--card]=\"isCard(attachment)\"\n    [class.str-chat-angular__message-attachment-file-single]=\"\n      isFile(attachment)\n    \"\n  >\n    <img\n      *ngIf=\"isImage(attachment)\"\n      class=\"str-chat__message-attachment--img\"\n      data-testclass=\"image\"\n      [src]=\"attachment.img_url || attachment.thumb_url || attachment.image_url\"\n      [alt]=\"attachment?.fallback\"\n      (load)=\"imageLoaded()\"\n    />\n    <div\n      *ngIf=\"isFile(attachment)\"\n      class=\"\n        str-chat__message-attachment-file--item\n        str-chat-angular__message-attachment-file-single\n      \"\n    >\n      <stream-icon icon=\"file\" [size]=\"30\"></stream-icon>\n      <div class=\"str-chat__message-attachment-file--item-text\">\n        <a\n          data-testclass=\"file-link\"\n          download\n          href=\"{{ attachment.asset_url }}\"\n          target=\"_blank\"\n        >\n          {{ attachment.title }}\n        </a>\n        <span data-testclass=\"size\" *ngIf=\"hasFileSize(attachment)\">{{\n          getFileSize(attachment)\n        }}</span>\n      </div>\n    </div>\n    <div\n      *ngIf=\"isCard(attachment)\"\n      class=\"str-chat__message-attachment-card str-chat__message-attachment-card--{{\n        attachment.type\n      }}\"\n    >\n      <div\n        *ngIf=\"attachment.image_url || attachment.thumb_url\"\n        class=\"str-chat__message-attachment-card--header\"\n      >\n        <img\n          data-testclass=\"card-img\"\n          alt=\"{{ attachment.image_url || attachment.thumb_url }}\"\n          src=\"{{ attachment.image_url || attachment.thumb_url }}\"\n        />\n      </div>\n      <div class=\"str-chat__message-attachment-card--content\">\n        <div class=\"str-chat__message-attachment-card--flex\">\n          <div\n            *ngIf=\"attachment.title\"\n            data-testclass=\"card-title\"\n            class=\"str-chat__message-attachment-card--title\"\n          >\n            {{ attachment.title }}\n          </div>\n          <div\n            *ngIf=\"attachment.text\"\n            class=\"str-chat__message-attachment-card--text\"\n            data-testclass=\"card-text\"\n          >\n            {{ attachment.text }}\n          </div>\n          <a\n            class=\"str-chat__message-attachment-card--url\"\n            *ngIf=\"attachment.title_link || attachment.og_scrape_url\"\n            data-testclass=\"url-link\"\n            noopener\n            noreferrer\n            href=\"{{ attachment.title_link || attachment.og_scrape_url }}\"\n            target=\"_blank\"\n          >\n            {{ trimUrl(attachment.title_link || attachment.og_scrape_url) }}\n          </a>\n        </div>\n      </div>\n    </div>\n  </div>\n</ng-container>\n"]}
@@ -0,0 +1,38 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Component } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../attachment.service";
5
+ import * as i2 from "../icon/icon.component";
6
+ import * as i3 from "../loading-indicator/loading-indicator.component";
7
+ import * as i4 from "@angular/common";
8
+ import * as i5 from "@ngx-translate/core";
9
+ export class AttachmentPreviewListComponent {
10
+ constructor(attachmentService) {
11
+ this.attachmentService = attachmentService;
12
+ this.attachmentUploads$ = this.attachmentService.attachmentUploads$;
13
+ }
14
+ retryAttachmentUpload(file) {
15
+ return __awaiter(this, void 0, void 0, function* () {
16
+ yield this.attachmentService.retryAttachmentUpload(file);
17
+ });
18
+ }
19
+ deleteAttachment(upload) {
20
+ return __awaiter(this, void 0, void 0, function* () {
21
+ yield this.attachmentService.deleteAttachment(upload);
22
+ });
23
+ }
24
+ trackByFile(_, item) {
25
+ return item.file;
26
+ }
27
+ }
28
+ AttachmentPreviewListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: AttachmentPreviewListComponent, deps: [{ token: i1.AttachmentService }], target: i0.ɵɵFactoryTarget.Component });
29
+ AttachmentPreviewListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: AttachmentPreviewListComponent, selector: "stream-attachment-preview-list", ngImport: i0, template: "<div class=\"rfu-image-previewer\">\n <ng-container\n *ngFor=\"\n let attachmentUpload of attachmentUploads$ | async;\n trackBy: trackByFile\n \"\n >\n <div\n *ngIf=\"attachmentUpload.type === 'image'\"\n class=\"rfu-image-previewer__image\"\n [class.rfu-image-previewer__image--loaded]=\"\n attachmentUpload.state === 'success'\n \"\n data-testclass=\"attachment-image-preview\"\n >\n <div\n *ngIf=\"attachmentUpload.state === 'error'\"\n class=\"rfu-image-previewer__retry\"\n (click)=\"retryAttachmentUpload(attachmentUpload.file)\"\n (keyup.enter)=\"retryAttachmentUpload(attachmentUpload.file)\"\n data-testclass=\"upload-error\"\n >\n <stream-icon icon=\"retry\"></stream-icon>\n </div>\n <div class=\"rfu-thumbnail__wrapper\" style=\"width: 100; height: 100\">\n <div class=\"rfu-thumbnail__overlay\">\n <div\n class=\"rfu-icon-button\"\n data-testclass=\"delete-attachment\"\n role=\"button\"\n (click)=\"deleteAttachment(attachmentUpload)\"\n (keyup.enter)=\"deleteAttachment(attachmentUpload)\"\n >\n <stream-icon icon=\"close\"></stream-icon>\n </div>\n </div>\n <img\n *ngIf=\"attachmentUpload.url || attachmentUpload.previewUri\"\n src=\"{{\n attachmentUpload.url\n ? attachmentUpload.url\n : attachmentUpload.previewUri\n }}\"\n alt=\"attachmentUpload.file.name\"\n class=\"rfu-thumbnail__image\"\n data-testclass=\"attachment-image\"\n />\n </div>\n <stream-loading-indicator\n data-testclass=\"loading-indicator\"\n color=\"rgba(255,255,255,0.7)\"\n *ngIf=\"attachmentUpload.state === 'uploading'\"\n ></stream-loading-indicator>\n </div>\n <div\n class=\"rfu-file-previewer\"\n *ngIf=\"attachmentUpload.type === 'file'\"\n data-testclass=\"attachment-file-preview\"\n >\n <ol>\n <li\n class=\"rfu-file-previewer__file\"\n [class.rfu-file-previewer__file--uploading]=\"\n attachmentUpload.state === 'uploading'\n \"\n [class.rfu-file-previewer__file--failed]=\"\n attachmentUpload.state === 'error'\n \"\n >\n <stream-icon icon=\"file\"></stream-icon>\n\n <a\n data-testclass=\"file-download-link\"\n href=\"{{ attachmentUpload.url }}\"\n (click)=\"attachmentUpload.url ? null : $event.preventDefault()\"\n (keyup.enter)=\"\n attachmentUpload.url ? null : $event.preventDefault()\n \"\n download\n >\n {{ attachmentUpload.file.name }}\n <ng-container *ngIf=\"attachmentUpload.state === 'error'\">\n <div\n data-testclass=\"file-upload-retry\"\n class=\"rfu-file-previewer__failed\"\n (click)=\"retryAttachmentUpload(attachmentUpload.file)\"\n (keyup.enter)=\"retryAttachmentUpload(attachmentUpload.file)\"\n translate\n >\n streamChat.failed\n </div>\n <div\n class=\"rfu-file-previewer__retry\"\n (click)=\"retryAttachmentUpload(attachmentUpload.file)\"\n (keyup.enter)=\"retryAttachmentUpload(attachmentUpload.file)\"\n translate\n >\n streamChat.retry\n </div>\n </ng-container>\n </a>\n\n <span\n data-testclass=\"file-delete\"\n class=\"rfu-file-previewer__close-button\"\n (click)=\"deleteAttachment(attachmentUpload)\"\n (keyup.enter)=\"deleteAttachment(attachmentUpload)\"\n >\n \u2718\n </span>\n <div\n *ngIf=\"attachmentUpload.state === 'uploading'\"\n class=\"rfu-file-previewer__loading-indicator\"\n >\n <stream-loading-indicator></stream-loading-indicator>\n </div>\n </li>\n </ol>\n </div>\n </ng-container>\n</div>\n", components: [{ type: i2.IconComponent, selector: "stream-icon", inputs: ["icon", "size"] }, { type: i3.LoadingIndicatorComponent, selector: "stream-loading-indicator", inputs: ["size", "color"] }], directives: [{ type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "async": i4.AsyncPipe } });
30
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: AttachmentPreviewListComponent, decorators: [{
31
+ type: Component,
32
+ args: [{
33
+ selector: 'stream-attachment-preview-list',
34
+ templateUrl: './attachment-preview-list.component.html',
35
+ styles: [],
36
+ }]
37
+ }], ctorParameters: function () { return [{ type: i1.AttachmentService }]; } });
38
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-preview-list.component.js","sourceRoot":"","sources":["../../../../../projects/stream-chat-angular/src/lib/attachment-preview-list/attachment-preview-list.component.ts","../../../../../projects/stream-chat-angular/src/lib/attachment-preview-list/attachment-preview-list.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;;;;;;;AAU1C,MAAM,OAAO,8BAA8B;IAGzC,YAAoB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACtD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC;IACtE,CAAC;IAEK,qBAAqB,CAAC,IAAU;;YACpC,MAAM,IAAI,CAAC,iBAAiB,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC3D,CAAC;KAAA;IAEK,gBAAgB,CAAC,MAAwB;;YAC7C,MAAM,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACxD,CAAC;KAAA;IAED,WAAW,CAAC,CAAS,EAAE,IAAsB;QAC3C,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;;2HAjBU,8BAA8B;+GAA9B,8BAA8B,sECV3C,orIAyHA;2FD/Ga,8BAA8B;kBAL1C,SAAS;mBAAC;oBACT,QAAQ,EAAE,gCAAgC;oBAC1C,WAAW,EAAE,0CAA0C;oBACvD,MAAM,EAAE,EAAE;iBACX","sourcesContent":["import { Component } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { AttachmentService } from '../attachment.service';\nimport { AttachmentUpload } from '../types';\n\n@Component({\n  selector: 'stream-attachment-preview-list',\n  templateUrl: './attachment-preview-list.component.html',\n  styles: [],\n})\nexport class AttachmentPreviewListComponent {\n  attachmentUploads$: Observable<AttachmentUpload[]>;\n\n  constructor(private attachmentService: AttachmentService) {\n    this.attachmentUploads$ = this.attachmentService.attachmentUploads$;\n  }\n\n  async retryAttachmentUpload(file: File) {\n    await this.attachmentService.retryAttachmentUpload(file);\n  }\n\n  async deleteAttachment(upload: AttachmentUpload) {\n    await this.attachmentService.deleteAttachment(upload);\n  }\n\n  trackByFile(_: number, item: AttachmentUpload) {\n    return item.file;\n  }\n}\n","<div class=\"rfu-image-previewer\">\n  <ng-container\n    *ngFor=\"\n      let attachmentUpload of attachmentUploads$ | async;\n      trackBy: trackByFile\n    \"\n  >\n    <div\n      *ngIf=\"attachmentUpload.type === 'image'\"\n      class=\"rfu-image-previewer__image\"\n      [class.rfu-image-previewer__image--loaded]=\"\n        attachmentUpload.state === 'success'\n      \"\n      data-testclass=\"attachment-image-preview\"\n    >\n      <div\n        *ngIf=\"attachmentUpload.state === 'error'\"\n        class=\"rfu-image-previewer__retry\"\n        (click)=\"retryAttachmentUpload(attachmentUpload.file)\"\n        (keyup.enter)=\"retryAttachmentUpload(attachmentUpload.file)\"\n        data-testclass=\"upload-error\"\n      >\n        <stream-icon icon=\"retry\"></stream-icon>\n      </div>\n      <div class=\"rfu-thumbnail__wrapper\" style=\"width: 100; height: 100\">\n        <div class=\"rfu-thumbnail__overlay\">\n          <div\n            class=\"rfu-icon-button\"\n            data-testclass=\"delete-attachment\"\n            role=\"button\"\n            (click)=\"deleteAttachment(attachmentUpload)\"\n            (keyup.enter)=\"deleteAttachment(attachmentUpload)\"\n          >\n            <stream-icon icon=\"close\"></stream-icon>\n          </div>\n        </div>\n        <img\n          *ngIf=\"attachmentUpload.url || attachmentUpload.previewUri\"\n          src=\"{{\n            attachmentUpload.url\n              ? attachmentUpload.url\n              : attachmentUpload.previewUri\n          }}\"\n          alt=\"attachmentUpload.file.name\"\n          class=\"rfu-thumbnail__image\"\n          data-testclass=\"attachment-image\"\n        />\n      </div>\n      <stream-loading-indicator\n        data-testclass=\"loading-indicator\"\n        color=\"rgba(255,255,255,0.7)\"\n        *ngIf=\"attachmentUpload.state === 'uploading'\"\n      ></stream-loading-indicator>\n    </div>\n    <div\n      class=\"rfu-file-previewer\"\n      *ngIf=\"attachmentUpload.type === 'file'\"\n      data-testclass=\"attachment-file-preview\"\n    >\n      <ol>\n        <li\n          class=\"rfu-file-previewer__file\"\n          [class.rfu-file-previewer__file--uploading]=\"\n            attachmentUpload.state === 'uploading'\n          \"\n          [class.rfu-file-previewer__file--failed]=\"\n            attachmentUpload.state === 'error'\n          \"\n        >\n          <stream-icon icon=\"file\"></stream-icon>\n\n          <a\n            data-testclass=\"file-download-link\"\n            href=\"{{ attachmentUpload.url }}\"\n            (click)=\"attachmentUpload.url ? null : $event.preventDefault()\"\n            (keyup.enter)=\"\n              attachmentUpload.url ? null : $event.preventDefault()\n            \"\n            download\n          >\n            {{ attachmentUpload.file.name }}\n            <ng-container *ngIf=\"attachmentUpload.state === 'error'\">\n              <div\n                data-testclass=\"file-upload-retry\"\n                class=\"rfu-file-previewer__failed\"\n                (click)=\"retryAttachmentUpload(attachmentUpload.file)\"\n                (keyup.enter)=\"retryAttachmentUpload(attachmentUpload.file)\"\n                translate\n              >\n                streamChat.failed\n              </div>\n              <div\n                class=\"rfu-file-previewer__retry\"\n                (click)=\"retryAttachmentUpload(attachmentUpload.file)\"\n                (keyup.enter)=\"retryAttachmentUpload(attachmentUpload.file)\"\n                translate\n              >\n                streamChat.retry\n              </div>\n            </ng-container>\n          </a>\n\n          <span\n            data-testclass=\"file-delete\"\n            class=\"rfu-file-previewer__close-button\"\n            (click)=\"deleteAttachment(attachmentUpload)\"\n            (keyup.enter)=\"deleteAttachment(attachmentUpload)\"\n          >\n            ✘\n          </span>\n          <div\n            *ngIf=\"attachmentUpload.state === 'uploading'\"\n            class=\"rfu-file-previewer__loading-indicator\"\n          >\n            <stream-loading-indicator></stream-loading-indicator>\n          </div>\n        </li>\n      </ol>\n    </div>\n  </ng-container>\n</div>\n"]}
@@ -0,0 +1,190 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Injectable } from '@angular/core';
3
+ import { BehaviorSubject } from 'rxjs';
4
+ import { isImageAttachment } from './is-image-attachment';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "./channel.service";
7
+ import * as i2 from "./notification.service";
8
+ export class AttachmentService {
9
+ constructor(channelService, notificationService) {
10
+ this.channelService = channelService;
11
+ this.notificationService = notificationService;
12
+ this.attachmentUploadInProgressCounterSubject = new BehaviorSubject(0);
13
+ this.attachmentUploadsSubject = new BehaviorSubject([]);
14
+ this.attachmentUploadInProgressCounter$ =
15
+ this.attachmentUploadInProgressCounterSubject.asObservable();
16
+ this.attachmentUploads$ = this.attachmentUploadsSubject.asObservable();
17
+ }
18
+ resetAttachmentUploads() {
19
+ this.attachmentUploadsSubject.next([]);
20
+ }
21
+ filesSelected(fileList) {
22
+ return __awaiter(this, void 0, void 0, function* () {
23
+ if (!fileList) {
24
+ return;
25
+ }
26
+ const imageFiles = [];
27
+ const dataFiles = [];
28
+ Array.from(fileList).forEach((file) => {
29
+ if (file.type.startsWith('image/') && !file.type.endsWith('.photoshop')) {
30
+ // photoshop files begin with 'image/'
31
+ imageFiles.push(file);
32
+ }
33
+ else {
34
+ dataFiles.push(file);
35
+ }
36
+ });
37
+ imageFiles.forEach((f) => this.createPreview(f));
38
+ const newUploads = [
39
+ ...imageFiles.map((file) => ({
40
+ file,
41
+ state: 'uploading',
42
+ type: 'image',
43
+ })),
44
+ ...dataFiles.map((file) => ({
45
+ file,
46
+ state: 'uploading',
47
+ type: 'file',
48
+ })),
49
+ ];
50
+ this.attachmentUploadsSubject.next([
51
+ ...this.attachmentUploadsSubject.getValue(),
52
+ ...newUploads,
53
+ ]);
54
+ yield this.uploadAttachments(newUploads);
55
+ });
56
+ }
57
+ retryAttachmentUpload(file) {
58
+ return __awaiter(this, void 0, void 0, function* () {
59
+ const attachmentUploads = this.attachmentUploadsSubject.getValue();
60
+ const upload = attachmentUploads.find((u) => u.file === file);
61
+ if (!upload) {
62
+ return;
63
+ }
64
+ upload.state = 'uploading';
65
+ this.attachmentUploadsSubject.next([...attachmentUploads]);
66
+ yield this.uploadAttachments([upload]);
67
+ });
68
+ }
69
+ deleteAttachment(upload) {
70
+ return __awaiter(this, void 0, void 0, function* () {
71
+ const attachmentUploads = this.attachmentUploadsSubject.getValue();
72
+ if (upload.state === 'success') {
73
+ try {
74
+ yield this.channelService.deleteAttachment(upload);
75
+ attachmentUploads.splice(attachmentUploads.indexOf(upload), 1);
76
+ }
77
+ catch (error) {
78
+ this.notificationService.addTemporaryNotification('streamChat.Error deleting attachment');
79
+ }
80
+ }
81
+ else {
82
+ attachmentUploads.splice(attachmentUploads.indexOf(upload), 1);
83
+ }
84
+ this.attachmentUploadsSubject.next([...attachmentUploads]);
85
+ });
86
+ }
87
+ mapToAttachments() {
88
+ const attachmentUploads = this.attachmentUploadsSubject.getValue();
89
+ return attachmentUploads
90
+ .filter((r) => r.state === 'success')
91
+ .map((r) => {
92
+ var _a, _b, _c;
93
+ const attachment = {
94
+ type: r.type,
95
+ };
96
+ if (r.type === 'image') {
97
+ attachment.fallback = (_a = r.file) === null || _a === void 0 ? void 0 : _a.name;
98
+ attachment.image_url = r.url;
99
+ }
100
+ else {
101
+ attachment.asset_url = r.url;
102
+ attachment.title = (_b = r.file) === null || _b === void 0 ? void 0 : _b.name;
103
+ attachment.file_size = (_c = r.file) === null || _c === void 0 ? void 0 : _c.size;
104
+ }
105
+ return attachment;
106
+ });
107
+ }
108
+ createFromAttachments(attachments) {
109
+ const attachmentUploads = [];
110
+ attachments.forEach((attachment) => {
111
+ if (isImageAttachment(attachment)) {
112
+ attachmentUploads.push({
113
+ url: (attachment.img_url ||
114
+ attachment.thumb_url ||
115
+ attachment.image_url),
116
+ state: 'success',
117
+ type: 'image',
118
+ file: {
119
+ name: attachment.fallback,
120
+ },
121
+ });
122
+ }
123
+ else if (attachment.type === 'file') {
124
+ attachmentUploads.push({
125
+ url: attachment.asset_url,
126
+ state: 'success',
127
+ file: {
128
+ name: attachment.title,
129
+ size: attachment.file_size,
130
+ },
131
+ type: 'file',
132
+ });
133
+ }
134
+ });
135
+ if (attachmentUploads.length > 0) {
136
+ this.attachmentUploadsSubject.next([
137
+ ...this.attachmentUploadsSubject.getValue(),
138
+ ...attachmentUploads,
139
+ ]);
140
+ }
141
+ }
142
+ createPreview(file) {
143
+ const reader = new FileReader();
144
+ reader.onload = (event) => {
145
+ var _a;
146
+ const attachmentUploads = this.attachmentUploadsSubject.getValue();
147
+ const upload = attachmentUploads.find((upload) => upload.file === file);
148
+ if (!upload) {
149
+ return;
150
+ }
151
+ upload.previewUri = ((_a = event.target) === null || _a === void 0 ? void 0 : _a.result) || undefined;
152
+ this.attachmentUploadsSubject.next([...attachmentUploads]);
153
+ };
154
+ reader.readAsDataURL(file);
155
+ }
156
+ uploadAttachments(uploads) {
157
+ return __awaiter(this, void 0, void 0, function* () {
158
+ const attachmentUploads = this.attachmentUploadsSubject.getValue();
159
+ this.attachmentUploadInProgressCounterSubject.next(this.attachmentUploadInProgressCounterSubject.getValue() + 1);
160
+ const result = yield this.channelService.uploadAttachments(uploads);
161
+ result.forEach((r) => {
162
+ const upload = attachmentUploads.find((upload) => upload.file === r.file);
163
+ if (!upload) {
164
+ if (r.url) {
165
+ void this.channelService.deleteAttachment(r);
166
+ }
167
+ return;
168
+ }
169
+ upload.state = r.state;
170
+ upload.url = r.url;
171
+ if (upload.state === 'error') {
172
+ this.notificationService.addTemporaryNotification(upload.type === 'image'
173
+ ? 'streamChat.Error uploading image'
174
+ : 'streamChat.Error uploading file');
175
+ }
176
+ });
177
+ this.attachmentUploadInProgressCounterSubject.next(this.attachmentUploadInProgressCounterSubject.getValue() - 1);
178
+ this.attachmentUploadsSubject.next([...attachmentUploads]);
179
+ });
180
+ }
181
+ }
182
+ AttachmentService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: AttachmentService, deps: [{ token: i1.ChannelService }, { token: i2.NotificationService }], target: i0.ɵɵFactoryTarget.Injectable });
183
+ AttachmentService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: AttachmentService, providedIn: 'root' });
184
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: AttachmentService, decorators: [{
185
+ type: Injectable,
186
+ args: [{
187
+ providedIn: 'root',
188
+ }]
189
+ }], ctorParameters: function () { return [{ type: i1.ChannelService }, { type: i2.NotificationService }]; } });
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/attachment.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { Attachment } from 'stream-chat';\nimport { ChannelService } from './channel.service';\nimport { isImageAttachment } from './is-image-attachment';\nimport { NotificationService } from './notification.service';\nimport { AttachmentUpload } from './types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class AttachmentService {\n  attachmentUploadInProgressCounter$: Observable<number>;\n  attachmentUploads$: Observable<AttachmentUpload[]>;\n  private attachmentUploadInProgressCounterSubject =\n    new BehaviorSubject<number>(0);\n  private attachmentUploadsSubject = new BehaviorSubject<AttachmentUpload[]>(\n    []\n  );\n\n  constructor(\n    private channelService: ChannelService,\n    private notificationService: NotificationService\n  ) {\n    this.attachmentUploadInProgressCounter$ =\n      this.attachmentUploadInProgressCounterSubject.asObservable();\n    this.attachmentUploads$ = this.attachmentUploadsSubject.asObservable();\n  }\n\n  resetAttachmentUploads() {\n    this.attachmentUploadsSubject.next([]);\n  }\n\n  async filesSelected(fileList: FileList | null) {\n    if (!fileList) {\n      return;\n    }\n    const imageFiles: File[] = [];\n    const dataFiles: File[] = [];\n\n    Array.from(fileList).forEach((file) => {\n      if (file.type.startsWith('image/') && !file.type.endsWith('.photoshop')) {\n        // photoshop files begin with 'image/'\n        imageFiles.push(file);\n      } else {\n        dataFiles.push(file);\n      }\n    });\n    imageFiles.forEach((f) => this.createPreview(f));\n    const newUploads = [\n      ...imageFiles.map((file) => ({\n        file,\n        state: 'uploading' as 'uploading',\n        type: 'image' as 'image',\n      })),\n      ...dataFiles.map((file) => ({\n        file,\n        state: 'uploading' as 'uploading',\n        type: 'file' as 'file',\n      })),\n    ];\n    this.attachmentUploadsSubject.next([\n      ...this.attachmentUploadsSubject.getValue(),\n      ...newUploads,\n    ]);\n    await this.uploadAttachments(newUploads);\n  }\n\n  async retryAttachmentUpload(file: File) {\n    const attachmentUploads = this.attachmentUploadsSubject.getValue();\n    const upload = attachmentUploads.find((u) => u.file === file);\n    if (!upload) {\n      return;\n    }\n    upload.state = 'uploading';\n    this.attachmentUploadsSubject.next([...attachmentUploads]);\n    await this.uploadAttachments([upload]);\n  }\n\n  async deleteAttachment(upload: AttachmentUpload) {\n    const attachmentUploads = this.attachmentUploadsSubject.getValue();\n    if (upload.state === 'success') {\n      try {\n        await this.channelService.deleteAttachment(upload);\n        attachmentUploads.splice(attachmentUploads.indexOf(upload), 1);\n      } catch (error) {\n        this.notificationService.addTemporaryNotification(\n          'streamChat.Error deleting attachment'\n        );\n      }\n    } else {\n      attachmentUploads.splice(attachmentUploads.indexOf(upload), 1);\n    }\n    this.attachmentUploadsSubject.next([...attachmentUploads]);\n  }\n\n  mapToAttachments() {\n    const attachmentUploads = this.attachmentUploadsSubject.getValue();\n    return attachmentUploads\n      .filter((r) => r.state === 'success')\n      .map((r) => {\n        const attachment: Attachment = {\n          type: r.type,\n        };\n        if (r.type === 'image') {\n          attachment.fallback = r.file?.name;\n          attachment.image_url = r.url;\n        } else {\n          attachment.asset_url = r.url;\n          attachment.title = r.file?.name;\n          attachment.file_size = r.file?.size;\n        }\n\n        return attachment;\n      });\n  }\n\n  createFromAttachments(attachments: Attachment[]) {\n    const attachmentUploads: AttachmentUpload[] = [];\n    attachments.forEach((attachment) => {\n      if (isImageAttachment(attachment)) {\n        attachmentUploads.push({\n          url: (attachment.img_url ||\n            attachment.thumb_url ||\n            attachment.image_url) as string,\n          state: 'success',\n          type: 'image',\n          file: {\n            name: attachment.fallback,\n          } as File,\n        });\n      } else if (attachment.type === 'file') {\n        attachmentUploads.push({\n          url: attachment.asset_url,\n          state: 'success',\n          file: {\n            name: attachment.title,\n            size: attachment.file_size,\n          } as File,\n          type: 'file',\n        });\n      }\n    });\n\n    if (attachmentUploads.length > 0) {\n      this.attachmentUploadsSubject.next([\n        ...this.attachmentUploadsSubject.getValue(),\n        ...attachmentUploads,\n      ]);\n    }\n  }\n\n  private createPreview(file: File) {\n    const reader = new FileReader();\n    reader.onload = (event) => {\n      const attachmentUploads = this.attachmentUploadsSubject.getValue();\n      const upload = attachmentUploads.find((upload) => upload.file === file);\n      if (!upload) {\n        return;\n      }\n      upload.previewUri = event.target?.result || undefined;\n      this.attachmentUploadsSubject.next([...attachmentUploads]);\n    };\n    reader.readAsDataURL(file as Blob);\n  }\n\n  private async uploadAttachments(uploads: AttachmentUpload[]) {\n    const attachmentUploads = this.attachmentUploadsSubject.getValue();\n    this.attachmentUploadInProgressCounterSubject.next(\n      this.attachmentUploadInProgressCounterSubject.getValue() + 1\n    );\n    const result = await this.channelService.uploadAttachments(uploads);\n    result.forEach((r) => {\n      const upload = attachmentUploads.find((upload) => upload.file === r.file);\n      if (!upload) {\n        if (r.url) {\n          void this.channelService.deleteAttachment(r);\n        }\n        return;\n      }\n      upload.state = r.state;\n      upload.url = r.url;\n      if (upload.state === 'error') {\n        this.notificationService.addTemporaryNotification(\n          upload.type === 'image'\n            ? 'streamChat.Error uploading image'\n            : 'streamChat.Error uploading file'\n        );\n      }\n    });\n    this.attachmentUploadInProgressCounterSubject.next(\n      this.attachmentUploadInProgressCounterSubject.getValue() - 1\n    );\n    this.attachmentUploadsSubject.next([...attachmentUploads]);\n  }\n}\n"]}