kr.debop4j.timeperiod.timerange.WeekRange.java Source code

Java tutorial

Introduction

Here is the source code for kr.debop4j.timeperiod.timerange.WeekRange.java

Source

/*
 * Copyright 2011-2013 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package kr.debop4j.timeperiod.timerange;

import kr.debop4j.timeperiod.ITimeCalendar;
import kr.debop4j.timeperiod.ITimePeriod;
import kr.debop4j.timeperiod.TimeCalendar;
import kr.debop4j.timeperiod.tools.Times;
import lombok.extern.slf4j.Slf4j;
import org.joda.time.DateTime;

/**
 *  (Week) .
 *
 * @author ? sunghyouk.bae@gmail.com
 * @since 13. 5. 13.  3:30
 */
@Slf4j
public class WeekRange extends WeekTimeRange {

    // region << Constructor >>

    /** Instantiates a new Week range. */
    public WeekRange() {
        this(new TimeCalendar());
    }

    /**
     * Instantiates a new Week range.
     *
     * @param timeCalendar the time calendar
     */
    public WeekRange(ITimeCalendar timeCalendar) {
        this(Times.now(), timeCalendar);
    }

    /**
     * Instantiates a new Week range.
     *
     * @param moment the moment
     */
    public WeekRange(DateTime moment) {
        this(moment, new TimeCalendar());
    }

    /**
     * Instantiates a new Week range.
     *
     * @param moment       the moment
     * @param timeCalendar the time calendar
     */
    public WeekRange(DateTime moment, ITimeCalendar timeCalendar) {
        super(moment, 1, timeCalendar);
    }

    /**
     * Instantiates a new Week range.
     *
     * @param period       the period
     * @param timeCalendar the time calendar
     */
    public WeekRange(ITimePeriod period, ITimeCalendar timeCalendar) {
        super(period, timeCalendar);
    }

    /**
     * Instantiates a new Week range.
     *
     * @param moment       the moment
     * @param weekCount    the week count
     * @param timeCalendar the time calendar
     */
    public WeekRange(DateTime moment, int weekCount, ITimeCalendar timeCalendar) {
        super(moment, weekCount, timeCalendar);
    }

    /**
     * Instantiates a new Week range.
     *
     * @param year       the year
     * @param weekOfYear the week of year
     */
    public WeekRange(int year, int weekOfYear) {
        super(year, weekOfYear, 1);
    }

    /**
     * Instantiates a new Week range.
     *
     * @param year         the year
     * @param weekOfYear   the week of year
     * @param timeCalendar the time calendar
     */
    public WeekRange(int year, int weekOfYear, ITimeCalendar timeCalendar) {
        super(year, weekOfYear, 1, timeCalendar);
    }

    // endregion

    /**
     * Gets week of year.
     *
     * @return the week of year
     */
    public int getWeekOfYear() {
        return getStartWeekOfYear();
    }

    /**
     * Gets first day of week.
     *
     * @return the first day of week
     */
    public DateTime getFirstDayOfWeek() {
        return getStart();
    }

    /**
     * Gets last day of week.
     *
     * @return the last day of week
     */
    public DateTime getLastDayOfWeek() {
        return getStart().plusDays(6);
    }

    /**
     * Is multiple calendar years.
     *
     * @return the boolean
     */
    public boolean isMultipleCalendarYears() {
        return getTimeCalendar().getYear(getFirstDayOfWeek()) != getTimeCalendar().getYear(getLastDayOfWeek());
    }

    /**
     * Previous week.
     *
     * @return the week range
     */
    public WeekRange previousWeek() {
        return addWeeks(-1);
    }

    /**
     * Next week.
     *
     * @return the week range
     */
    public WeekRange nextWeek() {
        return addWeeks(1);
    }

    /**
     * Add weeks.
     *
     * @param weeks the weeks
     * @return the week range
     */
    public WeekRange addWeeks(int weeks) {
        DateTime startOfWeek = Times.getStartOfYearWeek(getYear(), getStartWeekOfYear(), getTimeCalendar());
        return new WeekRange(startOfWeek.plusWeeks(weeks), getTimeCalendar());
    }

    private static final long serialVersionUID = 562359121625029972L;
}