Razlika između verzija stranice "Modul:Coordinates"

[pregledana izmjena][pregledana izmjena]
Uklonjeni sadržaj Dodani sadržaj
No edit summary
test
Red 3:
templates. It provides several methods, including
 
{{#invokeInvoke:Coordinates | coord }} : General function formatting and displaying
coordinate values.
 
{{#invokeInvoke:Coordinates | dec2dms }} : Simple function for converting decimal
degree values to DMS format.
 
{{#invokeInvoke:Coordinates | dms2dec }} : Simple function for converting DMS format
to decimal degree format.
 
{{#invokeInvoke:Coordinates | link }} : Export the link used to reach the tools
 
]]
 
require('Module:No globals')
 
local math_mod = require("Module:Math")
Line 43 ⟶ 41:
end
local s = (first .. second):upper()
return s:find('^[NS][EW]$') or s:find('^[EW][NS]$') or s:find('^[SJ][IZ]$') or s:find('^[IZ][SJ]$')
end
 
Line 53 ⟶ 51:
wrappers = 'Template:Coord'
})
return coordinates[funcName](args, frame)
end
end
Line 109 ⟶ 107:
end
local geodmshtml = '<span class="geo-dms" title="Karte, Maps, zračne fotografije, i ostali podaci zapodacije ovuove lokacijulokacije">'
.. '<span class="latitude">' .. coordinateSpec["dms-lat"] .. '</span> '
.. '<span class="longitude">' ..coordinateSpec["dms-long"] .. '</span>'
Line 118 ⟶ 116:
if lat < 0 then
-- FIXME this breaks the pre-existing precision
geodeclat = tostring(coordinateSpec["dec-lat"]):sub(2) .. "°JS"
else
geodeclat = (coordinateSpec["dec-lat"] or 0) .. "°SN"
end
 
Line 127 ⟶ 125:
if long < 0 then
-- FIXME does not handle unicode minus
geodeclong = tostring(coordinateSpec["dec-long"]):sub(2) .. "°ZW"
else
geodeclong = (coordinateSpec["dec-long"] or 0) .. "°IE"
end
local geodechtml = '<span class="geo-dec" title="Karte, Maps, zračne fotografije, i ostali podaci zapodacije ovuove lokacijulokacije">'
.. geodeclat .. ' '
.. geodeclong
Line 220 ⟶ 218:
local factor = 1
if direction == "S" or direction == "J" or direction == "W" or direction == "Z" then
factor = -1
end
Line 251 ⟶ 249:
if strong then
if lat_d < 0 then
table.insert(errors, {source, "Stepenistepeni geografske širine < 0 sa zastavicom za hemisferu"})
end
if long_d < 0 then
table.insert(errors, {source, "Stepenistepeni geografske dužine < 0 saa zastavicom za hemisferu"})
end
--[[
Line 263 ⟶ 261:
if long_d > 180 then
table.insert(errors, {source, "Stepenilongitude geografske dužinedegrees > 180 sa zastavicomwith zahemisphere hemisferuflag"})
end
]]
Line 269 ⟶ 267:
if lat_d > 90 then
table.insert(errors, {source, "Stepenistepeni geografske širine > 90"})
end
if lat_d < -90 then
table.insert(errors, {source, "Stepenistepeni geografske širine < −90-90"})
end
if lat_m >= 60 then
table.insert(errors, {source, "Minuteminute geografske širine >= 60"})
end
if lat_m < 0 then
table.insert(errors, {source, "Minuteminute geografske širine < 0"})
end
if lat_s >= 60 then
table.insert(errors, {source, "Sekundesekunde geografske širine >= 60"})
end
if lat_s < 0 then
table.insert(errors, {source, "Sekundesekunde geografske širine < 0"})
end
if long_d >= 360 then
table.insert(errors, {source, "Stepenistepeni geografske dužine >= 360"})
end
if long_d <= -360 then
table.insert(errors, {source, "Stepenistepeni geografske dužine <= −360-360"})
end
if long_m >= 60 then
table.insert(errors, {source, "Minuteminute geografske dužine >= 60"})
end
if long_m < 0 then
table.insert(errors, {source, "Minuteminute geografske dužine < 0"})
end
if long_s >= 60 then
table.insert(errors, {source, "Sekundesekunde geografske dužine >= 60"})
end
if long_s < 0 then
table.insert(errors, {source, "Sekundesekunde geografske dužine < 0"})
end
Line 311 ⟶ 309:
parseDec
 
Transforms decimal format latitude and longitude into the a
structure to be used in displaying coordinates
]]
Line 321 ⟶ 319:
return nil, {{"parseDec", "Nedostaje geografska dužina"}}
elseif not tonumber(long) then
return nil, {{"parseDec", "Geografsku dužinu nijeNije bilo moguće učitati geografsku dužinu kao broj: " .. long}}
end
Line 329 ⟶ 327:
 
local mode = coordinates.determineMode( lat, long );
coordinateSpec["dms-lat"] = convert_dec2dms( lat, "SN", "JS", mode) -- {{coord/dec2dms|{{{1}}}|N|S|{{coord/prec dec|{{{1}}}|{{{2}}}}}}}
coordinateSpec["dms-long"] = convert_dec2dms( long, "IE", "ZW", mode) -- {{coord/dec2dms|{{{2}}}|E|W|{{coord/prec dec|{{{1}}}|{{{2}}}}}}}
if format then
Line 348 ⟶ 346:
]]
local function parseDMS( lat_d, lat_m, lat_s, lat_f, long_d, long_m, long_s, long_f, format )
local coordinateSpec, errors, backward = {}, {}
local tmperrors = {}
lat_f = lat_f:upper();
Line 354 ⟶ 353:
-- Check if specified backward
if lat_f == 'E' or lat_f == 'I' or lat_f == 'W' or lat_f == 'Z' then
local t_d, t_m, t_s, t_f;
lat_d, long_d, lat_m, long_m, lat_s, long_s, lat_f, long_f, backward = long_d, lat_d, long_m, lat_m, long_s, lat_s, long_f, lat_f, true;
t_d = lat_d;
t_m = lat_m;
t_s = lat_s;
t_f = lat_f;
lat_d = long_d;
lat_m = long_m;
lat_s = long_s;
lat_f = long_f;
long_d = t_d;
long_m = t_m;
long_s = t_s;
long_f = t_f;
end
Line 362 ⟶ 373:
return nil, {{"parseDMS", "Nedostaje geografska dužina" }}
elseif not tonumber(long_d) then
return nil, {{"parseDMS", "Geografsku dužinu nijeNije bilo moguće učitati geografsku dužinu kao broj: " .. long_d }}
end
if not lat_m and not lat_s and not long_m and not long_s and #errors == 0 then
if math_mod._precision( lat_d ) > 0 or math_mod._precision( long_d ) > 0 then
if lat_f:upper() == 'S' or lat_f:upper() == 'J' then
lat_d = '-' .. lat_d;
end
if long_f:upper() == 'W' or long_f:upper() == 'Z' then
long_d = '-' .. long_d;
end
Line 389 ⟶ 400:
end
 
