001    /**
002     * Copyright 2005-2013 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     */
016    package org.kuali.rice.kew.api.document.attribute;
017    
018    import org.joda.time.DateTime;
019    import org.kuali.rice.core.api.util.jaxb.DateTimeAdapter;
020    
021    import javax.xml.bind.annotation.XmlAccessType;
022    import javax.xml.bind.annotation.XmlAccessorType;
023    import javax.xml.bind.annotation.XmlElement;
024    import javax.xml.bind.annotation.XmlRootElement;
025    import javax.xml.bind.annotation.XmlType;
026    import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter;
027    
028    /**
029     * A document attribute which contains date/time data.  Construct instances of {@code DocumentAttributeDateTime} using
030     * it's builder or the {@link DocumentAttributeFactory}.
031     *
032     * @author Kuali Rice Team (rice.collab@kuali.org)
033     */
034    @XmlRootElement(name = DocumentAttributeDateTime.Constants.ROOT_ELEMENT_NAME)
035    @XmlAccessorType(XmlAccessType.NONE)
036    @XmlType(name = DocumentAttributeDateTime.Constants.TYPE_NAME, propOrder = {
037        DocumentAttributeDateTime.Elements.VALUE
038    })
039    public final class DocumentAttributeDateTime extends DocumentAttribute {
040    
041        @XmlElement(name = Elements.VALUE, required = false)
042        @XmlJavaTypeAdapter(DateTimeAdapter.class)
043        private final DateTime value;
044    
045        @SuppressWarnings("unused")
046        private DocumentAttributeDateTime() {
047            this.value = null;
048        }
049    
050        private DocumentAttributeDateTime(Builder builder) {
051            super(builder.getName());
052            this.value = builder.getValue();
053        }
054    
055        @Override
056        public DateTime getValue() {
057            return value;
058        }
059    
060        @Override
061        public DocumentAttributeDataType getDataType() {
062            return DocumentAttributeDataType.DATE_TIME;
063        }
064    
065        /**
066         * A builder implementation which allows for construction of a {@code DocumentAttributeDateTime}.
067         */
068        public static final class Builder extends AbstractBuilder<DateTime> {
069    
070            private Builder(String name) {
071                super(name);
072            }
073    
074            /**
075             * Create a builder for the document attribute using the given attribute name.
076             *
077             * @param name the name of the document attribute which should be built by this builder, should never be a
078             * null or blank value
079             * @return a builder instance initialized with the given attribute name
080             */
081            public static Builder create(String name) {
082                return new Builder(name);
083            }
084    
085            @Override
086            public DocumentAttributeDataType getDataType() {
087                return DocumentAttributeDataType.DATE_TIME;
088            }
089    
090            @Override
091            public DocumentAttributeDateTime build() {
092                return new DocumentAttributeDateTime(this);
093            }
094            
095        }
096    
097        /**
098         * Defines some internal constants used on this class.
099         */
100        static class Constants {
101            final static String ROOT_ELEMENT_NAME = "documentAttributeDateTime";
102            final static String TYPE_NAME = "DocumentAttributeDateTimeType";
103        }
104    
105        /**
106         * A private class which exposes constants which define the XML element names to use when this object is marshalled to XML.
107         */
108        static class Elements {
109            final static String VALUE = "value";
110        }
111    
112    }