我正在尝试创建一个日历页面,用户可以在其中登录PTO(带薪休假)。 初始化时,我要点击一个API并获取日期,为每个日期创建Calendar事件,然后将它们推送到绑定到Radcalendars [eventSource]标签的Array。
这时,用户将根据需要看到现有的ods,ptos和日志/取消。 现有事件或加载后用户推送的事件都不会在Android上显示。
IOS上的页面: EodPtoPage-Ios
Android上的页面: EodPage-Android
EODPTO.COMPONENT.TS
import { Component, OnInit } from "@angular/core";
import { CalendarEvent, CalendarMonthViewStyle, CellStyle, DayCellStyle } from "nativescript-ui-calendar";
import { finalize } from "rxjs/operators";
import { Color } from "tns-core-modules/color/color";
import { isAndroid, isIOS } from "tns-core-modules/platform";
import { confirm } from "tns-core-modules/ui/dialogs";
import { AppComponent } from "~/app.component";
import { Constants } from "~/shared/constants";
import { ReportsService } from "~/shared/services/reports.service";
interface IEod {
IsPTO: number;
PTODate: Date;
}
@Component({
selector: "eodptocalendar",
moduleId: module.id,
templateUrl: "./eodpto.component.html",
styleUrls: ["./eodpto.component.css"]
})
export class EodPtoComponent implements OnInit {
calendarEvents = [];
heading: string;
private _selectedCalendarItem: CalendarEvent;
private _minDate: Date;
private _maxDate: Date;
private _selectedDate: Date;
private _monthViewStyle: CalendarMonthViewStyle;
constructor(private _reportsService: ReportsService, private _app: AppComponent) { }
ngOnInit() {
// Double Tapping in Android shows years so we only double tap log in Ios.
this.heading = isAndroid ? "Tap" : "Double Tap";
this._monthViewStyle = this.getMonthViewStyle();
const date = new Date();
this._minDate = new Date();
this._maxDate = new Date();
this._minDate.setDate(date.getDate() - 7);
this._maxDate.setDate(date.getDate() + 14);
this._reportsService.getPTODates(this._minDate, this._maxDate)
.subscribe(
(result: Array<IEod>) => {
for (const item of result) {
if (item.IsPTO) {
const event = new CalendarEvent("PTO", new Date(item.PTODate), new Date(item.PTODate), true, new Color("Green"));
this.calendarEvents.push(event);
} else {
const event = new CalendarEvent("EOD (No PTO)", new Date(item.PTODate), new Date(item.PTODate), true, new Color("Purple"));
this.calendarEvents.push(event);
}
}
},
() => {
this._app.ShowErrorAlert(Constants.e_GETPTO_ERROR, "Error Retrieving PTO Data");
}
);
}
get monthViewStyle(): CalendarMonthViewStyle {
return this._monthViewStyle;
}
onDateSelected(args) {
this._selectedDate = args.date;
this._selectedCalendarItem = this.calendarEvents.find((x) => x.startDate.toString() === args.date.toString());
if (isAndroid) {
this.showMessage();
}
}
onDoubleTap() {
if (isIOS) {
this.showMessage();
}
}
showMessage(): void {
if (this._selectedDate > this._minDate && this._selectedDate < this._maxDate) {
if (!!this._selectedCalendarItem) {
if (this._selectedCalendarItem.title === "PTO") {
this.EodLogPrompt("Cancel"); // If a PTO already exists on selected date
}
} else {
this.EodLogPrompt("Log"); // If No event(pto OR eod) exists on selected date
}
}
}
EodLogPrompt(logOrcancel?: string): void {
confirm({
title: `${logOrcancel} PTO`,
message: `${logOrcancel} PTO for ${this._reportsService.GetDateFormat(this._selectedDate)} ?`,
okButtonText: "Yes",
cancelButtonText: "Cancel"
}).then((result) => {
if (result) {
if (this._app.isNetworkAvailable) this.LogOrCancelPTO();
}
});
}
LogOrCancelPTO(): void {
this._app.isLoading = true;
this._reportsService.logPTODate(this._selectedDate)
.pipe(finalize(() => this._app.isLoading = false))
.subscribe(
(result) => {
if (result.IsSuccess && result.IsUpdated) {
if (result.IsPTO === 1) {
const newe = new CalendarEvent("PTO", this._selectedDate, this._selectedDate, true, new Color("Green"));
this.calendarEvents.push(newe);
alert(`Your PTO is logged for ${this._reportsService.GetDateFormat(this._selectedDate)}.`);
} else {
this.calendarEvents.splice(this.calendarEvents.indexOf(this._selectedCalendarItem), 1);
alert(`Your PTO is cancelled for ${this._reportsService.GetDateFormat(this._selectedDate)}.`);
}
} else {
if (result.ErrorMsg.isNullOrEmpty) {
if (result.ErrorMsg.toLowerCase() === "none") {
this._app.ShowErrorAlert("The PTO cannot be logged because you do not belong to any EOD distribution list. ");
} else if (result.ErrorMsg.toLowerCase() === "multiple") {
this._app.ShowErrorAlert("The PTO cannot be logged because you belong to multiple EOD distribution lists. ");
} else {
this._app.ShowErrorAlert(result.ErrorMsg);
}
}
}
},
(error: Response | any) => {
this._app.ShowErrorAlert(Constants.e_LOGPTO_ERROR);
console.log(error);
}
);
}
getMonthViewStyle(): CalendarMonthViewStyle {
const monthViewStyle = new CalendarMonthViewStyle();
monthViewStyle.backgroundColor = "White";
monthViewStyle.showTitle = true;
monthViewStyle.showDayNames = true;
const todayCellStyle = new DayCellStyle();
todayCellStyle.cellBackgroundColor = "Yellow";
todayCellStyle.cellTextColor = "Black";
monthViewStyle.todayCellStyle = todayCellStyle;
const dayNameCellStyle = new CellStyle(); // The Day Name Texts
dayNameCellStyle.cellBackgroundColor = "#c3d3d3";
dayNameCellStyle.cellBorderWidth = 1;
dayNameCellStyle.cellBorderColor = "Black";
dayNameCellStyle.cellTextColor = "Black";
dayNameCellStyle.cellTextFontStyle = "Bold";
dayNameCellStyle.cellTextSize = 14;
monthViewStyle.dayNameCellStyle = dayNameCellStyle;
const titleCellStyle = new DayCellStyle(); // The Month Text
titleCellStyle.cellBackgroundColor = "#568BB2";
titleCellStyle.cellBorderWidth = 1;
titleCellStyle.cellBorderColor = "Black";
titleCellStyle.cellTextColor = "Black";
titleCellStyle.cellTextFontStyle = "Bold";
titleCellStyle.cellTextSize = 18;
monthViewStyle.titleCellStyle = titleCellStyle;
return monthViewStyle;
}
}
EOD.COMPONENT.HTML
<Shared-ActionBar pageTitle="EOD PTO"></Shared-ActionBar>
<GridLayout rows="auto, *">
<StackLayout row="0" >
<StackLayout class="instructions m-x-auto p-5">
<StackLayout orientation="horizontal">
<StackLayout id="EOD">
</StackLayout>
<Label class="m-x-5">
<FormattedString>
<Span text="Purple " fontWeight="bold" ></Span>
<Span text="indicates EOD logged." ></Span>
</FormattedString>
</Label>
</StackLayout>
<StackLayout orientation="horizontal">
<StackLayout id="PTO">
</StackLayout>
<Label class="m-x-5">
<FormattedString>
<Span text="Green " fontWeight="bold" ></Span>
<Span text="indicates PTO logged." ></Span>
</FormattedString>
</Label>
</StackLayout>
<StackLayout orientation="horizontal">
<StackLayout id="Today">
</StackLayout>
<Label class="m-x-5">
<FormattedString>
<Span text="Yellow " fontWeight="bold" ></Span>
<Span text="indicates todays date." ></Span>
</FormattedString>
</Label>
</StackLayout>
</StackLayout>
<Label [text]='heading + " on a date to log PTO"' class="h3 text-center" textWrap="true"></Label>
</StackLayout>
<StackLayout row="1">
<RadCalendar
[eventSource]="calendarEvents"
eventsViewMode="Inline"
[minDate]="_minDate"
[maxDate]="_maxDate"
[monthViewStyle]="monthViewStyle"
(dateSelected)="onDateSelected($event)"
(doubleTap)="onDoubleTap($event)" ></RadCalendar>
</StackLayout>
<ActivityIndicator [busy]="_app.isLoading" *ngIf="_app.isLoading" horizontalAlignment="center"
verticalAlignment="center" class="activity-indicator" row="1"></ActivityIndicator>
</GridLayout>
我可以根据要求提供其他任何您想要的东西。我已经尝试过更改样式,更改事件源的类型,更改模块,更改屏幕大小等。什么都没用,我无法在Android中显示事件。