@datarailsshared/datarailsshared 1.3.49 → 1.3.51

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/_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 +3984 -3995
  5. package/bundles/datarailsshared-datarailsshared.umd.js.map +1 -1
  6. package/datarailsshared-datarailsshared-1.3.51.tgz +0 -0
  7. package/datarailsshared-datarailsshared.d.ts +9 -9
  8. package/datarailsshared-datarailsshared.metadata.json +1 -1
  9. package/esm2015/datarailsshared-datarailsshared.js +9 -9
  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 -57
  19. package/esm2015/lib/dr-accordion/accordion-item-header.component.js +79 -79
  20. package/esm2015/lib/dr-accordion/accordion-item.component.js +123 -123
  21. package/esm2015/lib/dr-accordion/accordion.component.js +43 -43
  22. package/esm2015/lib/dr-accordion/accordion.module.js +23 -23
  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 +97 -97
  28. package/esm2015/lib/dr-dropdown/dr-dropdown.component.js +110 -110
  29. package/esm2015/lib/dr-dropdown/dr-dropdown.directive.js +89 -89
  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 -80
  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 +183 -186
  36. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker.service.js +41 -41
  37. package/esm2015/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.js +129 -129
  38. package/esm2015/lib/dr-inputs/dr-input/dr-input.component.js +185 -185
  39. package/esm2015/lib/dr-inputs/dr-inputs.module.js +51 -51
  40. package/esm2015/lib/dr-inputs/dr-model-debounce-change.directive.js +31 -31
  41. package/esm2015/lib/dr-inputs/dr-select/dr-select.component.js +90 -90
  42. package/esm2015/lib/dr-inputs/dr-toggle/dr-toggle.component.js +64 -64
  43. package/esm2015/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.js +56 -56
  44. package/esm2015/lib/dr-inputs/radio-button/radio-button.component.js +64 -64
  45. package/esm2015/lib/dr-inputs/radio-button/radio-group.component.js +164 -164
  46. package/esm2015/lib/dr-popover/dr-popover-ref.js +20 -20
  47. package/esm2015/lib/dr-popover/dr-popover.component.js +77 -77
  48. package/esm2015/lib/dr-popover/dr-popover.directive.js +72 -72
  49. package/esm2015/lib/dr-popover/dr-popover.module.js +23 -23
  50. package/esm2015/lib/dr-popover/dr-popover.service.js +102 -102
  51. package/esm2015/lib/dr-spinner/dr-spinner.component.js +29 -29
  52. package/esm2015/lib/dr-spinner/dr-spinner.directive.js +53 -53
  53. package/esm2015/lib/dr-spinner/dr-spinner.module.js +18 -18
  54. package/esm2015/lib/dr-tabs/dr-tab.component.js +23 -23
  55. package/esm2015/lib/dr-tabs/dr-tabs.component.js +28 -28
  56. package/esm2015/lib/dr-tabs/dr-tabs.module.js +30 -30
  57. package/esm2015/lib/dr-tags/dr-tag.component.js +54 -54
  58. package/esm2015/lib/dr-tags/dr-tag.module.js +22 -22
  59. package/esm2015/lib/dr-tooltip/dr-tooltip.component.js +30 -30
  60. package/esm2015/lib/dr-tooltip/dr-tooltip.directive.js +102 -102
  61. package/esm2015/lib/dr-tooltip/dr-tooltip.module.js +23 -23
  62. package/esm2015/lib/list-tags/list-tag.component.js +41 -41
  63. package/esm2015/lib/list-tags/list-tag.module.js +29 -29
  64. package/esm2015/lib/models/constants.js +97 -97
  65. package/esm2015/lib/models/datePicker.js +40 -40
  66. package/esm2015/lib/models/dropdown.js +2 -2
  67. package/esm2015/lib/models/popover.js +27 -27
  68. package/esm2015/lib/models/serverTags.js +2 -2
  69. package/esm2015/public-api.js +57 -57
  70. package/fesm2015/datarailsshared-datarailsshared.js +3365 -3368
  71. package/fesm2015/datarailsshared-datarailsshared.js.map +1 -1
  72. package/lib/date-tags/date-tag.component.d.ts +27 -27
  73. package/lib/date-tags/date-tag.module.d.ts +4 -4
  74. package/lib/date-tags/day-tag/day-tag.component.d.ts +12 -12
  75. package/lib/date-tags/forecast-tag/forecast-tag.component.d.ts +21 -21
  76. package/lib/date-tags/month-tag/month-tag.component.d.ts +14 -14
  77. package/lib/date-tags/quarter-tag/quarter-tag.component.d.ts +17 -17
  78. package/lib/date-tags/week-tag/week-tag.component.d.ts +19 -19
  79. package/lib/date-tags/year-tag/year-tag.component.d.ts +14 -14
  80. package/lib/dr-accordion/accordion-item-body.component.d.ts +11 -11
  81. package/lib/dr-accordion/accordion-item-header.component.d.ts +16 -16
  82. package/lib/dr-accordion/accordion-item.component.d.ts +53 -53
  83. package/lib/dr-accordion/accordion.component.d.ts +19 -19
  84. package/lib/dr-accordion/accordion.module.d.ts +2 -2
  85. package/lib/dr-avatar/dr-avatar.component.d.ts +10 -10
  86. package/lib/dr-avatar/dr-avatar.module.d.ts +2 -2
  87. package/lib/dr-avatar/dr-avatar.pipe.d.ts +4 -4
  88. package/lib/dr-dropdown/dr-dropdown-item-show.pipe.d.ts +5 -5
  89. package/lib/dr-dropdown/dr-dropdown-position.directive.d.ts +12 -12
  90. package/lib/dr-dropdown/dr-dropdown.component.d.ts +26 -26
  91. package/lib/dr-dropdown/dr-dropdown.directive.d.ts +23 -23
  92. package/lib/dr-dropdown/dr-dropdown.module.d.ts +2 -2
  93. package/lib/dr-dropdown/dr-dropdown.service.d.ts +11 -11
  94. package/lib/dr-inputs/button/button.component.d.ts +21 -21
  95. package/lib/dr-inputs/checkbox/checkbox.component.d.ts +20 -20
  96. package/lib/dr-inputs/dr-date-picker/dr-date-picker-format.directive.d.ts +10 -10
  97. package/lib/dr-inputs/dr-date-picker/dr-date-picker.component.d.ts +54 -54
  98. package/lib/dr-inputs/dr-date-picker/dr-date-picker.service.d.ts +12 -12
  99. package/lib/dr-inputs/dr-date-picker/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +41 -41
  100. package/lib/dr-inputs/dr-input/dr-input.component.d.ts +58 -58
  101. package/lib/dr-inputs/dr-inputs.module.d.ts +2 -2
  102. package/lib/dr-inputs/dr-model-debounce-change.directive.d.ts +11 -11
  103. package/lib/dr-inputs/dr-select/dr-select.component.d.ts +38 -38
  104. package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +23 -23
  105. package/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.d.ts +19 -19
  106. package/lib/dr-inputs/radio-button/radio-button.component.d.ts +21 -21
  107. package/lib/dr-inputs/radio-button/radio-group.component.d.ts +39 -39
  108. package/lib/dr-popover/dr-popover-ref.d.ts +16 -16
  109. package/lib/dr-popover/dr-popover.component.d.ts +26 -26
  110. package/lib/dr-popover/dr-popover.directive.d.ts +26 -26
  111. package/lib/dr-popover/dr-popover.module.d.ts +2 -2
  112. package/lib/dr-popover/dr-popover.service.d.ts +17 -17
  113. package/lib/dr-spinner/dr-spinner.component.d.ts +10 -10
  114. package/lib/dr-spinner/dr-spinner.directive.d.ts +15 -15
  115. package/lib/dr-spinner/dr-spinner.module.d.ts +2 -2
  116. package/lib/dr-tabs/dr-tab.component.d.ts +8 -8
  117. package/lib/dr-tabs/dr-tabs.component.d.ts +11 -11
  118. package/lib/dr-tabs/dr-tabs.module.d.ts +2 -2
  119. package/lib/dr-tags/dr-tag.component.d.ts +15 -15
  120. package/lib/dr-tags/dr-tag.module.d.ts +2 -2
  121. package/lib/dr-tooltip/dr-tooltip.component.d.ts +16 -16
  122. package/lib/dr-tooltip/dr-tooltip.directive.d.ts +23 -23
  123. package/lib/dr-tooltip/dr-tooltip.module.d.ts +2 -2
  124. package/lib/list-tags/list-tag.component.d.ts +14 -14
  125. package/lib/list-tags/list-tag.module.d.ts +2 -2
  126. package/lib/models/constants.d.ts +87 -87
  127. package/lib/models/datePicker.d.ts +25 -25
  128. package/lib/models/dropdown.d.ts +48 -48
  129. package/lib/models/popover.d.ts +32 -32
  130. package/lib/models/serverTags.d.ts +28 -28
  131. package/package.json +1 -1
  132. package/public-api.d.ts +55 -55
  133. package/datarailsshared-datarailsshared-1.3.49.tgz +0 -0
