| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- /*
- * Apache 2.0 License
- *
- * Copyright (c) Sebastian Katzer 2017
- *
- * This file contains Original Code and/or Modifications of Original Code
- * as defined in and that are subject to the Apache License
- * Version 2.0 (the 'License'). You may not use this file except in
- * compliance with the License. Please obtain a copy of the License at
- * http://opensource.org/licenses/Apache-2.0/ and read it before using this
- * file.
- *
- * The Original Code and all software distributed under the License are
- * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
- * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
- * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
- * Please see the License for the specific language governing rights and
- * limitations under the License.
- */
- package de.appplant.cordova.plugin.notification.trigger;
- import java.util.Calendar;
- import java.util.Date;
- /**
- * Trigger class for interval based notification. Trigger by a fixed interval
- * from now.
- */
- public class IntervalTrigger extends DateTrigger {
- // The number of ticks per interval
- private final int ticks;
- // The unit of the ticks
- final Unit unit;
- /**
- * Interval trigger based from now.
- *
- * @param ticks The number of ticks per interval.
- * @param unit The unit of the ticks.
- */
- public IntervalTrigger(int ticks, Unit unit) {
- this.ticks = ticks;
- this.unit = unit;
- }
- /**
- * Gets the next trigger date.
- *
- * @param base The date from where to calculate the trigger date.
- *
- * @return null if there's none next trigger date.
- */
- @Override
- public Date getNextTriggerDate(Date base) {
- Calendar cal = getCal(base);
- addInterval(cal);
- incOccurrence();
- return cal.getTime();
- }
- /**
- * Adds the amount of ticks to the calendar.
- *
- * @param cal The calendar to manipulate.
- *
- * @return The calendar instance.
- */
- Calendar addInterval(Calendar cal) {
- switch (unit) {
- case SECOND:
- cal.add(Calendar.SECOND, ticks);
- break;
- case MINUTE:
- cal.add(Calendar.MINUTE, ticks);
- break;
- case HOUR:
- cal.add(Calendar.HOUR_OF_DAY, ticks);
- break;
- case DAY:
- cal.add(Calendar.DAY_OF_YEAR, ticks);
- break;
- case WEEK:
- cal.add(Calendar.WEEK_OF_YEAR, ticks);
- break;
- case MONTH:
- cal.add(Calendar.MONTH, ticks);
- break;
- case QUARTER:
- cal.add(Calendar.MONTH, ticks * 3);
- break;
- case YEAR:
- cal.add(Calendar.YEAR, ticks);
- break;
- }
- return cal;
- }
- }
|