@ng-nest/ui 13.0.2 → 13.0.3
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/carousel/carousel-panel.component.d.ts +2 -3
- package/date-picker/date-picker.property.d.ts +51 -1
- package/date-picker/date-range-portal.component.d.ts +7 -5
- package/date-picker/date-range.component.d.ts +5 -1
- package/date-picker/examples/en_US/default/disabled/README.md +1 -1
- package/date-picker/examples/en_US/default/time/README.md +6 -0
- package/date-picker/examples/zh_CN/default/disabled/README.md +1 -1
- package/date-picker/examples/zh_CN/default/time/README.md +6 -0
- package/date-picker/picker-date.component.d.ts +3 -0
- package/esm2020/button/button.component.mjs +2 -2
- package/esm2020/carousel/carousel-panel.component.mjs +11 -10
- package/esm2020/date-picker/date-picker.property.mjs +72 -2
- package/esm2020/date-picker/date-range-portal.component.mjs +45 -26
- package/esm2020/date-picker/date-range.component.mjs +31 -8
- package/esm2020/date-picker/picker-date.component.mjs +31 -4
- package/esm2020/menu/menu.component.mjs +2 -2
- package/esm2020/table/table.property.mjs +1 -1
- package/fesm2015/ng-nest-ui-button.mjs +2 -2
- package/fesm2015/ng-nest-ui-carousel.mjs +10 -10
- package/fesm2015/ng-nest-ui-carousel.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-date-picker.mjs +175 -36
- package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-menu.mjs +1 -1
- package/fesm2015/ng-nest-ui-menu.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-button.mjs +2 -2
- package/fesm2020/ng-nest-ui-carousel.mjs +10 -9
- package/fesm2020/ng-nest-ui-carousel.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-date-picker.mjs +175 -36
- package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-menu.mjs +1 -1
- package/fesm2020/ng-nest-ui-menu.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
- package/package.json +1 -1
- package/table/table.property.d.ts +1 -1
|
@@ -186,6 +186,31 @@ export class XPickerDateProperty extends XProperty {
|
|
|
186
186
|
* @en_US Display switch button
|
|
187
187
|
*/
|
|
188
188
|
this.showHeader = true;
|
|
189
|
+
/**
|
|
190
|
+
* @zh_CN 上一年
|
|
191
|
+
* @en_US Last year
|
|
192
|
+
*/
|
|
193
|
+
this.lastYearBtn = true;
|
|
194
|
+
/**
|
|
195
|
+
* @zh_CN 上月
|
|
196
|
+
* @en_US Last month
|
|
197
|
+
*/
|
|
198
|
+
this.lastMonthBtn = true;
|
|
199
|
+
/**
|
|
200
|
+
* @zh_CN 下一年
|
|
201
|
+
* @en_US Next year
|
|
202
|
+
*/
|
|
203
|
+
this.nextYearBtn = true;
|
|
204
|
+
/**
|
|
205
|
+
* @zh_CN 上月
|
|
206
|
+
* @en_US Next month
|
|
207
|
+
*/
|
|
208
|
+
this.nextMonthBtn = true;
|
|
209
|
+
/**
|
|
210
|
+
* @zh_CN 范围日期
|
|
211
|
+
* @en_US Range date
|
|
212
|
+
*/
|
|
213
|
+
this.rangeValue = [];
|
|
189
214
|
/**
|
|
190
215
|
* @zh_CN 选择类型
|
|
191
216
|
* @en_US Select type
|
|
@@ -201,16 +226,43 @@ export class XPickerDateProperty extends XProperty {
|
|
|
201
226
|
* @en_US Scope change event
|
|
202
227
|
*/
|
|
203
228
|
this.rangeChange = new EventEmitter();
|
|
229
|
+
/**
|
|
230
|
+
* @zh_CN 选年的事件
|
|
231
|
+
* @en_US Year change event
|
|
232
|
+
*/
|
|
233
|
+
this.yearChange = new EventEmitter();
|
|
234
|
+
/**
|
|
235
|
+
* @zh_CN 选月的事件
|
|
236
|
+
* @en_US Month change event
|
|
237
|
+
*/
|
|
238
|
+
this.monthChange = new EventEmitter();
|
|
239
|
+
/**
|
|
240
|
+
* @zh_CN 显示日期事件
|
|
241
|
+
* @en_US display date event
|
|
242
|
+
*/
|
|
243
|
+
this.displayChange = new EventEmitter();
|
|
204
244
|
}
|
|
205
245
|
}
|
|
206
246
|
/** @nocollapse */ /** @nocollapse */ XPickerDateProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: XPickerDateProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
207
|
-
/** @nocollapse */ /** @nocollapse */ XPickerDateProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.2", type: XPickerDateProperty, selector: "ng-component", inputs: { type: "type", display: "display", model: "model", dateTemp: "dateTemp", showHeader: "showHeader", rangePicker: "rangePicker" }, outputs: { typeChange: "typeChange", modelChange: "modelChange", rangeChange: "rangeChange" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
|
|
247
|
+
/** @nocollapse */ /** @nocollapse */ XPickerDateProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.2", type: XPickerDateProperty, selector: "ng-component", inputs: { type: "type", display: "display", model: "model", dateTemp: "dateTemp", showHeader: "showHeader", rangePicker: "rangePicker", lastYearBtn: "lastYearBtn", lastMonthBtn: "lastMonthBtn", nextYearBtn: "nextYearBtn", nextMonthBtn: "nextMonthBtn", rangeValue: "rangeValue", rangeType: "rangeType" }, outputs: { typeChange: "typeChange", modelChange: "modelChange", rangeChange: "rangeChange", yearChange: "yearChange", monthChange: "monthChange", displayChange: "displayChange" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
|
|
208
248
|
__decorate([
|
|
209
249
|
XInputBoolean()
|
|
210
250
|
], XPickerDateProperty.prototype, "showHeader", void 0);
|
|
211
251
|
__decorate([
|
|
212
252
|
XInputBoolean()
|
|
213
253
|
], XPickerDateProperty.prototype, "rangePicker", void 0);
|
|
254
|
+
__decorate([
|
|
255
|
+
XInputBoolean()
|
|
256
|
+
], XPickerDateProperty.prototype, "lastYearBtn", void 0);
|
|
257
|
+
__decorate([
|
|
258
|
+
XInputBoolean()
|
|
259
|
+
], XPickerDateProperty.prototype, "lastMonthBtn", void 0);
|
|
260
|
+
__decorate([
|
|
261
|
+
XInputBoolean()
|
|
262
|
+
], XPickerDateProperty.prototype, "nextYearBtn", void 0);
|
|
263
|
+
__decorate([
|
|
264
|
+
XInputBoolean()
|
|
265
|
+
], XPickerDateProperty.prototype, "nextMonthBtn", void 0);
|
|
214
266
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: XPickerDateProperty, decorators: [{
|
|
215
267
|
type: Component,
|
|
216
268
|
args: [{ template: '' }]
|
|
@@ -226,12 +278,30 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
|
|
|
226
278
|
type: Input
|
|
227
279
|
}], rangePicker: [{
|
|
228
280
|
type: Input
|
|
281
|
+
}], lastYearBtn: [{
|
|
282
|
+
type: Input
|
|
283
|
+
}], lastMonthBtn: [{
|
|
284
|
+
type: Input
|
|
285
|
+
}], nextYearBtn: [{
|
|
286
|
+
type: Input
|
|
287
|
+
}], nextMonthBtn: [{
|
|
288
|
+
type: Input
|
|
289
|
+
}], rangeValue: [{
|
|
290
|
+
type: Input
|
|
291
|
+
}], rangeType: [{
|
|
292
|
+
type: Input
|
|
229
293
|
}], typeChange: [{
|
|
230
294
|
type: Output
|
|
231
295
|
}], modelChange: [{
|
|
232
296
|
type: Output
|
|
233
297
|
}], rangeChange: [{
|
|
234
298
|
type: Output
|
|
299
|
+
}], yearChange: [{
|
|
300
|
+
type: Output
|
|
301
|
+
}], monthChange: [{
|
|
302
|
+
type: Output
|
|
303
|
+
}], displayChange: [{
|
|
304
|
+
type: Output
|
|
235
305
|
}] } });
|
|
236
306
|
/**
|
|
237
307
|
* PickerMonth
|
|
@@ -369,4 +439,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
|
|
|
369
439
|
}], startChange: [{
|
|
370
440
|
type: Output
|
|
371
441
|
}] } });
|
|
372
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.property.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-picker.property.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  XInputBoolean,\r\n  XProperty,\r\n  XBoolean,\r\n  XCorner,\r\n  XWithConfig,\r\n  XSize,\r\n  XTemplate,\r\n  XDataConvert,\r\n  XData,\r\n  XIdentityProperty\r\n} from '@ng-nest/ui/core';\r\nimport { Input, EventEmitter, Output, TemplateRef, Component } from '@angular/core';\r\nimport { XControlValueAccessor, XFormOption } from '@ng-nest/ui/base-form';\r\n\r\n/**\r\n * DatePicker\r\n * @selector x-date-picker\r\n * @decorator component\r\n */\r\nexport const XDatePickerPrefix = 'x-date-picker';\r\nconst X_CONFIG_NAME = 'datePicker';\r\n\r\n/**\r\n * DatePicker Property\r\n */\r\n@Component({ template: '' })\r\nexport class XDatePickerProperty extends XControlValueAccessor<any> implements XDatePickerOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME, 'yyyy-MM-dd') format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XCorner>(X_CONFIG_NAME, 'bottom-start') placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 快捷选择按钮，支持今天,昨天,明天\r\n   * @en_US Quick selection button, support today, yesterday, tomorrow\r\n   */\r\n  @Input() @XDataConvert() preset: XData<XDatePickerPreset> = [];\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  @Output() nodeEmit = new EventEmitter<number>();\r\n}\r\n\r\n/**\r\n * DatePicker Option\r\n * @undocument true\r\n */\r\nexport interface XDatePickerOption extends XFormOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Choose a type\r\n   */\r\n  type?: XDatePickerType;\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  size?: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  bordered?: XBoolean;\r\n  /**\r\n   * @zh_CN 前置标签\r\n   * @en_US Before label\r\n   */\r\n  before?: XTemplate;\r\n  /**\r\n   * @zh_CN 后置标签\r\n   * @en_US After label\r\n   */\r\n  after?: XTemplate;\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  nodeClick?: (value: number) => void;\r\n}\r\n\r\n/**\r\n * DateRange\r\n * @selector x-date-range\r\n * @decorator component\r\n */\r\nexport const XDateRangePrefix = 'x-date-range';\r\nconst X_CONFIG_RANGE_NAME = 'dateRange';\r\n\r\n/**\r\n * DateRange Property\r\n */\r\n@Component({ template: '' })\r\nexport class XDateRangeProperty extends XControlValueAccessor<any> implements XDateRangeOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_RANGE_NAME, 'yyyy-MM-dd') format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_RANGE_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XCorner>(X_CONFIG_RANGE_NAME, 'bottom-start') placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_RANGE_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_RANGE_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 快捷选择按钮，支持今天,昨天,明天\r\n   * @en_US Quick selection button, support today, yesterday, tomorrow\r\n   */\r\n  @Input() @XDataConvert() preset: XData<XDatePickerPreset> = [];\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  @Output() nodeEmit = new EventEmitter<number[]>();\r\n}\r\n\r\n/**\r\n * DateRange Option\r\n * @undocument true\r\n */\r\nexport interface XDateRangeOption extends XFormOption {\r\n  /**\r\n   * @zh_CN tab 键控制次序\r\n   * @en_US Tab key control order\r\n   */\r\n  tabindex?: number;\r\n}\r\n\r\n/**\r\n * @zh_CN 快捷选择按钮\r\n * @en_US Quick selection button\r\n */\r\nexport interface XDatePickerPreset extends XIdentityProperty {\r\n  /**\r\n   * @zh_CN 自定义函数\r\n   * @en_US Custom function\r\n   */\r\n  func: () => Date;\r\n}\r\n\r\n/**\r\n * @zh_CN 日期选择类型\r\n * @en_US Date selection type\r\n */\r\nexport type XDatePickerType = 'date' | 'month' | 'year' | 'date-time' | 'date-hour' | 'date-minute';\r\n\r\n/**\r\n * @zh_CN 日期数据类型\r\n * @en_US Date data type\r\n */\r\nexport type XDatePickerModelType = 'date' | 'number' | 'string';\r\n\r\n/**\r\n * DatePicker Portal\r\n * @selector x-date-picker-portal\r\n * @decorator component\r\n */\r\nexport const XDatePickerPortalPrefix = 'x-date-picker-portal';\r\n\r\n/**\r\n * DateRange Portal\r\n * @selector x-date-range-portal\r\n * @decorator component\r\n */\r\nexport const XDateRangePortalPrefix = 'x-date-range-portal';\r\n\r\n/**\r\n * PickerDate\r\n * @selector x-picker-date\r\n * @decorator component\r\n */\r\nexport const XPickerDatePrefix = 'x-picker-date';\r\n\r\n/**\r\n * PickerDate Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerDateProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 日期显示模板\r\n   * @en_US Date display template\r\n   */\r\n  @Input() dateTemp?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 范围选择\r\n   * @en_US Range picker\r\n   */\r\n  @Input() @XInputBoolean() rangePicker?: XBoolean;\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 范围变化的事件\r\n   * @en_US Scope change event\r\n   */\r\n  @Output() rangeChange = new EventEmitter<Date[]>();\r\n}\r\n\r\n/**\r\n * PickerMonth\r\n * @selector x-picker-month\r\n * @decorator component\r\n */\r\nexport const XPickerMonthPrefix = 'x-picker-month';\r\n\r\n/**\r\n * PickerMonth Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerMonthProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display: Date = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 月份显示模板\r\n   * @en_US Month display template\r\n   */\r\n  @Input() monthTemp?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 范围变化的事件\r\n   * @en_US Scope change event\r\n   */\r\n  @Output() rangeChange = new EventEmitter<Date[]>();\r\n}\r\n\r\n/**\r\n * PickerYear\r\n * @selector x-picker-year\r\n * @decorator component\r\n */\r\nexport const XPickerYearPrefix = 'x-picker-year';\r\n\r\n/**\r\n * PickerYear Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerYearProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display: Date = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 开始年份变化的事件\r\n   * @en_US Start year change event\r\n   */\r\n  @Output() startChange = new EventEmitter<number>();\r\n}\r\n"]}
|
|
442
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.property.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-picker.property.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  XInputBoolean,\r\n  XProperty,\r\n  XBoolean,\r\n  XCorner,\r\n  XWithConfig,\r\n  XSize,\r\n  XTemplate,\r\n  XDataConvert,\r\n  XData,\r\n  XIdentityProperty\r\n} from '@ng-nest/ui/core';\r\nimport { Input, EventEmitter, Output, TemplateRef, Component } from '@angular/core';\r\nimport { XControlValueAccessor, XFormOption } from '@ng-nest/ui/base-form';\r\n\r\n/**\r\n * DatePicker\r\n * @selector x-date-picker\r\n * @decorator component\r\n */\r\nexport const XDatePickerPrefix = 'x-date-picker';\r\nconst X_CONFIG_NAME = 'datePicker';\r\n\r\n/**\r\n * DatePicker Property\r\n */\r\n@Component({ template: '' })\r\nexport class XDatePickerProperty extends XControlValueAccessor<any> implements XDatePickerOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_NAME, 'yyyy-MM-dd') format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XCorner>(X_CONFIG_NAME, 'bottom-start') placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 快捷选择按钮，支持今天,昨天,明天\r\n   * @en_US Quick selection button, support today, yesterday, tomorrow\r\n   */\r\n  @Input() @XDataConvert() preset: XData<XDatePickerPreset> = [];\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  @Output() nodeEmit = new EventEmitter<number>();\r\n}\r\n\r\n/**\r\n * DatePicker Option\r\n * @undocument true\r\n */\r\nexport interface XDatePickerOption extends XFormOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Choose a type\r\n   */\r\n  type?: XDatePickerType;\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  size?: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  bordered?: XBoolean;\r\n  /**\r\n   * @zh_CN 前置标签\r\n   * @en_US Before label\r\n   */\r\n  before?: XTemplate;\r\n  /**\r\n   * @zh_CN 后置标签\r\n   * @en_US After label\r\n   */\r\n  after?: XTemplate;\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  nodeClick?: (value: number) => void;\r\n}\r\n\r\n/**\r\n * DateRange\r\n * @selector x-date-range\r\n * @decorator component\r\n */\r\nexport const XDateRangePrefix = 'x-date-range';\r\nconst X_CONFIG_RANGE_NAME = 'dateRange';\r\n\r\n/**\r\n * DateRange Property\r\n */\r\n@Component({ template: '' })\r\nexport class XDateRangeProperty extends XControlValueAccessor<any> implements XDateRangeOption {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 格式化类型\r\n   * @en_US Format type\r\n   */\r\n  @Input() @XWithConfig<string>(X_CONFIG_RANGE_NAME, 'yyyy-MM-dd') format?: string;\r\n  /**\r\n   * @zh_CN 清除按钮\r\n   * @en_US Clear button\r\n   */\r\n  @Input() @XWithConfig<XBoolean>(X_CONFIG_RANGE_NAME, true) @XInputBoolean() clearable?: XBoolean;\r\n  /**\r\n   * @zh_CN 展示方位\r\n   * @en_US Display position\r\n   */\r\n  @Input() @XWithConfig<XCorner>(X_CONFIG_RANGE_NAME, 'bottom-start') placement?: XCorner;\r\n  /**\r\n   * @zh_CN 尺寸\r\n   * @en_US Size\r\n   */\r\n  @Input() @XWithConfig<XSize>(X_CONFIG_RANGE_NAME, 'medium') override size!: XSize;\r\n  /**\r\n   * @zh_CN 显示边框\r\n   * @en_US Display Border\r\n   */\r\n  @Input() @XInputBoolean() @XWithConfig<XBoolean>(X_CONFIG_RANGE_NAME, true) bordered!: XBoolean;\r\n  /**\r\n   * @zh_CN 快捷选择按钮，支持今天,昨天,明天\r\n   * @en_US Quick selection button, support today, yesterday, tomorrow\r\n   */\r\n  @Input() @XDataConvert() preset: XData<XDatePickerPreset> = [];\r\n  /**\r\n   * @zh_CN 节点点击的事件\r\n   * @en_US Node click event\r\n   */\r\n  @Output() nodeEmit = new EventEmitter<number[]>();\r\n}\r\n\r\n/**\r\n * DateRange Option\r\n * @undocument true\r\n */\r\nexport interface XDateRangeOption extends XFormOption {\r\n  /**\r\n   * @zh_CN tab 键控制次序\r\n   * @en_US Tab key control order\r\n   */\r\n  tabindex?: number;\r\n}\r\n\r\n/**\r\n * @zh_CN 快捷选择按钮\r\n * @en_US Quick selection button\r\n */\r\nexport interface XDatePickerPreset extends XIdentityProperty {\r\n  /**\r\n   * @zh_CN 自定义函数\r\n   * @en_US Custom function\r\n   */\r\n  func: () => Date;\r\n}\r\n\r\n/**\r\n * @zh_CN 日期选择类型\r\n * @en_US Date selection type\r\n */\r\nexport type XDatePickerType = 'date' | 'month' | 'year' | 'date-time' | 'date-hour' | 'date-minute';\r\n\r\n/**\r\n * @zh_CN 日期数据类型\r\n * @en_US Date data type\r\n */\r\nexport type XDatePickerModelType = 'date' | 'number' | 'string';\r\n\r\n/**\r\n * DatePicker Portal\r\n * @selector x-date-picker-portal\r\n * @decorator component\r\n */\r\nexport const XDatePickerPortalPrefix = 'x-date-picker-portal';\r\n\r\n/**\r\n * DateRange Portal\r\n * @selector x-date-range-portal\r\n * @decorator component\r\n */\r\nexport const XDateRangePortalPrefix = 'x-date-range-portal';\r\n\r\n/**\r\n * PickerDate\r\n * @selector x-picker-date\r\n * @decorator component\r\n */\r\nexport const XPickerDatePrefix = 'x-picker-date';\r\n\r\n/**\r\n * PickerDate Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerDateProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 日期显示模板\r\n   * @en_US Date display template\r\n   */\r\n  @Input() dateTemp?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 范围选择\r\n   * @en_US Range picker\r\n   */\r\n  @Input() @XInputBoolean() rangePicker?: XBoolean;\r\n  /**\r\n   * @zh_CN 上一年\r\n   * @en_US Last year\r\n   */\r\n  @Input() @XInputBoolean() lastYearBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 上月\r\n   * @en_US Last month\r\n   */\r\n  @Input() @XInputBoolean() lastMonthBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 下一年\r\n   * @en_US Next year\r\n   */\r\n  @Input() @XInputBoolean() nextYearBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 上月\r\n   * @en_US Next month\r\n   */\r\n  @Input() @XInputBoolean() nextMonthBtn: XBoolean = true;\r\n  /**\r\n   * @zh_CN 范围日期\r\n   * @en_US Range date\r\n   */\r\n  @Input() rangeValue: number[] = [];\r\n  /**\r\n   * @zh_CN 当前选择的是开始/结束日期\r\n   * @en_US The current choice is the start / end date\r\n   */\r\n  @Input() rangeType!: XDatePickerRangType;\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 范围变化的事件\r\n   * @en_US Scope change event\r\n   */\r\n  @Output() rangeChange = new EventEmitter<Date[]>();\r\n  /**\r\n   * @zh_CN 选年的事件\r\n   * @en_US Year change event\r\n   */\r\n  @Output() yearChange = new EventEmitter<number>();\r\n  /**\r\n   * @zh_CN 选月的事件\r\n   * @en_US Month change event\r\n   */\r\n  @Output() monthChange = new EventEmitter<number>();\r\n  /**\r\n   * @zh_CN 显示日期事件\r\n   * @en_US display date event\r\n   */\r\n  @Output() displayChange = new EventEmitter<Date>();\r\n}\r\n\r\n/**\r\n * @zh_CN 当前选择的是开始/结束日期\r\n * @en_US The current choice is the start / end date\r\n */\r\nexport type XDatePickerRangType = 'start' | 'end';\r\n\r\n/**\r\n * PickerMonth\r\n * @selector x-picker-month\r\n * @decorator component\r\n */\r\nexport const XPickerMonthPrefix = 'x-picker-month';\r\n\r\n/**\r\n * PickerMonth Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerMonthProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display: Date = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 月份显示模板\r\n   * @en_US Month display template\r\n   */\r\n  @Input() monthTemp?: TemplateRef<any>;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 范围变化的事件\r\n   * @en_US Scope change event\r\n   */\r\n  @Output() rangeChange = new EventEmitter<Date[]>();\r\n}\r\n\r\n/**\r\n * PickerYear\r\n * @selector x-picker-year\r\n * @decorator component\r\n */\r\nexport const XPickerYearPrefix = 'x-picker-year';\r\n\r\n/**\r\n * PickerYear Property\r\n */\r\n@Component({ template: '' })\r\nexport class XPickerYearProperty extends XProperty {\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Input() type: XDatePickerType = 'date';\r\n  /**\r\n   * @zh_CN 显示的日期\r\n   * @en_US Date displayed\r\n   */\r\n  @Input() display: Date = new Date();\r\n  /**\r\n   * @zh_CN 选中的日期\r\n   * @en_US Selected date\r\n   */\r\n  @Input() model?: Date;\r\n  /**\r\n   * @zh_CN 显示切换按钮\r\n   * @en_US Display switch button\r\n   */\r\n  @Input() @XInputBoolean() showHeader: XBoolean = true;\r\n  /**\r\n   * @zh_CN 选中的事件\r\n   * @en_US Selected event\r\n   */\r\n  @Output() modelChange = new EventEmitter<Date>();\r\n  /**\r\n   * @zh_CN 选择类型\r\n   * @en_US Select type\r\n   */\r\n  @Output() typeChange = new EventEmitter<XDatePickerType>();\r\n  /**\r\n   * @zh_CN 开始年份变化的事件\r\n   * @en_US Start year change event\r\n   */\r\n  @Output() startChange = new EventEmitter<number>();\r\n}\r\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, ViewEncapsulation, ChangeDetectionStrategy, HostBinding, HostListener } from '@angular/core';
|
|
2
2
|
import { XDateRangePortalPrefix } from './date-picker.property';
|
|
3
|
-
import { XIsEmpty, XConnectBaseAnimation,
|
|
3
|
+
import { XIsEmpty, XConnectBaseAnimation, XAddMonths, XAddYears } from '@ng-nest/ui/core';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
5
|
import { takeUntil, map } from 'rxjs/operators';
|
|
6
6
|
import { DatePipe, LowerCasePipe } from '@angular/common';
|
|
@@ -40,6 +40,10 @@ export class XDateRangePortalComponent {
|
|
|
40
40
|
this.placement = x;
|
|
41
41
|
this.cdr.detectChanges();
|
|
42
42
|
});
|
|
43
|
+
this.inputActiveChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {
|
|
44
|
+
this.activeType = x;
|
|
45
|
+
this.setDefault();
|
|
46
|
+
});
|
|
43
47
|
this.i18n.localeChange
|
|
44
48
|
.pipe(map((x) => x.datePicker), takeUntil(this._unSubject))
|
|
45
49
|
.subscribe((x) => {
|
|
@@ -63,50 +67,65 @@ export class XDateRangePortalComponent {
|
|
|
63
67
|
this.model = this.display;
|
|
64
68
|
this.startModel = this.model;
|
|
65
69
|
this.endModel = XAddMonths(this.model, 1);
|
|
70
|
+
this.setDisplay(this.model);
|
|
66
71
|
}
|
|
67
|
-
this.time = this.model.getTime();
|
|
68
72
|
this._type = this.type;
|
|
69
|
-
this.setDisplay(this.model);
|
|
70
73
|
this.cdr.detectChanges();
|
|
71
74
|
}
|
|
72
75
|
stopPropagation(event) {
|
|
73
76
|
event.stopPropagation();
|
|
74
77
|
}
|
|
75
78
|
setDefault() {
|
|
76
|
-
const
|
|
77
|
-
|
|
78
|
-
if (this.value.length > 0) {
|
|
79
|
+
const type = this.activeType || 'start';
|
|
80
|
+
if (type === 'start') {
|
|
79
81
|
this.startModel = new Date(this.value[0]);
|
|
80
82
|
this.startDisplay = this.startModel;
|
|
83
|
+
this.endModel = XAddMonths(this.startModel, 1);
|
|
84
|
+
this.endDisplay = this.endModel;
|
|
81
85
|
}
|
|
82
|
-
if (
|
|
86
|
+
else if (type === 'end') {
|
|
83
87
|
this.endModel = new Date(this.value[1]);
|
|
84
88
|
this.endDisplay = this.endModel;
|
|
89
|
+
this.startModel = XAddMonths(this.endModel, -1);
|
|
90
|
+
this.startDisplay = this.startModel;
|
|
85
91
|
}
|
|
92
|
+
this.cdr.detectChanges();
|
|
86
93
|
}
|
|
87
94
|
setDisplay(date) {
|
|
88
95
|
this.display = new Date(date.getFullYear(), date.getMonth(), 1);
|
|
89
96
|
this.startDisplay = this.display;
|
|
90
97
|
this.endDisplay = XAddMonths(this.display, 1);
|
|
91
98
|
}
|
|
92
|
-
dateChange(date) {
|
|
99
|
+
dateChange(date, type) {
|
|
93
100
|
let time = date.getTime();
|
|
94
101
|
if (this.value.length === 0) {
|
|
95
|
-
this.value
|
|
102
|
+
this.value = [time];
|
|
96
103
|
this.startNodeEmit(date);
|
|
97
104
|
}
|
|
98
105
|
else if (this.value.length === 1) {
|
|
99
106
|
if (time > this.value[0]) {
|
|
100
|
-
this.value.
|
|
107
|
+
this.value = [...this.value, time];
|
|
101
108
|
this.endNodeEmit(date);
|
|
102
109
|
}
|
|
103
110
|
else {
|
|
104
|
-
this.value.
|
|
111
|
+
this.value = [time, ...this.value];
|
|
105
112
|
this.startNodeEmit(date);
|
|
106
113
|
this.endNodeEmit(new Date(this.value[1]));
|
|
107
114
|
}
|
|
108
115
|
this.nodeEmit(this.value.map((x) => new Date(x)));
|
|
109
116
|
}
|
|
117
|
+
else {
|
|
118
|
+
if (type === 'start') {
|
|
119
|
+
this.value = [time, this.value[1]];
|
|
120
|
+
this.startNodeEmit(date);
|
|
121
|
+
}
|
|
122
|
+
else if (type === 'end') {
|
|
123
|
+
this.value = [this.value[0], time];
|
|
124
|
+
this.cdr.detectChanges();
|
|
125
|
+
this.endNodeEmit(date);
|
|
126
|
+
}
|
|
127
|
+
this.nodeEmit(this.value.map((x) => new Date(x)), type !== 'start');
|
|
128
|
+
}
|
|
110
129
|
}
|
|
111
130
|
typeChange(type) {
|
|
112
131
|
this.type = type;
|
|
@@ -160,18 +179,6 @@ export class XDateRangePortalComponent {
|
|
|
160
179
|
getLocaleMonth(date) {
|
|
161
180
|
return this.locale[this.lowerCasePipe.transform(this.datePipe.transform(date, 'LLLL'))];
|
|
162
181
|
}
|
|
163
|
-
onToday() {
|
|
164
|
-
this.dateChange(new Date());
|
|
165
|
-
}
|
|
166
|
-
onYesterday() {
|
|
167
|
-
this.dateChange(XAddDays(new Date(), -1));
|
|
168
|
-
}
|
|
169
|
-
onTomorrow() {
|
|
170
|
-
this.dateChange(XAddDays(new Date(), 1));
|
|
171
|
-
}
|
|
172
|
-
onPresetFunc(item) {
|
|
173
|
-
this.dateChange(item.func());
|
|
174
|
-
}
|
|
175
182
|
selectTime(time) {
|
|
176
183
|
this.time = time.getTime();
|
|
177
184
|
// this.nodeEmit(this.setModel(this.model, time), false);
|
|
@@ -181,12 +188,24 @@ export class XDateRangePortalComponent {
|
|
|
181
188
|
this.model = new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes(), time.getSeconds());
|
|
182
189
|
return this.model;
|
|
183
190
|
}
|
|
191
|
+
startYearChange(num) {
|
|
192
|
+
this.endDisplay = XAddYears(this.endDisplay, num);
|
|
193
|
+
}
|
|
194
|
+
endYearChange(num) {
|
|
195
|
+
this.startDisplay = XAddYears(this.startDisplay, num);
|
|
196
|
+
}
|
|
197
|
+
startMonthChange(num) {
|
|
198
|
+
this.endDisplay = XAddMonths(this.endDisplay, num);
|
|
199
|
+
}
|
|
200
|
+
endMonthChange(num) {
|
|
201
|
+
this.startDisplay = XAddMonths(this.startDisplay, num);
|
|
202
|
+
}
|
|
184
203
|
}
|
|
185
204
|
/** @nocollapse */ /** @nocollapse */ XDateRangePortalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: XDateRangePortalComponent, deps: [{ token: i1.DatePipe }, { token: i1.LowerCasePipe }, { token: i0.ChangeDetectorRef }, { token: i2.XI18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
186
|
-
/** @nocollapse */ /** @nocollapse */ XDateRangePortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.2", type: XDateRangePortalComponent, selector: "x-date-range-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], ngImport: i0, template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-
|
|
205
|
+
/** @nocollapse */ /** @nocollapse */ XDateRangePortalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.2", type: XDateRangePortalComponent, selector: "x-date-range-portal", host: { listeners: { "@x-connect-base-animation.done": "done($event)", "@x-connect-base-animation.start": "start($event)" }, properties: { "@x-connect-base-animation": "this.placement" } }, providers: [DatePipe, LowerCasePipe], ngImport: i0, template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-body\">\r\n <x-picker-date\r\n class=\"x-date-range-portal-start\"\r\n [(display)]=\"startDisplay\"\r\n [model]=\"startModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [nextYearBtn]=\"false\"\r\n [nextMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'start')\"\r\n (yearChange)=\"startYearChange($event)\"\r\n (monthChange)=\"startMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n <x-picker-date\r\n class=\"x-date-range-portal-end\"\r\n [(display)]=\"endDisplay\"\r\n [model]=\"endModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [lastYearBtn]=\"false\"\r\n [lastMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'end')\"\r\n (yearChange)=\"endYearChange($event)\"\r\n (monthChange)=\"endMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-range-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:34rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-range-portal.date-time{width:27rem}.x-date-range-portal.date-hour{width:19.75rem}.x-date-range-portal.date-minute{width:23.375rem}.x-date-range-portal-content{display:flex}.x-date-range-portal-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset>x-button{flex:1}.x-date-range-portal-year-month{flex:1;text-align:center}.x-date-range-portal-body{display:flex}.x-date-range-portal-start{flex:1}.x-date-range-portal-end{flex:1}.x-date-range-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-range-portal-date{flex:1}.x-date-range-portal-time{display:flex;flex-direction:column}.x-date-range-portal-time-label{padding:.4rem;text-align:center;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-range-portal-time .x-time-picker-frame{border-width:var(--x-border-width) 0 0 var(--x-border-width);box-shadow:none}\n"], components: [{ type: i3.XPickerDateComponent, selector: "x-picker-date" }, { type: i4.XButtonComponent, selector: "x-button" }], directives: [{ type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "date": i1.DatePipe }, animations: [XConnectBaseAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
187
206
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: XDateRangePortalComponent, decorators: [{
|
|
188
207
|
type: Component,
|
|
189
|
-
args: [{ selector: `${XDateRangePortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-
|
|
208
|
+
args: [{ selector: `${XDateRangePortalPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, animations: [XConnectBaseAnimation], providers: [DatePipe, LowerCasePipe], template: "<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <div class=\"x-date-range-portal-body\">\r\n <x-picker-date\r\n class=\"x-date-range-portal-start\"\r\n [(display)]=\"startDisplay\"\r\n [model]=\"startModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [nextYearBtn]=\"false\"\r\n [nextMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'start')\"\r\n (yearChange)=\"startYearChange($event)\"\r\n (monthChange)=\"startMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n <x-picker-date\r\n class=\"x-date-range-portal-end\"\r\n [(display)]=\"endDisplay\"\r\n [model]=\"endModel\"\r\n [rangeValue]=\"value\"\r\n [rangeType]=\"activeType\"\r\n [lastYearBtn]=\"false\"\r\n [lastMonthBtn]=\"false\"\r\n (modelChange)=\"dateChange($event, 'end')\"\r\n (yearChange)=\"endYearChange($event)\"\r\n (monthChange)=\"endMonthChange($event)\"\r\n rangePicker\r\n ></x-picker-date>\r\n </div>\r\n </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n <div class=\"x-date-range-portal-year-month\">\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n </div>\r\n <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n", styles: ["@charset \"UTF-8\";.x-date-range-portal{margin:.0625rem 0;font-size:var(--x-font-size);color:var(--x-text);border:var(--x-border-width) var(--x-border-style) var(--x-border);border-radius:var(--x-border-radius);box-shadow:var(--x-box-shadow) var(--x-box-shadow-light-color);background-color:var(--x-background);width:34rem;display:flex;flex-direction:column;font-size:var(--x-font-size-small)}.x-date-range-portal.date-time{width:27rem}.x-date-range-portal.date-hour{width:19.75rem}.x-date-range-portal.date-minute{width:23.375rem}.x-date-range-portal-content{display:flex}.x-date-range-portal-header{display:flex;align-items:center;justify-content:space-between;padding:.4rem;border-bottom:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset{display:flex;align-items:center;justify-content:center;border-top:var(--x-border-width) solid var(--x-border)}.x-date-range-portal-preset>x-button{flex:1}.x-date-range-portal-year-month{flex:1;text-align:center}.x-date-range-portal-body{display:flex}.x-date-range-portal-start{flex:1}.x-date-range-portal-end{flex:1}.x-date-range-portal-footer{display:flex;justify-content:flex-end;border-top:var(--x-border-width) var(--x-border-style) var(--x-border);padding:.5rem}.x-date-range-portal-date{flex:1}.x-date-range-portal-time{display:flex;flex-direction:column}.x-date-range-portal-time-label{padding:.4rem;text-align:center;border-left:var(--x-border-width) var(--x-border-style) var(--x-border)}.x-date-range-portal-time .x-time-picker-frame{border-width:var(--x-border-width) 0 0 var(--x-border-width);box-shadow:none}\n"] }]
|
|
190
209
|
}], ctorParameters: function () { return [{ type: i1.DatePipe }, { type: i1.LowerCasePipe }, { type: i0.ChangeDetectorRef }, { type: i2.XI18nService }]; }, propDecorators: { placement: [{
|
|
191
210
|
type: HostBinding,
|
|
192
211
|
args: ['@x-connect-base-animation']
|
|
@@ -197,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
|
|
|
197
216
|
type: HostListener,
|
|
198
217
|
args: ['@x-connect-base-animation.start', ['$event']]
|
|
199
218
|
}] } });
|
|
200
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-range-portal.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-range-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  OnInit,\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  HostBinding,\r\n  HostListener\r\n} from '@angular/core';\r\nimport { XDateRangePortalPrefix, XDatePickerPreset, XDatePickerType } from './date-picker.property';\r\nimport { XIsEmpty, XConnectBaseAnimation, XPositionTopBottom, XAddDays, XAddMonths } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, map } from 'rxjs/operators';\r\nimport { DatePipe, LowerCasePipe } from '@angular/common';\r\nimport { XI18nService, XI18nDatePicker } from '@ng-nest/ui/i18n';\r\n\r\n@Component({\r\n  selector: `${XDateRangePortalPrefix}`,\r\n  templateUrl: './date-range-portal.component.html',\r\n  styleUrls: ['./date-range-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XConnectBaseAnimation],\r\n  providers: [DatePipe, LowerCasePipe]\r\n})\r\nexport class XDateRangePortalComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  @HostBinding('@x-connect-base-animation') public placement!: XPositionTopBottom;\r\n  @HostListener('@x-connect-base-animation.done', ['$event']) done(event: { toState: any }) {\r\n    this.animating(false);\r\n    event.toState === 'void' && this.destroyPortal();\r\n  }\r\n  @HostListener('@x-connect-base-animation.start', ['$event']) start() {\r\n    this.animating(true);\r\n  }\r\n\r\n  type: XDatePickerType = 'date';\r\n  display = new Date();\r\n  model!: Date;\r\n  startModel!: Date;\r\n  endModel!: Date;\r\n  startYear!: number;\r\n  startDisplay: Date = new Date();\r\n  endDisplay: Date = XAddMonths(this.startDisplay, 1);\r\n  value: number[] = [];\r\n  valueChange!: Subject<number[]>;\r\n  positionChange!: Subject<any>;\r\n  animating!: Function;\r\n  closePortal!: Function;\r\n  destroyPortal!: Function;\r\n  nodeEmit!: (date: Date[], sure?: boolean) => void;\r\n  startNodeEmit!: (date: Date) => void;\r\n  endNodeEmit!: (date: Date) => void;\r\n  locale: XI18nDatePicker = {};\r\n  time!: number;\r\n  preset: XDatePickerPreset[] = [];\r\n  private _type!: XDatePickerType;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(public datePipe: DatePipe, public lowerCasePipe: LowerCasePipe, public cdr: ChangeDetectorRef, public i18n: XI18nService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.valueChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.value = x;\r\n      this.init();\r\n    });\r\n    this.positionChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.placement = x;\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.datePicker as XI18nDatePicker),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.init();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  init() {\r\n    if (!XIsEmpty(this.value)) {\r\n      this.setDefault();\r\n    } else {\r\n      this.value = [];\r\n      this.model = this.display;\r\n      this.startModel = this.model;\r\n      this.endModel = XAddMonths(this.model, 1);\r\n    }\r\n    this.time = this.model.getTime();\r\n    this._type = this.type;\r\n    this.setDisplay(this.model);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  stopPropagation(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  setDefault() {\r\n    const date = new Date();\r\n    this.model = date;\r\n    if (this.value.length > 0) {\r\n      this.startModel = new Date(this.value[0]);\r\n      this.startDisplay = this.startModel;\r\n    }\r\n    if (this.value.length > 1) {\r\n      this.endModel = new Date(this.value[1]);\r\n      this.endDisplay = this.endModel;\r\n    }\r\n  }\r\n\r\n  setDisplay(date: Date) {\r\n    this.display = new Date(date.getFullYear(), date.getMonth(), 1);\r\n    this.startDisplay = this.display;\r\n    this.endDisplay = XAddMonths(this.display, 1);\r\n  }\r\n\r\n  dateChange(date: Date) {\r\n    let time = date.getTime();\r\n    if (this.value.length === 0) {\r\n      this.value.push(time);\r\n      this.startNodeEmit(date);\r\n    } else if (this.value.length === 1) {\r\n      if (time > this.value[0]) {\r\n        this.value.push(time);\r\n        this.endNodeEmit(date);\r\n      } else {\r\n        this.value.unshift(time);\r\n        this.startNodeEmit(date);\r\n        this.endNodeEmit(new Date(this.value[1]));\r\n      }\r\n      this.nodeEmit(this.value.map((x) => new Date(x)));\r\n    }\r\n  }\r\n\r\n  typeChange(type: XDatePickerType) {\r\n    this.type = type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  monthChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'month') {\r\n      this.model = date;\r\n      // this.nodeEmit(date);\r\n    } else {\r\n      this.type = this._type;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'year') {\r\n      this.model = date;\r\n      // this.nodeEmit(date);\r\n    } else {\r\n      this.type = 'month';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearStartChange(number: number) {\r\n    this.startYear = number;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextMonth(num: number) {\r\n    let date = new Date(this.display);\r\n    date.setMonth(date.getMonth() + num);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextYear(num: number) {\r\n    let date = new Date(this.display);\r\n    date.setFullYear(date.getFullYear() + num);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextYears(num: number) {\r\n    this.startYear += num;\r\n    let date = new Date(this.display);\r\n    date.setFullYear(this.startYear);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  getLocaleMonth(date: Date) {\r\n    return (this.locale as any)[this.lowerCasePipe.transform(this.datePipe.transform(date, 'LLLL') as string)];\r\n  }\r\n\r\n  onToday() {\r\n    this.dateChange(new Date());\r\n  }\r\n\r\n  onYesterday() {\r\n    this.dateChange(XAddDays(new Date(), -1));\r\n  }\r\n\r\n  onTomorrow() {\r\n    this.dateChange(XAddDays(new Date(), 1));\r\n  }\r\n\r\n  onPresetFunc(item: XDatePickerPreset) {\r\n    this.dateChange(item.func());\r\n  }\r\n\r\n  selectTime(time: Date) {\r\n    this.time = time.getTime();\r\n    // this.nodeEmit(this.setModel(this.model, time), false);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setModel(date: Date, time: Date) {\r\n    this.model = new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes(), time.getSeconds());\r\n    return this.model;\r\n  }\r\n}\r\n","<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n  <ng-container *ngSwitchCase=\"'date'\">\r\n    <div class=\"x-date-range-portal-header\">\r\n      <ng-container *ngTemplateOutlet=\"startDateHeaderTpl\"></ng-container>\r\n      <ng-container *ngTemplateOutlet=\"endDateHeaderTpl\"></ng-container>\r\n    </div>\r\n    <div class=\"x-date-range-portal-body\">\r\n      <x-picker-date\r\n        class=\"x-date-range-portal-start\"\r\n        [display]=\"startDisplay\"\r\n        [model]=\"startModel\"\r\n        (modelChange)=\"dateChange($event)\"\r\n        rangePicker\r\n      ></x-picker-date>\r\n      <x-picker-date\r\n        class=\"x-date-range-portal-end\"\r\n        [display]=\"endDisplay\"\r\n        [model]=\"endModel\"\r\n        (modelChange)=\"dateChange($event)\"\r\n        rangePicker\r\n      ></x-picker-date>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n  <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n  <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n  <div class=\"x-date-range-portal-year-month\">\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n  </div>\r\n  <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n  <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n  <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n  <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n  <div class=\"x-date-range-portal-year-month\">\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n  </div>\r\n  <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n  <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-portal.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/date-picker/date-range-portal.component.ts","../../../../../lib/ng-nest/ui/date-picker/date-range-portal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  OnInit,\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  HostBinding,\r\n  HostListener\r\n} from '@angular/core';\r\nimport { XDateRangePortalPrefix, XDatePickerPreset, XDatePickerType } from './date-picker.property';\r\nimport { XIsEmpty, XConnectBaseAnimation, XPositionTopBottom, XAddMonths, XAddYears } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, map } from 'rxjs/operators';\r\nimport { DatePipe, LowerCasePipe } from '@angular/common';\r\nimport { XI18nService, XI18nDatePicker } from '@ng-nest/ui/i18n';\r\n\r\n@Component({\r\n  selector: `${XDateRangePortalPrefix}`,\r\n  templateUrl: './date-range-portal.component.html',\r\n  styleUrls: ['./date-range-portal.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [XConnectBaseAnimation],\r\n  providers: [DatePipe, LowerCasePipe]\r\n})\r\nexport class XDateRangePortalComponent implements OnInit, OnDestroy, AfterViewInit {\r\n  @HostBinding('@x-connect-base-animation') public placement!: XPositionTopBottom;\r\n  @HostListener('@x-connect-base-animation.done', ['$event']) done(event: { toState: any }) {\r\n    this.animating(false);\r\n    event.toState === 'void' && this.destroyPortal();\r\n  }\r\n  @HostListener('@x-connect-base-animation.start', ['$event']) start() {\r\n    this.animating(true);\r\n  }\r\n\r\n  type: XDatePickerType = 'date';\r\n  display = new Date();\r\n  model!: Date;\r\n  startModel!: Date;\r\n  endModel!: Date;\r\n  startYear!: number;\r\n  startDisplay: Date = new Date();\r\n  endDisplay: Date = XAddMonths(this.startDisplay, 1);\r\n  value: number[] = [];\r\n  valueChange!: Subject<number[]>;\r\n  positionChange!: Subject<any>;\r\n  inputActiveChange!: Subject<'start' | 'end'>;\r\n  activeType!: 'start' | 'end';\r\n  animating!: Function;\r\n  closePortal!: Function;\r\n  destroyPortal!: Function;\r\n  nodeEmit!: (date: Date[], sure?: boolean) => void;\r\n  startNodeEmit!: (date: Date) => void;\r\n  endNodeEmit!: (date: Date) => void;\r\n  locale: XI18nDatePicker = {};\r\n  time!: number;\r\n  preset: XDatePickerPreset[] = [];\r\n  private _type!: XDatePickerType;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(public datePipe: DatePipe, public lowerCasePipe: LowerCasePipe, public cdr: ChangeDetectorRef, public i18n: XI18nService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.valueChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.value = x;\r\n      this.init();\r\n    });\r\n    this.positionChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.placement = x;\r\n      this.cdr.detectChanges();\r\n    });\r\n    this.inputActiveChange.pipe(takeUntil(this._unSubject)).subscribe((x) => {\r\n      this.activeType = x;\r\n      this.setDefault();\r\n    });\r\n    this.i18n.localeChange\r\n      .pipe(\r\n        map((x) => x.datePicker as XI18nDatePicker),\r\n        takeUntil(this._unSubject)\r\n      )\r\n      .subscribe((x) => {\r\n        this.locale = x;\r\n        this.cdr.markForCheck();\r\n      });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.init();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  init() {\r\n    if (!XIsEmpty(this.value)) {\r\n      this.setDefault();\r\n    } else {\r\n      this.value = [];\r\n      this.model = this.display;\r\n      this.startModel = this.model;\r\n      this.endModel = XAddMonths(this.model, 1);\r\n      this.setDisplay(this.model);\r\n    }\r\n    this._type = this.type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  stopPropagation(event: Event): void {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  setDefault() {\r\n    const type = this.activeType || 'start';\r\n    if (type === 'start') {\r\n      this.startModel = new Date(this.value[0]);\r\n      this.startDisplay = this.startModel;\r\n      this.endModel = XAddMonths(this.startModel, 1);\r\n      this.endDisplay = this.endModel;\r\n    } else if (type === 'end') {\r\n      this.endModel = new Date(this.value[1]);\r\n      this.endDisplay = this.endModel;\r\n      this.startModel = XAddMonths(this.endModel, -1);\r\n      this.startDisplay = this.startModel;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setDisplay(date: Date) {\r\n    this.display = new Date(date.getFullYear(), date.getMonth(), 1);\r\n    this.startDisplay = this.display;\r\n    this.endDisplay = XAddMonths(this.display, 1);\r\n  }\r\n\r\n  dateChange(date: Date, type: 'start' | 'end') {\r\n    let time = date.getTime();\r\n    if (this.value.length === 0) {\r\n      this.value = [time];\r\n      this.startNodeEmit(date);\r\n    } else if (this.value.length === 1) {\r\n      if (time > this.value[0]) {\r\n        this.value = [...this.value, time];\r\n        this.endNodeEmit(date);\r\n      } else {\r\n        this.value = [time, ...this.value];\r\n        this.startNodeEmit(date);\r\n        this.endNodeEmit(new Date(this.value[1]));\r\n      }\r\n      this.nodeEmit(this.value.map((x) => new Date(x)));\r\n    } else {\r\n      if (type === 'start') {\r\n        this.value = [time, this.value[1]];\r\n        this.startNodeEmit(date);\r\n      } else if (type === 'end') {\r\n        this.value = [this.value[0], time];\r\n        this.cdr.detectChanges();\r\n        this.endNodeEmit(date);\r\n      }\r\n      this.nodeEmit(\r\n        this.value.map((x) => new Date(x)),\r\n        type !== 'start'\r\n      );\r\n    }\r\n  }\r\n\r\n  typeChange(type: XDatePickerType) {\r\n    this.type = type;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  monthChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'month') {\r\n      this.model = date;\r\n      // this.nodeEmit(date);\r\n    } else {\r\n      this.type = this._type;\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearChange(date: Date) {\r\n    this.setDisplay(date);\r\n    if (this._type === 'year') {\r\n      this.model = date;\r\n      // this.nodeEmit(date);\r\n    } else {\r\n      this.type = 'month';\r\n    }\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  yearStartChange(number: number) {\r\n    this.startYear = number;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextMonth(num: number) {\r\n    let date = new Date(this.display);\r\n    date.setMonth(date.getMonth() + num);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextYear(num: number) {\r\n    let date = new Date(this.display);\r\n    date.setFullYear(date.getFullYear() + num);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  nextYears(num: number) {\r\n    this.startYear += num;\r\n    let date = new Date(this.display);\r\n    date.setFullYear(this.startYear);\r\n    this.setDisplay(date);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  getLocaleMonth(date: Date) {\r\n    return (this.locale as any)[this.lowerCasePipe.transform(this.datePipe.transform(date, 'LLLL') as string)];\r\n  }\r\n\r\n  selectTime(time: Date) {\r\n    this.time = time.getTime();\r\n    // this.nodeEmit(this.setModel(this.model, time), false);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setModel(date: Date, time: Date) {\r\n    this.model = new Date(date.getFullYear(), date.getMonth(), date.getDate(), time.getHours(), time.getMinutes(), time.getSeconds());\r\n    return this.model;\r\n  }\r\n\r\n  startYearChange(num: number) {\r\n    this.endDisplay = XAddYears(this.endDisplay, num);\r\n  }\r\n\r\n  endYearChange(num: number) {\r\n    this.startDisplay = XAddYears(this.startDisplay, num);\r\n  }\r\n\r\n  startMonthChange(num: number) {\r\n    this.endDisplay = XAddMonths(this.endDisplay, num);\r\n  }\r\n\r\n  endMonthChange(num: number) {\r\n    this.startDisplay = XAddMonths(this.startDisplay, num);\r\n  }\r\n}\r\n","<div class=\"x-date-range-portal {{ type }}\" [ngSwitch]=\"type\">\r\n  <ng-container *ngSwitchCase=\"'date'\">\r\n    <div class=\"x-date-range-portal-body\">\r\n      <x-picker-date\r\n        class=\"x-date-range-portal-start\"\r\n        [(display)]=\"startDisplay\"\r\n        [model]=\"startModel\"\r\n        [rangeValue]=\"value\"\r\n        [rangeType]=\"activeType\"\r\n        [nextYearBtn]=\"false\"\r\n        [nextMonthBtn]=\"false\"\r\n        (modelChange)=\"dateChange($event, 'start')\"\r\n        (yearChange)=\"startYearChange($event)\"\r\n        (monthChange)=\"startMonthChange($event)\"\r\n        rangePicker\r\n      ></x-picker-date>\r\n      <x-picker-date\r\n        class=\"x-date-range-portal-end\"\r\n        [(display)]=\"endDisplay\"\r\n        [model]=\"endModel\"\r\n        [rangeValue]=\"value\"\r\n        [rangeType]=\"activeType\"\r\n        [lastYearBtn]=\"false\"\r\n        [lastMonthBtn]=\"false\"\r\n        (modelChange)=\"dateChange($event, 'end')\"\r\n        (yearChange)=\"endYearChange($event)\"\r\n        (monthChange)=\"endMonthChange($event)\"\r\n        rangePicker\r\n      ></x-picker-date>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n\r\n<ng-template #startDateHeaderTpl>\r\n  <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\"></x-button>\r\n  <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\"></x-button>\r\n  <div class=\"x-date-range-portal-year-month\">\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ startDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(startDisplay) }}</x-button>\r\n  </div>\r\n  <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n  <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon style=\"visibility: hidden\"></x-button>\r\n</ng-template>\r\n\r\n<ng-template #endDateHeaderTpl>\r\n  <x-button icon=\"fto-chevrons-left\" size=\"small\" onlyIcon (click)=\"nextYear(-1)\" style=\"visibility: hidden\"></x-button>\r\n  <x-button icon=\"fto-chevron-left\" size=\"small\" onlyIcon (click)=\"nextMonth(-1)\" style=\"visibility: hidden\"></x-button>\r\n  <div class=\"x-date-range-portal-year-month\">\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('year')\">{{ endDisplay | date: 'yyyy' }}{{ locale.year }}</x-button>\r\n    <x-button type=\"text\" size=\"small\" (click)=\"typeChange('month')\">{{ getLocaleMonth(endDisplay) }}</x-button>\r\n  </div>\r\n  <x-button icon=\"fto-chevron-right\" size=\"small\" onlyIcon (click)=\"nextMonth(1)\"></x-button>\r\n  <x-button icon=\"fto-chevrons-right\" size=\"small\" onlyIcon (click)=\"nextYear(1)\"></x-button>\r\n</ng-template>\r\n"]}
|