/*******************************************************************************
* Copyright 2010 Atos Worldline SAS
*
* Licensed by Atos Worldline SAS under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* Atos Worldline SAS licenses this file to You 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 net.padaf.xmpbox.type;
import java.io.IOException;
import java.util.Calendar;
import net.padaf.xmpbox.XMPMetadata;
import net.padaf.xmpbox.parser.DateConverter;
/**
* Object representation of a Date XMP type
*
* @author a183132
*
*/
public class DateType extends AbstractSimpleProperty {
/**
* Property Date type constructor (namespaceURI is not given)
*
* @param metadata
* The metadata to attach to this property
* @param prefix
* The prefix to set for this property
* @param propertyName
* The local Name of this property
* @param value
* The value to set for this property
*/
public DateType(XMPMetadata metadata, String prefix, String propertyName,
Object value) {
super(metadata, prefix, propertyName, value);
}
/**
* Property Date type constructor (namespaceURI is given)
*
* @param metadata
* The metadata to attach to this property
* @param namespaceURI
* the namespace URI to associate to this property
* @param prefix
* The prefix to set for this property
* @param propertyName
* The local Name of this property
* @param value
* The value to set for this property
*/
public DateType(XMPMetadata metadata, String namespaceURI, String prefix,
String propertyName, Object value) {
super(metadata, namespaceURI, prefix, propertyName, value);
}
/**
* Set property value
*
* @param value
* the new Calendar element value
* @throws InappropriateTypeException
*/
private void setValueFromCalendar(Calendar value) {
objValue = value;
element.setTextContent(DateConverter.toISO8601(value));
}
/**
* return the property value
*
* @return boolean
*/
public Calendar getValue() {
return (Calendar) objValue;
}
/**
* Check if the value has a type which can be understood
*
* @param value
* Object value to check
* @return True if types are compatibles
*/
public boolean isGoodType(Object value) {
if (value instanceof Calendar) {
return true;
} else if (value instanceof String) {
try {
DateConverter.toCalendar((String) value);
return true;
} catch (IOException e) {
return false;
}
}
return false;
}
/**
* Set value of this property
*
* @param value
* The value to set
*/
public void setValue(Object value) {
if (!isGoodType(value)) {
throw new IllegalArgumentException(
"Value given is not allowed for the Date type.");
} else {
// if string object
if (value instanceof String) {
setValueFromString((String) value);
} else {
// if Calendar
setValueFromCalendar((Calendar) value);
}
}
}
/**
* Set the property value with a String
*
* @param value
* The String value
*/
private void setValueFromString(String value) {
try {
setValueFromCalendar(DateConverter.toCalendar((String) value));
} catch (IOException e) {
// SHOULD NEVER HAPPEN
// STRING HAS BEEN CHECKED BEFORE
throw new IllegalArgumentException(e.getCause());
}
}
}