All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.javarosa.xform.util.XFormAnswerDataSerializer Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (C) 2009 JavaRosa
 *
 * 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 org.javarosa.xform.util;

import java.util.Date;
import java.util.ArrayList;
import java.util.List;

import org.javarosa.core.data.IDataPointer;
import org.javarosa.core.model.IAnswerDataSerializer;
import org.javarosa.core.model.data.BooleanData;
import org.javarosa.core.model.data.DateData;
import org.javarosa.core.model.data.DateTimeData;
import org.javarosa.core.model.data.DecimalData;
import org.javarosa.core.model.data.GeoTraceData;
import org.javarosa.core.model.data.GeoPointData;
import org.javarosa.core.model.data.GeoShapeData;
import org.javarosa.core.model.data.IAnswerData;
import org.javarosa.core.model.data.IntegerData;
import org.javarosa.core.model.data.LongData;
import org.javarosa.core.model.data.MultiPointerAnswerData;
import org.javarosa.core.model.data.PointerAnswerData;
import org.javarosa.core.model.data.MultipleItemsData;
import org.javarosa.core.model.data.SelectOneData;
import org.javarosa.core.model.data.StringData;
import org.javarosa.core.model.data.TimeData;
import org.javarosa.core.model.data.UncastData;
import org.javarosa.core.model.data.helper.Selection;
import org.javarosa.core.model.utils.DateUtils;
import org.kxml2.kdom.Element;

/**
 * The XFormAnswerDataSerializer takes in AnswerData objects, and provides
 * an XForms compliant (String or Element) representation of that AnswerData.
 *
 * By default, this serializer can properly operate on StringData, DateData
 * MultipleItemsData, and SelectOneData AnswerData objects. This list can be
 * extended by registering appropriate XForm serializing AnswerDataSerializers
 * with this class.
 *
 * @author Clayton Sims
 *
 */
public class XFormAnswerDataSerializer implements IAnswerDataSerializer {

    public final static String DELIMITER = " ";

   List additionalSerializers = new ArrayList(1);

    public void registerAnswerSerializer(IAnswerDataSerializer ads) {
        additionalSerializers.add(ads);
    }

    public boolean canSerialize(IAnswerData data) {
        if (data instanceof StringData || data instanceof DateData || data instanceof TimeData ||
            data instanceof MultipleItemsData || data instanceof SelectOneData ||
            data instanceof IntegerData || data instanceof DecimalData || data instanceof PointerAnswerData    ||
            data instanceof MultiPointerAnswerData ||
            data instanceof GeoPointData || data instanceof GeoTraceData || data instanceof GeoShapeData ||
            data instanceof LongData || data instanceof DateTimeData || data instanceof UncastData) {
            return true;
        } else {
            return false;
        }
    }

    /**
     * @param data The AnswerDataObject to be serialized
     * @return A String which contains the given answer
     */
    public Object serializeAnswerData(UncastData data) {
        return data.getString();
    }


    /**
     * @param data The AnswerDataObject to be serialized
     * @return A String which contains the given answer
     */
    public Object serializeAnswerData(StringData data) {
        return (String)data.getValue();
    }

    /**
     * @param data The AnswerDataObject to be serialized
     * @return A String which contains a date in xsd:date
     * formatting
     */
    public Object serializeAnswerData(DateData data) {
        return DateUtils.formatDate((Date)data.getValue(), DateUtils.FORMAT_ISO8601);
    }

    /**
     * @param data The AnswerDataObject to be serialized
     * @return A String which contains a date in xsd:date
     * formatting
     */
    public Object serializeAnswerData(DateTimeData data) {
        return DateUtils.formatDateTime((Date)data.getValue(), DateUtils.FORMAT_ISO8601);
    }

    /**
     * @param data The AnswerDataObject to be serialized
     * @return A String which contains a date in xsd:time
     * formatting
     */
    public Object serializeAnswerData(TimeData data) {
        return DateUtils.formatTime((Date)data.getValue(), DateUtils.FORMAT_ISO8601);
    }

    /**
     * @param data The AnswerDataObject to be serialized
     * @return A String which contains a reference to the
     * data
     */
    public Object serializeAnswerData(PointerAnswerData data) {
        //Note: In order to override this default behavior, a
        //new serializer should be used, and then registered
        //with this serializer
        IDataPointer pointer = (IDataPointer)data.getValue();
        return pointer.getDisplayText();
    }

    /**
     * @param data The AnswerDataObject to be serialized
     * @return A String which contains a reference to the
     * data
     */
    public Object serializeAnswerData(MultiPointerAnswerData data) {
        //Note: In order to override this default behavior, a
        //new serializer should be used, and then registered
        //with this serializer
        IDataPointer[] pointers = (IDataPointer[])data.getValue();
        if(pointers.length == 1) {
            return pointers[0].getDisplayText();
        }
        Element parent = new Element();
        for(int i = 0; i < pointers.length; ++i) {
            Element datael = new Element();
            datael.setName("data");

            datael.addChild(Element.TEXT, pointers[i].getDisplayText());
            parent.addChild(Element.ELEMENT, datael);
        }
        return parent;
    }

    /**
     * @param data The AnswerDataObject to be serialized
     * @return A string containing the xforms compliant format
     * for a