@bizdoc/core 1.13.21 → 1.13.25

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 (133) hide show
  1. package/assets/i18n/cldr-data/main/ar/ca-buddhist.json +530 -0
  2. package/assets/i18n/cldr-data/main/ar/ca-chinese.json +1254 -0
  3. package/assets/i18n/cldr-data/main/ar/ca-coptic.json +539 -0
  4. package/assets/i18n/cldr-data/main/ar/ca-dangi.json +1254 -0
  5. package/assets/i18n/cldr-data/main/ar/ca-ethiopic-amete-alem.json +536 -0
  6. package/assets/i18n/cldr-data/main/ar/ca-ethiopic.json +539 -0
  7. package/assets/i18n/cldr-data/main/ar/ca-generic.json +533 -0
  8. package/assets/i18n/cldr-data/main/ar/ca-gregorian.json +557 -0
  9. package/assets/i18n/cldr-data/main/ar/ca-hebrew.json +542 -0
  10. package/assets/i18n/cldr-data/main/ar/ca-indian.json +530 -0
  11. package/assets/i18n/cldr-data/main/ar/ca-islamic-civil.json +530 -0
  12. package/assets/i18n/cldr-data/main/ar/ca-islamic-rgsa.json +530 -0
  13. package/assets/i18n/cldr-data/main/ar/ca-islamic-tbla.json +530 -0
  14. package/assets/i18n/cldr-data/main/ar/ca-islamic-umalqura.json +530 -0
  15. package/assets/i18n/cldr-data/main/ar/ca-islamic.json +530 -0
  16. package/assets/i18n/cldr-data/main/ar/ca-japanese.json +1238 -0
  17. package/assets/i18n/cldr-data/main/ar/ca-persian.json +530 -0
  18. package/assets/i18n/cldr-data/main/ar/ca-roc.json +533 -0
  19. package/assets/i18n/cldr-data/main/ar/characters.json +52 -0
  20. package/assets/i18n/cldr-data/main/ar/currencies.json +2306 -0
  21. package/assets/i18n/cldr-data/main/ar/dateFields.json +1039 -0
  22. package/assets/i18n/cldr-data/main/ar/delimiters.json +18 -0
  23. package/assets/i18n/cldr-data/main/ar/languages.json +556 -0
  24. package/assets/i18n/cldr-data/main/ar/layout.json +18 -0
  25. package/assets/i18n/cldr-data/main/ar/listPatterns.json +68 -0
  26. package/assets/i18n/cldr-data/main/ar/localeDisplayNames.json +230 -0
  27. package/assets/i18n/cldr-data/main/ar/measurementSystemNames.json +19 -0
  28. package/assets/i18n/cldr-data/main/ar/numbers.json +511 -0
  29. package/assets/i18n/cldr-data/main/ar/posix.json +18 -0
  30. package/assets/i18n/cldr-data/main/ar/scripts.json +202 -0
  31. package/assets/i18n/cldr-data/main/ar/territories.json +324 -0
  32. package/assets/i18n/cldr-data/main/ar/timeZoneNames.json +2268 -0
  33. package/assets/i18n/cldr-data/main/ar/units.json +4587 -0
  34. package/assets/i18n/cldr-data/main/ar/variants.json +119 -0
  35. package/assets/i18n/cldr-data/main/de/ca-buddhist.json +530 -0
  36. package/assets/i18n/cldr-data/main/de/ca-chinese.json +1254 -0
  37. package/assets/i18n/cldr-data/main/de/ca-coptic.json +539 -0
  38. package/assets/i18n/cldr-data/main/de/ca-dangi.json +1254 -0
  39. package/assets/i18n/cldr-data/main/de/ca-ethiopic-amete-alem.json +536 -0
  40. package/assets/i18n/cldr-data/main/de/ca-ethiopic.json +539 -0
  41. package/assets/i18n/cldr-data/main/de/ca-generic.json +533 -0
  42. package/assets/i18n/cldr-data/main/de/ca-gregorian.json +551 -0
  43. package/assets/i18n/cldr-data/main/de/ca-hebrew.json +542 -0
  44. package/assets/i18n/cldr-data/main/de/ca-indian.json +530 -0
  45. package/assets/i18n/cldr-data/main/de/ca-islamic-civil.json +530 -0
  46. package/assets/i18n/cldr-data/main/de/ca-islamic-rgsa.json +530 -0
  47. package/assets/i18n/cldr-data/main/de/ca-islamic-tbla.json +530 -0
  48. package/assets/i18n/cldr-data/main/de/ca-islamic-umalqura.json +530 -0
  49. package/assets/i18n/cldr-data/main/de/ca-islamic.json +530 -0
  50. package/assets/i18n/cldr-data/main/de/ca-japanese.json +1238 -0
  51. package/assets/i18n/cldr-data/main/de/ca-persian.json +530 -0
  52. package/assets/i18n/cldr-data/main/de/ca-roc.json +533 -0
  53. package/assets/i18n/cldr-data/main/de/characters.json +52 -0
  54. package/assets/i18n/cldr-data/main/de/contextTransforms.json +18 -0
  55. package/assets/i18n/cldr-data/main/de/currencies.json +1932 -0
  56. package/assets/i18n/cldr-data/main/de/dateFields.json +679 -0
  57. package/assets/i18n/cldr-data/main/de/delimiters.json +18 -0
  58. package/assets/i18n/cldr-data/main/de/languages.json +640 -0
  59. package/assets/i18n/cldr-data/main/de/layout.json +18 -0
  60. package/assets/i18n/cldr-data/main/de/listPatterns.json +68 -0
  61. package/assets/i18n/cldr-data/main/de/localeDisplayNames.json +230 -0
  62. package/assets/i18n/cldr-data/main/de/measurementSystemNames.json +19 -0
  63. package/assets/i18n/cldr-data/main/de/numbers.json +155 -0
  64. package/assets/i18n/cldr-data/main/de/posix.json +18 -0
  65. package/assets/i18n/cldr-data/main/de/scripts.json +209 -0
  66. package/assets/i18n/cldr-data/main/de/territories.json +324 -0
  67. package/assets/i18n/cldr-data/main/de/timeZoneNames.json +2332 -0
  68. package/assets/i18n/cldr-data/main/de/units.json +2546 -0
  69. package/assets/i18n/cldr-data/main/de/variants.json +119 -0
  70. package/assets/i18n/cldr-data/main/ru/ca-buddhist.json +524 -0
  71. package/assets/i18n/cldr-data/main/ru/ca-chinese.json +1248 -0
  72. package/assets/i18n/cldr-data/main/ru/ca-coptic.json +533 -0
  73. package/assets/i18n/cldr-data/main/ru/ca-dangi.json +1248 -0
  74. package/assets/i18n/cldr-data/main/ru/ca-ethiopic-amete-alem.json +530 -0
  75. package/assets/i18n/cldr-data/main/ru/ca-ethiopic.json +533 -0
  76. package/assets/i18n/cldr-data/main/ru/ca-generic.json +527 -0
  77. package/assets/i18n/cldr-data/main/ru/ca-gregorian.json +546 -0
  78. package/assets/i18n/cldr-data/main/ru/ca-hebrew.json +536 -0
  79. package/assets/i18n/cldr-data/main/ru/ca-indian.json +524 -0
  80. package/assets/i18n/cldr-data/main/ru/ca-islamic-civil.json +524 -0
  81. package/assets/i18n/cldr-data/main/ru/ca-islamic-rgsa.json +524 -0
  82. package/assets/i18n/cldr-data/main/ru/ca-islamic-tbla.json +524 -0
  83. package/assets/i18n/cldr-data/main/ru/ca-islamic-umalqura.json +524 -0
  84. package/assets/i18n/cldr-data/main/ru/ca-islamic.json +524 -0
  85. package/assets/i18n/cldr-data/main/ru/ca-japanese.json +1232 -0
  86. package/assets/i18n/cldr-data/main/ru/ca-persian.json +524 -0
  87. package/assets/i18n/cldr-data/main/ru/ca-roc.json +527 -0
  88. package/assets/i18n/cldr-data/main/ru/characters.json +52 -0
  89. package/assets/i18n/cldr-data/main/ru/contextTransforms.json +62 -0
  90. package/assets/i18n/cldr-data/main/ru/currencies.json +2001 -0
  91. package/assets/i18n/cldr-data/main/ru/dateFields.json +859 -0
  92. package/assets/i18n/cldr-data/main/ru/delimiters.json +18 -0
  93. package/assets/i18n/cldr-data/main/ru/languages.json +557 -0
  94. package/assets/i18n/cldr-data/main/ru/layout.json +18 -0
  95. package/assets/i18n/cldr-data/main/ru/listPatterns.json +68 -0
  96. package/assets/i18n/cldr-data/main/ru/localeDisplayNames.json +230 -0
  97. package/assets/i18n/cldr-data/main/ru/measurementSystemNames.json +19 -0
  98. package/assets/i18n/cldr-data/main/ru/numbers.json +231 -0
  99. package/assets/i18n/cldr-data/main/ru/posix.json +18 -0
  100. package/assets/i18n/cldr-data/main/ru/scripts.json +209 -0
  101. package/assets/i18n/cldr-data/main/ru/territories.json +324 -0
  102. package/assets/i18n/cldr-data/main/ru/timeZoneNames.json +2317 -0
  103. package/assets/i18n/cldr-data/main/ru/units.json +3647 -0
  104. package/assets/i18n/cldr-data/main/ru/variants.json +119 -0
  105. package/esm2020/lib/compose/action/assign-action.component.mjs +2 -1
  106. package/esm2020/lib/compose/action/moveto-action.component.mjs +88 -0
  107. package/esm2020/lib/compose/attachments/preview/attachment-preview.component.mjs +6 -6
  108. package/esm2020/lib/core/controls/file.input.mjs +3 -3
  109. package/esm2020/lib/core/info/attachment-info.service.mjs +1 -1
  110. package/esm2020/lib/core/mailbox.service.mjs +3 -3
  111. package/esm2020/lib/core/session.service.mjs +12 -10
  112. package/esm2020/lib/core/translate.service.mjs +18 -10
  113. package/esm2020/lib/core/translations.mjs +15 -7
  114. package/esm2020/lib/cube/cube.service.mjs +1 -1
  115. package/esm2020/lib/cube/grid/spreadsheet.component.mjs +2 -2
  116. package/esm2020/lib/cube/matrix/table.component.mjs +5 -3
  117. package/esm2020/lib/cube/view.pane.component.mjs +3 -3
  118. package/esm2020/lib/reports/report.mobile.component.mjs +11 -3
  119. package/esm2020/lib/reports/report.pane.component.mjs +1 -1
  120. package/esm2020/lib/shared.module.mjs +5 -4
  121. package/fesm2015/bizdoc-core.mjs +181 -87
  122. package/fesm2015/bizdoc-core.mjs.map +1 -1
  123. package/fesm2020/bizdoc-core.mjs +181 -87
  124. package/fesm2020/bizdoc-core.mjs.map +1 -1
  125. package/lib/compose/action/moveto-action.component.d.ts +36 -0
  126. package/lib/core/mailbox.service.d.ts +1 -1
  127. package/lib/core/translate.service.d.ts +3 -0
  128. package/lib/core/translations.d.ts +14 -6
  129. package/lib/cube/cube.service.d.ts +1 -1
  130. package/lib/reports/report.mobile.component.d.ts +3 -0
  131. package/lib/reports/report.pane.component.d.ts +1 -1
  132. package/lib/shared.module.d.ts +112 -111
  133. package/package.json +11 -11