return coordinateSpec, errors, backward
end
 
Line 398 ⟶ 409:
local function formatTest(args)
local result, errors
local backward, primary = false, false
 
local function getParam(args, lim)
Line 413 ⟶ 424:
elseif not tonumber(args[1]) then
-- bad lat logic
return errorPrinter( {{"formatTest", "Geografsku širinu nijeNije bilo moguće učitati geografsku širinu kao broj:" .. args[1]}} )
elseif not args[4] and not args[5] and not args[6] then
-- dec logic
Line 420 ⟶ 431:
return errorPrinter(errors);
end
result.param = table.concat({args[1], 'N', args[2] or '', 'E', args[3] or ''}, '_')
-- formatting for geohack: geohack expects D_N_D_E notation or D;D notation
-- wikiminiatlas doesn't support D;D notation
-- #coordinates parserfunction doesn't support negative decimals with NSWE
result.param = table.concat({
math.abs(tonumber(args[1])),
((tonumber(args[1]) or 0) < 0) and 'S' or 'N',
math.abs(tonumber(args[2])),
((tonumber(args[2]) or 0) < 0) and 'W' or 'E',
args[3] or ''}, '_')
elseif dmsTest(args[4], args[8]) then
-- dms logic
result, errors, backward = parseDMS(args[1], args[2], args[3], args[4],
args[5], args[6], args[7], args[8], args.format)
if args[10] then
table.insert(errors, {'formatTest', 'Pronađeni dodatniDodatni neočekivani parametri'})
end
if not result then
Line 442 ⟶ 445:
elseif dmsTest(args[3], args[6]) then
-- dm logic
result, errors, backward = parseDMS(args[1], args[2], nil, args[3],
args[4], args[5], nil, args[6], args['format'])
if args[8] then
table.insert(errors, {'formatTest', 'Pronađeni dodatniDodatni neočekivani parametri'})
end
if not result then
Line 453 ⟶ 456:
elseif dmsTest(args[2], args[4]) then
-- d logic
result, errors, backward = parseDMS(args[1], nil, nil, args[2],
args[3], nil, nil, args[4], args.format)
if args[6] then
table.insert(errors, {'formatTest', 'Pronađeni dodatniDodatni neočekivani parametri'})
end
if not result then
Line 471 ⟶ 474:
for _, v in ipairs(extra_param) do
if args[v] then
table.insert(errors, {'formatTest', 'Parametar: "' .. v .. '=" bitreba trebalo da budebiti "' .. v .. ':"' })
end
end
Line 479 ⟶ 482:
ret = ret .. ' ' .. errorPrinter(errors) .. '[[Kategorija:Stranice sa neispravnim koordinatama]]'
end
return ret, backward
end
 
