Exemplo n.º 1
0
        static public void ImportTaxLevels (Country country, string data)
        {
            // Lock out salary processing

            Persistence.Key["TaxDataImporting"] = "1";

            // Clear existing tables for countryId

            SwarmDb.GetDatabaseForWriting().DeleteTaxLevels(country.Identity);

            string[] lines = data.Split('\n');   // if \r\n is used, the \r will be harmlessly at the end of lines

            foreach (string line in lines)
            {
                if (line.Length > 5)
                {
                    // LAYOUT:
                    // 30B36  79801  80000381673984037340373403984039840
                    // 30%36  80001  84800   48   50   47   47   50   50
                    // +---------+---------+---------+
                    // 0123456789012345678901234567890
                    // 0         1         2         3

                    // First example line is a fixed tax amount, second is a percentage
                    // We're only interested in "column one" in positions 19-23

                    // This is for Sweden only, ffs!

                    bool isPercentage = line[2] == '%' ? true : false;

                    int lowerBracket = Int32.Parse(line.Substring(5, 7));
                    double tax = Double.Parse(line.Substring(19, 5));
                    int taxLevelId = Int32.Parse(line.Substring(3, 2));

                    if (isPercentage)
                    {
                        tax = tax / 100.0;
                    }

                    SwarmDb.GetDatabaseForWriting().CreateTaxLevel(country.Identity, taxLevelId, lowerBracket, tax);
                }
            }

            // Re-enable salary processing

            Persistence.Key["TaxDataImporting"] = "0";
        }
Exemplo n.º 2
0
        static public double GetTax (Country country, int taxLevelIdentifier, double grossSalary)
        {
            if (grossSalary < 1.0)  // The lowest tax bracket is 1 currency unit
            {
                return 0.0;  // no tax
            }

            double taxLevel = SwarmDb.GetDatabaseForReading().GetTaxLevel(country.Identity, taxLevelIdentifier,
                                                      (int) Math.Floor(grossSalary));

            if (taxLevel < 1.0)
            {
                // Percentage

                return Math.Floor(grossSalary*taxLevel);
            }

            // otherwise, absolute number

            return taxLevel;
        }
Exemplo n.º 3
0
 public static Geographies FromLevel(Country country, GeographyLevel level)
 {
     return(FromLevel(country.Identity, level));
 }
Exemplo n.º 4
0
 public static Geography FromOfficialDesignation (Country country, GeographyLevel level, string designation)
 {
     return FromOfficialDesignation(country.Identity, level, designation);
 }