@huntsman-cancer-institute/input 16.0.1 → 17.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/date/date-base.d.ts +65 -65
- package/date/date-date-range.component.d.ts +32 -32
- package/date/date-date.component.d.ts +53 -53
- package/date/date-validator.d.ts +17 -17
- package/date/date.module.d.ts +16 -16
- package/dropdown/dropdown-index.d.ts +6 -6
- package/dropdown/dropdown-select-result.component.d.ts +23 -23
- package/dropdown/dropdown-select.component.d.ts +76 -76
- package/dropdown/dropdown.component.d.ts +40 -40
- package/dropdown/dropdown.module.d.ts +13 -13
- package/dropdown/dropdown.service.d.ts +51 -51
- package/dropdown/messages.d.ts +11 -11
- package/dropdown/select-item.d.ts +16 -16
- package/dropdown/template-dropdown.directive.d.ts +12 -12
- package/esm2022/date/date-base.mjs +114 -114
- package/esm2022/date/date-date-range.component.mjs +92 -92
- package/esm2022/date/date-date.component.mjs +189 -189
- package/esm2022/date/date-validator.mjs +40 -40
- package/esm2022/date/date.module.mjs +60 -60
- package/esm2022/dropdown/dropdown-index.mjs +5 -5
- package/esm2022/dropdown/dropdown-select-result.component.mjs +85 -85
- package/esm2022/dropdown/dropdown-select.component.mjs +360 -360
- package/esm2022/dropdown/dropdown.component.mjs +170 -170
- package/esm2022/dropdown/dropdown.module.mjs +50 -50
- package/esm2022/dropdown/dropdown.service.mjs +133 -133
- package/esm2022/dropdown/messages.mjs +9 -9
- package/esm2022/dropdown/select-item.mjs +11 -11
- package/esm2022/dropdown/template-dropdown.directive.mjs +26 -26
- package/esm2022/huntsman-cancer-institute-input.mjs +4 -4
- package/esm2022/index.mjs +19 -19
- package/esm2022/inline/inline.component.mjs +179 -179
- package/esm2022/inline/inline.module.mjs +28 -28
- package/esm2022/search/search.component.mjs +157 -157
- package/esm2022/search/search.module.mjs +32 -32
- package/esm2022/select/custom-combobox.component.mjs +531 -531
- package/esm2022/select/custom-multi-combobox.component.mjs +232 -232
- package/esm2022/select/md-multi-select.component.mjs +127 -127
- package/esm2022/select/md-select.component.mjs +107 -107
- package/esm2022/select/native-select.component.mjs +188 -188
- package/esm2022/select/select.module.mjs +83 -83
- package/fesm2022/huntsman-cancer-institute-input.mjs +2797 -2797
- package/fesm2022/huntsman-cancer-institute-input.mjs.map +1 -1
- package/index.d.ts +20 -20
- package/inline/inline.component.d.ts +66 -66
- package/inline/inline.module.d.ts +9 -9
- package/package.json +7 -7
- package/search/search.component.d.ts +42 -42
- package/search/search.module.d.ts +10 -10
- package/select/custom-combobox.component.d.ts +98 -98
- package/select/custom-multi-combobox.component.d.ts +50 -50
- package/select/md-multi-select.component.d.ts +32 -32
- package/select/md-select.component.d.ts +30 -30
- package/select/native-select.component.d.ts +37 -37
- package/select/select.module.d.ts +21 -21
|
@@ -1,65 +1,65 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, ViewChild } from "@angular/core";
|
|
2
|
-
import { DateComponent } from "./date-date.component";
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "./date-date.component";
|
|
5
|
-
/**
|
|
6
|
-
* TODO: Confirm timezone behavior.
|
|
7
|
-
*
|
|
8
|
-
* @since 4.0.0
|
|
9
|
-
*/
|
|
10
|
-
export class DateRangeComponent {
|
|
11
|
-
constructor() {
|
|
12
|
-
// Binded data from the parent component.
|
|
13
|
-
this.dateFormat = "shortDate";
|
|
14
|
-
this.inputDataChange = new EventEmitter();
|
|
15
|
-
}
|
|
16
|
-
ngOnInit() {
|
|
17
|
-
this.setRange();
|
|
18
|
-
}
|
|
19
|
-
/**
|
|
20
|
-
*
|
|
21
|
-
*/
|
|
22
|
-
ngAfterViewInit() {
|
|
23
|
-
// if there is no start date but there is an end date, make the start date go to the end date
|
|
24
|
-
if (!this.inputStartData && this.inputEndData) {
|
|
25
|
-
let dt = new Date(this.inputEndData);
|
|
26
|
-
this.sp.startDate = { year: dt.getFullYear(), month: dt.getMonth() + 1, day: dt.getDate() };
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
onClickSubmitStartDate(startData) {
|
|
30
|
-
this.setRange();
|
|
31
|
-
// if there is no start date but there is an end date, make the start date go to the end date
|
|
32
|
-
if (!startData && this.inputEndData) {
|
|
33
|
-
let dt = new Date(this.inputEndData);
|
|
34
|
-
this.sp.startDate = { year: dt.getFullYear(), month: dt.getMonth() + 1, day: dt.getDate() };
|
|
35
|
-
}
|
|
36
|
-
this.inputDataChange.emit([this.inputStartData, this.inputEndData]);
|
|
37
|
-
}
|
|
38
|
-
onClickSubmitEndDate(endData) {
|
|
39
|
-
this.setRange();
|
|
40
|
-
this.inputDataChange.emit([this.inputStartData, this.inputEndData]);
|
|
41
|
-
}
|
|
42
|
-
setRange() {
|
|
43
|
-
// set the minDate to 20 years in the past by default
|
|
44
|
-
let today = new Date();
|
|
45
|
-
if (!this.minStartDate) {
|
|
46
|
-
this.minStartDate = { year: today.getFullYear() - 20, month: today.getMonth() + 1, day: today.getDate() };
|
|
47
|
-
}
|
|
48
|
-
this.minEndDate = this.minStartDate;
|
|
49
|
-
// set the maxDate to today by default
|
|
50
|
-
this.maxStartDate = { year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate() };
|
|
51
|
-
this.maxEndDate = this.maxStartDate;
|
|
52
|
-
if (this.inputEndData) {
|
|
53
|
-
let endDate = new Date(this.inputEndData);
|
|
54
|
-
this.maxStartDate = { year: endDate.getFullYear(), month: endDate.getMonth() + 1, day: endDate.getDate() };
|
|
55
|
-
}
|
|
56
|
-
if (this.inputStartData) {
|
|
57
|
-
let startDate = new Date(this.inputStartData);
|
|
58
|
-
this.minEndDate = { year: startDate.getFullYear(), month: startDate.getMonth() + 1, day: startDate.getDate() };
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
62
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from "@angular/core";
|
|
2
|
+
import { DateComponent } from "./date-date.component";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./date-date.component";
|
|
5
|
+
/**
|
|
6
|
+
* TODO: Confirm timezone behavior.
|
|
7
|
+
*
|
|
8
|
+
* @since 4.0.0
|
|
9
|
+
*/
|
|
10
|
+
export class DateRangeComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
// Binded data from the parent component.
|
|
13
|
+
this.dateFormat = "shortDate";
|
|
14
|
+
this.inputDataChange = new EventEmitter();
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() {
|
|
17
|
+
this.setRange();
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
*
|
|
21
|
+
*/
|
|
22
|
+
ngAfterViewInit() {
|
|
23
|
+
// if there is no start date but there is an end date, make the start date go to the end date
|
|
24
|
+
if (!this.inputStartData && this.inputEndData) {
|
|
25
|
+
let dt = new Date(this.inputEndData);
|
|
26
|
+
this.sp.startDate = { year: dt.getFullYear(), month: dt.getMonth() + 1, day: dt.getDate() };
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
onClickSubmitStartDate(startData) {
|
|
30
|
+
this.setRange();
|
|
31
|
+
// if there is no start date but there is an end date, make the start date go to the end date
|
|
32
|
+
if (!startData && this.inputEndData) {
|
|
33
|
+
let dt = new Date(this.inputEndData);
|
|
34
|
+
this.sp.startDate = { year: dt.getFullYear(), month: dt.getMonth() + 1, day: dt.getDate() };
|
|
35
|
+
}
|
|
36
|
+
this.inputDataChange.emit([this.inputStartData, this.inputEndData]);
|
|
37
|
+
}
|
|
38
|
+
onClickSubmitEndDate(endData) {
|
|
39
|
+
this.setRange();
|
|
40
|
+
this.inputDataChange.emit([this.inputStartData, this.inputEndData]);
|
|
41
|
+
}
|
|
42
|
+
setRange() {
|
|
43
|
+
// set the minDate to 20 years in the past by default
|
|
44
|
+
let today = new Date();
|
|
45
|
+
if (!this.minStartDate) {
|
|
46
|
+
this.minStartDate = { year: today.getFullYear() - 20, month: today.getMonth() + 1, day: today.getDate() };
|
|
47
|
+
}
|
|
48
|
+
this.minEndDate = this.minStartDate;
|
|
49
|
+
// set the maxDate to today by default
|
|
50
|
+
this.maxStartDate = { year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate() };
|
|
51
|
+
this.maxEndDate = this.maxStartDate;
|
|
52
|
+
if (this.inputEndData) {
|
|
53
|
+
let endDate = new Date(this.inputEndData);
|
|
54
|
+
this.maxStartDate = { year: endDate.getFullYear(), month: endDate.getMonth() + 1, day: endDate.getDate() };
|
|
55
|
+
}
|
|
56
|
+
if (this.inputStartData) {
|
|
57
|
+
let startDate = new Date(this.inputStartData);
|
|
58
|
+
this.minEndDate = { year: startDate.getFullYear(), month: startDate.getMonth() + 1, day: startDate.getDate() };
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: DateRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
62
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: DateRangeComponent, selector: "hci-date-range", inputs: { dateFormat: "dateFormat", inputStartData: "inputStartData", inputEndData: "inputEndData", startLabel: "startLabel", endLabel: "endLabel", minStartDate: "minStartDate" }, outputs: { inputDataChange: "inputDataChange" }, viewQueries: [{ propertyName: "sp", first: true, predicate: ["startdate"], descendants: true, static: true }, { propertyName: "ep", first: true, predicate: ["enddate"], descendants: true, static: true }], ngImport: i0, template: `
|
|
63
63
|
<div class="d-flex flex-wrap date-range">
|
|
64
64
|
<hci-date #startdate
|
|
65
65
|
class="date"
|
|
@@ -80,12 +80,12 @@ export class DateRangeComponent {
|
|
|
80
80
|
[maxDate]="maxEndDate">
|
|
81
81
|
</hci-date>
|
|
82
82
|
</div>
|
|
83
|
-
`, isInline: true, dependencies: [{ kind: "component", type: i1.DateComponent, selector: "hci-date", inputs: ["dateFormat", "minDate", "maxDate", "label", "inputData", "modifiedData"], outputs: ["inputDataChange"] }] }); }
|
|
84
|
-
}
|
|
85
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
86
|
-
type: Component,
|
|
87
|
-
args: [{
|
|
88
|
-
selector: "hci-date-range",
|
|
83
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i1.DateComponent, selector: "hci-date", inputs: ["dateFormat", "minDate", "maxDate", "label", "inputData", "modifiedData"], outputs: ["inputDataChange"] }] }); }
|
|
84
|
+
}
|
|
85
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: DateRangeComponent, decorators: [{
|
|
86
|
+
type: Component,
|
|
87
|
+
args: [{
|
|
88
|
+
selector: "hci-date-range",
|
|
89
89
|
template: `
|
|
90
90
|
<div class="d-flex flex-wrap date-range">
|
|
91
91
|
<hci-date #startdate
|
|
@@ -107,27 +107,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
107
107
|
[maxDate]="maxEndDate">
|
|
108
108
|
</hci-date>
|
|
109
109
|
</div>
|
|
110
|
-
`
|
|
111
|
-
}]
|
|
112
|
-
}], propDecorators: { sp: [{
|
|
113
|
-
type: ViewChild,
|
|
114
|
-
args: ["startdate", { static: true }]
|
|
115
|
-
}], ep: [{
|
|
116
|
-
type: ViewChild,
|
|
117
|
-
args: ["enddate", { static: true }]
|
|
118
|
-
}], dateFormat: [{
|
|
119
|
-
type: Input
|
|
120
|
-
}], inputStartData: [{
|
|
121
|
-
type: Input
|
|
122
|
-
}], inputEndData: [{
|
|
123
|
-
type: Input
|
|
124
|
-
}], startLabel: [{
|
|
125
|
-
type: Input
|
|
126
|
-
}], endLabel: [{
|
|
127
|
-
type: Input
|
|
128
|
-
}], inputDataChange: [{
|
|
129
|
-
type: Output
|
|
130
|
-
}], minStartDate: [{
|
|
131
|
-
type: Input
|
|
132
|
-
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
110
|
+
`
|
|
111
|
+
}]
|
|
112
|
+
}], propDecorators: { sp: [{
|
|
113
|
+
type: ViewChild,
|
|
114
|
+
args: ["startdate", { static: true }]
|
|
115
|
+
}], ep: [{
|
|
116
|
+
type: ViewChild,
|
|
117
|
+
args: ["enddate", { static: true }]
|
|
118
|
+
}], dateFormat: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], inputStartData: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], inputEndData: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], startLabel: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], endLabel: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], inputDataChange: [{
|
|
129
|
+
type: Output
|
|
130
|
+
}], minStartDate: [{
|
|
131
|
+
type: Input
|
|
132
|
+
}] } });
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-date-range.component.js","sourceRoot":"","sources":["../../../../projects/input/src/date/date-date-range.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, AfterViewInit, Output, ViewChild} from \"@angular/core\";\r\n\r\nimport {DateComponent} from \"./date-date.component\";\r\n\r\n/**\r\n * TODO: Confirm timezone behavior.\r\n *\r\n * @since 4.0.0\r\n */\r\n@Component({\r\n  selector: \"hci-date-range\",\r\n  template: `  \r\n    <div class=\"d-flex flex-wrap date-range\">\r\n      <hci-date #startdate\r\n                class=\"date\"\r\n                [label]=\"startLabel\"\r\n                [(inputData)]=\"inputStartData\"\r\n                (inputDataChange)=\"onClickSubmitStartDate($event)\"\r\n                [dateFormat]=\"dateFormat\"\r\n                [minDate]=\"minStartDate\"\r\n                [maxDate]=\"maxStartDate\">\r\n      </hci-date>\r\n      <hci-date #enddate\r\n                class=\"date\"\r\n                [label]=\"endLabel\"\r\n                [(inputData)]=\"inputEndData\"\r\n                (inputDataChange)=\"onClickSubmitEndDate($event)\"\r\n                [dateFormat]=\"dateFormat\"\r\n                [minDate]=\"minEndDate\"\r\n                [maxDate]=\"maxEndDate\">\r\n      </hci-date>\r\n    </div>\r\n  `\r\n})\r\nexport class DateRangeComponent implements AfterViewInit {\r\n\r\n    @ViewChild(\"startdate\", {static: true})\r\n    sp: DateComponent;\r\n\r\n    @ViewChild(\"enddate\", {static: true})\r\n    ep: DateComponent;\r\n\r\n   // Binded data from the parent component.\r\n   @Input() dateFormat: string = \"shortDate\";\r\n   @Input() inputStartData: Object;\r\n   @Input() inputEndData: Object;\r\n   @Input() startLabel: string;\r\n   @Input() endLabel: string;\r\n   @Output() inputDataChange = new EventEmitter<any[]>();\r\n\r\n   @Input() minStartDate: any;\r\n   public maxStartDate;\r\n   public minEndDate;\r\n   public maxEndDate;\r\n\r\n   ngOnInit() {\r\n     this.setRange();\r\n   }\r\n\r\n   /**\r\n   *\r\n   */\r\n  ngAfterViewInit() {\r\n     // if there is no start date but there is an end date, make the start date go to the end date\r\n     if (!this.inputStartData && this.inputEndData) {\r\n       let dt: Date = new Date(<string>this.inputEndData);\r\n       this.sp.startDate = {year: dt.getFullYear(), month: dt.getMonth() + 1, day: dt.getDate()};\r\n     }\r\n  }\r\n\r\n  onClickSubmitStartDate(startData) {\r\n    this.setRange();\r\n    // if there is no start date but there is an end date, make the start date go to the end date\r\n    if (!startData && this.inputEndData) {\r\n      let dt: Date = new Date(<string>this.inputEndData);\r\n      this.sp.startDate = {year: dt.getFullYear(), month: dt.getMonth() + 1, day: dt.getDate()};\r\n    }\r\n    this.inputDataChange.emit([this.inputStartData, this.inputEndData]);\r\n  }\r\n\r\n  onClickSubmitEndDate(endData) {\r\n    this.setRange();\r\n    this.inputDataChange.emit([this.inputStartData, this.inputEndData]);\r\n  }\r\n\r\n  private setRange() {\r\n    // set the minDate to 20 years in the past by default\r\n    let today = new Date();\r\n    if (!this.minStartDate) {\r\n        this.minStartDate = {year: today.getFullYear() - 20, month: today.getMonth() + 1, day: today.getDate()};\r\n    }\r\n    this.minEndDate = this.minStartDate;\r\n    // set the maxDate to today by default\r\n    this.maxStartDate = {year: today.getFullYear(), month: today.getMonth() + 1, day: today.getDate()};\r\n    this.maxEndDate = this.maxStartDate;\r\n    if (this.inputEndData) {\r\n        let endDate = new Date(<string>this.inputEndData);\r\n        this.maxStartDate = {year: endDate.getFullYear(), month: endDate.getMonth() + 1, day: endDate.getDate()};\r\n    }\r\n    if (this.inputStartData) {\r\n        let startDate = new Date(<string>this.inputStartData);\r\n        this.minEndDate = {year: startDate.getFullYear(), month: startDate.getMonth() + 1, day: startDate.getDate()};\r\n    }\r\n  }\r\n}\r\n"]}
|