Exemple #1
0
        /// <summary>
        /// 
        ///     GetToText methode returen the translated string, if defined int the Translate table. 
        ///     If the fromText is not found, the value of fromText is returned unchanged.
        ///     Multiple definitions for the same source string can be registered, and in case, 
        ///     the property and context fields must be used to separate them.    
        /// 
        /// </summary>
        /// <param name="fromText"> The string to be translated </param>
        /// <param name="context"> The context the definition is aimed for. </param>
        /// <param name="propType"> The row type. This is to be used to pinpoint the search string if multiple definitions exists </param>
        /// <returns> The translated string contained in the ToText field </returns>
        public static string GetToText(EnumsXlt.Criterias criteria, string fromText, EnumsXlt.PropertyTypes property, string context, string toLanguageCode = "no")
        {
            if (fromText.Trim() == "")
                return "";

            List<Model.Translation> coll = new List<Model.Translation>();
            using (var ctx = new Model.TranslationEntities())
            {
                if (string.IsNullOrEmpty(toLanguageCode)) 
                    toLanguageCode = "no";

                // Do search by criteria
                coll = (from xl in ctx.Translation
                        where xl.Criteria.ToLower() == criteria.ToString().ToLower() &&
                              xl.FromLang == FromLanguageCode && 
                              xl.FromText == fromText && 
                              xl.Property.ToLower() == property.ToString().ToLower() &&
                              xl.Context.ToLower() == context.ToLower() &&
                              xl.ToLang == toLanguageCode
                        select xl).ToList();

                return (coll != null && coll.Count > 0) ? coll.First().ToText : fromText;  
            }
        }
Exemple #2
0
        /// <summary>
        /// 
        ///     ToText methode returen the translated string, if defined int the Translate table. 
        ///     If the fromText is not found, the value of fromText is returned unchanged.
        ///     Multiple definitions for the same source string can be registered, and in case, 
        ///     the context and rowtype fields must be used to separate them.    
        /// 
        /// </summary>
        /// <param name="fromText"> The string to be translated </param>
        /// <param name="context"> The context the definition is aimed for. </param>
        /// <param name="propType"> The row type. This is to be used to pinpoint the search string if multiple definitions exists </param>
        /// <returns> The translated string contained in the ToText field </returns>
        public static string ToText(EnumsXlt.Criterias criteria, string fromText, EnumsXlt.PropertyTypes property, string context, string toLanguageCode = "no")
        {
            if (fromText.Trim() == "")
                return ""; 

            GetTranslations();

            if (string.IsNullOrEmpty(toLanguageCode))
                toLanguageCode = "no";

            // Serach collection
            foreach (Model.Translation xl in _translateColl)
            {
                if (xl.Criteria.ToLower() == criteria.ToString().ToLower() &&
                    xl.FromLang == FromLanguageCode &&
                    xl.FromText == fromText &&
                    xl.Property.ToLower() == property.ToString().ToLower() &&
                    xl.Context.ToLower() == context.ToLower() &&
                    xl.ToLang == toLanguageCode)
                    return xl.ToText; 
            }
            return fromText; 
        }
Exemple #3
0
        /// <summary>
        /// 
        /// </summary>
        /// <param name="criteria"></param>
        /// <param name="propertyType"></param>
        /// <param name="context"></param>
        /// <param name="toLanguageCode"></param>
        /// <returns></returns>
        public static List<Model.Translation> GetXltByKeys(EnumsXlt.PropertyTypes property, string context, EnumsXlt.Criterias criteria = EnumsXlt.Criterias.None, string toLanguageCode = "no")
        {
            List<Model.Translation> newColl = new List<Model.Translation>();
            if (context == null)
                return newColl; 

            GetTranslations(); 
            using (var ctx = new Model.TranslationEntities())
            {
                if (string.IsNullOrEmpty(toLanguageCode))
                    toLanguageCode = "no";

                // Serach matching entities
                foreach (Model.Translation xl in _translateColl)
                {
                    if (((criteria == EnumsXlt.Criterias.None) || (criteria != EnumsXlt.Criterias.None && xl.Criteria.ToLower() == criteria.ToString().ToLower())) &&
                        xl.FromLang == FromLanguageCode &&
                        xl.Property.ToLower() == property.ToString().ToLower() &&
                        xl.Context.ToLower() == context.ToLower() &&
                        xl.ToLang == toLanguageCode)
                    {
                        newColl.Add(xl);
                    }
                }
            }
            return newColl;
        }