@@ -1,101 +1,101 @@
1
- import { Component, Input } from "@angular/core";
2
- import { AnyTagComponent } from "../date-tag.component";
3
- // @ts-ignore
4
- const moment = require("moment");
5
- export class QuarterTagComponent extends AnyTagComponent {
6
- constructor() {
7
- super();
8
- this.lockedDate = [];
9
- this.selectedValue = 0;
10
- this.quarters = [];
11
- this.dateFilter = (date) => {
12
- let status = true;
13
- this.lockedDate.forEach(timestamp => {
14
- const lockDate = moment.unix(timestamp);
15
- const quarterDate = moment.unix(date.value);
16
- if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {
17
- date.disable = true;
18
- status = false;
19
- }
20
- });
21
- return status;
22
- };
23
- }
24
- ngOnInit() {
25
- this.initName();
26
- this.quarters = this.getQuarterOptions();
27
- for (const quarter of this.quarters) {
28
- quarter.disable = false;
29
- if (quarter.isSelected) {
30
- this.selectedValue = quarter.value;
31
- this.chosenTagHandler(quarter.value);
32
- }
33
- this.dateFilter(quarter);
34
- }
35
- }
36
- initName() {
37
- if (!this.name) {
38
- this.name = "Quarter";
39
- }
40
- }
41
- changeSelectHandler(event) {
42
- this.chosenTagHandler(event.value);
43
- }
44
- chosenTagHandler(value) {
45
- const date = new Date(value * 1000);
46
- const resultDate = moment.utc(date);
47
- const resultTag = {
48
- name: this.name,
49
- value: parseInt(resultDate.format("X"), 10),
50
- label: this.getQuarterLabel(resultDate.toString()),
51
- locked: !this.dateFilter(value)
52
- };
53
- this.dateChange.emit(resultTag);
54
- }
55
- getQuarterOptions() {
56
- const quartersBeforeToday = 8;
57
- const quartersAfterToday = 8;
58
- const dateNow = new Date();
59
- const dateNowUnix = this.getUTCTimestamp(dateNow);
60
- let defaultValue = dateNowUnix;
61
- let tempDate = new Date();
62
- if (this.defaultValue) {
63
- defaultValue = this.defaultValue * 1000;
64
- }
65
- let afterDefault = Math.round(Math.abs(dateNowUnix - defaultValue) / 7776000000) + quartersAfterToday;
66
- afterDefault = Math.min(afterDefault, 100);
67
- let i, tempValue;
68
- const to_return = [];
69
- for (i = 0 - quartersBeforeToday; i <= afterDefault; i++) {
70
- tempDate = new Date(defaultValue);
71
- tempDate.setDate(15);
72
- tempDate.setMonth(tempDate.getMonth() + 3 * i);
73
- tempValue = this.getUTCTimestamp(tempDate);
74
- to_return.push({
75
- value: tempValue / 1000,
76
- label: this.getQuarterLabel(tempValue),
77
- isSelected: (i === 0),
78
- });
79
- }
80
- return to_return;
81
- }
82
- getQuarterLabel(timeValue) {
83
- const date = new Date(timeValue);
84
- return "Q" + Math.floor((date.getMonth() / 3) + 1) + " " + date.getFullYear();
85
- }
86
- getUTCTimestamp(date) {
87
- const month = Math.floor(date.getMonth() / 3) * 3;
88
- return Date.UTC(date.getFullYear(), month, 1, 12, 0, 0, 0);
89
- }
90
- }
91
- QuarterTagComponent.decorators = [
92
- { type: Component, args: [{
93
- template: "<div>\r\n <mat-form-field>\r\n <mat-select placeholder=\"{{name}}\" (selectionChange)=\"changeSelectHandler($event)\" [(value)]=\"selectedValue\">\r\n <mat-option *ngFor=\"let quarter of quarters\" [value]=\"quarter.value\" [disabled]=\"quarter.disable\">{{quarter.label}}</mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n</div>\r\n",
94
- selector: "quarter-tag"
95
- },] }
96
- ];
97
- QuarterTagComponent.ctorParameters = () => [];
98
- QuarterTagComponent.propDecorators = {
99
- lockedDate: [{ type: Input }]
100
- };
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quarter-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/quarter-tag/quarter-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from \"@angular/core\";\r\nimport {IDateTag} from \"../../models/serverTags\";\r\nimport {Moment} from \"moment\";\r\nimport {AnyTagComponent} from \"../date-tag.component\";\r\nimport {MatSelectChange} from \"@angular/material/select\";\r\n// @ts-ignore\r\nconst moment = require(\"moment\");\r\n\r\n@Component({\r\n    templateUrl: \"quarter-tag.component.html\",\r\n    selector: \"quarter-tag\",\r\n})\r\nexport class QuarterTagComponent extends AnyTagComponent implements OnInit {\r\n    @Input() lockedDate: any[] = [];\r\n    selectedValue = 0;\r\n    quarters: any[] = [];\r\n\r\n    constructor() {\r\n        super();\r\n    }\r\n\r\n    ngOnInit() {\r\n      this.initName();\r\n      this.quarters = this.getQuarterOptions();\r\n\r\n      for (const quarter of this.quarters) {\r\n          quarter.disable = false;\r\n\r\n          if (quarter.isSelected) {\r\n              this.selectedValue = quarter.value;\r\n              this.chosenTagHandler(quarter.value);\r\n          }\r\n\r\n          this.dateFilter(quarter);\r\n      }\r\n    }\r\n\r\n    initName() {\r\n      if (!this.name) {\r\n        this.name = \"Quarter\";\r\n      }\r\n    }\r\n\r\n    changeSelectHandler(event: MatSelectChange) {\r\n      this.chosenTagHandler(event.value);\r\n    }\r\n\r\n    chosenTagHandler(value) {\r\n        const date = new Date(value * 1000);\r\n        const resultDate: Moment = moment.utc(date);\r\n        const resultTag: IDateTag = {\r\n            name: this.name,\r\n            value: parseInt(resultDate.format(\"X\"), 10),\r\n            label: this.getQuarterLabel(resultDate.toString()),\r\n            locked: !this.dateFilter(value)\r\n        };\r\n        this.dateChange.emit(resultTag);\r\n    }\r\n\r\n    getQuarterOptions() {\r\n        const quartersBeforeToday = 8;\r\n        const quartersAfterToday = 8;\r\n        const dateNow = new Date();\r\n        const dateNowUnix = this.getUTCTimestamp(dateNow);\r\n        let defaultValue = dateNowUnix;\r\n        let tempDate =  new Date();\r\n        if (this.defaultValue) {\r\n          defaultValue = this.defaultValue * 1000;\r\n        }\r\n\r\n        let afterDefault = Math.round(Math.abs(dateNowUnix - defaultValue) / 7776000000) + quartersAfterToday;\r\n        afterDefault = Math.min(afterDefault, 100);\r\n        let i, tempValue;\r\n        const to_return: any[] = [];\r\n        for (i = 0 - quartersBeforeToday; i <= afterDefault; i++) {\r\n            tempDate = new Date(defaultValue);\r\n            tempDate.setDate(15);\r\n            tempDate.setMonth(tempDate.getMonth() + 3 * i);\r\n            tempValue = this.getUTCTimestamp(tempDate);\r\n            to_return.push({\r\n                value: tempValue / 1000,\r\n                label: this.getQuarterLabel(tempValue),\r\n                isSelected: (i === 0),\r\n            });\r\n        }\r\n        return to_return;\r\n    }\r\n\r\n    private getQuarterLabel(timeValue) {\r\n        const date = new Date(timeValue);\r\n        return \"Q\" + Math.floor((date.getMonth() / 3) + 1) + \" \" + date.getFullYear();\r\n    }\r\n\r\n    private getUTCTimestamp(date) {\r\n        const month = Math.floor(date.getMonth() / 3) * 3;\r\n        return Date.UTC(date.getFullYear(), month, 1, 12, 0, 0, 0);\r\n    }\r\n\r\n  dateFilter = (date) => {\r\n    let status = true;\r\n\r\n    this.lockedDate.forEach(timestamp => {\r\n      const lockDate = moment.unix(timestamp);\r\n      const quarterDate = moment.unix(date.value);\r\n\r\n      if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {\r\n        date.disable = true;\r\n        status = false;\r\n      }\r\n    });\r\n\r\n    return status;\r\n  }\r\n}\r\n"]}
1
+ import { Component, Input } from "@angular/core";
2
+ import { AnyTagComponent } from "../date-tag.component";
3
+ // @ts-ignore
4
+ const moment = require("moment");
5
+ export class QuarterTagComponent extends AnyTagComponent {
6
+ constructor() {
7
+ super();
8
+ this.lockedDate = [];
9
+ this.selectedValue = 0;
10
+ this.quarters = [];
11
+ this.dateFilter = (date) => {
12
+ let status = true;
13
+ this.lockedDate.forEach(timestamp => {
14
+ const lockDate = moment.unix(timestamp);
15
+ const quarterDate = moment.unix(date.value);
16
+ if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {
17
+ date.disable = true;
18
+ status = false;
19
+ }
20
+ });
21
+ return status;
22
+ };
23
+ }
24
+ ngOnInit() {
25
+ this.initName();
26
+ this.quarters = this.getQuarterOptions();
27
+ for (const quarter of this.quarters) {
28
+ quarter.disable = false;
29
+ if (quarter.isSelected) {
30
+ this.selectedValue = quarter.value;
31
+ this.chosenTagHandler(quarter.value);
32
+ }
33
+ this.dateFilter(quarter);
34
+ }
35
+ }
36
+ initName() {
37
+ if (!this.name) {
38
+ this.name = "Quarter";
39
+ }
40
+ }
41
+ changeSelectHandler(event) {
42
+ this.chosenTagHandler(event.value);
43
+ }
44
+ chosenTagHandler(value) {
45
+ const date = new Date(value * 1000);
46
+ const resultDate = moment.utc(date);
47
+ const resultTag = {
48
+ name: this.name,
49
+ value: parseInt(resultDate.format("X"), 10),
50
+ label: this.getQuarterLabel(resultDate.toString()),
51
+ locked: !this.dateFilter(value)
52
+ };
53
+ this.dateChange.emit(resultTag);
54
+ }
55
+ getQuarterOptions() {
56
+ const quartersBeforeToday = 8;
57
+ const quartersAfterToday = 8;
58
+ const dateNow = new Date();
59
+ const dateNowUnix = this.getUTCTimestamp(dateNow);
60
+ let defaultValue = dateNowUnix;
61
+ let tempDate = new Date();
62
+ if (this.defaultValue) {
63
+ defaultValue = this.defaultValue * 1000;
64
+ }
65
+ let afterDefault = Math.round(Math.abs(dateNowUnix - defaultValue) / 7776000000) + quartersAfterToday;
66
+ afterDefault = Math.min(afterDefault, 100);
67
+ let i, tempValue;
68
+ const to_return = [];
69
+ for (i = 0 - quartersBeforeToday; i <= afterDefault; i++) {
70
+ tempDate = new Date(defaultValue);
71
+ tempDate.setDate(15);
72
+ tempDate.setMonth(tempDate.getMonth() + 3 * i);
73
+ tempValue = this.getUTCTimestamp(tempDate);
74
+ to_return.push({
75
+ value: tempValue / 1000,
76
+ label: this.getQuarterLabel(tempValue),
77
+ isSelected: (i === 0),
78
+ });
79
+ }
80
+ return to_return;
81
+ }
82
+ getQuarterLabel(timeValue) {
83
+ const date = new Date(timeValue);
84
+ return "Q" + Math.floor((date.getMonth() / 3) + 1) + " " + date.getFullYear();
85
+ }
86
+ getUTCTimestamp(date) {
87
+ const month = Math.floor(date.getMonth() / 3) * 3;
88
+ return Date.UTC(date.getFullYear(), month, 1, 12, 0, 0, 0);
89
+ }
90
+ }
91
+ QuarterTagComponent.decorators = [
92
+ { type: Component, args: [{
93
+ template: "<div>\n <mat-form-field>\n <mat-select placeholder=\"{{name}}\" (selectionChange)=\"changeSelectHandler($event)\" [(value)]=\"selectedValue\">\n <mat-option *ngFor=\"let quarter of quarters\" [value]=\"quarter.value\" [disabled]=\"quarter.disable\">{{quarter.label}}</mat-option>\n </mat-select>\n </mat-form-field>\n</div>\n",
94
+ selector: "quarter-tag"
95
+ },] }
96
+ ];
97
+ QuarterTagComponent.ctorParameters = () => [];
98
+ QuarterTagComponent.propDecorators = {
99
+ lockedDate: [{ type: Input }]
100
+ };
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quarter-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/quarter-tag/quarter-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from \"@angular/core\";\nimport {IDateTag} from \"../../models/serverTags\";\nimport {Moment} from \"moment\";\nimport {AnyTagComponent} from \"../date-tag.component\";\nimport {MatSelectChange} from \"@angular/material/select\";\n// @ts-ignore\nconst moment = require(\"moment\");\n\n@Component({\n    templateUrl: \"quarter-tag.component.html\",\n    selector: \"quarter-tag\",\n})\nexport class QuarterTagComponent extends AnyTagComponent implements OnInit {\n    @Input() lockedDate: any[] = [];\n    selectedValue = 0;\n    quarters: any[] = [];\n\n    constructor() {\n        super();\n    }\n\n    ngOnInit() {\n      this.initName();\n      this.quarters = this.getQuarterOptions();\n\n      for (const quarter of this.quarters) {\n          quarter.disable = false;\n\n          if (quarter.isSelected) {\n              this.selectedValue = quarter.value;\n              this.chosenTagHandler(quarter.value);\n          }\n\n          this.dateFilter(quarter);\n      }\n    }\n\n    initName() {\n      if (!this.name) {\n        this.name = \"Quarter\";\n      }\n    }\n\n    changeSelectHandler(event: MatSelectChange) {\n      this.chosenTagHandler(event.value);\n    }\n\n    chosenTagHandler(value) {\n        const date = new Date(value * 1000);\n        const resultDate: Moment = moment.utc(date);\n        const resultTag: IDateTag = {\n            name: this.name,\n            value: parseInt(resultDate.format(\"X\"), 10),\n            label: this.getQuarterLabel(resultDate.toString()),\n            locked: !this.dateFilter(value)\n        };\n        this.dateChange.emit(resultTag);\n    }\n\n    getQuarterOptions() {\n        const quartersBeforeToday = 8;\n        const quartersAfterToday = 8;\n        const dateNow = new Date();\n        const dateNowUnix = this.getUTCTimestamp(dateNow);\n        let defaultValue = dateNowUnix;\n        let tempDate =  new Date();\n        if (this.defaultValue) {\n          defaultValue = this.defaultValue * 1000;\n        }\n\n        let afterDefault = Math.round(Math.abs(dateNowUnix - defaultValue) / 7776000000) + quartersAfterToday;\n        afterDefault = Math.min(afterDefault, 100);\n        let i, tempValue;\n        const to_return: any[] = [];\n        for (i = 0 - quartersBeforeToday; i <= afterDefault; i++) {\n            tempDate = new Date(defaultValue);\n            tempDate.setDate(15);\n            tempDate.setMonth(tempDate.getMonth() + 3 * i);\n            tempValue = this.getUTCTimestamp(tempDate);\n            to_return.push({\n                value: tempValue / 1000,\n                label: this.getQuarterLabel(tempValue),\n                isSelected: (i === 0),\n            });\n        }\n        return to_return;\n    }\n\n    private getQuarterLabel(timeValue) {\n        const date = new Date(timeValue);\n        return \"Q\" + Math.floor((date.getMonth() / 3) + 1) + \" \" + date.getFullYear();\n    }\n\n    private getUTCTimestamp(date) {\n        const month = Math.floor(date.getMonth() / 3) * 3;\n        return Date.UTC(date.getFullYear(), month, 1, 12, 0, 0, 0);\n    }\n\n  dateFilter = (date) => {\n    let status = true;\n\n    this.lockedDate.forEach(timestamp => {\n      const lockDate = moment.unix(timestamp);\n      const quarterDate = moment.unix(date.value);\n\n      if (lockDate.year() === quarterDate.year() && lockDate.month() === quarterDate.month()) {\n        date.disable = true;\n        status = false;\n      }\n    });\n\n    return status;\n  }\n}\n"]}
@@ -1,124 +1,124 @@
1
- import { Component, Input } from "@angular/core";
2
- import { AnyTagComponent } from "../date-tag.component";
3
- import { FormControl } from "@angular/forms";
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 WEEK_FORMATS = {
9
- parse: {
10
- dateInput: "WW-YYYY",
11
- },
12
- display: {
13
- dateInput: "[Week] WW, YYYY",
14
- monthYearLabel: "MMMM YYYY",
15
- dateA11yLabel: "LL",
16
- monthYearA11yLabel: "MMMM YYYY"
17
- },
18
- };
19
- const ɵ0 = WEEK_FORMATS;
20
- export class WeekTagComponent extends AnyTagComponent {
21
- constructor() {
22
- super();
23
- this.lockedDate = [];
24
- this.date = new FormControl(moment());
25
- this.selectedValue = "";
26
- this.dateFilter = (date) => {
27
- const calendarDate = moment(date);
28
- let status = true;
29
- this.lockedDate.forEach(timestamp => {
30
- const lockDate = moment.unix(timestamp);
31
- return status = !(lockDate.week() === calendarDate.week() && lockDate.year() === calendarDate.year());
32
- });
33
- return status;
34
- };
35
- }
36
- ngOnInit() {
37
- this.initName();
38
- const now = new Date();
39
- now.setHours(0, 0, 0, 0);
40
- const dateUnix = this.getUTCTimestamp(this.getMonday(now));
41
- let default_value_time = dateUnix;
42
- const one_day_in_seconds = 86400;
43
- if (this.defaultValue) {
44
- default_value_time = (this.defaultValue + one_day_in_seconds) * 1000;
45
- }
46
- const default_date = new Date(default_value_time);
47
- const weekNumber = this.getWeekNumberByDate(default_date);
48
- const yearNumber = default_date.getFullYear();
49
- const dateStr = `${yearNumber}-W${weekNumber}`;
50
- this.dateObj.date = dateStr;
51
- this.selectedValue = dateStr;
52
- this.chosenTagHandler(default_date);
53
- }
54
- initName() {
55
- if (!this.name) {
56
- this.name = "Week";
57
- }
58
- }
59
- chosenDateHandler(normalizedDay) {
60
- const date = moment(normalizedDay).unix();
61
- this.chosenTagHandler(date);
62
- }
63
- chosenTagHandler(value) {
64
- let date;
65
- console.log("chosenTag", value);
66
- if (value > 1000000000000) {
67
- date = new Date(value);
68
- }
69
- else {
70
- date = new Date(value * 1000);
71
- }
72
- const resultDate = moment(date);
73
- const resultTag = {
74
- name: this.name,
75
- value: parseInt(resultDate.format("X"), 10),
76
- label: this.getWeekLabel(date),
77
- locked: !this.dateFilter(value)
78
- };
79
- console.log("resultTag", resultTag);
80
- this.dateChange.emit(resultTag);
81
- }
82
- getWeekLabel(date) {
83
- return "W" + this.pad(moment(date).isoWeek(), 2) +
84
- " " + moment(date).year();
85
- }
86
- getUTCTimestamp(date) {
87
- return Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), 12, 0, 0, 0);
88
- }
89
- getMonday(date) {
90
- const day = date.getDay() || 7;
91
- if (day !== 1) {
92
- date.setHours(-24 * (day - 1));
93
- }
94
- return date;
95
- }
96
- getWeekNumberByDate(date) {
97
- return this.pad(moment(date).isoWeek(), 2);
98
- }
99
- pad(n, width, z = "0") {
100
- z = z || "0";
101
- n = n + "";
102
- return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;
103
- }
104
- }
105
- WeekTagComponent.decorators = [
106
- { type: Component, args: [{
107
- template: "<div>\r\n <mat-form-field class=\"date-select-box\">\r\n <input\r\n matInput\r\n placeholder=\"{{name}}\"\r\n name=\"week\"\r\n [formControl]=\"date\"\r\n [matDatepicker]=\"datepicker\"\r\n [matDatepickerFilter]=\"dateFilter\"\r\n (ngModelChange)=\"chosenDateHandler($event)\">\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker\r\n #datepicker\r\n startView=\"month\"\r\n ></mat-datepicker>\r\n </mat-form-field>\r\n</div>\r\n",
108
- selector: "week-tag",
109
- providers: [
110
- {
111
- provide: DateAdapter,
112
- useClass: MomentDateAdapter,
113
- deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
114
- },
115
- { provide: MAT_DATE_FORMATS, useValue: ɵ0 },
116
- ]
117
- },] }
118
- ];
119
- WeekTagComponent.ctorParameters = () => [];
120
- WeekTagComponent.propDecorators = {
121
- lockedDate: [{ type: Input }]
122
- };
123
- export { ɵ0 };
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"week-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/week-tag/week-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from \"@angular/core\";\r\nimport {IDateTag} from \"../../models/serverTags\";\r\nimport {Moment} from \"moment\";\r\nimport {AnyTagComponent} from \"../date-tag.component\";\r\nimport {FormControl} from \"@angular/forms\";\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 WEEK_FORMATS = {\r\n  parse: {\r\n    dateInput: \"WW-YYYY\",\r\n  },\r\n  display: {\r\n    dateInput: \"[Week] WW, 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: \"week-tag.component.html\",\r\n    selector: \"week-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: WEEK_FORMATS},\r\n    ],\r\n})\r\nexport class WeekTagComponent extends AnyTagComponent implements OnInit {\r\n    @Input() lockedDate: any[] = [];\r\n\r\n    date = new FormControl(moment());\r\n    selectedValue = \"\";\r\n\r\n    constructor() {\r\n        super();\r\n    }\r\n\r\n    ngOnInit() {\r\n      this.initName();\r\n\r\n      const now = new Date();\r\n      now.setHours(0, 0, 0, 0);\r\n\r\n      const dateUnix = this.getUTCTimestamp(this.getMonday(now));\r\n      let default_value_time = dateUnix;\r\n      const one_day_in_seconds = 86400;\r\n      if (this.defaultValue) {\r\n        default_value_time = (this.defaultValue + one_day_in_seconds) * 1000;\r\n      }\r\n\r\n      const default_date = new Date(default_value_time);\r\n      const weekNumber = this.getWeekNumberByDate(default_date);\r\n      const yearNumber = default_date.getFullYear();\r\n      const dateStr = `${yearNumber}-W${weekNumber}`;\r\n      this.dateObj.date = dateStr;\r\n      this.selectedValue = dateStr;\r\n      this.chosenTagHandler(default_date);\r\n    }\r\n\r\n    initName() {\r\n      if (!this.name) {\r\n        this.name = \"Week\";\r\n      }\r\n    }\r\n\r\n    chosenDateHandler(normalizedDay) {\r\n      const date = moment(normalizedDay).unix();\r\n      this.chosenTagHandler(date);\r\n    }\r\n\r\n    dateFilter = (date) => {\r\n      const calendarDate = moment(date);\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.week() === calendarDate.week() && lockDate.year() === calendarDate.year());\r\n      });\r\n\r\n      return status;\r\n    }\r\n\r\n    chosenTagHandler(value) {\r\n        let date;\r\n        console.log(\"chosenTag\", value);\r\n        if (value > 1000000000000) {\r\n          date = new Date(value);\r\n        } else {\r\n          date = new Date(value * 1000);\r\n        }\r\n\r\n        const resultDate: Moment = moment(date);\r\n        const resultTag: IDateTag = {\r\n            name: this.name,\r\n            value: parseInt(resultDate.format(\"X\"), 10),\r\n            label: this.getWeekLabel(date),\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    private getWeekLabel(date) {\r\n      return \"W\" + this.pad( moment(date).isoWeek(), 2) +\r\n        \" \" + moment(date).year();\r\n    }\r\n\r\n    private getUTCTimestamp(date) {\r\n        return Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), 12, 0, 0, 0);\r\n    }\r\n\r\n    private getMonday(date) {\r\n        const day = date.getDay() || 7;\r\n        if (day !== 1) {\r\n            date.setHours(-24 * (day - 1));\r\n        }\r\n        return date;\r\n    }\r\n\r\n    private getWeekNumberByDate(date: Date) {\r\n      return this.pad(moment(date).isoWeek(), 2);\r\n    }\r\n\r\n    private pad(n, width, z = \"0\") {\r\n      z = z || \"0\";\r\n      n = n + \"\";\r\n      return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;\r\n    }\r\n}\r\n"]}
1
+ import { Component, Input } from "@angular/core";
2
+ import { AnyTagComponent } from "../date-tag.component";
3
+ import { FormControl } from "@angular/forms";
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 WEEK_FORMATS = {
9
+ parse: {
10
+ dateInput: "WW-YYYY",
11
+ },
12
+ display: {
13
+ dateInput: "[Week] WW, YYYY",
14
+ monthYearLabel: "MMMM YYYY",
15
+ dateA11yLabel: "LL",
16
+ monthYearA11yLabel: "MMMM YYYY"
17
+ },
18
+ };
19
+ const ɵ0 = WEEK_FORMATS;
20
+ export class WeekTagComponent extends AnyTagComponent {
21
+ constructor() {
22
+ super();
23
+ this.lockedDate = [];
24
+ this.date = new FormControl(moment());
25
+ this.selectedValue = "";
26
+ this.dateFilter = (date) => {
27
+ const calendarDate = moment(date);
28
+ let status = true;
29
+ this.lockedDate.forEach(timestamp => {
30
+ const lockDate = moment.unix(timestamp);
31
+ return status = !(lockDate.week() === calendarDate.week() && lockDate.year() === calendarDate.year());
32
+ });
33
+ return status;
34
+ };
35
+ }
36
+ ngOnInit() {
37
+ this.initName();
38
+ const now = new Date();
39
+ now.setHours(0, 0, 0, 0);
40
+ const dateUnix = this.getUTCTimestamp(this.getMonday(now));
41
+ let default_value_time = dateUnix;
42
+ const one_day_in_seconds = 86400;
43
+ if (this.defaultValue) {
44
+ default_value_time = (this.defaultValue + one_day_in_seconds) * 1000;
45
+ }
46
+ const default_date = new Date(default_value_time);
47
+ const weekNumber = this.getWeekNumberByDate(default_date);
48
+ const yearNumber = default_date.getFullYear();
49
+ const dateStr = `${yearNumber}-W${weekNumber}`;
50
+ this.dateObj.date = dateStr;
51
+ this.selectedValue = dateStr;
52
+ this.chosenTagHandler(default_date);
53
+ }
54
+ initName() {
55
+ if (!this.name) {
56
+ this.name = "Week";
57
+ }
58
+ }
59
+ chosenDateHandler(normalizedDay) {
60
+ const date = moment(normalizedDay).unix();
61
+ this.chosenTagHandler(date);
62
+ }
63
+ chosenTagHandler(value) {
64
+ let date;
65
+ console.log("chosenTag", value);
66
+ if (value > 1000000000000) {
67
+ date = new Date(value);
68
+ }
69
+ else {
70
+ date = new Date(value * 1000);
71
+ }
72
+ const resultDate = moment(date);
73
+ const resultTag = {
74
+ name: this.name,
75
+ value: parseInt(resultDate.format("X"), 10),
76
+ label: this.getWeekLabel(date),
77
+ locked: !this.dateFilter(value)
78
+ };
79
+ console.log("resultTag", resultTag);
80
+ this.dateChange.emit(resultTag);
81
+ }
82
+ getWeekLabel(date) {
83
+ return "W" + this.pad(moment(date).isoWeek(), 2) +
84
+ " " + moment(date).year();
85
+ }
86
+ getUTCTimestamp(date) {
87
+ return Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), 12, 0, 0, 0);
88
+ }
89
+ getMonday(date) {
90
+ const day = date.getDay() || 7;
91
+ if (day !== 1) {
92
+ date.setHours(-24 * (day - 1));
93
+ }
94
+ return date;
95
+ }
96
+ getWeekNumberByDate(date) {
97
+ return this.pad(moment(date).isoWeek(), 2);
98
+ }
99
+ pad(n, width, z = "0") {
100
+ z = z || "0";
101
+ n = n + "";
102
+ return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;
103
+ }
104
+ }
105
+ WeekTagComponent.decorators = [
106
+ { type: Component, args: [{
107
+ template: "<div>\n <mat-form-field class=\"date-select-box\">\n <input\n matInput\n placeholder=\"{{name}}\"\n name=\"week\"\n [formControl]=\"date\"\n [matDatepicker]=\"datepicker\"\n [matDatepickerFilter]=\"dateFilter\"\n (ngModelChange)=\"chosenDateHandler($event)\">\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\n <mat-datepicker\n #datepicker\n startView=\"month\"\n ></mat-datepicker>\n </mat-form-field>\n</div>\n",
108
+ selector: "week-tag",
109
+ providers: [
110
+ {
111
+ provide: DateAdapter,
112
+ useClass: MomentDateAdapter,
113
+ deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
114
+ },
115
+ { provide: MAT_DATE_FORMATS, useValue: ɵ0 },
116
+ ]
117
+ },] }
118
+ ];
119
+ WeekTagComponent.ctorParameters = () => [];
120
+ WeekTagComponent.propDecorators = {
121
+ lockedDate: [{ type: Input }]
122
+ };
123
+ export { ɵ0 };
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"week-tag.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/date-tags/week-tag/week-tag.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from \"@angular/core\";\nimport {IDateTag} from \"../../models/serverTags\";\nimport {Moment} from \"moment\";\nimport {AnyTagComponent} from \"../date-tag.component\";\nimport {FormControl} from \"@angular/forms\";\nimport {DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE} from \"@angular/material/core\";\nimport {MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter} from \"@angular/material-moment-adapter\";\n// @ts-ignore\nconst moment = require(\"moment\");\n\nconst WEEK_FORMATS = {\n  parse: {\n    dateInput: \"WW-YYYY\",\n  },\n  display: {\n    dateInput: \"[Week] WW, YYYY\",\n    monthYearLabel: \"MMMM YYYY\",\n    dateA11yLabel: \"LL\",\n    monthYearA11yLabel: \"MMMM YYYY\"\n  },\n};\n\n@Component({\n    templateUrl: \"week-tag.component.html\",\n    selector: \"week-tag\",\n    providers: [\n      {\n        provide: DateAdapter,\n        useClass: MomentDateAdapter,\n        deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],\n      },\n      {provide: MAT_DATE_FORMATS, useValue: WEEK_FORMATS},\n    ],\n})\nexport class WeekTagComponent extends AnyTagComponent implements OnInit {\n    @Input() lockedDate: any[] = [];\n\n    date = new FormControl(moment());\n    selectedValue = \"\";\n\n    constructor() {\n        super();\n    }\n\n    ngOnInit() {\n      this.initName();\n\n      const now = new Date();\n      now.setHours(0, 0, 0, 0);\n\n      const dateUnix = this.getUTCTimestamp(this.getMonday(now));\n      let default_value_time = dateUnix;\n      const one_day_in_seconds = 86400;\n      if (this.defaultValue) {\n        default_value_time = (this.defaultValue + one_day_in_seconds) * 1000;\n      }\n\n      const default_date = new Date(default_value_time);\n      const weekNumber = this.getWeekNumberByDate(default_date);\n      const yearNumber = default_date.getFullYear();\n      const dateStr = `${yearNumber}-W${weekNumber}`;\n      this.dateObj.date = dateStr;\n      this.selectedValue = dateStr;\n      this.chosenTagHandler(default_date);\n    }\n\n    initName() {\n      if (!this.name) {\n        this.name = \"Week\";\n      }\n    }\n\n    chosenDateHandler(normalizedDay) {\n      const date = moment(normalizedDay).unix();\n      this.chosenTagHandler(date);\n    }\n\n    dateFilter = (date) => {\n      const calendarDate = moment(date);\n      let status = true;\n\n      this.lockedDate.forEach(timestamp => {\n        const lockDate = moment.unix(timestamp);\n\n        return status = !(lockDate.week() === calendarDate.week() && lockDate.year() === calendarDate.year());\n      });\n\n      return status;\n    }\n\n    chosenTagHandler(value) {\n        let date;\n        console.log(\"chosenTag\", value);\n        if (value > 1000000000000) {\n          date = new Date(value);\n        } else {\n          date = new Date(value * 1000);\n        }\n\n        const resultDate: Moment = moment(date);\n        const resultTag: IDateTag = {\n            name: this.name,\n            value: parseInt(resultDate.format(\"X\"), 10),\n            label: this.getWeekLabel(date),\n            locked: !this.dateFilter(value)\n        };\n        console.log(\"resultTag\", resultTag);\n        this.dateChange.emit(resultTag);\n      }\n\n    private getWeekLabel(date) {\n      return \"W\" + this.pad( moment(date).isoWeek(), 2) +\n        \" \" + moment(date).year();\n    }\n\n    private getUTCTimestamp(date) {\n        return Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), 12, 0, 0, 0);\n    }\n\n    private getMonday(date) {\n        const day = date.getDay() || 7;\n        if (day !== 1) {\n            date.setHours(-24 * (day - 1));\n        }\n        return date;\n    }\n\n    private getWeekNumberByDate(date: Date) {\n      return this.pad(moment(date).isoWeek(), 2);\n    }\n\n    private pad(n, width, z = \"0\") {\n      z = z || \"0\";\n      n = n + \"\";\n      return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;\n    }\n}\n"]}