@@ -0,0 +1,119 @@
1
+ {
2
+ "main": {
3
+ "ru": {
4
+ "identity": {
5
+ "version": {
6
+ "_cldrVersion": "36"
7
+ },
8
+ "language": "ru"
9
+ },
10
+ "localeDisplayNames": {
11
+ "variants": {
12
+ "1901": "Традиционная немецкая орфография",
13
+ "1994": "Стандартизированная резьянская орфография",
14
+ "1996": "Правила немецкой орфографии установленные с 1996 года",
15
+ "1606NICT": "Поздне-средневековый французский до 1606 г.",
16
+ "1694ACAD": "1694ACAD",
17
+ "1959ACAD": "1959ACAD",
18
+ "ABL1943": "ABL1943",
19
+ "AKUAPEM": "AKUAPEM",
20
+ "ALALC97": "ALALC97",
21
+ "ALUKU": "ALUKU",
22
+ "AO1990": "AO1990",
23
+ "ARANES": "ARANES",
24
+ "AREVELA": "Восточно-армянский",
25
+ "AREVMDA": "Западно-армянский",
26
+ "ASANTE": "ASANTE",
27
+ "AUVERN": "AUVERN",
28
+ "BAKU1926": "Унифицированный тюрско-латинский алфавит",
29
+ "BALANKA": "BALANKA",
30
+ "BARLA": "BARLA",
31
+ "BASICENG": "BASICENG",
32
+ "BAUDDHA": "BAUDDHA",
33
+ "BISCAYAN": "BISCAYAN",
34
+ "BISKE": "BISKE",
35
+ "BOHORIC": "BOHORIC",
36
+ "BOONT": "BOONT",
37
+ "BORNHOLM": "BORNHOLM",
38
+ "CISAUP": "CISAUP",
39
+ "COLB1945": "COLB1945",
40
+ "CORNU": "CORNU",
41
+ "CREISS": "CREISS",
42
+ "DAJNKO": "DAJNKO",
43
+ "EKAVSK": "EKAVSK",
44
+ "EMODENG": "EMODENG",
45
+ "FONIPA": "Международный фонетический алфавит",
46
+ "FONKIRSH": "FONKIRSH",
47
+ "FONNAPA": "FONNAPA",
48
+ "FONUPA": "FONUPA",
49
+ "FONXSAMP": "FONXSAMP",
50
+ "GASCON": "GASCON",
51
+ "GRCLASS": "GRCLASS",
52
+ "GRITAL": "GRITAL",
53
+ "GRMISTR": "GRMISTR",
54
+ "HEPBURN": "HEPBURN",
55
+ "HOGNORSK": "HOGNORSK",
56
+ "HSISTEMO": "HSISTEMO",
57
+ "IJEKAVSK": "IJEKAVSK",
58
+ "ITIHASA": "ITIHASA",
59
+ "IVANCHOV": "IVANCHOV",
60
+ "JAUER": "JAUER",
61
+ "JYUTPING": "JYUTPING",
62
+ "KKCOR": "KKCOR",
63
+ "KOCIEWIE": "KOCIEWIE",
64
+ "KSCOR": "KSCOR",
65
+ "LAUKIKA": "LAUKIKA",
66
+ "LEMOSIN": "LEMOSIN",
67
+ "LENGADOC": "LENGADOC",
68
+ "LIPAW": "LIPAW",
69
+ "LUNA1918": "LUNA1918",
70
+ "METELKO": "METELKO",
71
+ "MONOTON": "Монотонный",
72
+ "NDYUKA": "NDYUKA",
73
+ "NEDIS": "NEDIS",
74
+ "NEWFOUND": "NEWFOUND",
75
+ "NICARD": "NICARD",
76
+ "NJIVA": "NJIVA",
77
+ "NULIK": "NULIK",
78
+ "OSOJS": "OSOJS",
79
+ "OXENDICT": "OXENDICT",
80
+ "PAHAWH2": "PAHAWH2",
81
+ "PAHAWH3": "PAHAWH3",
82
+ "PAHAWH4": "PAHAWH4",
83
+ "PAMAKA": "PAMAKA",
84
+ "PETR1708": "PETR1708",
85
+ "PINYIN": "Пиньинь",
86
+ "POLYTON": "Многотональный",
87
+ "POSIX": "Компьютерный",
88
+ "PROVENC": "PROVENC",
89
+ "PUTER": "PUTER",
90
+ "REVISED": "REVISED",
91
+ "RIGIK": "RIGIK",
92
+ "ROZAJ": "Резьянский",
93
+ "RUMGR": "RUMGR",
94
+ "SAAHO": "Сахо",
95
+ "SCOTLAND": "Англо-шотландский",
96
+ "SCOUSE": "SCOUSE",
97
+ "SIMPLE": "SIMPLE",
98
+ "SOLBA": "SOLBA",
99
+ "SOTAV": "SOTAV",
100
+ "SPANGLIS": "SPANGLIS",
101
+ "SURMIRAN": "SURMIRAN",
102
+ "SURSILV": "SURSILV",
103
+ "SUTSILV": "SUTSILV",
104
+ "TARASK": "Тарашкевица",
105
+ "UCCOR": "UCCOR",
106
+ "UCRCOR": "UCRCOR",
107
+ "ULSTER": "ULSTER",
108
+ "UNIFON": "UNIFON",
109
+ "VAIDIKA": "VAIDIKA",
110
+ "VALENCIA": "Валенсийский",
111
+ "VALLADER": "VALLADER",
112
+ "VIVARAUP": "VIVARAUP",
113
+ "WADEGILE": "Система Уэйда – Джайлза",
114
+ "XSISTEMO": "XSISTEMO"
115
+ }
116
+ }
117
+ }
118
+ }
119
+ }
@@ -70,6 +70,7 @@ let AssignActionComponent = class AssignActionComponent {
70
70
  }