Exemple #4
0
        /// <summary>
        /// Get Translation entity collection by keys 
        /// </summary>
        /// <param name="propertyType"></param>
        /// <param name="context"></param>
        /// <param name="toLanguageCode"></param>
        /// <returns></returns>
        public static List<Model.Translation> GetTranslationByKeys(EnumsXlt.Criterias criteria, EnumsXlt.PropertyTypes property, string context = null, string toLanguageCode = "no")
        {
            List<Model.Translation> coll = new List<Model.Translation>();
            using (var ctx = new Model.TranslationEntities())
            {
                if (string.IsNullOrEmpty(toLanguageCode))
                    toLanguageCode = "no";


                coll = (from xl in ctx.Translation
                        where xl.FromLang == FromLanguageCode && xl.ToLang == toLanguageCode && 
                              xl.Criteria.ToLower() == criteria.ToString().ToLower() &&  
                              xl.Property.ToLower() == property.ToString().ToLower() && 
                              (context == null || (context != null && xl.Context.ToLower() == context.ToLower()))
                        select xl).ToList();

                return (coll != null) ? coll : new List<Model.Translation>();
            }
        }
Exemple #5
0
        public static string ToText(string fromText, EnumsXlt.PropertyTypes property, string context, string toLanguageCode = "no")
        {
            if (fromText.Trim() == "")
                return "";
            string toText = fromText;
            List<Model.Translation> coll;
            coll = XltTool.GetXltByKeys(property, context, EnumsXlt.Criterias.None);
            foreach (Model.Translation tr in coll)
            {
                switch (tr.Criteria.ToString().ToLower())
                {
                    case "startwith":
                        if (toText.ToLower().StartsWith(tr.FromText.ToLower()))
                            toText = toText.Replace(tr.FromText, tr.ToText);
                        break;
                    case "endwith":
                        if (toText.ToLower().EndsWith(tr.FromText.ToLower()))
                            toText = toText.Replace(tr.FromText, tr.ToText);
                        break;
                    case "exact":
                        if (toText.ToLower() == tr.FromText.ToLower())
                            toText = toText.Replace(tr.FromText, tr.ToText);
                        break;
                    case "contains":
                        if (toText.ToLower().Contains(tr.FromText.ToLower()))
                            toText = toText.Replace(tr.FromText, tr.ToText);
                        break;
                    case "none":
                        if (tr.FromText == "*")
                            toText = tr.ToText;
                        else
                            if (toText.ToLower().Contains(tr.FromText.ToLower()))
                                toText = toText.Replace(tr.FromText, tr.ToText);
                        break;
                    default:
                        // No translation
                        break;
                }
            }

            return toText;
        }
Exemple #6
0
 /// <summary>
 /// Translate text with defaults.
 /// Note: For the last parameter Context, you can use EnumsXlt.Contexts.String.ToString() to avoid typeing missstakes. 
 /// </summary>
 /// <param name="sourceText">Source text</param>
 /// <param name="propertyType">Property type</param>
 /// <param name="criteria">Criteria</param>
 /// <param name="context">Context</param>
 /// <returns></returns>
 public static string Xlt(string sourceText, EnumsXlt.PropertyTypes propertyType = EnumsXlt.PropertyTypes.Text, EnumsXlt.Criterias criteria = EnumsXlt.Criterias.Contains, string context = "String")
 {
     return XltTool.ToText(criteria, sourceText, propertyType, context);
 }