@datarailsshared/datarailsshared 1.3.30 → 1.3.33

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 (127) hide show
  1. package/_datarailsshared.styles.css +3 -3
  2. package/assets/styles/_styles.scss +2 -2
  3. package/assets/styles/img/default-avatar.svg +5 -5
  4. package/bundles/datarailsshared-datarailsshared.umd.js +3715 -3345
  5. package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
  6. package/datarailsshared-datarailsshared-1.3.33.tgz +0 -0
  7. package/datarailsshared-datarailsshared.d.ts +7 -7
  8. package/datarailsshared-datarailsshared.metadata.json +1 -1
  9. package/esm2015/datarailsshared-datarailsshared.js +7 -7
  10. package/esm2015/lib/date-tags/date-tag.component.js +70 -70
  11. package/esm2015/lib/date-tags/date-tag.module.js +50 -50
  12. package/esm2015/lib/date-tags/day-tag/day-tag.component.js +81 -81
  13. package/esm2015/lib/date-tags/forecast-tag/forecast-tag.component.js +143 -143
  14. package/esm2015/lib/date-tags/month-tag/month-tag.component.js +87 -87
  15. package/esm2015/lib/date-tags/quarter-tag/quarter-tag.component.js +101 -101
  16. package/esm2015/lib/date-tags/week-tag/week-tag.component.js +124 -124
  17. package/esm2015/lib/date-tags/year-tag/year-tag.component.js +93 -93
  18. package/esm2015/lib/dr-accordion/accordion-item-body.component.js +57 -0
  19. package/esm2015/lib/dr-accordion/accordion-item-header.component.js +79 -0
  20. package/esm2015/lib/dr-accordion/accordion-item.component.js +123 -0
  21. package/esm2015/lib/dr-accordion/accordion.component.js +43 -0
  22. package/esm2015/lib/dr-accordion/accordion.module.js +23 -0
  23. package/esm2015/lib/dr-avatar/dr-avatar.component.js +42 -42
  24. package/esm2015/lib/dr-avatar/dr-avatar.module.js +26 -26
  25. package/esm2015/lib/dr-avatar/dr-avatar.pipe.js +15 -15
  26. package/esm2015/lib/dr-dropdown/dr-dropdown-item-show.pipe.js +12 -12
  27. package/esm2015/lib/dr-dropdown/dr-dropdown-position.directive.js +89 -89
  28. package/esm2015/lib/dr-dropdown/dr-dropdown.component.js +103 -103
  29. package/esm2015/lib/dr-dropdown/dr-dropdown.directive.js +75 -75
  30. package/esm2015/lib/dr-dropdown/dr-dropdown.module.js +34 -34
  31. package/esm2015/lib/dr-dropdown/dr-dropdown.service.js +24 -24
  32. package/esm2015/lib/dr-inputs/button/button.component.js +80 -79
  33. package/esm2015/lib/dr-inputs/checkbox/checkbox.component.js +63 -63
  34. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.js +47 -47
  35. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.component.js +131 -131
  36. package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +181 -166
  37. package/esm2015/lib/dr-inputs/dr-inputs.module.js +43 -43
  38. package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +87 -87
  39. package/esm2015/lib/dr-inputs/dr-toggle/dr-toggle.component.js +64 -64
  40. package/esm2015/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.js +52 -52
  41. package/esm2015/lib/dr-inputs/radio-button/radio-button.component.js +64 -64
  42. package/esm2015/lib/dr-inputs/radio-button/radio-group.component.js +164 -164
  43. package/esm2015/lib/dr-popover/dr-popover-ref.js +20 -20
  44. package/esm2015/lib/dr-popover/dr-popover.component.js +77 -77
  45. package/esm2015/lib/dr-popover/dr-popover.directive.js +72 -72
  46. package/esm2015/lib/dr-popover/dr-popover.module.js +23 -23
  47. package/esm2015/lib/dr-popover/dr-popover.service.js +102 -102
  48. package/esm2015/lib/dr-spinner/dr-spinner.component.js +29 -29
  49. package/esm2015/lib/dr-spinner/dr-spinner.directive.js +53 -53
  50. package/esm2015/lib/dr-spinner/dr-spinner.module.js +18 -18
  51. package/esm2015/lib/dr-tabs/dr-tab.component.js +23 -23
  52. package/esm2015/lib/dr-tabs/dr-tabs.component.js +28 -27
  53. package/esm2015/lib/dr-tabs/dr-tabs.module.js +30 -30
  54. package/esm2015/lib/dr-tags/dr-tag.component.js +54 -54
  55. package/esm2015/lib/dr-tags/dr-tag.module.js +22 -22
  56. package/esm2015/lib/dr-tooltip/dr-tooltip.component.js +30 -30
  57. package/esm2015/lib/dr-tooltip/dr-tooltip.directive.js +102 -102
  58. package/esm2015/lib/dr-tooltip/dr-tooltip.module.js +23 -23
  59. package/esm2015/lib/list-tags/list-tag.component.js +41 -41
  60. package/esm2015/lib/list-tags/list-tag.module.js +29 -29
  61. package/esm2015/lib/models/constants.js +97 -97
  62. package/esm2015/lib/models/datePicker.js +37 -37
  63. package/esm2015/lib/models/dropdown.js +2 -2
  64. package/esm2015/lib/models/popover.js +27 -27
  65. package/esm2015/lib/models/serverTags.js +2 -2
  66. package/esm2015/public-api.js +55 -50
  67. package/fesm2015/datarailsshared-datarailsshared.js +3099 -2779
  68. package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
  69. package/lib/date-tags/date-tag.component.d.ts +27 -27
  70. package/lib/date-tags/date-tag.module.d.ts +4 -4
  71. package/lib/date-tags/day-tag/day-tag.component.d.ts +12 -12
  72. package/lib/date-tags/forecast-tag/forecast-tag.component.d.ts +21 -21
  73. package/lib/date-tags/month-tag/month-tag.component.d.ts +14 -14
  74. package/lib/date-tags/quarter-tag/quarter-tag.component.d.ts +17 -17
  75. package/lib/date-tags/week-tag/week-tag.component.d.ts +19 -19
  76. package/lib/date-tags/year-tag/year-tag.component.d.ts +14 -14
  77. package/lib/dr-accordion/accordion-item-body.component.d.ts +11 -0
  78. package/lib/dr-accordion/accordion-item-header.component.d.ts +16 -0
  79. package/lib/dr-accordion/accordion-item.component.d.ts +53 -0
  80. package/lib/dr-accordion/accordion.component.d.ts +19 -0
  81. package/lib/dr-accordion/accordion.module.d.ts +2 -0
  82. package/lib/dr-avatar/dr-avatar.component.d.ts +10 -10
  83. package/lib/dr-avatar/dr-avatar.module.d.ts +2 -2
  84. package/lib/dr-avatar/dr-avatar.pipe.d.ts +4 -4
  85. package/lib/dr-dropdown/dr-dropdown-item-show.pipe.d.ts +5 -5
  86. package/lib/dr-dropdown/dr-dropdown-position.directive.d.ts +11 -11
  87. package/lib/dr-dropdown/dr-dropdown.component.d.ts +23 -23
  88. package/lib/dr-dropdown/dr-dropdown.directive.d.ts +19 -19
  89. package/lib/dr-dropdown/dr-dropdown.module.d.ts +2 -2
  90. package/lib/dr-dropdown/dr-dropdown.service.d.ts +11 -11
  91. package/lib/dr-inputs/button/button.component.d.ts +21 -20
  92. package/lib/dr-inputs/checkbox/checkbox.component.d.ts +20 -20
  93. package/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.d.ts +10 -10
  94. package/lib/dr-inputs/dr-date-picker/dr-date-picker.component.d.ts +28 -28
  95. package/lib/dr-inputs/dr-input/dr-input.component.d.ts +55 -53
  96. package/lib/dr-inputs/dr-inputs.module.d.ts +2 -2
  97. package/lib/dr-inputs/dr-select/dr-select.component.d.ts +36 -36
  98. package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +23 -23
  99. package/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.d.ts +17 -17
  100. package/lib/dr-inputs/radio-button/radio-button.component.d.ts +21 -21
  101. package/lib/dr-inputs/radio-button/radio-group.component.d.ts +39 -39
  102. package/lib/dr-popover/dr-popover-ref.d.ts +16 -16
  103. package/lib/dr-popover/dr-popover.component.d.ts +26 -26
  104. package/lib/dr-popover/dr-popover.directive.d.ts +26 -26
  105. package/lib/dr-popover/dr-popover.module.d.ts +2 -2
  106. package/lib/dr-popover/dr-popover.service.d.ts +17 -17
  107. package/lib/dr-spinner/dr-spinner.component.d.ts +10 -10
  108. package/lib/dr-spinner/dr-spinner.directive.d.ts +15 -15
  109. package/lib/dr-spinner/dr-spinner.module.d.ts +2 -2
  110. package/lib/dr-tabs/dr-tab.component.d.ts +8 -8
  111. package/lib/dr-tabs/dr-tabs.component.d.ts +11 -10
  112. package/lib/dr-tabs/dr-tabs.module.d.ts +2 -2
  113. package/lib/dr-tags/dr-tag.component.d.ts +15 -15
  114. package/lib/dr-tags/dr-tag.module.d.ts +2 -2
  115. package/lib/dr-tooltip/dr-tooltip.component.d.ts +16 -16
  116. package/lib/dr-tooltip/dr-tooltip.directive.d.ts +23 -23
  117. package/lib/dr-tooltip/dr-tooltip.module.d.ts +2 -2
  118. package/lib/list-tags/list-tag.component.d.ts +14 -14
  119. package/lib/list-tags/list-tag.module.d.ts +2 -2
  120. package/lib/models/constants.d.ts +87 -87
  121. package/lib/models/datePicker.d.ts +21 -21
  122. package/lib/models/dropdown.d.ts +47 -47
  123. package/lib/models/popover.d.ts +32 -32
  124. package/lib/models/serverTags.d.ts +28 -28
  125. package/package.json +1 -1
  126. package/public-api.d.ts +54 -49
  127. package/datarailsshared-datarailsshared-1.3.30.tgz +0 -0
