Package controllers

Source Code of controllers.Application$DistanceCalc

package controllers;

import org.mongodb.morphia.Morphia;
import com.google.common.base.CharMatcher;
import com.google.common.base.Function;
import com.google.common.base.Strings;
import com.google.common.collect.Iterables;
import com.google.common.collect.Lists;
import com.google.inject.Inject;
import com.mongodb.BasicDBList;
import com.mongodb.BasicDBObject;
import com.mongodb.CommandResult;
import models.Model;
import models.PostcodeUnit;
import play.data.Form;
import play.data.validation.Constraints;
import play.mvc.Controller;
import play.mvc.Result;
import views.html.index;
import views.html.map;

import javax.annotation.Nullable;
import java.util.ArrayList;
import java.util.List;

import static play.data.Form.form;
import static play.libs.Json.toJson;

public class Application extends Controller {
    @Inject
    public static Morphia morphia;

    public static class DistanceCalc {
        @Constraints.Required
        public String postcode;

        @Constraints.Required
        public int distance = 10;

        public String validate() {
            if (PostcodeUnit.find.field("postcode").equal(postcode).get() == null) {
                return "Invalid postcode";
            }

            return null;
        }
    }

    public static class Geocode {
        @Constraints.Required
        public String postcode;

        public String validate() {
            if (PostcodeUnit.find.field("postcode").equal(postcode).get() == null) {
                return "Invalid postcode";
            }

            return null;
        }
    }

    public static Result index() {
        return ok(index.render(form(DistanceCalc.class), form(Geocode.class), new ArrayList<PostcodeUnit>()));
    }

    public static Result map() {
        return ok(map.render());
    }

    public static Result ll() {
        Form<Geocode> geocodeForm = form(Geocode.class).bindFromRequest();
        if (geocodeForm.hasErrors()) {
            return badRequest(index.render(form(DistanceCalc.class), geocodeForm, new ArrayList<PostcodeUnit>()));
        } else {
            Geocode geocode = geocodeForm.get();

            PostcodeUnit unit = PostcodeUnit.find.field("postcode").equal(CharMatcher.WHITESPACE.removeFrom(geocode.postcode).toUpperCase()).get();
            return ok(toJson(unit.location));
        }
    }

    public static Result latLng(String postcode) {
        if (Strings.isNullOrEmpty(postcode)) return badRequest("empty postcode");
        postcode = CharMatcher.WHITESPACE.removeFrom(postcode).toUpperCase();
        if (postcode.length() < 5 || postcode.length() > 7) return badRequest("illegal postcode format");

        PostcodeUnit unit = PostcodeUnit.find.field("postcode").equal(postcode).get();
        if (unit == null) {
            return notFound();
        } else {
            return ok(toJson(unit.location));
        }
    }

    public static Result en() {
        Form<Geocode> geocodeForm = form(Geocode.class).bindFromRequest();
        if (geocodeForm.hasErrors()) {
            return badRequest(index.render(form(DistanceCalc.class), geocodeForm, new ArrayList<PostcodeUnit>()));
        } else {
            Geocode geocode = geocodeForm.get();

            PostcodeUnit unit = PostcodeUnit.find.field("postcode").equal(CharMatcher.WHITESPACE.removeFrom(geocode.postcode).toUpperCase()).get();
            return ok(toJson(unit.cartesianLocation));
        }
    }

    public static Result eastingsNorthings(String postcode) {
        if (Strings.isNullOrEmpty(postcode)) return badRequest("empty postcode");
        postcode = CharMatcher.WHITESPACE.removeFrom(postcode).toUpperCase();
        if (postcode.length() < 5 || postcode.length() > 7) return badRequest("illegal postcode format");

        PostcodeUnit unit = PostcodeUnit.find.field("postcode").equal(postcode).get();
        if (unit == null) {
            return notFound();
        } else {
            return ok(toJson(unit.cartesianLocation));
        }
    }

    public static Result near(String latitude, String longitude) {
        return ok(toJson(findNearMiles(Double.parseDouble(latitude), Double.parseDouble(longitude), 15, 100)));
    }

    public static Result calc() {
        Form<DistanceCalc> distanceCalcForm = form(DistanceCalc.class).bindFromRequest();
        if (distanceCalcForm.hasErrors()) {
            return badRequest(index.render(distanceCalcForm, form(Geocode.class), new ArrayList<PostcodeUnit>()));
        } else {
            DistanceCalc calc = distanceCalcForm.get();

            PostcodeUnit postcode = PostcodeUnit.find.field("postcode").equal(CharMatcher.WHITESPACE.removeFrom(calc.postcode).toUpperCase()).get();
            List<PostcodeUnit> near = findNearMiles(postcode.location.latitude, postcode.location.longitude, calc.distance, 100);

            StringBuilder message = new StringBuilder();
            message.append("Found ")
                    .append(near.size())
                    .append(" post codes within ")
                    .append(calc.distance)
                    .append(" miles from ")
                    .append(postcode.postcode)
                    .append(".");

            if (near.size() == 100) {
                message.append(" The list was capped to 100 postcodes.");
            }

            flash("success", message.toString());

            return ok(index.render(distanceCalcForm, form(Geocode.class), near));
        }
    }

    protected static List<PostcodeUnit> findNearMiles(double latitude, double longitude, int miles, int limit) {
        BasicDBObject geoNearCommand = new BasicDBObject();
        geoNearCommand.put("geoNear", "pcu");
        double coord[] = {latitude, longitude};
        geoNearCommand.put("near", coord);
        geoNearCommand.put("maxDistance", miles / 69.17);
        geoNearCommand.put("num", limit);
        geoNearCommand.put("spherical", true);

        CommandResult geoNearResult = Model.datastore.getDB().command(geoNearCommand);
        BasicDBList geoNearResults = (BasicDBList) geoNearResult.get("results");

        return Lists.newArrayList(Iterables.transform(geoNearResults, new Function<Object, PostcodeUnit>() {
            @Override
            public PostcodeUnit apply(@Nullable Object input) {
                BasicDBObject pcuObject = (BasicDBObject) ((BasicDBObject) input).get("obj");
                return morphia.fromDBObject(PostcodeUnit.class, pcuObject);
            }
        }));
    }
}
TOP

Related Classes of controllers.Application$DistanceCalc

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.