71
71
  ngOnDestroy() {
72
72
  this._destroy.next();
73
+ this._destroy.complete();
73
74
  }
74
75
  };
75
76
  AssignActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AssignActionComponent, deps: [{ token: i1.FormBuilder }, { token: i2.SessionService }, { token: i3.AccountService }], target: i0.ɵɵFactoryTarget.Component });
@@ -87,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
87
88
  type: ViewChild,
88
89
  args: ['nameInput', { static: true, read: ElementRef }]
89
90
  }] } });
90
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assign-action.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/compose/action/assign-action.component.ts","../../../../../../libraries/core/src/lib/compose/action/assign-action.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, Validators } from '@angular/forms';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\r\nimport { debounceTime, Observable, Subject } from 'rxjs';\r\nimport { takeUntil, filter, map, switchMap } from 'rxjs/operators';\r\nimport { isString } from '../../core/functions';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { UserInfo } from '../../core/models';\r\nimport { ArgumentsComponent } from '../../core/base';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { AccountService } from '../../core/account.service';\r\n\r\n@Component({\r\n  templateUrl: './assign-action.component.html'\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-action-assign'\r\n})\r\nexport class AssignActionComponent implements ArgumentsComponent, OnInit, OnDestroy {\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA];\r\n  @ViewChild('nameInput', { static: true, read: ElementRef }) nameInput: ElementRef<HTMLInputElement>;\r\n  readonly form = this._fb.group({\r\n    userIds: this._fb.control(null, Validators.required),\r\n    fyi: this._fb.control(false),\r\n    roundtrip: this._fb.control(false),\r\n    note: this._fb.control(null, Validators.maxLength(200))\r\n  });\r\n  readonly userIds = this._fb.control([]);\r\n  users$: Observable<UserInfo[]>;\r\n  private _destroy = new Subject<void>();\r\n  constructor(private _fb: FormBuilder, private _session: SessionService, private _accounts: AccountService) {\r\n  }\r\n  ngOnInit(): void {\r\n    const me = this._session.userId;\r\n    this.users$ = this.userIds.valueChanges.\r\n      pipe(\r\n        debounceTime(200),\r\n        takeUntil(this._destroy),\r\n        switchMap(v =>\r\n          this._accounts.findAll(v, { take: 20 }).\r\n            pipe(map(r =>\r\n              r.filter(u => u.id !== me)))));\r\n  }\r\n  /**\r\n   *\r\n   * @param inp\r\n   * @param event\r\n   */\r\n  userSelected(inp: HTMLInputElement, event: MatAutocompleteSelectedEvent): void {\r\n    const userIds = this.form.controls['userIds'].value as string[] || [];\r\n    userIds.push(event.option.value);\r\n    this.form.controls['userIds'].setValue(userIds);\r\n    inp.value = '';\r\n  }\r\n  /**\r\n   *\r\n   * @param id\r\n   */\r\n  removed(id: string): void {\r\n    const userIds = this.form.controls['userIds'].value as string[];\r\n\r\n    const index = userIds.indexOf(id);\r\n\r\n    if (userIds.length > 1) {\r\n      index >= 0 &&\r\n        userIds.splice(index, 1);\r\n\r\n      this.form.updateValueAndValidity();\r\n    }\r\n    else \r\n      this.form.controls['userIds'].setValue(null);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n  }\r\n}\r\n","<form autocomplete=\"off\" fxLayout=\"column\" [formGroup]=\"form\">\r\n  <mat-form-field>\r\n    <mat-chip-list #chipList [attr.aria-label]=\"'AssignTo'|translate\">\r\n      <mat-chip *ngFor=\"let u of form.value.userIds\"\r\n                [selectable]=\"true\"\r\n                [removable]=\"true\"\r\n                (removed)=\"removed(u)\">\r\n        {{u | userName | async }}\r\n        <mat-icon matChipRemove>cancel</mat-icon>\r\n      </mat-chip>\r\n      <input required [placeholder]=\"'AssignTo'|translate\"\r\n             [formControl]=userIds\r\n             cdkFocusInitial \r\n             #nameInput\r\n             [matAutocomplete]=\"auto\"\r\n             [matChipInputFor]=\"chipList\"\r\n             [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n    </mat-chip-list>\r\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"userSelected(nameInput, $event)\">\r\n      <mat-option *ngFor=\"let u of users$ | async\" [value]=\"u.id\">\r\n        {{u.name}}\r\n        <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n      </mat-option>\r\n    </mat-autocomplete>\r\n    <mat-error *ngIf=\"form.controls.userIds.hasError('required')\">{{'Required'|translate:('AssignTo'|translate)}}</mat-error>\r\n  </mat-form-field>\r\n  <mat-checkbox formControlName=fyi> {{ 'AssignFYI' | translate }}</mat-checkbox>\r\n  <!--<mat-checkbox formControlName=roundtrip> {{ 'AssignRoundtrip' | translate }}</mat-checkbox>-->\r\n  <mat-form-field>\r\n    <textarea matInput cdkTextareaAutosize formControlName=\"note\" [placeholder]=\"'Note'|translate\" maxlength=\"200\">\r\n    </textarea>\r\n    <mat-hint align=\"end\">{{form.controls['note'].value?.length || 0}} / {{200}}</mat-hint>\r\n    <mat-hint>{{'AssignNoteHint'| translate}}</mat-hint>\r\n  </mat-form-field>\r\n</form>\r\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"assign-action.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/compose/action/assign-action.component.ts","../../../../../../libraries/core/src/lib/compose/action/assign-action.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, Validators } from '@angular/forms';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\r\nimport { debounceTime, Observable, Subject } from 'rxjs';\r\nimport { takeUntil, map, switchMap } from 'rxjs/operators';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { UserInfo } from '../../core/models';\r\nimport { ArgumentsComponent } from '../../core/base';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { AccountService } from '../../core/account.service';\r\n\r\n@Component({\r\n  templateUrl: './assign-action.component.html'\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-action-assign'\r\n})\r\nexport class AssignActionComponent implements ArgumentsComponent, OnInit, OnDestroy {\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA];\r\n  @ViewChild('nameInput', { static: true, read: ElementRef }) nameInput: ElementRef<HTMLInputElement>;\r\n  readonly form = this._fb.group({\r\n    userIds: this._fb.control(null, Validators.required),\r\n    fyi: this._fb.control(false),\r\n    roundtrip: this._fb.control(false),\r\n    note: this._fb.control(null, Validators.maxLength(200))\r\n  });\r\n  readonly userIds = this._fb.control([]);\r\n  users$: Observable<UserInfo[]>;\r\n  private _destroy = new Subject<void>();\r\n  constructor(private _fb: FormBuilder, private _session: SessionService, private _accounts: AccountService) {\r\n  }\r\n  ngOnInit(): void {\r\n    const me = this._session.userId;\r\n    this.users$ = this.userIds.valueChanges.\r\n      pipe(\r\n        debounceTime(200),\r\n        takeUntil(this._destroy),\r\n        switchMap(v =>\r\n          this._accounts.findAll(v, { take: 20 }).\r\n            pipe(map(r =>\r\n              r.filter(u => u.id !== me)))));\r\n  }\r\n  /**\r\n   *\r\n   * @param inp\r\n   * @param event\r\n   */\r\n  userSelected(inp: HTMLInputElement, event: MatAutocompleteSelectedEvent): void {\r\n    const userIds = this.form.controls['userIds'].value as string[] || [];\r\n    userIds.push(event.option.value);\r\n    this.form.controls['userIds'].setValue(userIds);\r\n    inp.value = '';\r\n  }\r\n  /**\r\n   *\r\n   * @param id\r\n   */\r\n  removed(id: string): void {\r\n    const userIds = this.form.controls['userIds'].value as string[];\r\n\r\n    const index = userIds.indexOf(id);\r\n\r\n    if (userIds.length > 1) {\r\n      index >= 0 &&\r\n        userIds.splice(index, 1);\r\n\r\n      this.form.updateValueAndValidity();\r\n    }\r\n    else \r\n      this.form.controls['userIds'].setValue(null);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<form autocomplete=\"off\" fxLayout=\"column\" [formGroup]=\"form\">\r\n  <mat-form-field>\r\n    <mat-chip-list #chipList [attr.aria-label]=\"'AssignTo'|translate\">\r\n      <mat-chip *ngFor=\"let u of form.value.userIds\"\r\n                [selectable]=\"true\"\r\n                [removable]=\"true\"\r\n                (removed)=\"removed(u)\">\r\n        {{u | userName | async }}\r\n        <mat-icon matChipRemove>cancel</mat-icon>\r\n      </mat-chip>\r\n      <input required [placeholder]=\"'AssignTo'|translate\"\r\n             [formControl]=userIds\r\n             cdkFocusInitial \r\n             #nameInput\r\n             [matAutocomplete]=\"auto\"\r\n             [matChipInputFor]=\"chipList\"\r\n             [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n    </mat-chip-list>\r\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"userSelected(nameInput, $event)\">\r\n      <mat-option *ngFor=\"let u of users$ | async\" [value]=\"u.id\">\r\n        {{u.name}}\r\n        <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n      </mat-option>\r\n    </mat-autocomplete>\r\n    <mat-error *ngIf=\"form.controls.userIds.hasError('required')\">{{'Required'|translate:('AssignTo'|translate)}}</mat-error>\r\n  </mat-form-field>\r\n  <mat-checkbox formControlName=fyi> {{ 'AssignFYI' | translate }}</mat-checkbox>\r\n  <!--<mat-checkbox formControlName=roundtrip> {{ 'AssignRoundtrip' | translate }}</mat-checkbox>-->\r\n  <mat-form-field>\r\n    <textarea matInput cdkTextareaAutosize formControlName=\"note\" [placeholder]=\"'Note'|translate\" maxlength=\"200\">\r\n    </textarea>\r\n    <mat-hint align=\"end\">{{form.controls['note'].value?.length || 0}} / {{200}}</mat-hint>\r\n    <mat-hint>{{'AssignNoteHint'| translate}}</mat-hint>\r\n  </mat-form-field>\r\n</form>\r\n"]}
@@ -0,0 +1,88 @@
1
+ import { __decorate } from "tslib";
2
+ import { Component, ElementRef, ViewChild } from '@angular/core';
3
+ import { Validators } from '@angular/forms';
4
+ import { COMMA, ENTER } from '@angular/cdk/keycodes';
5
+ import { debounceTime, Subject } from 'rxjs';
6
+ import { takeUntil, map, switchMap } from 'rxjs/operators';
7
+ import { BizDoc } from '../../core/decorators';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/forms";
10
+ import * as i2 from "../../core/session.service";
11
+ import * as i3 from "../../core/account.service";
12
+ import * as i4 from "@angular/material/form-field";
13
+ import * as i5 from "@angular/material/chips";
14
+ import * as i6 from "@angular/material/icon";
15
+ import * as i7 from "@angular/material/autocomplete";
16
+ import * as i8 from "@angular/material/core";
17
+ import * as i9 from "@angular/flex-layout/flex";
18
+ import * as i10 from "@angular/common";
19
+ import * as i11 from "@angular/material/input";
20
+ import * as i12 from "@angular/cdk/text-field";
21
+ import * as i13 from "../../core/pipes/translate.pipe";
22
+ import * as i14 from "../../core/pipes/user-name.pipe";
23
+ let MoveToActionComponent = class MoveToActionComponent {
24
+ constructor(_fb, _session, _accounts) {
25
+ this._fb = _fb;
26
+ this._session = _session;
27
+ this._accounts = _accounts;
28
+ this.separatorKeysCodes = [ENTER, COMMA];
29
+ this.form = this._fb.group({
30
+ userIds: this._fb.control(null, Validators.required),
31
+ note: this._fb.control(null, Validators.maxLength(200))
32
+ });
33
+ this.userIds = this._fb.control([]);
34
+ this._destroy = new Subject();
35
+ }
36
+ ngOnInit() {
37
+ const me = this._session.userId;
38
+ this.users$ = this.userIds.valueChanges.
39
+ pipe(debounceTime(200), takeUntil(this._destroy), switchMap(v => this._accounts.findAll(v, { take: 20 }).
40
+ pipe(map(r => r.filter(u => u.id !== me)))));
41
+ }
42
+ /**
43
+ *
44
+ * @param inp
45
+ * @param event
46
+ */
47
+ userSelected(inp, event) {
48
+ const userIds = this.form.controls['userIds'].value || [];
49
+ userIds.push(event.option.value);
50
+ this.form.controls['userIds'].setValue(userIds);
51
+ inp.value = '';
52
+ }
53
+ /**
54
+ *
55
+ * @param id
56
+ */
57
+ removed(id) {
58
+ const userIds = this.form.controls['userIds'].value;
59
+ const index = userIds.indexOf(id);
60
+ if (userIds.length > 1) {
61
+ index >= 0 &&
62
+ userIds.splice(index, 1);
63
+ this.form.updateValueAndValidity();
64
+ }
65
+ else
66
+ this.form.controls['userIds'].setValue(null);
67
+ }
68
+ ngOnDestroy() {
69
+ this._destroy.next();
70
+ this._destroy.complete();
71
+ }
72
+ };
73
+ MoveToActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: MoveToActionComponent, deps: [{ token: i1.FormBuilder }, { token: i2.SessionService }, { token: i3.AccountService }], target: i0.ɵɵFactoryTarget.Component });
74
+ MoveToActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: MoveToActionComponent, selector: "ng-component", viewQueries: [{ propertyName: "nameInput", first: true, predicate: ["nameInput"], descendants: true, read: ElementRef, static: true }], ngImport: i0, template: "<form autocomplete=\"off\" fxLayout=\"column\" [formGroup]=\"form\">\r\n <mat-form-field>\r\n <mat-chip-list #chipList [attr.aria-label]=\"'AssignTo'|translate\">\r\n <mat-chip *ngFor=\"let u of form.value.userIds\"\r\n [selectable]=\"true\"\r\n [removable]=\"true\"\r\n (removed)=\"removed(u)\">\r\n {{u | userName | async }}\r\n <mat-icon matChipRemove>cancel</mat-icon>\r\n </mat-chip>\r\n <input required [placeholder]=\"'AssignTo'|translate\"\r\n [formControl]=userIds\r\n cdkFocusInitial \r\n #nameInput\r\n [matAutocomplete]=\"auto\"\r\n [matChipInputFor]=\"chipList\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n </mat-chip-list>\r\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"userSelected(nameInput, $event)\">\r\n <mat-option *ngFor=\"let u of users$ | async\" [value]=\"u.id\">\r\n {{u.name}}\r\n <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-error *ngIf=\"form.controls.userIds.hasError('required')\">{{'Required'|translate:('AssignTo'|translate)}}</mat-error>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <textarea matInput cdkTextareaAutosize formControlName=\"note\" [placeholder]=\"'Note'|translate\" maxlength=\"200\">\r\n </textarea>\r\n <mat-hint align=\"end\">{{form.controls['note'].value?.length || 0}} / {{200}}</mat-hint>\r\n <mat-hint>{{'AssignNoteHint'| translate}}</mat-hint>\r\n </mat-form-field>\r\n</form>\r\n", components: [{ type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i5.MatChipList, selector: "mat-chip-list", inputs: ["errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i8.MatOption, selector: "mat-option", exportAs: ["matOption"] }], directives: [{ type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i9.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { type: i5.MatChipRemove, selector: "[matChipRemove]" }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i7.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i5.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.MatError, selector: "mat-error", inputs: ["id"] }, { type: i11.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i12.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i4.MatHint, selector: "mat-hint", inputs: ["align", "id"] }], pipes: { "translate": i13.TranslatePipe, "async": i10.AsyncPipe, "userName": i14.UserNamePipe } });
75
+ MoveToActionComponent = __decorate([
76
+ BizDoc({
77
+ selector: 'bizdoc-action-moveto'
78
+ })
79
+ ], MoveToActionComponent);
80
+ export { MoveToActionComponent };
81
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: MoveToActionComponent, decorators: [{
82
+ type: Component,
83
+ args: [{ template: "<form autocomplete=\"off\" fxLayout=\"column\" [formGroup]=\"form\">\r\n <mat-form-field>\r\n <mat-chip-list #chipList [attr.aria-label]=\"'AssignTo'|translate\">\r\n <mat-chip *ngFor=\"let u of form.value.userIds\"\r\n [selectable]=\"true\"\r\n [removable]=\"true\"\r\n (removed)=\"removed(u)\">\r\n {{u | userName | async }}\r\n <mat-icon matChipRemove>cancel</mat-icon>\r\n </mat-chip>\r\n <input required [placeholder]=\"'AssignTo'|translate\"\r\n [formControl]=userIds\r\n cdkFocusInitial \r\n #nameInput\r\n [matAutocomplete]=\"auto\"\r\n [matChipInputFor]=\"chipList\"\r\n [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n </mat-chip-list>\r\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"userSelected(nameInput, $event)\">\r\n <mat-option *ngFor=\"let u of users$ | async\" [value]=\"u.id\">\r\n {{u.name}}\r\n <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-error *ngIf=\"form.controls.userIds.hasError('required')\">{{'Required'|translate:('AssignTo'|translate)}}</mat-error>\r\n </mat-form-field>\r\n <mat-form-field>\r\n <textarea matInput cdkTextareaAutosize formControlName=\"note\" [placeholder]=\"'Note'|translate\" maxlength=\"200\">\r\n </textarea>\r\n <mat-hint align=\"end\">{{form.controls['note'].value?.length || 0}} / {{200}}</mat-hint>\r\n <mat-hint>{{'AssignNoteHint'| translate}}</mat-hint>\r\n </mat-form-field>\r\n</form>\r\n" }]
84
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.SessionService }, { type: i3.AccountService }]; }, propDecorators: { nameInput: [{
85
+ type: ViewChild,
86
+ args: ['nameInput', { static: true, read: ElementRef }]
87
+ }] } });
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"moveto-action.component.js","sourceRoot":"","sources":["../../../../../../libraries/core/src/lib/compose/action/moveto-action.component.ts","../../../../../../libraries/core/src/lib/compose/action/moveto-action.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, Validators } from '@angular/forms';\r\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\r\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\r\nimport { debounceTime, Observable, Subject } from 'rxjs';\r\nimport { takeUntil, map, switchMap } from 'rxjs/operators';\r\nimport { BizDoc } from '../../core/decorators';\r\nimport { UserInfo } from '../../core/models';\r\nimport { ArgumentsComponent } from '../../core/base';\r\nimport { SessionService } from '../../core/session.service';\r\nimport { AccountService } from '../../core/account.service';\r\n\r\n@Component({\r\n  templateUrl: './moveto-action.component.html'\r\n})\r\n@BizDoc({\r\n  selector: 'bizdoc-action-moveto'\r\n})\r\nexport class MoveToActionComponent implements ArgumentsComponent, OnInit, OnDestroy {\r\n  readonly separatorKeysCodes: number[] = [ENTER, COMMA];\r\n  @ViewChild('nameInput', { static: true, read: ElementRef }) nameInput: ElementRef<HTMLInputElement>;\r\n  readonly form = this._fb.group({\r\n    userIds: this._fb.control(null, Validators.required),\r\n    note: this._fb.control(null, Validators.maxLength(200))\r\n  });\r\n  readonly userIds = this._fb.control([]);\r\n  users$: Observable<UserInfo[]>;\r\n  private _destroy = new Subject<void>();\r\n  constructor(private _fb: FormBuilder, private _session: SessionService, private _accounts: AccountService) {\r\n  }\r\n  ngOnInit(): void {\r\n    const me = this._session.userId;\r\n    this.users$ = this.userIds.valueChanges.\r\n      pipe(\r\n        debounceTime(200),\r\n        takeUntil(this._destroy),\r\n        switchMap(v =>\r\n          this._accounts.findAll(v, { take: 20 }).\r\n            pipe(map(r =>\r\n              r.filter(u => u.id !== me)))));\r\n  }\r\n  /**\r\n   *\r\n   * @param inp\r\n   * @param event\r\n   */\r\n  userSelected(inp: HTMLInputElement, event: MatAutocompleteSelectedEvent): void {\r\n    const userIds = this.form.controls['userIds'].value as string[] || [];\r\n    userIds.push(event.option.value);\r\n    this.form.controls['userIds'].setValue(userIds);\r\n    inp.value = '';\r\n  }\r\n  /**\r\n   *\r\n   * @param id\r\n   */\r\n  removed(id: string): void {\r\n    const userIds = this.form.controls['userIds'].value as string[];\r\n\r\n    const index = userIds.indexOf(id);\r\n\r\n    if (userIds.length > 1) {\r\n      index >= 0 &&\r\n        userIds.splice(index, 1);\r\n\r\n      this.form.updateValueAndValidity();\r\n    }\r\n    else \r\n      this.form.controls['userIds'].setValue(null);\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<form autocomplete=\"off\" fxLayout=\"column\" [formGroup]=\"form\">\r\n  <mat-form-field>\r\n    <mat-chip-list #chipList [attr.aria-label]=\"'AssignTo'|translate\">\r\n      <mat-chip *ngFor=\"let u of form.value.userIds\"\r\n                [selectable]=\"true\"\r\n                [removable]=\"true\"\r\n                (removed)=\"removed(u)\">\r\n        {{u | userName | async }}\r\n        <mat-icon matChipRemove>cancel</mat-icon>\r\n      </mat-chip>\r\n      <input required [placeholder]=\"'AssignTo'|translate\"\r\n             [formControl]=userIds\r\n             cdkFocusInitial \r\n             #nameInput\r\n             [matAutocomplete]=\"auto\"\r\n             [matChipInputFor]=\"chipList\"\r\n             [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\">\r\n    </mat-chip-list>\r\n    <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"userSelected(nameInput, $event)\">\r\n      <mat-option *ngFor=\"let u of users$ | async\" [value]=\"u.id\">\r\n        {{u.name}}\r\n        <span *ngIf=\"u.email\">&nbsp; - {{u.email}}</span>\r\n      </mat-option>\r\n    </mat-autocomplete>\r\n    <mat-error *ngIf=\"form.controls.userIds.hasError('required')\">{{'Required'|translate:('AssignTo'|translate)}}</mat-error>\r\n  </mat-form-field>\r\n  <mat-form-field>\r\n    <textarea matInput cdkTextareaAutosize formControlName=\"note\" [placeholder]=\"'Note'|translate\" maxlength=\"200\">\r\n    </textarea>\r\n    <mat-hint align=\"end\">{{form.controls['note'].value?.length || 0}} / {{200}}</mat-hint>\r\n    <mat-hint>{{'AssignNoteHint'| translate}}</mat-hint>\r\n  </mat-form-field>\r\n</form>\r\n"]}
@@ -34,7 +34,7 @@ export class AttachmentPreview {
34
34
  this._afterClosed = new Subject();
35
35
  this.dir = _directionality.value;
36
36
  this.isImage = isImage(this.data.file.contentType);
37
- this.objectData = sanitizer.bypassSecurityTrustResourceUrl(this._url());
37
+ this.objectData = sanitizer.bypassSecurityTrustResourceUrl(this._url(true));
38
38
  this.beforeClose().subscribe(() => this.slideDown = 'leave');
39
39
  }
