001/**
002 * Copyright 2005-2017 The Kuali Foundation
003 *
004 * Licensed under the Educational Community License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.opensource.org/licenses/ecl2.php
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016package org.kuali.rice.kim.bo.ui;
017
018import javax.persistence.Column;
019import javax.persistence.MappedSuperclass;
020import javax.persistence.Transient;
021import java.sql.Timestamp;
022
023/**
024 * This is a description of what this class does - shyu don't forget to fill this in. 
025 * 
026 * @author Kuali Rice Team (rice.collab@kuali.org)
027 *
028 */
029@MappedSuperclass
030public class KimDocumentBoActivatableToFromBase  extends KimDocumentBoBase {
031    private static final long serialVersionUID = 9042706897191231671L;
032
033        @Column(name="ACTV_FRM_DT")
034        protected Timestamp activeFromDate;
035        @Column(name="ACTV_TO_DT")
036        protected Timestamp activeToDate;
037
038        //@Type(type="yes_no")
039        @Column(name="ACTV_IND")
040    protected boolean active = true;
041
042        @Transient
043        protected boolean edit;
044
045        public void setActive(boolean active) {
046                this.active = active;
047        }
048
049        /**
050         * @return the activeFromDate
051         */
052        public Timestamp getActiveFromDate() {
053                return this.activeFromDate;
054        }
055
056        /**
057         * @param activeFromDate the activeFromDate to set
058         */
059        public void setActiveFromDate(Timestamp activeFromDate) {
060                this.activeFromDate = activeFromDate;
061        }
062
063        /**
064         * @return the activeToDate
065         */
066        public Timestamp getActiveToDate() {
067                return this.activeToDate;
068        }
069
070        /**
071         * @param activeToDate the activeToDate to set
072         */
073        public void setActiveToDate(Timestamp activeToDate) {
074                this.activeToDate = activeToDate;
075        }
076
077        public boolean isActive() {
078                long now = System.currentTimeMillis();          
079                return (activeFromDate == null || now > activeFromDate.getTime()) && (activeToDate == null || now < activeToDate.getTime());
080        }
081
082        /**
083         * @return the edit
084         */
085        public boolean isEdit() {
086                return this.edit;
087        }
088
089        /**
090         * @param edit the edit to set
091         */
092        public void setEdit(boolean edit) {
093                this.edit = edit;
094        }
095}