/// Version 1.0.0
/// Last modified 24.5.2014
///
/// Copyright (C) 2014 Atte Söderlund
///
/// Halyri-system is a prototype emergency call system. Its purpose is to
/// demonstrate the use of the advanced capabilities available in the current
/// generation smartphones in facilitating the emergency service dispatcher's
/// capability to determine the nature of the emergency and to dispatch help.
///
/// For more information, see the README file of this package.
///
/// The MIT License (MIT)
///
/// Permission is hereby granted, free of charge, to any person obtaining a copy
/// of this software and associated documentation files (the "Software"), to
/// deal in the Software without restriction, including without limitation the
/// rights to use, copy, modify, merge, publish, distribute, sublicense,
/// and/or sell copies of the Software, and to permit persons to whom the
/// Software is furnished to do so, subject to the following conditions:
///
/// The above copyright notice and this permission notice shall be included in
/// all copies or substantial portions of the Software.
///
/// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
/// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
/// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
/// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
/// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
/// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
/// IN THE SOFTWARE.
///
using System;
using System.Diagnostics;
using System.Globalization;
using System.Windows.Data;
namespace Hake_WPF.Conversion
{
    /// Atte Söderlund
    /// 
    /// The class converter for phonenumbers. It is used to convert a array of phonenumbers to a string.
    /// 
    [ValueConversion(typeof(String[]), typeof(String))]
    class PhoneNumberConverter : IValueConverter
    {
        /// 
        /// Converts string[] to string so that each unit from string[] is in one string.
        /// 
        /// The string[] of phone numbers.
        /// Not in use. Specifies target type.
        /// Not in use. Converting parameters.
        /// Not in use. Culture info to be used in the conversion.
        /// Returns phone numbers as string.
        public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
        {
            try
            {
                String[] phoneNumbers = (String[])value;
                String returnString = phoneNumbers[0];
                for (int i = 1; i < phoneNumbers.Length; i++)
                    returnString = returnString + "\n" + phoneNumbers[i];
                return returnString;
            }
            catch (Exception e)
            {
                Debug.WriteLine("Cannot cast value to String[] on converter: " + e.Message);
            }
            return null;
        }
        /// 
        /// Method to convert phone numbers back to original. Returns always null because this method is not implemented.
        /// 
        /// String.
        /// Not in use. Specifies target type.
        /// Not in use. Converting parameters.
        /// Not in use. Culture info to be used in the conversion.
        /// Returns the orginal value.
        /// 
        public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
        {
            return null;
        }
    }
}