40
40
  resize() {
@@ -52,8 +52,8 @@ export class AttachmentPreview {
52
52
  download() {
53
53
  location.assign(this._url());
54
54
  }
55
- _url() {
56
- return this._service.formatDownloadUrl(this.data.documentId, this.data.file.id);
55
+ _url(inline) {
56
+ return this._service.formatDownloadUrl(this.data.documentId, this.data.file.id, inline);
57
57
  }
58
58
  rotate() {
59
59
  const elem = (this.isImage ? this.img : this.obj).nativeElement;
@@ -96,7 +96,7 @@ export class AttachmentPreview {
96
96
  }
97
97
  }
98
98
  AttachmentPreview.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AttachmentPreview, deps: [{ token: i1.Directionality }, { token: i0.Renderer2 }, { token: FILE_PREVIEW_DIALOG_DATA }, { token: i2.DomSanitizer }, { token: i3.MailboxService }, { token: i4.OverlayRef }], target: i0.ɵɵFactoryTarget.Component });
99
- AttachmentPreview.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: AttachmentPreview, selector: "bizdoc-attachment-preview", host: { listeners: { "document:resize": "resize()", "document:keydown.escape": "close()" } }, viewQueries: [{ propertyName: "obj", first: true, predicate: ["obj"], descendants: true }, { propertyName: "img", first: true, predicate: ["img"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n [dir]=\"dir\" (@slideContent.done)=\"onAnimationDone($event)\">\r\n <div class=\"toolbar-wrapper\" fxLayout=\"row\" [@slideDown]=\"slideDown\" *ngIf=\"!loading\">\r\n <button mat-icon-button (click)=\"close()\" bizdocTooltip=\"{{'Back' | translate}}\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <span class=\"mat-body-1\">{{data.file.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"rotate()\" bizdocTooltip=\"{{'Rotate' | translate }}\"><mat-icon>screen_rotation</mat-icon></button>\r\n <button mat-icon-button (click)=\"download()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n </div>\r\n <div class=\"spinner-wrapper\" *ngIf=\"loading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n <object (load)=\"onLoad($event)\" [data]=\"objectData\" [type]=\"data.file.contentType\" *ngIf=\"!isImage\" #obj></object>\r\n <img *ngIf=\"isImage\" (load)=\"onLoad($event)\" [style.opacity]=\"loading ? 0 : 1\" [@fade]=\"loading ? 'fadeOut' : 'fadeIn'\" [src]=\"objectData\" #img>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;align-items:center}.spinner-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1}img{width:100%;max-width:500px;height:auto}.overlay-content{padding:1em}.overlay-content .toolbar-wrapper{align-items:center;color:#f5f5f5}.divider{flex:1 1 auto}\n"], components: [{ type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i1.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i10.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }], pipes: { "translate": i11.TranslatePipe }, animations: [
99
+ AttachmentPreview.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: AttachmentPreview, selector: "bizdoc-attachment-preview", host: { listeners: { "document:resize": "resize()", "document:keydown.escape": "close()" } }, viewQueries: [{ propertyName: "obj", first: true, predicate: ["obj"], descendants: true }, { propertyName: "img", first: true, predicate: ["img"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n [dir]=\"dir\" (@slideContent.done)=\"onAnimationDone($event)\">\r\n <div class=\"toolbar-wrapper\" fxLayout=\"row\" [@slideDown]=\"slideDown\" *ngIf=\"!loading\">\r\n <button mat-icon-button (click)=\"close()\" bizdocTooltip=\"{{'Back' | translate}}\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <span class=\"mat-body-1\">{{data.file.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"rotate()\" bizdocTooltip=\"{{'Rotate' | translate }}\"><mat-icon>screen_rotation</mat-icon></button>\r\n <button mat-icon-button (click)=\"download()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n </div>\r\n <div class=\"spinner-wrapper\" *ngIf=\"loading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n <object (load)=\"onLoad($event)\" [data]=\"objectData\" [type]=\"data.file.contentType\" *ngIf=\"!isImage\" #obj width=\"250\"\r\n height=\"200\">\r\n </object>\r\n <img *ngIf=\"isImage\" (load)=\"onLoad($event)\" [style.opacity]=\"loading ? 0 : 1\" [@fade]=\"loading ? 'fadeOut' : 'fadeIn'\" [src]=\"objectData\" #img>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;align-items:center}.spinner-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1}img{width:100%;max-width:500px;height:auto}.overlay-content{padding:1em}.overlay-content .toolbar-wrapper{align-items:center;color:#f5f5f5}.divider{flex:1 1 auto}\n"], components: [{ type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i1.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i10.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }], pipes: { "translate": i11.TranslatePipe }, animations: [
100
100
  trigger('fade', [
101
101
  state('fadeOut', style({ opacity: 0 })),
102
102
  state('fadeIn', style({ opacity: 1 })),
@@ -135,7 +135,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
135
135
  state('leave', style({ transform: 'translate3d(0, 25%, 0)', opacity: 0 })),
136
136
  transition('* => *', animate(ANIMATION_TIMINGS)),
137
137
  ])
138
- ], template: "<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n [dir]=\"dir\" (@slideContent.done)=\"onAnimationDone($event)\">\r\n <div class=\"toolbar-wrapper\" fxLayout=\"row\" [@slideDown]=\"slideDown\" *ngIf=\"!loading\">\r\n <button mat-icon-button (click)=\"close()\" bizdocTooltip=\"{{'Back' | translate}}\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <span class=\"mat-body-1\">{{data.file.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"rotate()\" bizdocTooltip=\"{{'Rotate' | translate }}\"><mat-icon>screen_rotation</mat-icon></button>\r\n <button mat-icon-button (click)=\"download()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n </div>\r\n <div class=\"spinner-wrapper\" *ngIf=\"loading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n <object (load)=\"onLoad($event)\" [data]=\"objectData\" [type]=\"data.file.contentType\" *ngIf=\"!isImage\" #obj></object>\r\n <img *ngIf=\"isImage\" (load)=\"onLoad($event)\" [style.opacity]=\"loading ? 0 : 1\" [@fade]=\"loading ? 'fadeOut' : 'fadeIn'\" [src]=\"objectData\" #img>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;align-items:center}.spinner-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1}img{width:100%;max-width:500px;height:auto}.overlay-content{padding:1em}.overlay-content .toolbar-wrapper{align-items:center;color:#f5f5f5}.divider{flex:1 1 auto}\n"] }]
138
+ ], template: "<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n [dir]=\"dir\" (@slideContent.done)=\"onAnimationDone($event)\">\r\n <div class=\"toolbar-wrapper\" fxLayout=\"row\" [@slideDown]=\"slideDown\" *ngIf=\"!loading\">\r\n <button mat-icon-button (click)=\"close()\" bizdocTooltip=\"{{'Back' | translate}}\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <span class=\"mat-body-1\">{{data.file.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"rotate()\" bizdocTooltip=\"{{'Rotate' | translate }}\"><mat-icon>screen_rotation</mat-icon></button>\r\n <button mat-icon-button (click)=\"download()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n </div>\r\n <div class=\"spinner-wrapper\" *ngIf=\"loading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n <object (load)=\"onLoad($event)\" [data]=\"objectData\" [type]=\"data.file.contentType\" *ngIf=\"!isImage\" #obj width=\"250\"\r\n height=\"200\">\r\n </object>\r\n <img *ngIf=\"isImage\" (load)=\"onLoad($event)\" [style.opacity]=\"loading ? 0 : 1\" [@fade]=\"loading ? 'fadeOut' : 'fadeIn'\" [src]=\"objectData\" #img>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;align-items:center}.spinner-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1}img{width:100%;max-width:500px;height:auto}.overlay-content{padding:1em}.overlay-content .toolbar-wrapper{align-items:center;color:#f5f5f5}.divider{flex:1 1 auto}\n"] }]
139
139
  }], ctorParameters: function () { return [{ type: i1.Directionality }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
140
140
  type: Inject,
141
141
  args: [FILE_PREVIEW_DIALOG_DATA]
@@ -152,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
152
152
  type: HostListener,
153
153
  args: ['document:keydown.escape', []]
154
154
  }] } });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-preview.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/compose/attachments/preview/attachment-preview.component.ts","../../../../../../../libraries/core/src/lib/compose/attachments/preview/attachment-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, InjectionToken, Inject, HostListener, EventEmitter, OnInit, ViewChild, ElementRef, AfterViewInit, Renderer2 } from '@angular/core';\r\nimport { OverlayRef } from '@angular/cdk/overlay';\r\nimport { Attachment } from '../../../core/models';\r\nimport { trigger, state, transition, style, animate, AnimationEvent } from '@angular/animations';\r\nimport { take, filter } from 'rxjs/operators';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\r\nimport { Directionality, Direction } from '@angular/cdk/bidi';\r\nimport { isImage } from '../../../core/functions';\r\nimport { MailboxService } from '../../../core/mailbox.service';\r\n\r\nexport const FILE_PREVIEW_DIALOG_DATA = new InjectionToken<PreviewData>('FILE_PREVIEW_DIALOG_DATA');\r\n\r\nconst ANIMATION_TIMINGS = '400ms cubic-bezier(0.25, 0.8, 0.25, 1)';\r\n\r\n@Component({\r\n  selector: 'bizdoc-attachment-preview',\r\n  templateUrl: './attachment-preview.component.html',\r\n  styleUrls: ['./attachment-preview.component.scss'],\r\n  animations: [\r\n    trigger('fade', [\r\n      state('fadeOut', style({ opacity: 0 })),\r\n      state('fadeIn', style({ opacity: 1 })),\r\n      transition('* => fadeIn', animate(ANIMATION_TIMINGS))\r\n    ]),\r\n    trigger('slideDown', [\r\n      state('void', style({ transform: 'translateY(-100%)' })),\r\n      state('enter', style({ transform: 'translateY(0)' })),\r\n      state('leave', style({ transform: 'translateY(-100%)' })),\r\n      transition('* => *', animate('400ms cubic-bezier(0.25, 0.8, 0.25, 1)'))\r\n    ]),\r\n    trigger('slideContent', [\r\n      state('void', style({ transform: 'translate3d(0, 25%, 0) scale(0.9)', opacity: 0 })),\r\n      state('enter', style({ transform: 'none', opacity: 1 })),\r\n      state('leave', style({ transform: 'translate3d(0, 25%, 0)', opacity: 0 })),\r\n      transition('* => *', animate(ANIMATION_TIMINGS)),\r\n    ])\r\n  ]\r\n})\r\n/** attachment-preview component*/\r\nexport class AttachmentPreview implements OnInit, AfterViewInit {\r\n  @ViewChild('obj', { static: false }) obj: ElementRef;\r\n  @ViewChild('img', { static: true }) img: ElementRef;\r\n  objectData: SafeUrl;\r\n  loading = true;\r\n  dir: Direction;\r\n  isImage: boolean;\r\n  animationState: 'void' | 'enter' | 'leave' = 'enter';\r\n  slideDown: 'enter' | 'leave' | 'void' = 'enter';\r\n  readonly animationStateChanged = new EventEmitter<AnimationEvent>();\r\n  private _deg = 0;\r\n  private readonly _beforeClose = new Subject<void>();\r\n  private readonly _afterClosed = new Subject<void>();\r\n  /** attachment-preview ctor */\r\n  constructor(_directionality: Directionality,\r\n    private _renderer: Renderer2, @Inject(FILE_PREVIEW_DIALOG_DATA) public data: PreviewData,\r\n    sanitizer: DomSanitizer,\r\n    private _service: MailboxService,\r\n    private _overlayRef: OverlayRef) {\r\n    this.dir = _directionality.value;\r\n    this.isImage = isImage(this.data.file.contentType);\r\n    this.objectData = sanitizer.bypassSecurityTrustResourceUrl(this._url());\r\n    this.beforeClose().subscribe(() => this.slideDown = 'leave');\r\n  }\r\n  @HostListener('document:resize', [])\r\n  resize() {\r\n    if (!this.isImage) {\r\n      this._renderer.setStyle(this.obj.nativeElement, 'min-width', `${window.innerWidth}px`);\r\n      this._renderer.setStyle(this.obj.nativeElement, 'min-height', `${window.innerHeight}px`)\r\n    }\r\n  }\r\n  ngOnInit(): void {\r\n    this._overlayRef.backdropClick().subscribe(() => this.close());\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this.resize();\r\n  }\r\n  download() {\r\n    location.assign(this._url());\r\n  }\r\n  private _url(): string {\r\n    return this._service.formatDownloadUrl(this.data.documentId, this.data.file.id);\r\n  }\r\n\r\n  rotate() {\r\n    const elem = (this.isImage ? this.img : this.obj).nativeElement;\r\n    this._deg = this._deg === 270 ? 0 : this._deg + 90;\r\n    elem.style.transform = `rotate(${this._deg}deg)`;\r\n  }\r\n  onLoad(_evt: Event) {\r\n    this.loading = false;\r\n  }\r\n  afterClosed(): Observable<void> {\r\n    return this._afterClosed.asObservable();\r\n  }\r\n\r\n  beforeClose(): Observable<void> {\r\n    return this._beforeClose.asObservable();\r\n  }\r\n  @HostListener('document:keydown.escape', [])\r\n  close(): void {\r\n    // Listen for animation 'start' events\r\n    this.animationStateChanged.pipe(\r\n      filter(event => event.phaseName === 'start'),\r\n      take(1)\r\n    ).subscribe(() => {\r\n      this._beforeClose.next();\r\n      this._beforeClose.complete();\r\n      this._overlayRef.detachBackdrop();\r\n    });\r\n\r\n    // Listen for animation 'done' events\r\n    this.animationStateChanged.pipe(\r\n      filter(event => event.phaseName === 'done' && event.toState === 'leave'),\r\n      take(1)\r\n    ).subscribe(() => {\r\n      this._overlayRef.dispose();\r\n      this._afterClosed.next();\r\n      this._afterClosed.complete();\r\n    });\r\n\r\n    // Start exit animation\r\n    this.startExitAnimation();\r\n  }\r\n  onAnimationStart(event: AnimationEvent) {\r\n    this.animationStateChanged.emit(event);\r\n  }\r\n\r\n  onAnimationDone(event: AnimationEvent) {\r\n    this.animationStateChanged.emit(event);\r\n  }\r\n\r\n  private startExitAnimation() {\r\n    this.animationState = 'leave';\r\n  }\r\n}\r\nexport interface PreviewData {\r\n  documentId: number;\r\n  file: Attachment;\r\n}\r\n","<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n [dir]=\"dir\" (@slideContent.done)=\"onAnimationDone($event)\">\r\n  <div class=\"toolbar-wrapper\" fxLayout=\"row\" [@slideDown]=\"slideDown\" *ngIf=\"!loading\">\r\n    <button mat-icon-button (click)=\"close()\" bizdocTooltip=\"{{'Back' | translate}}\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n    <span class=\"mat-body-1\">{{data.file.fileName}}</span>\r\n    <span class=\"divider\"></span>\r\n    <button mat-icon-button (click)=\"rotate()\" bizdocTooltip=\"{{'Rotate' | translate }}\"><mat-icon>screen_rotation</mat-icon></button>\r\n    <button mat-icon-button (click)=\"download()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n  </div>\r\n  <div class=\"spinner-wrapper\" *ngIf=\"loading\">\r\n    <mat-spinner></mat-spinner>\r\n  </div>\r\n  <object (load)=\"onLoad($event)\" [data]=\"objectData\" [type]=\"data.file.contentType\" *ngIf=\"!isImage\" #obj></object>\r\n  <img *ngIf=\"isImage\" (load)=\"onLoad($event)\" [style.opacity]=\"loading ? 0 : 1\" [@fade]=\"loading ? 'fadeOut' : 'fadeIn'\" [src]=\"objectData\" #img>\r\n</div>\r\n"]}
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment-preview.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/compose/attachments/preview/attachment-preview.component.ts","../../../../../../../libraries/core/src/lib/compose/attachments/preview/attachment-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, InjectionToken, Inject, HostListener, EventEmitter, OnInit, ViewChild, ElementRef, AfterViewInit, Renderer2 } from '@angular/core';\r\nimport { OverlayRef } from '@angular/cdk/overlay';\r\nimport { Attachment } from '../../../core/models';\r\nimport { trigger, state, transition, style, animate, AnimationEvent } from '@angular/animations';\r\nimport { take, filter } from 'rxjs/operators';\r\nimport { Observable, Subject } from 'rxjs';\r\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\r\nimport { Directionality, Direction } from '@angular/cdk/bidi';\r\nimport { isImage } from '../../../core/functions';\r\nimport { MailboxService } from '../../../core/mailbox.service';\r\n\r\nexport const FILE_PREVIEW_DIALOG_DATA = new InjectionToken<PreviewData>('FILE_PREVIEW_DIALOG_DATA');\r\n\r\nconst ANIMATION_TIMINGS = '400ms cubic-bezier(0.25, 0.8, 0.25, 1)';\r\n\r\n@Component({\r\n  selector: 'bizdoc-attachment-preview',\r\n  templateUrl: './attachment-preview.component.html',\r\n  styleUrls: ['./attachment-preview.component.scss'],\r\n  animations: [\r\n    trigger('fade', [\r\n      state('fadeOut', style({ opacity: 0 })),\r\n      state('fadeIn', style({ opacity: 1 })),\r\n      transition('* => fadeIn', animate(ANIMATION_TIMINGS))\r\n    ]),\r\n    trigger('slideDown', [\r\n      state('void', style({ transform: 'translateY(-100%)' })),\r\n      state('enter', style({ transform: 'translateY(0)' })),\r\n      state('leave', style({ transform: 'translateY(-100%)' })),\r\n      transition('* => *', animate('400ms cubic-bezier(0.25, 0.8, 0.25, 1)'))\r\n    ]),\r\n    trigger('slideContent', [\r\n      state('void', style({ transform: 'translate3d(0, 25%, 0) scale(0.9)', opacity: 0 })),\r\n      state('enter', style({ transform: 'none', opacity: 1 })),\r\n      state('leave', style({ transform: 'translate3d(0, 25%, 0)', opacity: 0 })),\r\n      transition('* => *', animate(ANIMATION_TIMINGS)),\r\n    ])\r\n  ]\r\n})\r\n/** attachment-preview component*/\r\nexport class AttachmentPreview implements OnInit, AfterViewInit {\r\n  @ViewChild('obj', { static: false }) obj: ElementRef;\r\n  @ViewChild('img', { static: true }) img: ElementRef;\r\n  objectData: SafeUrl;\r\n  loading = true;\r\n  dir: Direction;\r\n  isImage: boolean;\r\n  animationState: 'void' | 'enter' | 'leave' = 'enter';\r\n  slideDown: 'enter' | 'leave' | 'void' = 'enter';\r\n  readonly animationStateChanged = new EventEmitter<AnimationEvent>();\r\n  private _deg = 0;\r\n  private readonly _beforeClose = new Subject<void>();\r\n  private readonly _afterClosed = new Subject<void>();\r\n  /** attachment-preview ctor */\r\n  constructor(_directionality: Directionality,\r\n    private _renderer: Renderer2, @Inject(FILE_PREVIEW_DIALOG_DATA) public data: PreviewData,\r\n    sanitizer: DomSanitizer,\r\n    private _service: MailboxService,\r\n    private _overlayRef: OverlayRef) {\r\n    this.dir = _directionality.value;\r\n    this.isImage = isImage(this.data.file.contentType);\r\n    this.objectData = sanitizer.bypassSecurityTrustResourceUrl(this._url(true));\r\n    this.beforeClose().subscribe(() => this.slideDown = 'leave');\r\n  }\r\n  @HostListener('document:resize', [])\r\n  resize() {\r\n    if (!this.isImage) {\r\n      this._renderer.setStyle(this.obj.nativeElement, 'min-width', `${window.innerWidth}px`);\r\n      this._renderer.setStyle(this.obj.nativeElement, 'min-height', `${window.innerHeight}px`)\r\n    }\r\n  }\r\n  ngOnInit(): void {\r\n    this._overlayRef.backdropClick().subscribe(() => this.close());\r\n  }\r\n  ngAfterViewInit(): void {\r\n    this.resize();\r\n  }\r\n  download() {\r\n    location.assign(this._url());\r\n  }\r\n  private _url(inline?: boolean): string {\r\n    return this._service.formatDownloadUrl(this.data.documentId, this.data.file.id, inline);\r\n  }\r\n\r\n  rotate() {\r\n    const elem = (this.isImage ? this.img : this.obj).nativeElement;\r\n    this._deg = this._deg === 270 ? 0 : this._deg + 90;\r\n    elem.style.transform = `rotate(${this._deg}deg)`;\r\n  }\r\n  onLoad(_evt: Event) {\r\n    this.loading = false;\r\n  }\r\n  afterClosed(): Observable<void> {\r\n    return this._afterClosed.asObservable();\r\n  }\r\n\r\n  beforeClose(): Observable<void> {\r\n    return this._beforeClose.asObservable();\r\n  }\r\n  @HostListener('document:keydown.escape', [])\r\n  close(): void {\r\n    // Listen for animation 'start' events\r\n    this.animationStateChanged.pipe(\r\n      filter(event => event.phaseName === 'start'),\r\n      take(1)\r\n    ).subscribe(() => {\r\n      this._beforeClose.next();\r\n      this._beforeClose.complete();\r\n      this._overlayRef.detachBackdrop();\r\n    });\r\n\r\n    // Listen for animation 'done' events\r\n    this.animationStateChanged.pipe(\r\n      filter(event => event.phaseName === 'done' && event.toState === 'leave'),\r\n      take(1)\r\n    ).subscribe(() => {\r\n      this._overlayRef.dispose();\r\n      this._afterClosed.next();\r\n      this._afterClosed.complete();\r\n    });\r\n\r\n    // Start exit animation\r\n    this.startExitAnimation();\r\n  }\r\n  onAnimationStart(event: AnimationEvent) {\r\n    this.animationStateChanged.emit(event);\r\n  }\r\n\r\n  onAnimationDone(event: AnimationEvent) {\r\n    this.animationStateChanged.emit(event);\r\n  }\r\n\r\n  private startExitAnimation() {\r\n    this.animationState = 'leave';\r\n  }\r\n}\r\nexport interface PreviewData {\r\n  documentId: number;\r\n  file: Attachment;\r\n}\r\n","<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n     [dir]=\"dir\" (@slideContent.done)=\"onAnimationDone($event)\">\r\n  <div class=\"toolbar-wrapper\" fxLayout=\"row\" [@slideDown]=\"slideDown\" *ngIf=\"!loading\">\r\n    <button mat-icon-button (click)=\"close()\" bizdocTooltip=\"{{'Back' | translate}}\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n    <span class=\"mat-body-1\">{{data.file.fileName}}</span>\r\n    <span class=\"divider\"></span>\r\n    <button mat-icon-button (click)=\"rotate()\" bizdocTooltip=\"{{'Rotate' | translate }}\"><mat-icon>screen_rotation</mat-icon></button>\r\n    <button mat-icon-button (click)=\"download()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n  </div>\r\n  <div class=\"spinner-wrapper\" *ngIf=\"loading\">\r\n    <mat-spinner></mat-spinner>\r\n  </div>\r\n  <object (load)=\"onLoad($event)\" [data]=\"objectData\" [type]=\"data.file.contentType\" *ngIf=\"!isImage\" #obj width=\"250\"\r\n          height=\"200\">\r\n  </object>\r\n  <img *ngIf=\"isImage\" (load)=\"onLoad($event)\" [style.opacity]=\"loading ? 0 : 1\" [@fade]=\"loading ? 'fadeOut' : 'fadeIn'\" [src]=\"objectData\" #img>\r\n</div>\r\n"]}