Line 517 ⟶ 520:
 
Usage:
{{#invoke Invoke:Coordinates | link }}
]]
Line 530 ⟶ 533:
 
Usage:
{{#invoke Invoke:Coordinates | dec2dms | decimal_coordinate | positive_suffix |
negative_suffix | precision }}
Line 569 ⟶ 572:
 
Usage:
{{#invoke Invoke:Coordinates | dms2dec | direction_flag | degrees |
minutes | seconds }}
Line 592 ⟶ 595:
 
Usage:
{{#invoke Invoke:Coordinates | coord }}
{{#invoke Invoke:Coordinates | coord | lat | long }}
{{#invoke Invoke:Coordinates | coord | lat | lat_flag | long | long_flag }}
...
Line 607 ⟶ 610:
coordinates.coord = makeInvokeFunc('_coord')
function coordinates._coord(args)
if (not args[1] or not tonumber(args[1])) and not args[2] and mw.wikibase.getEntityObject() then
args[3] = args[1]; args[1] = nil
local entity = mw.wikibase.getEntityObject()
if entity
Line 626 ⟶ 628:
end
local contents, backward = formatTest(args)
local Notes = args.notes or ''
local Display = args.display and args.display:lower() or 'inline'
Line 637 ⟶ 639:
-- Finds whether coordinates are displayed in the title.
return s:find('title') ~= nil or s == 't' or s == 'it' or s == 'ti'
end
local function coord_wrapper(in_args)
-- Calls the parser function {{#coordinates:}}.
return mw.getCurrentFrame():callParserFunction('#coordinates', in_args) or ''
end
Line 652 ⟶ 649:
.. displaytitle(contents, Notes)
.. makeWikidataCategories()
end
if not args.nosave then
local page_title, count = mw.title.getCurrentTitle(), 1
if backward then
local tmp = {}
while not string.find((args[count-1] or ''), '[EW]') do tmp[count] = (args[count] or ''); count = count+1 end
tmp.count = count; count = 2*(count-1)
while count >= tmp.count do table.insert(tmp, 1, (args[count] or '')); count = count-1 end
for i, v in ipairs(tmp) do args[i] = v end
else
while count <= 9 do args[count] = (args[count] or ''); count = count+1 end
end
if isInTitle(Display) and not page_title.isTalkPage and (page_title.subpageText ~= 'doc' and page_title.subpageText ~= 'dok') and page_title.subpageText ~= 'testcases' then args[10] = 'primary' end
args.notes, args.format, args.display = nil
text = text .. coord_wrapper(args)
end
return text
Line 718 ⟶ 700:
for i, v in ipairs(frame.args) do
if i ~= 1 then
if not mw.ustring.find(frame.args[1], (mw.ustring.match(frame.args[i], '^(.-:)') or '')) then frame.args[1] = mw.ustring.gsub(frame.args[1], '(params=.-)_? ', '%1_'..frame.args[i]..' ') end
frame.args[1] = mw.ustring.gsub(frame.args[1], '(params=.-)_? ', '%1_'..frame.args[i]..' ')
end
end
end
if frame.args.name then
if not mw.ustring.find(frame.args[1], '<span class="vcard">') then
local namestr = frame.args.name
frame.args[1] = mw.ustring.gsub(frame.args[1],
'(<span class="geo%-default">)(<span[^<>]*>[^<>]*</span><span[^<>]*>[^<>]*<span[^<>]*>[^<>]*</span></span>)(</span>)',
'%1<span class="vcard">%2<span style="display:none">&#xfeff; (<span class="fn org">' .. namestr .. '</span>)</span></span>%3')
frame.args[1] = mw.ustring.gsub(frame.args[1], '(&params=[^&"<>%[%] ]*) ', '%1&title=' .. mw.uri.encode(namestr) .. ' ')
end
end