예제 #1
0
        private string GetTreeMapData(CityStatistic someCityStat)
        {
            // full value of data parameter
            string result = "[";

            result += "{            \"label\": \"" + someCityStat.City.Name + "\",       \"fillcolor\": \"8c8c8c\",  \"value\": \"" + someCityStat.ServicesProvided + "\",      \"data\":       \r\n\t[ ";


            foreach (OrganizationStatistic organization in someCityStat.OrganizationStatistic)
            {
                result += " \r\n\t{\r\n\t\t\"label\": \"" + organization.Organization.Name + "\",    \"fillcolor\": \"8c8c8c\",  \"value\": \"" + organization.TotalServices + "\", \"data\": \r\n\t\t[\r\n";

                DivisionsOperations divOp = new DivisionsOperations(db);

                foreach (DivisionStatistic division in organization.DivisionStatistic)
                {
                    DivisionStatistic divisionStat = divOp.GetDivisionStatistic(division.Division.Id, false);
                    result += "\r\n\t\t\t{\r\n \t\t\t\t\"label\": \"" + division.Division.Name + "\",  \"value\": \"" + divisionStat.ServicesProvided + "\",  \"sValue\": \"" + divisionStat.SummaryIndex.ToString("0.#") + "\" ";
                    result += "\r\n\t\t\t}\r\n\t\t\t ,";
                }
                result  = result.TrimEnd(',');
                result += "\r\n\t\t]\r\n \r\n\t}\r\n\t ,";
            }
            result  = result.TrimEnd(',');
            result += "\r\n\t]}\r\n]\r\n";

            result += ",\r\n \"colorrange\": {        \"mapbypercent\": \"1\",        \"gradient\": \"1\",        \"minvalue\": \"0\",        \"code\": ";

            result += "   \"7FFF00\",        \"startlabel\": \"Позитивно\",      \"endlabel\": \"Негативно\",        \"color\": [            {";
            result += "\"code\": \"EE0000\",                \"maxvalue\": \"100\",                \"label\": \"Static\"            },            {                \"code\": \"7FFF00\",                \"maxvalue\": \"100\",                \"label\": \"AVERAGE\"            }        ]    }  ";


            return(result);
        }
예제 #2
0
        public CitiesStatistic GetCitiesStat()
        {
            CitiesStatistic result     = new CitiesStatistic(db);
            List <City>     someCities = db.Cities.ToList();

            result.GraphData = "[";

            CityOperations cityOp = new CityOperations(db);

            foreach (City item in someCities)
            {
                CityStatistic someCityStat = cityOp.GetCityStatistic(item);

                result.TotalServicesProvided     += someCityStat.ServicesProvided;
                result.TotalSuccessServicesCount += someCityStat.SuccessServicesProvided;
                result.TotalFailedServicesCount  += someCityStat.FailedServicesProvided;

                result.GraphData += "{ 'label': '" + item.Name + "', 'value': '" + someCityStat.ServicesProvided + "' },";

                result.CitiesStats.Add(someCityStat);
            }

            result.GraphData           = result.GraphData.TrimEnd(',') + "]";
            result.TreeMapData         = GetTreeMapData(result);
            result.DetailedTreeMapData = GetDetailedTreeMapData(result);
            return(result);
        }
예제 #3
0
        public CityStatistic GetCityStatistic(City someCity)
        {
            CityStatistic result = new CityStatistic(db, someCity);

            result.ServicesProvided       = db.ServiceToClients.Where(m => m.ValueSet.HasValue).Where(m => m.Worker.WorkPlace.Division.Organization.CityId == someCity.Id).Count();
            result.FailedServicesProvided = db.ServiceToClients.Where(m => m.ValueSet.HasValue).Where(m => m.Value == -1).Where(m => m.Worker.WorkPlace.Division.Organization.CityId == someCity.Id).Count();

            result.SuccessServicesProvided = db.ServiceToClients.Where(m => m.ValueSet.HasValue).Where(m => m.Value == 1).Where(m => m.Worker.WorkPlace.Division.Organization.CityId == someCity.Id).Count();

            result.SummaryIndex = ((double)100 / (((double)result.SuccessServicesProvided + (double)result.FailedServicesProvided) / (double)result.FailedServicesProvided));

            OrganizationOperations orgOp = new OrganizationOperations(db);

            foreach (Organization item in someCity.Organizations)
            {
                OrganizationStatistic someOrgStat = orgOp.GetOrganizationStatistic(item.Id, false);
                result.OrganizationStatistic.Add(someOrgStat);
            }

            result.TreeMapData = GetTreeMapData(result);


            return(result);
        }