@@ -1,93 +1,93 @@
1
- import { Component, Input } from "@angular/core";
2
- import { FormControl } from "@angular/forms";
3
- import { AnyTagComponent } from "../date-tag.component";
4
- import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from "@angular/material/core";
5
- import { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from "@angular/material-moment-adapter";
6
- // @ts-ignore
7
- const moment = require("moment");
8
- const YEAR_FORMATS = {
9
- parse: {
10
- dateInput: "YYYY",
11
- },
12
- display: {
13
- dateInput: "YYYY",
14
- monthYearLabel: "MMMM YYYY",
15
- dateA11yLabel: "LL",
16
- monthYearA11yLabel: "MMMM YYYY"
17
- },
18
- };
19
- const ɵ0 = YEAR_FORMATS;
20
- export class YearTagComponent extends AnyTagComponent {
21
- constructor() {
22
- super();
23
- this.lockedDate = [];
24
- this.date = new FormControl(moment());
25
- this.dateFilter = (date) => {
26
- const calendarDateYear = moment(date).year();
27
- let status = true;
28
- this.lockedDate.forEach(timestamp => {
29
- const lockDate = moment.unix(timestamp);
30
- return status = !(lockDate.year() === calendarDateYear);
31
- });
32
- return status;
33
- };
34
- }
35
- initDate() {
36
- if (this.defaultValue) {
37
- this.dateObj.date = moment(new Date(this.defaultValue * 1000)).utc().format("YYYY");
38
- this.date = new FormControl(moment(this.defaultValue * 1000));
39
- }
40
- else {
41
- this.dateObj.date = moment(new Date()).format("YYYY");
42
- }
43
- }
44
- initName() {
45
- if (!this.name) {
46
- this.name = "Year";
47
- }
48
- }
49
- chosenTagHandler(value) {
50
- const date = new Date();
51
- const year = moment(value).year();
52
- date.setTime(0);
53
- date.setFullYear(year, 0, 1);
54
- const resultDate = moment.utc(date);
55
- resultDate.hour(12);
56
- const resultTag = {
57
- name: this.name,
58
- value: parseInt(resultDate.format("X"), 10),
59
- label: resultDate.format("YYYY"),
60
- locked: !this.dateFilter(value)
61
- };
62
- console.log("resultTag", resultTag);
63
- this.dateChange.emit(resultTag);
64
- }
65
- chosenYearHandler(normalizedYear, datepicker) {
66
- const ctrlValue = this.date.value;
67
- ctrlValue.year(normalizedYear.year());
68
- this.date.setValue(ctrlValue);
69
- this.dateObj.date = this.date.value;
70
- this.chosenTagHandler(this.date.value);
71
- datepicker.close();
72
- }
73
- }
74
- YearTagComponent.decorators = [
75
- { type: Component, args: [{
76
- template: "<div>\n <mat-form-field class=\"date-select-box\">\n <input\n matInput\n placeholder=\"{{name}}\"\n name=\"Year\"\n [formControl]=\"date\"\n [matDatepicker]=\"datepicker\"\n [matDatepickerFilter]=\"dateFilter\">\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\n <mat-datepicker\n #datepicker\n startView=\"multi-year\"\n (yearSelected)=\"chosenYearHandler($event, datepicker)\"\n panelClass=\"date-month-picker\"\n ></mat-datepicker>\n </mat-form-field>\n</div>\n",
77
- selector: "year-tag",
78
- providers: [
79
- {
80
- provide: DateAdapter,
81
- useClass: MomentDateAdapter,
82
- deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
83
- },
84
- { provide: MAT_DATE_FORMATS, useValue: ɵ0 },
85
- ]
86
- },] }
87
- ];
88
- YearTagComponent.ctorParameters = () => [];
89
- YearTagComponent.propDecorators = {
90
- lockedDate: [{ type: Input }]
91
- };
92
- export { ɵ0 };
93
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieWVhci10YWcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZGF0ZS10YWdzL3llYXItdGFnL3llYXItdGFnLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBUyxNQUFNLGVBQWUsQ0FBQztBQUN2RCxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFJM0MsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBQyxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDdEYsT0FBTyxFQUFDLCtCQUErQixFQUFFLGlCQUFpQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFDcEcsYUFBYTtBQUNiLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUVqQyxNQUFNLFlBQVksR0FBRztJQUNuQixLQUFLLEVBQUU7UUFDTCxTQUFTLEVBQUUsTUFBTTtLQUNsQjtJQUNELE9BQU8sRUFBRTtRQUNQLFNBQVMsRUFBRSxNQUFNO1FBQ2pCLGNBQWMsRUFBRSxXQUFXO1FBQzNCLGFBQWEsRUFBRSxJQUFJO1FBQ25CLGtCQUFrQixFQUFFLFdBQVc7S0FDaEM7Q0FDRixDQUFDO1dBVzBDLFlBQVk7QUFJeEQsTUFBTSxPQUFPLGdCQUFpQixTQUFRLGVBQWU7SUFLbkQ7UUFDRSxLQUFLLEVBQUUsQ0FBQztRQUxELGVBQVUsR0FBVSxFQUFFLENBQUM7UUFFaEMsU0FBSSxHQUFHLElBQUksV0FBVyxDQUFDLE1BQU0sRUFBRSxDQUFDLENBQUM7UUFpRGpDLGVBQVUsR0FBRyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ3BCLE1BQU0sZ0JBQWdCLEdBQUcsTUFBTSxDQUFDLElB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LEtBQUssRUFBRSxDQUFDO0lBQ3JCLENBQUM7OztZQS9ERixTQUFTLFNBQUM7Z0JBQ1AsNG9CQUFzQztnQkFDdEMsUUFBUSxFQUFFLFVBQVU7Z0JBQ3BCLFNBQVMsRUFBRTtvQkFDVDt3QkFDRSxPQUFPLEVBQUUsV0FBVzt3QkFDcEIsUUFBUSxFQUFFLGlCQUFpQjt3QkFDM0IsSUFBSSxFQUFFLENBQUMsZUFBZSxFQUFFLCtCQUErQixDQUFDO3FCQUN6RDtvQkFDRCxFQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLElBQWMsRUFBQztpQkFDcEQ7YUFDSjs7Ozt5QkFHRSxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIElucHV0LCBPbkluaXR9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQge0Zvcm1Db250cm9sfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcbmltcG9ydCB7TWF0RGF0ZXBpY2tlcn0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXJcIjtcbmltcG9ydCB7TW9tZW50fSBmcm9tIFwibW9tZW50XCI7XG5pbXBvcnQge0lEYXRlVGFnfSBmcm9tIFwiLi4vLi4vbW9kZWxzL3NlcnZlclRhZ3NcIjtcbmltcG9ydCB7QW55VGFnQ29tcG9uZW50fSBmcm9tIFwiLi4vZGF0ZS10YWcuY29tcG9uZW50XCI7XG5pbXBvcnQge0RhdGVBZGFwdGVyLCBNQVRfREFURV9GT1JNQVRTLCBNQVRfREFURV9MT0NBTEV9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9jb3JlXCI7XG5pbXBvcnQge01BVF9NT01FTlRfREFURV9BREFQVEVSX09QVElPTlMsIE1vbWVudERhdGVBZGFwdGVyfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwtbW9tZW50LWFkYXB0ZXJcIjtcbi8vIEB0cy1pZ25vcmVcbmNvbnN0IG1vbWVudCA9IHJlcXVpcmUoXCJtb21lbnRcIik7XG5cbmNvbnN0IFlFQVJfRk9STUFUUyA9IHtcbiAgcGFyc2U6IHtcbiAgICBkYXRlSW5wdXQ6IFwiWVlZWVwiLFxuICB9LFxuICBkaXNwbGF5OiB7XG4gICAgZGF0ZUlucHV0OiBcIllZWVlcIixcbiAgICBtb250aFllYXJMYWJlbDogXCJNTU1NIFlZWVlcIixcbiAgICBkYXRlQTExeUxhYmVsOiBcIkxMXCIsXG4gICAgbW9udGhZZWFyQTExeUxhYmVsOiBcIk1NTU0gWVlZWVwiXG4gIH0sXG59O1xuXG5AQ29tcG9uZW50KHtcbiAgICB0ZW1wbGF0ZVVybDogXCJ5ZWFyLXRhZy5jb21wb25lbnQuaHRtbFwiLFxuICAgIHNlbGVjdG9yOiBcInllYXItdGFnXCIsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICB7XG4gICAgICAgIHByb3ZpZGU6IERhdGVBZGFwdGVyLFxuICAgICAgICB1c2VDbGFzczogTW9tZW50RGF0ZUFkYXB0ZXIsXG4gICAgICAgIGRlcHM6IFtNQVRfREFURV9MT0NBTEUsIE1BVF9NT01FTlRfREFURV9BREFQVEVSX09QVElPTlNdLFxuICAgICAgfSxcbiAgICAgIHtwcm92aWRlOiBNQVRfREFURV9GT1JNQVRTLCB1c2VWYWx1ZTogWUVBUl9GT1JNQVRTfSxcbiAgICBdLFxufSlcblxuZXhwb3J0IGNsYXNzIFllYXJUYWdDb21wb25lbnQgZXh0ZW5kcyBBbnlUYWdDb21wb25lbnQge1xuICBASW5wdXQoKSBsb2NrZWREYXRlOiBhbnlbXSA9IFtdO1xuXG4gIGRhdGUgPSBuZXcgRm9ybUNvbnRyb2wobW9tZW50KCkpO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG4gIH1cblxuICBpbml0RGF0ZSgpIHtcbiAgICBpZiAodGhpcy5kZWZhdWx0VmFsdWUpIHtcbiAgICAgIHRoaXMuZGF0ZU9iai5kYXRlID0gbW9tZW50KG5ldyBEYXRlKHRoaXMuZGVmYXVsdFZhbHVlICogMTAwMCkpLnV0YygpLmZvcm1hdChcIllZWVlcIik7XG4gICAgICB0aGlzLmRhdGUgPSBuZXcgRm9ybUNvbnRyb2wobW9tZW50KHRoaXMuZGVmYXVsdFZhbHVlICogMTAwMCkpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmRhdGVPYmouZGF0ZSA9IG1vbWVudChuZXcgRGF0ZSgpKS5mb3JtYXQoXCJZWVlZXCIpO1xuICAgIH1cbiAgfVxuXG4gIGluaXROYW1lKCkge1xuICAgIGlmICghdGhpcy5uYW1lKSB7XG4gICAgICB0aGlzLm5hbWUgPSBcIlllYXJcIjtcbiAgICB9XG4gIH1cblxuICBjaG9zZW5UYWdIYW5kbGVyKHZhbHVlKSB7XG4gICAgICBjb25zdCBkYXRlID0gbmV3IERhdGUoKTtcbiAgICAgIGNvbnN0IHllYXIgPSBtb21lbnQodmFsdWUpLnllYXIoKTtcbiAgICAgIGRhdGUuc2V0VGltZSgwKTtcbiAgICAgIGRhdGUuc2V0RnVsbFllYXIoeWVhciwgMCwgMSk7XG4gICAgICBjb25zdCByZXN1bHREYXRlOiBNb21lbnQgPSBtb21lbnQudXRjKGRhdGUpO1xuICAgICAgcmVzdWx0RGF0ZS5ob3VyKDEyKTtcbiAgICAgIGNvbnN0IHJlc3VsdFRhZzogSURhdGVUYWcgPSB7XG4gICAgICAgICAgbmFtZTogdGhpcy5uYW1lLFxuICAgICAgICAgIHZhbHVlOiBwYXJzZUludChyZXN1bHREYXRlLmZvcm1hdChcIlhcIiksIDEwKSxcbiAgICAgICAgICBsYWJlbDogcmVzdWx0RGF0ZS5mb3JtYXQoXCJZWVlZXCIpLFxuICAgICAgICAgIGxvY2tlZDogIXRoaXMuZGF0ZUZpbHRlcih2YWx1ZSlcbiAgICAgIH07XG4gICAgICBjb25zb2xlLmxvZyhcInJlc3VsdFRhZ1wiLCByZXN1bHRUYWcpO1xuICAgICAgdGhpcy5kYXRlQ2hhbmdlLmVtaXQocmVzdWx0VGFnKTtcbiAgfVxuXG4gIGNob3NlblllYXJIYW5kbGVyKG5vcm1hbGl6ZWRZZWFyOiBNb21lbnQsIGRhdGVwaWNrZXI6IE1hdERhdGVwaWNrZXI8TW9tZW50Pikge1xuICAgIGNvbnN0IGN0cmxWYWx1ZSA9IHRoaXMuZGF0ZS52YWx1ZTtcbiAgICBjdHJsVmFsdWUueWVhcihub3JtYWxpemVkWWVhci55ZWFyKCkpO1xuXG4gICAgdGhpcy5kYXRlLnNldFZhbHVlKGN0cmxWYWx1ZSk7XG4gICAgdGhpcy5kYXRlT2JqLmRhdGUgPSB0aGlzLmRhdGUudmFsdWU7XG4gICAgdGhpcy5jaG9zZW5UYWdIYW5kbGVyKHRoaXMuZGF0ZS52YWx1ZSk7XG5cbiAgICBkYXRlcGlja2VyLmNsb3NlKCk7XG4gIH1cblxuICBkYXRlRmlsdGVyID0gKGRhdGUpID0+IHtcbiAgICBjb25zdCBjYWxlbmRhckRhdGVZZWFyID0gbW9tZW50KGRhdGUpLnllYXIoKTtcbiAgICBsZXQgc3RhdHVzID0gdHJ1ZTtcblxuICAgIHRoaXMubG9ja2VkRGF0ZS5mb3JFYWNoKHRpbWVzdGFtcCA9PiB7XG4gICAgICBjb25zdCBsb2NrRGF0ZSA9IG1vbWVudC51bml4KHRpbWVzdGFtcCk7XG5cbiAgICAgIHJldHVybiBzdGF0dXMgPSAhKGxvY2tEYXRlLnllYXIoKSA9PT0gY2FsZW5kYXJEYXRlWWVhcilcbiAgICB9KTtcblxuICAgIHJldHVybiBzdGF0dXM7XG4gIH1cbn1cbiJdfQ==
1
+ import { Component, Input } from "@angular/core";
2
+ import { FormControl } from "@angular/forms";
3
+ import { AnyTagComponent } from "../date-tag.component";
4
+ import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from "@angular/material/core";
5
+ import { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from "@angular/material-moment-adapter";
6
+ // @ts-ignore
7
+ const moment = require("moment");
8
+ const YEAR_FORMATS = {
9
+ parse: {
10
+ dateInput: "YYYY",
11
+ },
12
+ display: {
13
+ dateInput: "YYYY",
14
+ monthYearLabel: "MMMM YYYY",
15
+ dateA11yLabel: "LL",
16
+ monthYearA11yLabel: "MMMM YYYY"
17
+ },
18
+ };
19
+ const ɵ0 = YEAR_FORMATS;
20
+ export class YearTagComponent extends AnyTagComponent {
21
+ constructor() {
22
+ super();
23
+ this.lockedDate = [];
24
+ this.date = new FormControl(moment());
25
+ this.dateFilter = (date) => {
26
+ const calendarDateYear = moment(date).year();
27
+ let status = true;
28
+ this.lockedDate.forEach(timestamp => {
29
+ const lockDate = moment.unix(timestamp);
30
+ return status = !(lockDate.year() === calendarDateYear);
31
+ });
32
+ return status;
33
+ };
34
+ }
35
+ initDate() {
36
+ if (this.defaultValue) {
37
+ this.dateObj.date = moment(new Date(this.defaultValue * 1000)).utc().format("YYYY");
38
+ this.date = new FormControl(moment(this.defaultValue * 1000));
39
+ }
40
+ else {
41
+ this.dateObj.date = moment(new Date()).format("YYYY");
42
+ }
43
+ }
44
+ initName() {
45
+ if (!this.name) {
46
+ this.name = "Year";
47
+ }
48
+ }
49
+ chosenTagHandler(value) {
50
+ const date = new Date();
51
+ const year = moment(value).year();
52
+ date.setTime(0);
53
+ date.setFullYear(year, 0, 1);
54
+ const resultDate = moment.utc(date);
55
+ resultDate.hour(12);
56
+ const resultTag = {
57
+ name: this.name,
58
+ value: parseInt(resultDate.format("X"), 10),
59
+ label: resultDate.format("YYYY"),
60
+ locked: !this.dateFilter(value)
61
+ };
62
+ console.log("resultTag", resultTag);
63
+ this.dateChange.emit(resultTag);
64
+ }
65
+ chosenYearHandler(normalizedYear, datepicker) {
66
+ const ctrlValue = this.date.value;
67
+ ctrlValue.year(normalizedYear.year());
68
+ this.date.setValue(ctrlValue);
69
+ this.dateObj.date = this.date.value;
70
+ this.chosenTagHandler(this.date.value);
71
+ datepicker.close();
72
+ }
73
+ }
74
+ YearTagComponent.decorators = [
75
+ { type: Component, args: [{
76
+ template: "<div>\r\n <mat-form-field class=\"date-select-box\">\r\n <input\r\n matInput\r\n placeholder=\"{{name}}\"\r\n name=\"Year\"\r\n [formControl]=\"date\"\r\n [matDatepicker]=\"datepicker\"\r\n [matDatepickerFilter]=\"dateFilter\">\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker\r\n #datepicker\r\n startView=\"multi-year\"\r\n (yearSelected)=\"chosenYearHandler($event, datepicker)\"\r\n panelClass=\"date-month-picker\"\r\n ></mat-datepicker>\r\n </mat-form-field>\r\n</div>\r\n",
77
+ selector: "year-tag",
78
+ providers: [
79
+ {
80
+ provide: DateAdapter,
81
+ useClass: MomentDateAdapter,
82
+ deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
83
+ },
84
+ { provide: MAT_DATE_FORMATS, useValue: ɵ0 },
85
+ ]
86
+ },] }
87
+ ];
88
+ YearTagComponent.ctorParameters = () => [];
89
+ YearTagComponent.propDecorators = {
90
+ lockedDate: [{ type: Input }]
91
+ };
92
+ export { ɵ0 };
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"year-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/year-tag/year-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from \"@angular/core\";\r\nimport {FormControl} from \"@angular/forms\";\r\nimport {MatDatepicker} from \"@angular/material/datepicker\";\r\nimport {Moment} from \"moment\";\r\nimport {IDateTag} from \"../../models/serverTags\";\r\nimport {AnyTagComponent} from \"../date-tag.component\";\r\nimport {DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE} from \"@angular/material/core\";\r\nimport {MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter} from \"@angular/material-moment-adapter\";\r\n// @ts-ignore\r\nconst moment = require(\"moment\");\r\n\r\nconst YEAR_FORMATS = {\r\n  parse: {\r\n    dateInput: \"YYYY\",\r\n  },\r\n  display: {\r\n    dateInput: \"YYYY\",\r\n    monthYearLabel: \"MMMM YYYY\",\r\n    dateA11yLabel: \"LL\",\r\n    monthYearA11yLabel: \"MMMM YYYY\"\r\n  },\r\n};\r\n\r\n@Component({\r\n    templateUrl: \"year-tag.component.html\",\r\n    selector: \"year-tag\",\r\n    providers: [\r\n      {\r\n        provide: DateAdapter,\r\n        useClass: MomentDateAdapter,\r\n        deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],\r\n      },\r\n      {provide: MAT_DATE_FORMATS, useValue: YEAR_FORMATS},\r\n    ],\r\n})\r\n\r\nexport class YearTagComponent extends AnyTagComponent {\r\n  @Input() lockedDate: any[] = [];\r\n\r\n  date = new FormControl(moment());\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  initDate() {\r\n    if (this.defaultValue) {\r\n      this.dateObj.date = moment(new Date(this.defaultValue * 1000)).utc().format(\"YYYY\");\r\n      this.date = new FormControl(moment(this.defaultValue * 1000));\r\n    } else {\r\n      this.dateObj.date = moment(new Date()).format(\"YYYY\");\r\n    }\r\n  }\r\n\r\n  initName() {\r\n    if (!this.name) {\r\n      this.name = \"Year\";\r\n    }\r\n  }\r\n\r\n  chosenTagHandler(value) {\r\n      const date = new Date();\r\n      const year = moment(value).year();\r\n      date.setTime(0);\r\n      date.setFullYear(year, 0, 1);\r\n      const resultDate: Moment = moment.utc(date);\r\n      resultDate.hour(12);\r\n      const resultTag: IDateTag = {\r\n          name: this.name,\r\n          value: parseInt(resultDate.format(\"X\"), 10),\r\n          label: resultDate.format(\"YYYY\"),\r\n          locked: !this.dateFilter(value)\r\n      };\r\n      console.log(\"resultTag\", resultTag);\r\n      this.dateChange.emit(resultTag);\r\n  }\r\n\r\n  chosenYearHandler(normalizedYear: Moment, datepicker: MatDatepicker<Moment>) {\r\n    const ctrlValue = this.date.value;\r\n    ctrlValue.year(normalizedYear.year());\r\n\r\n    this.date.setValue(ctrlValue);\r\n    this.dateObj.date = this.date.value;\r\n    this.chosenTagHandler(this.date.value);\r\n\r\n    datepicker.close();\r\n  }\r\n\r\n  dateFilter = (date) => {\r\n    const calendarDateYear = moment(date).year();\r\n    let status = true;\r\n\r\n    this.lockedDate.forEach(timestamp => {\r\n      const lockDate = moment.unix(timestamp);\r\n\r\n      return status = !(lockDate.year() === calendarDateYear)\r\n    });\r\n\r\n    return status;\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,57 @@
1
+ import { Component, ChangeDetectionStrategy, Host, ChangeDetectorRef, } from '@angular/core';
2
+ import { trigger, state, style, animate, transition } from '@angular/animations';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { Subject } from 'rxjs';
5
+ import { DrAccordionItemComponent } from './accordion-item.component';
6
+ const accordionItemBodyTrigger = trigger('accordionItemBody', [
7
+ state('collapsed', style({
8
+ overflow: 'hidden',
9
+ visibility: 'hidden',
10
+ height: 0,
11
+ })),
12
+ state('expanded', style({
13
+ overflow: 'hidden',
14
+ visibility: 'visible',
15
+ })),
16
+ transition('collapsed => expanded', animate('100ms ease-in')),
17
+ transition('expanded => collapsed', animate('100ms ease-out')),
18
+ ]);
19
+ export class DrAccordionItemBodyComponent {
20
+ constructor(accordionItem, cd) {
21
+ this.accordionItem = accordionItem;
22
+ this.cd = cd;
23
+ this.destroy$ = new Subject();
24
+ }
25
+ get state() {
26
+ return this.accordionItem.collapsed ? 'collapsed' : 'expanded';
27
+ }
28
+ ngOnInit() {
29
+ this.accordionItem.accordionItemInvalidate
30
+ .pipe(takeUntil(this.destroy$))
31
+ .subscribe(() => this.cd.markForCheck());
32
+ }
33
+ ngOnDestroy() {
34
+ this.destroy$.next();
35
+ this.destroy$.complete();
36
+ }
37
+ }
38
+ DrAccordionItemBodyComponent.decorators = [
39
+ { type: Component, args: [{
40
+ selector: 'dr-accordion-item-body',
41
+ template: `
42
+ <div [@accordionItemBody]="{ value: state }">
43
+ <div class="item-body">
44
+ <ng-content></ng-content>
45
+ </div>
46
+ </div>
47
+ `,
48
+ animations: [accordionItemBodyTrigger],
49
+ changeDetection: ChangeDetectionStrategy.OnPush,
50
+ styles: [".item-body{flex:1;-ms-flex:1 1 auto;overflow:auto;position:relative}\n"]
51
+ },] }
52
+ ];
53
+ DrAccordionItemBodyComponent.ctorParameters = () => [
54
+ { type: DrAccordionItemComponent, decorators: [{ type: Host }] },
55
+ { type: ChangeDetectorRef }
56
+ ];
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLWl0ZW0tYm9keS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1hY2NvcmRpb24vYWNjb3JkaW9uLWl0ZW0tYm9keS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCx1QkFBdUIsRUFDdkIsSUFBSSxFQUNKLGlCQUFpQixHQUdsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pGLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQy9CLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRXRFLE1BQU0sd0JBQXdCLEdBQUcsT0FBTyxDQUFDLG1CQUFtQixFQUFFO0lBQzVELEtBQUssQ0FDSCxXQUFXLEVBQ1gsS0FBSyxDQUFDO1FBQ0osUUFBUSxFQUFFLFFBQVE7UUFDbEIsVUFBVSxFQUFFLFFBQVE7UUFDcEIsTUFBTSxFQUFFLENBQUM7S0FDVixDQUFDLENBQ0g7SUFDRCxLQUFLLENBQ0gsVUFBVSxFQUNWLEtBQUssQ0FBQztRQUNKLFFBQVEsRUFBRSxRQUFRO1FBQ2xCLFVBQVUsRUFBRSxTQUFTO0tBQ3RCLENBQUMsQ0FDSDtJQUNELFVBQVUsQ0FBQyx1QkFBdUIsRUFBRSxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUM7SUFDN0QsVUFBVSxDQUFDLHVCQUF1QixFQUFFLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0NBQy9ELENBQUMsQ0FBQztBQWVILE1BQU0sT0FBTyw0QkFBNEI7SUFHdkMsWUFBNEIsYUFBdUMsRUFBVSxFQUFxQjtRQUF0RSxrQkFBYSxHQUFiLGFBQWEsQ0FBMEI7UUFBVSxPQUFFLEdBQUYsRUFBRSxDQUFtQjtRQUYxRixhQUFRLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQUU4RCxDQUFDO0lBRXRHLElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDO0lBQ2pFLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLGFBQWEsQ0FBQyx1QkFBdUI7YUFDdkMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7YUFDOUIsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDckIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMzQixDQUFDOzs7WUEvQkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSx3QkFBd0I7Z0JBQ2xDLFFBQVEsRUFBRTs7Ozs7O0dBTVQ7Z0JBRUQsVUFBVSxFQUFFLENBQUMsd0JBQXdCLENBQUM7Z0JBQ3RDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNOzthQUNoRDs7O1lBbENRLHdCQUF3Qix1QkFzQ2xCLElBQUk7WUE3Q2pCLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIEhvc3QsXHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgT25Jbml0LFxyXG4gIE9uRGVzdHJveSxcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgdHJpZ2dlciwgc3RhdGUsIHN0eWxlLCBhbmltYXRlLCB0cmFuc2l0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XHJcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBEckFjY29yZGlvbkl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2FjY29yZGlvbi1pdGVtLmNvbXBvbmVudCc7XHJcblxyXG5jb25zdCBhY2NvcmRpb25JdGVtQm9keVRyaWdnZXIgPSB0cmlnZ2VyKCdhY2NvcmRpb25JdGVtQm9keScsIFtcclxuICBzdGF0ZShcclxuICAgICdjb2xsYXBzZWQnLFxyXG4gICAgc3R5bGUoe1xyXG4gICAgICBvdmVyZmxvdzogJ2hpZGRlbicsXHJcbiAgICAgIHZpc2liaWxpdHk6ICdoaWRkZW4nLFxyXG4gICAgICBoZWlnaHQ6IDAsXHJcbiAgICB9KSxcclxuICApLFxyXG4gIHN0YXRlKFxyXG4gICAgJ2V4cGFuZGVkJyxcclxuICAgIHN0eWxlKHtcclxuICAgICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxyXG4gICAgICB2aXNpYmlsaXR5OiAndmlzaWJsZScsXHJcbiAgICB9KSxcclxuICApLFxyXG4gIHRyYW5zaXRpb24oJ2NvbGxhcHNlZCA9PiBleHBhbmRlZCcsIGFuaW1hdGUoJzEwMG1zIGVhc2UtaW4nKSksXHJcbiAgdHJhbnNpdGlvbignZXhwYW5kZWQgPT4gY29sbGFwc2VkJywgYW5pbWF0ZSgnMTAwbXMgZWFzZS1vdXQnKSksXHJcbl0pO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdkci1hY2NvcmRpb24taXRlbS1ib2R5JyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGRpdiBbQGFjY29yZGlvbkl0ZW1Cb2R5XT1cInsgdmFsdWU6IHN0YXRlIH1cIj5cclxuICAgICAgPGRpdiBjbGFzcz1cIml0ZW0tYm9keVwiPlxyXG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuICBgLFxyXG4gIHN0eWxlVXJsczogWycuL2FjY29yZGlvbi1pdGVtLWJvZHkuY29tcG9uZW50LnNjc3MnXSxcclxuICBhbmltYXRpb25zOiBbYWNjb3JkaW9uSXRlbUJvZHlUcmlnZ2VyXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxufSlcclxuZXhwb3J0IGNsYXNzIERyQWNjb3JkaW9uSXRlbUJvZHlDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XHJcbiAgcHJpdmF0ZSBkZXN0cm95JCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKEBIb3N0KCkgcHJpdmF0ZSBhY2NvcmRpb25JdGVtOiBEckFjY29yZGlvbkl0ZW1Db21wb25lbnQsIHByaXZhdGUgY2Q6IENoYW5nZURldGVjdG9yUmVmKSB7fVxyXG5cclxuICBnZXQgc3RhdGUoKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLmFjY29yZGlvbkl0ZW0uY29sbGFwc2VkID8gJ2NvbGxhcHNlZCcgOiAnZXhwYW5kZWQnO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLmFjY29yZGlvbkl0ZW0uYWNjb3JkaW9uSXRlbUludmFsaWRhdGVcclxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSQpKVxyXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHRoaXMuY2QubWFya0ZvckNoZWNrKCkpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICB0aGlzLmRlc3Ryb3kkLm5leHQoKTtcclxuICAgIHRoaXMuZGVzdHJveSQuY29tcGxldGUoKTtcclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,79 @@
1
+ import { Component, ChangeDetectionStrategy, Host, HostBinding, HostListener, ChangeDetectorRef, } from '@angular/core';
2
+ import { trigger, state, style, animate, transition } from '@angular/animations';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { Subject } from 'rxjs';
5
+ import { DrAccordionItemComponent } from './accordion-item.component';
6
+ export class DrAccordionItemHeaderComponent {
7
+ constructor(accordionItem, cd) {
8
+ this.accordionItem = accordionItem;
9
+ this.cd = cd;
10
+ this.destroy$ = new Subject();
11
+ }
12
+ get isCollapsed() {
13
+ return this.accordionItem.collapsed;
14
+ }
15
+ get expanded() {
16
+ return !this.accordionItem.collapsed;
17
+ }
18
+ get tabbable() {
19
+ return this.accordionItem.disabled ? '-1' : '0';
20
+ }
21
+ get disabled() {
22
+ return this.accordionItem.disabled;
23
+ }
24
+ toggle() {
25
+ this.accordionItem.toggle();
26
+ }
27
+ get state() {
28
+ if (this.isCollapsed) {
29
+ return 'collapsed';
30
+ }
31
+ return 'expanded';
32
+ }
33
+ ngOnInit() {
34
+ this.accordionItem.accordionItemInvalidate
35
+ .pipe(takeUntil(this.destroy$))
36
+ .subscribe(() => this.cd.markForCheck());
37
+ }
38
+ ngOnDestroy() {
39
+ this.destroy$.next();
40
+ this.destroy$.complete();
41
+ }
42
+ }
43
+ DrAccordionItemHeaderComponent.decorators = [
44
+ { type: Component, args: [{
45
+ selector: 'dr-accordion-item-header',
46
+ template: `
47
+ <ng-content select="dr-accordion-item-title"></ng-content>
48
+ <ng-content select="dr-accordion-item-description"></ng-content>
49
+ <ng-content></ng-content>
50
+ <i class="dr-icon-arrow-down expansion-indicator"
51
+ [@expansionIndicator]="state"
52
+ *ngIf="!disabled">
53
+ </i>
54
+ `,
55
+ animations: [
56
+ trigger('expansionIndicator', [
57
+ state('expanded', style({
58
+ transform: 'rotate(180deg)',
59
+ })),
60
+ transition('collapsed => expanded', animate('100ms ease-in')),
61
+ transition('expanded => collapsed', animate('100ms ease-out')),
62
+ ]),
63
+ ],
64
+ changeDetection: ChangeDetectionStrategy.OnPush,
65
+ styles: [":host{display:flex;align-items:center;cursor:pointer;position:relative;border-bottom:1px solid #edf1f7;color:#222b45;font-family:\"Poppins\",sans-serif;font-size:13px;font-weight:600;line-height:1.5rem;padding:1.25rem;text-transform:capitalize}:host:focus{outline:0}:host .expansion-indicator{font-size:24px;position:absolute;right:10px;font-weight:700}\n"]
66
+ },] }
67
+ ];
68
+ DrAccordionItemHeaderComponent.ctorParameters = () => [
69
+ { type: DrAccordionItemComponent, decorators: [{ type: Host }] },
70
+ { type: ChangeDetectorRef }
71
+ ];
72
+ DrAccordionItemHeaderComponent.propDecorators = {
73
+ isCollapsed: [{ type: HostBinding, args: ['class.accordion-item-header-collapsed',] }],
74
+ expanded: [{ type: HostBinding, args: ['class.accordion-item-header-expanded',] }, { type: HostBinding, args: ['attr.aria-expanded',] }],
75
+ tabbable: [{ type: HostBinding, args: ['attr.tabindex',] }],
76
+ disabled: [{ type: HostBinding, args: ['attr.aria-disabled',] }],
77
+ toggle: [{ type: HostListener, args: ['click',] }, { type: HostListener, args: ['keydown.space',] }, { type: HostListener, args: ['keydown.enter',] }]
78
+ };
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLWl0ZW0taGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWFjY29yZGlvbi9hY2NvcmRpb24taXRlbS1oZWFkZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsdUJBQXVCLEVBQ3ZCLElBQUksRUFDSixXQUFXLEVBQ1gsWUFBWSxFQUdaLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2pGLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQy9CLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBNEJ0RSxNQUFNLE9BQU8sOEJBQThCO0lBc0N6QyxZQUE0QixhQUF1QyxFQUFVLEVBQXFCO1FBQXRFLGtCQUFhLEdBQWIsYUFBYSxDQUEwQjtRQUFVLE9BQUUsR0FBRixFQUFFLENBQW1CO1FBckMxRixhQUFRLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQXNDdkMsQ0FBQztJQXBDRCxJQUNJLFdBQVc7UUFDYixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxJQUVJLFFBQVE7UUFDVixPQUFPLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUM7SUFDdkMsQ0FBQztJQUVELElBQ0ksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDO0lBQ2xELENBQUM7SUFFRCxJQUNJLFFBQVE7UUFDVixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDO0lBQ3JDLENBQUM7SUFLRCxNQUFNO1FBQ0osSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFBSSxLQUFLO1FBQ1AsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3BCLE9BQU8sV0FBVyxDQUFDO1NBQ3BCO1FBQ0QsT0FBTyxVQUFVLENBQUM7SUFDcEIsQ0FBQztJQUtELFFBQVE7UUFDTixJQUFJLENBQUMsYUFBYSxDQUFDLHVCQUF1QjthQUN2QyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUM5QixTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzNCLENBQUM7OztZQTVFRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLDBCQUEwQjtnQkFFcEMsUUFBUSxFQUFFOzs7Ozs7OztHQVFUO2dCQUNELFVBQVUsRUFBRTtvQkFDVixPQUFPLENBQUMsb0JBQW9CLEVBQUU7d0JBQzVCLEtBQUssQ0FDSCxVQUFVLEVBQ1YsS0FBSyxDQUFDOzRCQUNKLFNBQVMsRUFBRSxnQkFBZ0I7eUJBQzVCLENBQUMsQ0FDSDt3QkFDRCxVQUFVLENBQUMsdUJBQXVCLEVBQUUsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUFDO3dCQUM3RCxVQUFVLENBQUMsdUJBQXVCLEVBQUUsT0FBTyxDQUFDLGdCQUFnQixDQUFDLENBQUM7cUJBQy9ELENBQUM7aUJBQ0g7Z0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07O2FBQ2hEOzs7WUEzQlEsd0JBQXdCLHVCQWtFbEIsSUFBSTtZQXZFakIsaUJBQWlCOzs7MEJBb0NoQixXQUFXLFNBQUMsdUNBQXVDO3VCQUtuRCxXQUFXLFNBQUMsc0NBQXNDLGNBQ2xELFdBQVcsU0FBQyxvQkFBb0I7dUJBS2hDLFdBQVcsU0FBQyxlQUFlO3VCQUszQixXQUFXLFNBQUMsb0JBQW9CO3FCQUtoQyxZQUFZLFNBQUMsT0FBTyxjQUNwQixZQUFZLFNBQUMsZUFBZSxjQUM1QixZQUFZLFNBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIEhvc3QsXHJcbiAgSG9zdEJpbmRpbmcsXHJcbiAgSG9zdExpc3RlbmVyLFxyXG4gIE9uSW5pdCxcclxuICBPbkRlc3Ryb3ksXHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IHRyaWdnZXIsIHN0YXRlLCBzdHlsZSwgYW5pbWF0ZSwgdHJhbnNpdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xyXG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgRHJBY2NvcmRpb25JdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9hY2NvcmRpb24taXRlbS5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdkci1hY2NvcmRpb24taXRlbS1oZWFkZXInLFxyXG4gIHN0eWxlVXJsczogWycuL2FjY29yZGlvbi1pdGVtLWhlYWRlci5jb21wb25lbnQuc2NzcyddLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJkci1hY2NvcmRpb24taXRlbS10aXRsZVwiPjwvbmctY29udGVudD5cclxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImRyLWFjY29yZGlvbi1pdGVtLWRlc2NyaXB0aW9uXCI+PC9uZy1jb250ZW50PlxyXG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgPGkgY2xhc3M9XCJkci1pY29uLWFycm93LWRvd24gZXhwYW5zaW9uLWluZGljYXRvclwiXHJcbiAgICAgICBbQGV4cGFuc2lvbkluZGljYXRvcl09XCJzdGF0ZVwiXHJcbiAgICAgICAqbmdJZj1cIiFkaXNhYmxlZFwiPlxyXG4gICAgPC9pPlxyXG4gIGAsXHJcbiAgYW5pbWF0aW9uczogW1xyXG4gICAgdHJpZ2dlcignZXhwYW5zaW9uSW5kaWNhdG9yJywgW1xyXG4gICAgICBzdGF0ZShcclxuICAgICAgICAnZXhwYW5kZWQnLFxyXG4gICAgICAgIHN0eWxlKHtcclxuICAgICAgICAgIHRyYW5zZm9ybTogJ3JvdGF0ZSgxODBkZWcpJyxcclxuICAgICAgICB9KSxcclxuICAgICAgKSxcclxuICAgICAgdHJhbnNpdGlvbignY29sbGFwc2VkID0+IGV4cGFuZGVkJywgYW5pbWF0ZSgnMTAwbXMgZWFzZS1pbicpKSxcclxuICAgICAgdHJhbnNpdGlvbignZXhwYW5kZWQgPT4gY29sbGFwc2VkJywgYW5pbWF0ZSgnMTAwbXMgZWFzZS1vdXQnKSksXHJcbiAgICBdKSxcclxuICBdLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRHJBY2NvcmRpb25JdGVtSGVhZGVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xyXG4gIHByaXZhdGUgZGVzdHJveSQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG5cclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmFjY29yZGlvbi1pdGVtLWhlYWRlci1jb2xsYXBzZWQnKVxyXG4gIGdldCBpc0NvbGxhcHNlZCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLmFjY29yZGlvbkl0ZW0uY29sbGFwc2VkO1xyXG4gIH1cclxuXHJcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5hY2NvcmRpb24taXRlbS1oZWFkZXItZXhwYW5kZWQnKVxyXG4gIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLWV4cGFuZGVkJylcclxuICBnZXQgZXhwYW5kZWQoKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gIXRoaXMuYWNjb3JkaW9uSXRlbS5jb2xsYXBzZWQ7XHJcbiAgfVxyXG5cclxuICBASG9zdEJpbmRpbmcoJ2F0dHIudGFiaW5kZXgnKVxyXG4gIGdldCB0YWJiYWJsZSgpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuYWNjb3JkaW9uSXRlbS5kaXNhYmxlZCA/ICctMScgOiAnMCc7XHJcbiAgfVxyXG5cclxuICBASG9zdEJpbmRpbmcoJ2F0dHIuYXJpYS1kaXNhYmxlZCcpXHJcbiAgZ2V0IGRpc2FibGVkKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMuYWNjb3JkaW9uSXRlbS5kaXNhYmxlZDtcclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJylcclxuICBASG9zdExpc3RlbmVyKCdrZXlkb3duLnNwYWNlJylcclxuICBASG9zdExpc3RlbmVyKCdrZXlkb3duLmVudGVyJylcclxuICB0b2dnbGUoKSB7XHJcbiAgICB0aGlzLmFjY29yZGlvbkl0ZW0udG9nZ2xlKCk7XHJcbiAgfVxyXG5cclxuICBnZXQgc3RhdGUoKTogc3RyaW5nIHtcclxuICAgIGlmICh0aGlzLmlzQ29sbGFwc2VkKSB7XHJcbiAgICAgIHJldHVybiAnY29sbGFwc2VkJztcclxuICAgIH1cclxuICAgIHJldHVybiAnZXhwYW5kZWQnO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IoQEhvc3QoKSBwcml2YXRlIGFjY29yZGlvbkl0ZW06IERyQWNjb3JkaW9uSXRlbUNvbXBvbmVudCwgcHJpdmF0ZSBjZDogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5hY2NvcmRpb25JdGVtLmFjY29yZGlvbkl0ZW1JbnZhbGlkYXRlXHJcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3kkKSlcclxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB0aGlzLmNkLm1hcmtGb3JDaGVjaygpKTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgdGhpcy5kZXN0cm95JC5uZXh0KCk7XHJcbiAgICB0aGlzLmRlc3Ryb3kkLmNvbXBsZXRlKCk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -0,0 +1,123 @@
1
+ import { Component, ChangeDetectionStrategy, ChangeDetectorRef, Input, Output, EventEmitter, HostBinding, Host, } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { DrAccordionComponent } from './accordion.component';
5
+ export class DrAccordionItemComponent {
6
+ constructor(accordion, cd) {
7
+ this.accordion = accordion;
8
+ this.cd = cd;
9
+ /**
10
+ * Emits whenever the expanded state of the accordion changes.
11
+ * Primarily used to facilitate two-way binding.
12
+ */
13
+ this.collapsedChange = new EventEmitter();
14
+ this.accordionItemInvalidate = new Subject();
15
+ this.collapsedValue = true;
16
+ this.disabledValue = false;
17
+ this.destroy$ = new Subject();
18
+ }
19
+ /**
20
+ * Item is collapse (`true` by default)
21
+ * @type {boolean}
22
+ */
23
+ get collapsed() {
24
+ return this.collapsedValue;
25
+ }
26
+ set collapsed(val) {
27
+ this.collapsedValue = !!val;
28
+ this.collapsedChange.emit(this.collapsedValue);
29
+ this.invalidate();
30
+ }
31
+ /**
32
+ * Item is expanded (`false` by default)
33
+ */
34
+ get expanded() {
35
+ return !this.collapsed;
36
+ }
37
+ set expanded(val) {
38
+ this.collapsedValue = !val;
39
+ }
40
+ /**
41
+ * Item is disabled and cannot be opened.
42
+ * @type {boolean}
43
+ */
44
+ get disabled() {
45
+ return this.disabledValue;
46
+ }
47
+ set disabled(val) {
48
+ this.disabledValue = !!val;
49
+ this.invalidate();
50
+ }
51
+ /**
52
+ * Open/close the item
53
+ */
54
+ toggle() {
55
+ if (!this.disabled) {
56
+ // we need this temporary variable as `openCloseItems.next` will change current value we need to save
57
+ const willSet = !this.collapsed;
58
+ if (!this.accordion.multi) {
59
+ this.accordion.openCloseItems.next(true);
60
+ }
61
+ this.collapsed = willSet;
62
+ }
63
+ }
64
+ /**
65
+ * Open the item.
66
+ */
67
+ open() {
68
+ if (!this.disabled) {
69
+ this.collapsed = false;
70
+ }
71
+ }
72
+ /**
73
+ * Collapse the item.
74
+ */
75
+ close() {
76
+ if (!this.disabled) {
77
+ this.collapsed = true;
78
+ }
79
+ }
80
+ ngOnInit() {
81
+ this.accordion.openCloseItems
82
+ .pipe(takeUntil(this.destroy$))
83
+ .subscribe(collapsed => {
84
+ if (!this.disabled) {
85
+ this.collapsed = collapsed;
86
+ }
87
+ });
88
+ }
89
+ ngOnChanges(changes) {
90
+ this.accordionItemInvalidate.next(true);
91
+ }
92
+ ngOnDestroy() {
93
+ this.destroy$.next();
94
+ this.destroy$.complete();
95
+ this.accordionItemInvalidate.complete();
96
+ }
97
+ invalidate() {
98
+ this.accordionItemInvalidate.next(true);
99
+ this.cd.markForCheck();
100
+ }
101
+ }
102
+ DrAccordionItemComponent.decorators = [
103
+ { type: Component, args: [{
104
+ selector: 'dr-accordion-item',
105
+ template: `
106
+ <ng-content select="dr-accordion-item-header"></ng-content>
107
+ <ng-content select="dr-accordion-item-body"></ng-content>
108
+ `,
109
+ changeDetection: ChangeDetectionStrategy.OnPush,
110
+ styles: [":host{background-color:#fff;color:#222b45;font-family:\"Poppins\",sans-serif;font-size:16px;font-weight:400;line-height:1.25rem;display:flex;flex-direction:column}\n"]
111
+ },] }
112
+ ];
113
+ DrAccordionItemComponent.ctorParameters = () => [
114
+ { type: DrAccordionComponent, decorators: [{ type: Host }] },
115
+ { type: ChangeDetectorRef }
116
+ ];
117
+ DrAccordionItemComponent.propDecorators = {
118
+ collapsed: [{ type: Input, args: ['collapsed',] }, { type: HostBinding, args: ['class.collapsed',] }],
119
+ expanded: [{ type: Input, args: ['expanded',] }, { type: HostBinding, args: ['class.expanded',] }],
120
+ disabled: [{ type: Input, args: ['disabled',] }, { type: HostBinding, args: ['class.disabled',] }],
121
+ collapsedChange: [{ type: Output }]
122
+ };
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion-item.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-accordion/accordion-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  SimpleChanges,\r\n  HostBinding,\r\n  Host,\r\n  OnInit,\r\n  OnChanges,\r\n  OnDestroy,\r\n} from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { DrAccordionComponent } from './accordion.component';\r\n\r\n@Component({\r\n  selector: 'dr-accordion-item',\r\n  styleUrls: ['./accordion-item.component.scss'],\r\n  template: `\r\n    <ng-content select=\"dr-accordion-item-header\"></ng-content>\r\n    <ng-content select=\"dr-accordion-item-body\"></ng-content>\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class DrAccordionItemComponent implements OnInit, OnChanges, OnDestroy {\r\n\r\n  /**\r\n   * Item is collapse (`true` by default)\r\n   * @type {boolean}\r\n   */\r\n  @Input('collapsed')\r\n  @HostBinding('class.collapsed')\r\n  get collapsed(): boolean {\r\n    return this.collapsedValue;\r\n  }\r\n  set collapsed(val: boolean) {\r\n    this.collapsedValue = !!val;\r\n    this.collapsedChange.emit(this.collapsedValue);\r\n    this.invalidate();\r\n  }\r\n  static ngAcceptInputType_collapsed: any;\r\n\r\n  /**\r\n   * Item is expanded (`false` by default)\r\n   */\r\n  @Input('expanded')\r\n  @HostBinding('class.expanded')\r\n  get expanded(): boolean {\r\n    return !this.collapsed;\r\n  }\r\n  set expanded(val: boolean) {\r\n    this.collapsedValue = !val;\r\n  }\r\n  static ngAcceptInputType_expanded: any;\r\n\r\n  /**\r\n   * Item is disabled and cannot be opened.\r\n   * @type {boolean}\r\n   */\r\n  @Input('disabled')\r\n  @HostBinding('class.disabled')\r\n  get disabled(): boolean {\r\n    return this.disabledValue;\r\n  }\r\n  set disabled(val: boolean) {\r\n    this.disabledValue = !!val;\r\n    this.invalidate();\r\n  }\r\n  static ngAcceptInputType_disabled: any;\r\n\r\n  /**\r\n   * Emits whenever the expanded state of the accordion changes.\r\n   * Primarily used to facilitate two-way binding.\r\n   */\r\n  @Output() collapsedChange = new EventEmitter<boolean>();\r\n\r\n  accordionItemInvalidate = new Subject<boolean>();\r\n\r\n  private collapsedValue = true;\r\n  private disabledValue = false;\r\n  private destroy$ = new Subject<void>();\r\n\r\n  constructor(@Host() private accordion: DrAccordionComponent, private cd: ChangeDetectorRef) {\r\n  }\r\n\r\n  /**\r\n   * Open/close the item\r\n   */\r\n  toggle() {\r\n    if (!this.disabled) {\r\n      // we need this temporary variable as `openCloseItems.next` will change current value we need to save\r\n      const willSet = !this.collapsed;\r\n\r\n      if (!this.accordion.multi) {\r\n        this.accordion.openCloseItems.next(true);\r\n      }\r\n      this.collapsed = willSet;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Open the item.\r\n   */\r\n  open() {\r\n    if (!this.disabled) {\r\n      this.collapsed = false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Collapse the item.\r\n   */\r\n  close() {\r\n    if (!this.disabled) {\r\n      this.collapsed = true;\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.accordion.openCloseItems\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(collapsed => {\r\n        if (!this.disabled) {\r\n          this.collapsed = collapsed;\r\n        }\r\n      });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    this.accordionItemInvalidate.next(true);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n    this.accordionItemInvalidate.complete();\r\n  }\r\n\r\n  private invalidate() {\r\n    this.accordionItemInvalidate.next(true);\r\n    this.cd.markForCheck();\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,43 @@
1
+ import { Component, ChangeDetectionStrategy, Input } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ export class DrAccordionComponent {
4
+ constructor() {
5
+ this.openCloseItems = new Subject();
6
+ this.multiValue = false;
7
+ }
8
+ /**
9
+ * Allow multiple items to be expanded at the same time.
10
+ */
11
+ get multi() {
12
+ return this.multiValue;
13
+ }
14
+ set multi(val) {
15
+ this.multiValue = !!val;
16
+ }
17
+ /**
18
+ * Opens all enabled accordion items.
19
+ */
20
+ openAll() {
21
+ if (this.multi) {
22
+ this.openCloseItems.next(false);
23
+ }
24
+ }
25
+ /**
26
+ * Closes all enabled accordion items.
27
+ */
28
+ closeAll() {
29
+ this.openCloseItems.next(true);
30
+ }
31
+ }
32
+ DrAccordionComponent.decorators = [
33
+ { type: Component, args: [{
34
+ selector: 'dr-accordion',
35
+ template: '<ng-content select="dr-accordion-item"></ng-content>',
36
+ changeDetection: ChangeDetectionStrategy.OnPush,
37
+ styles: [":host{display:block;box-shadow:#2c33491a 0 5px 10px}\n"]
38
+ },] }
39
+ ];
40
+ DrAccordionComponent.propDecorators = {
41
+ multi: [{ type: Input, args: ['multi',] }]
42
+ };
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWFjY29yZGlvbi9hY2NvcmRpb24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFRL0IsTUFBTSxPQUFPLG9CQUFvQjtJQU5qQztRQVFFLG1CQUFjLEdBQUcsSUFBSSxPQUFPLEVBQVcsQ0FBQztRQWFoQyxlQUFVLEdBQUcsS0FBSyxDQUFDO0lBaUI3QixDQUFDO0lBNUJDOztPQUVHO0lBQ0gsSUFDSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7SUFDRCxJQUFJLEtBQUssQ0FBQyxHQUFZO1FBQ3BCLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQztJQUMxQixDQUFDO0lBSUQ7O09BRUc7SUFDSCxPQUFPO1FBQ0wsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDakM7SUFDSCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxRQUFRO1FBQ04sSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDakMsQ0FBQzs7O1lBckNGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsY0FBYztnQkFDeEIsUUFBUSxFQUFFLHNEQUFzRDtnQkFFaEUsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07O2FBQ2hEOzs7b0JBUUUsS0FBSyxTQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2RyLWFjY29yZGlvbicsXHJcbiAgdGVtcGxhdGU6ICc8bmctY29udGVudCBzZWxlY3Q9XCJkci1hY2NvcmRpb24taXRlbVwiPjwvbmctY29udGVudD4nLFxyXG4gIHN0eWxlVXJsczogWycuL2FjY29yZGlvbi5jb21wb25lbnQuc2NzcyddLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRHJBY2NvcmRpb25Db21wb25lbnQge1xyXG4gIHN0YXRpYyBuZ0FjY2VwdElucHV0VHlwZV9tdWx0aTogYW55O1xyXG4gIG9wZW5DbG9zZUl0ZW1zID0gbmV3IFN1YmplY3Q8Ym9vbGVhbj4oKTtcclxuXHJcbiAgLyoqXHJcbiAgICogIEFsbG93IG11bHRpcGxlIGl0ZW1zIHRvIGJlIGV4cGFuZGVkIGF0IHRoZSBzYW1lIHRpbWUuXHJcbiAgICovXHJcbiAgQElucHV0KCdtdWx0aScpXHJcbiAgZ2V0IG11bHRpKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMubXVsdGlWYWx1ZTtcclxuICB9XHJcbiAgc2V0IG11bHRpKHZhbDogYm9vbGVhbikge1xyXG4gICAgdGhpcy5tdWx0aVZhbHVlID0gISF2YWw7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIG11bHRpVmFsdWUgPSBmYWxzZTtcclxuXHJcbiAgLyoqXHJcbiAgICogT3BlbnMgYWxsIGVuYWJsZWQgYWNjb3JkaW9uIGl0ZW1zLlxyXG4gICAqL1xyXG4gIG9wZW5BbGwoKSB7XHJcbiAgICBpZiAodGhpcy5tdWx0aSkge1xyXG4gICAgICB0aGlzLm9wZW5DbG9zZUl0ZW1zLm5leHQoZmFsc2UpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQ2xvc2VzIGFsbCBlbmFibGVkIGFjY29yZGlvbiBpdGVtcy5cclxuICAgKi9cclxuICBjbG9zZUFsbCgpIHtcclxuICAgIHRoaXMub3BlbkNsb3NlSXRlbXMubmV4dCh0cnVlKTtcclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,23 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { DrAccordionComponent } from './accordion.component';
4
+ import { DrAccordionItemComponent } from './accordion-item.component';
5
+ import { DrAccordionItemHeaderComponent } from './accordion-item-header.component';
6
+ import { DrAccordionItemBodyComponent } from './accordion-item-body.component';
7
+ const DR_ACCORDION_COMPONENTS = [
8
+ DrAccordionComponent,
9
+ DrAccordionItemComponent,
10
+ DrAccordionItemHeaderComponent,
11
+ DrAccordionItemBodyComponent,
12
+ ];
13
+ export class DrAccordionModule {
14
+ }
15
+ DrAccordionModule.decorators = [
16
+ { type: NgModule, args: [{
17
+ imports: [CommonModule],
18
+ exports: [...DR_ACCORDION_COMPONENTS],
19
+ declarations: [...DR_ACCORDION_COMPONENTS],
20
+ providers: [],
21
+ },] }
22
+ ];
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWFjY29yZGlvbi9hY2NvcmRpb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzdELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3RFLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBRS9FLE1BQU0sdUJBQXVCLEdBQUc7SUFDOUIsb0JBQW9CO0lBQ3BCLHdCQUF3QjtJQUN4Qiw4QkFBOEI7SUFDOUIsNEJBQTRCO0NBQzdCLENBQUM7QUFRRixNQUFNLE9BQU8saUJBQWlCOzs7WUFON0IsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztnQkFDdkIsT0FBTyxFQUFFLENBQUMsR0FBRyx1QkFBdUIsQ0FBQztnQkFDckMsWUFBWSxFQUFFLENBQUMsR0FBRyx1QkFBdUIsQ0FBQztnQkFDMUMsU0FBUyxFQUFFLEVBQUU7YUFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IERyQWNjb3JkaW9uQ29tcG9uZW50IH0gZnJvbSAnLi9hY2NvcmRpb24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgRHJBY2NvcmRpb25JdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9hY2NvcmRpb24taXRlbS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBEckFjY29yZGlvbkl0ZW1IZWFkZXJDb21wb25lbnQgfSBmcm9tICcuL2FjY29yZGlvbi1pdGVtLWhlYWRlci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBEckFjY29yZGlvbkl0ZW1Cb2R5Q29tcG9uZW50IH0gZnJvbSAnLi9hY2NvcmRpb24taXRlbS1ib2R5LmNvbXBvbmVudCc7XHJcblxyXG5jb25zdCBEUl9BQ0NPUkRJT05fQ09NUE9ORU5UUyA9IFtcclxuICBEckFjY29yZGlvbkNvbXBvbmVudCxcclxuICBEckFjY29yZGlvbkl0ZW1Db21wb25lbnQsXHJcbiAgRHJBY2NvcmRpb25JdGVtSGVhZGVyQ29tcG9uZW50LFxyXG4gIERyQWNjb3JkaW9uSXRlbUJvZHlDb21wb25lbnQsXHJcbl07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gIGV4cG9ydHM6IFsuLi5EUl9BQ0NPUkRJT05fQ09NUE9ORU5UU10sXHJcbiAgZGVjbGFyYXRpb25zOiBbLi4uRFJfQUNDT1JESU9OX0NPTVBPTkVOVFNdLFxyXG4gIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEckFjY29yZGlvbk1vZHVsZSB7fVxyXG4iXX0=