From: Michael Andreen Date: Tue, 11 Sep 2007 18:15:11 +0000 (+0200) Subject: Fix bug with not counting first wave on target and also show solo attacks and def... X-Git-Url: https://ruin.nu/git/?a=commitdiff_plain;h=c35e53c7fbb397b42cfe491eedd7bb1d8a075614;p=ndwebbie.git Fix bug with not counting first wave on target and also show solo attacks and def outside ND/Gal on overview --- diff --git a/NDWeb/Pages/MemberIntel.pm b/NDWeb/Pages/MemberIntel.pm index d8a72ce..2ec5785 100644 --- a/NDWeb/Pages/MemberIntel.pm +++ b/NDWeb/Pages/MemberIntel.pm @@ -61,7 +61,7 @@ sub render_body { LEFT OUTER JOIN current_planet_stats t ON i.target = t.id LEFT OUTER JOIN (SELECT rt.id,planet,tick FROM raids r JOIN raid_targets rt ON r.id = rt.raid) rt ON rt.planet = i.target - AND (rt.tick + 12) > i.tick AND rt.tick < i.tick + AND (rt.tick + 12) > i.tick AND rt.tick <= i.tick LEFT OUTER JOIN raid_claims rc ON rt.id = rc.target AND rc.uid = u.uid LEFT OUTER JOIN (SELECT sender, eta, landing_tick FROM calls c JOIN incomings i ON i.call = c.id) inc ON inc.sender = i.target @@ -133,11 +133,17 @@ sub render_body { my $query = $DBH->prepare(q{SELECT u.uid,u.username,u.attack_points, u.defense_points, n.tick ,count(CASE WHEN i.mission = 'Attack' THEN 1 ELSE NULL END) AS attacks ,count(CASE WHEN (i.mission = 'Defend' OR i.mission = 'AllyDef') THEN 1 ELSE NULL END) AS defenses + ,count(CASE WHEN i.mission = 'Attack' AND rt.id IS NULL THEN 1 ELSE NULL END) AS solo + ,count(CASE WHEN i.mission = 'Defend' OR i.mission = 'AllyDef' THEN NULLIF(i.ingal OR (t.alliance_id = 1),TRUE) ELSE NULL END) AS bad_def FROM users u JOIN groupmembers gm USING (uid) LEFT OUTER JOIN (SELECT DISTINCT ON (planet) planet,tick from scans where type = 'News' ORDER BY planet,tick DESC) n USING (planet) LEFT OUTER JOIN (SELECT * FROM intel WHERE amount = -1) i ON i.sender = u.planet LEFT OUTER JOIN current_planet_stats t ON i.target = t.id + LEFT OUTER JOIN (SELECT rt.id,planet,tick FROM raids r + JOIN raid_targets rt ON r.id = rt.raid) rt ON rt.planet = i.target + AND (rt.tick + 12) > i.tick AND rt.tick <= i.tick + LEFT OUTER JOIN raid_claims rc ON rt.id = rc.target AND rc.uid = u.uid WHERE gm.gid = 2 GROUP BY u.uid,u.username,u.attack_points, u.defense_points,n.tick ORDER BY attacks DESC,defenses DESC, attack_points DESC, defense_points DESC}); diff --git a/templates/memberIntel.tmpl b/templates/memberIntel.tmpl index ff5c871..c6fae51 100644 --- a/templates/memberIntel.tmpl +++ b/templates/memberIntel.tmpl @@ -1,7 +1,7 @@ - +
@@ -16,7 +16,7 @@
AttackPt
- +
@@ -44,6 +44,8 @@ + +
DefensePt