|
|
|
import {
|
|
|
|
VTapeLayout,
|
|
|
|
CenterLayout,
|
|
|
|
shortcut,
|
|
|
|
Widget,
|
|
|
|
createItems,
|
|
|
|
i18nText,
|
|
|
|
isNull,
|
|
|
|
isEmptyObject,
|
|
|
|
isEmptyString,
|
|
|
|
isNotEmptyObject,
|
|
|
|
getDate
|
|
|
|
} from "@/core";
|
|
|
|
import { LinearSegment } from "@/case";
|
|
|
|
import { Tab, TextButton, ButtonGroup } from "@/base";
|
|
|
|
import { StaticDateTimePaneCard } from "./card.static.datetimepane";
|
|
|
|
import { DynamicDateCard, DynamicDateCombo, DynamicDateHelper } from "../dynamicdate";
|
|
|
|
import { DynamicDatePane } from "../datepane";
|
|
|
|
|
|
|
|
@shortcut()
|
|
|
|
export class DynamicDateTimePane extends Widget {
|
|
|
|
static xtype = "bi.dynamic_date_time_pane";
|
|
|
|
|
|
|
|
static EVENT_CHANGE = "EVENT_CHANGE";
|
|
|
|
static EVENT_BEFORE_YEAR_MONTH_POPUPVIEW = "EVENT_BEFORE_YEAR_MONTH_POPUPVIEW";
|
|
|
|
|
|
|
|
static Static = 1;
|
|
|
|
static Dynamic = 2;
|
|
|
|
|
|
|
|
props = {
|
|
|
|
baseCls: "bi-dynamic-date-pane",
|
|
|
|
minDate: "1900-01-01",
|
|
|
|
maxDate: "2099-12-31",
|
|
|
|
supportDynamic: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const o = this.options;
|
|
|
|
|
|
|
|
return {
|
|
|
|
type: VTapeLayout.xtype,
|
|
|
|
items: [
|
|
|
|
{
|
|
|
|
el: {
|
|
|
|
type: LinearSegment.xtype,
|
|
|
|
invisible: !o.supportDynamic,
|
|
|
|
cls: "bi-split-bottom",
|
|
|
|
height: 30,
|
|
|
|
items: createItems(
|
|
|
|
[
|
|
|
|
{
|
|
|
|
text: i18nText("BI-Multi_Date_YMD"),
|
|
|
|
value: DynamicDateTimePane.Static,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: i18nText("BI-Basic_Dynamic_Title"),
|
|
|
|
value: DynamicDateTimePane.Dynamic,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
{
|
|
|
|
textAlign: "center",
|
|
|
|
}
|
|
|
|
),
|
|
|
|
listeners: [
|
|
|
|
{
|
|
|
|
eventName: ButtonGroup.EVENT_CHANGE,
|
|
|
|
action: () => {
|
|
|
|
const value = this.switcher.getValue()[0];
|
|
|
|
let date;
|
|
|
|
this.dateTab.setSelect(value);
|
|
|
|
switch (value) {
|
|
|
|
case DynamicDateTimePane.Static:
|
|
|
|
date = DynamicDateHelper.getCalculation(this.dynamicPane.getValue());
|
|
|
|
this.ymd.setValue({
|
|
|
|
year: date.getFullYear(),
|
|
|
|
month: date.getMonth() + 1,
|
|
|
|
day: date.getDate(),
|
|
|
|
});
|
|
|
|
break;
|
|
|
|
case DynamicDateTimePane.Dynamic:
|
|
|
|
this.dynamicPane.setValue({
|
|
|
|
year: 0,
|
|
|
|
});
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
this.fireEvent(DynamicDateTimePane.EVENT_CHANGE);
|
|
|
|
},
|
|
|
|
}
|
|
|
|
],
|
|
|
|
ref: _ref => {
|
|
|
|
this.switcher = _ref;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
height: o.supportDynamic ? 30 : 0,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: Tab.xtype,
|
|
|
|
ref: _ref => {
|
|
|
|
this.dateTab = _ref;
|
|
|
|
},
|
|
|
|
showIndex: DynamicDateTimePane.Static,
|
|
|
|
cardCreator: v => {
|
|
|
|
switch (v) {
|
|
|
|
case DynamicDateTimePane.Static:
|
|
|
|
return {
|
|
|
|
type: StaticDateTimePaneCard.xtype,
|
|
|
|
min: o.minDate,
|
|
|
|
max: o.maxDate,
|
|
|
|
behaviors: o.behaviors,
|
|
|
|
listeners: [
|
|
|
|
{
|
|
|
|
eventName: "EVENT_CHANGE",
|
|
|
|
action: () => {
|
|
|
|
this.fireEvent(DynamicDateTimePane.EVENT_CHANGE);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
eventName: "EVENT_BEFORE_YEAR_MONTH_POPUPVIEW",
|
|
|
|
action: () => {
|
|
|
|
this.fireEvent(DynamicDateTimePane.EVENT_BEFORE_YEAR_MONTH_POPUPVIEW);
|
|
|
|
},
|
|
|
|
}
|
|
|
|
],
|
|
|
|
ref: _ref => {
|
|
|
|
this.ymd = _ref;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
case DynamicDateTimePane.Dynamic:
|
|
|
|
default:
|
|
|
|
return {
|
|
|
|
type: VTapeLayout.xtype,
|
|
|
|
items: [
|
|
|
|
{
|
|
|
|
type: DynamicDateCard.xtype,
|
|
|
|
min: o.minDate,
|
|
|
|
max: o.maxDate,
|
|
|
|
ref: _ref => {
|
|
|
|
this.dynamicPane = _ref;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
el: {
|
|
|
|
type: CenterLayout.xtype,
|
|
|
|
items: [
|
|
|
|
{
|
|
|
|
type: TextButton.xtype,
|
|
|
|
cls: "bi-high-light bi-border-top",
|
|
|
|
shadow: true,
|
|
|
|
text: i18nText("BI-Basic_Clear"),
|
|
|
|
textHeight: 23,
|
|
|
|
listeners: [
|
|
|
|
{
|
|
|
|
eventName: TextButton.EVENT_CHANGE,
|
|
|
|
action: () => {
|
|
|
|
this.setValue();
|
|
|
|
this.fireEvent(DynamicDatePane.EVENT_CHANGE);
|
|
|
|
},
|
|
|
|
}
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: TextButton.xtype,
|
|
|
|
cls: "bi-border-left bi-high-light bi-border-top",
|
|
|
|
textHeight: 23,
|
|
|
|
shadow: true,
|
|
|
|
text: i18nText("BI-Basic_OK"),
|
|
|
|
listeners: [
|
|
|
|
{
|
|
|
|
eventName: TextButton.EVENT_CHANGE,
|
|
|
|
action: () => {
|
|
|
|
const type = this.dateTab.getSelect();
|
|
|
|
if (type === DynamicDateCombo.Dynamic) {
|
|
|
|
this.dynamicPane.checkValidation(true) &&
|
|
|
|
this.fireEvent(
|
|
|
|
DynamicDatePane.EVENT_CHANGE
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
this.fireEvent(DynamicDatePane.EVENT_CHANGE);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
|
|
|
],
|
|
|
|
}
|
|
|
|
],
|
|
|
|
},
|
|
|
|
height: 24,
|
|
|
|
}
|
|
|
|
],
|
|
|
|
};
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
|
|
|
],
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
created() {
|
|
|
|
this.setValue(this.options.value);
|
|
|
|
}
|
|
|
|
|
|
|
|
_checkValueValid(value) {
|
|
|
|
return isNull(value) || isEmptyObject(value) || isEmptyString(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
_checkValue(v) {
|
|
|
|
switch (v.type) {
|
|
|
|
case DynamicDateCombo.Dynamic:
|
|
|
|
return isNotEmptyObject(v.value);
|
|
|
|
case DynamicDateCombo.Static:
|
|
|
|
default:
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
setMinDate(minDate) {
|
|
|
|
if (this.options.minDate !== minDate) {
|
|
|
|
this.options.minDate = minDate;
|
|
|
|
this.ymd.setMinDate(minDate);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
setMaxDate(maxDate) {
|
|
|
|
if (this.options.maxDate !== maxDate) {
|
|
|
|
this.options.maxDate = maxDate;
|
|
|
|
this.ymd.setMaxDate(maxDate);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
setValue(v) {
|
|
|
|
v = v || {};
|
|
|
|
const type = v.type || DynamicDateTimePane.Static;
|
|
|
|
const value = v.value || v;
|
|
|
|
this.switcher.setValue(type);
|
|
|
|
this.dateTab.setSelect(type);
|
|
|
|
switch (type) {
|
|
|
|
case DynamicDateTimePane.Dynamic:
|
|
|
|
this.dynamicPane.setValue(value);
|
|
|
|
break;
|
|
|
|
case DynamicDateTimePane.Static:
|
|
|
|
default:
|
|
|
|
if (this._checkValueValid(value)) {
|
|
|
|
const date = getDate();
|
|
|
|
this.ymd.setValue({
|
|
|
|
year: date.getFullYear(),
|
|
|
|
month: date.getMonth() + 1,
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
this.ymd.setValue(value);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
getValue() {
|
|
|
|
return {
|
|
|
|
type: this.dateTab.getSelect(),
|
|
|
|
value: this.dateTab.getValue(),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|