「Widget:Custom map」の版間の差分
提供:メタファー リファンタジオ 攻略Wiki
ヘイグ運営用アカウント (トーク | 投稿記録) 編集の要約なし タグ: 手動差し戻し |
ヘイグ運営用アカウント (トーク | 投稿記録) 編集の要約なし |
||
511行目: | 511行目: | ||
function loadPinsFromWikiPage() { | function loadPinsFromWikiPage() { | ||
var host = window.location.origin; | getMwToken() | ||
.then(function(token) { | |||
var host = window.location.origin; | |||
var geojsonPage = "<!--{$geojson}-->"; | |||
var url = API_BASE_URL + '/index.php/' + geojsonPage; | |||
return $.ajax({ | |||
type: "GET", | |||
url: url, | |||
dataType: "html", | |||
headers: { | |||
'Authorization': 'Bearer ' + token | |||
} | |||
}); | |||
}) | |||
.then(function(htmlContent) { | |||
try { | try { | ||
var parser = new DOMParser(); | var parser = new DOMParser(); | ||
var doc = parser.parseFromString(htmlContent, "text/html"); | var doc = parser.parseFromString(htmlContent, "text/html"); | ||
541行目: | 547行目: | ||
} catch (error) { | } catch (error) { | ||
console.error("Error processing data:", error); | console.error("Error processing data:", error); | ||
throw error; | |||
} | } | ||
} | }) | ||
.catch(function(error) { | |||
console.error("Error loading data:", error); | |||
}); | |||
} | } | ||
681行目: | 680行目: | ||
// トークンを取得する関数 | |||
function getMwToken() { | |||
return new Promise((resolve, reject) => { | |||
$.ajax({ | |||
url: API_BASE_URL + '/api.php', | |||
data: { | |||
action: 'query', | |||
meta: 'tokens', | |||
type: 'csrf', | |||
format: 'json' | |||
}, | |||
type: 'GET', | |||
success: function(response) { | |||
if (response.query && response.query.tokens && response.query.tokens.csrftoken) { | |||
resolve(response.query.tokens.csrftoken); | |||
} else { | |||
reject(new Error('Failed to get token')); | |||
} | |||
}, | |||
error: function(xhr, status, error) { | |||
reject(error); | |||
} | |||
}); | |||
}); | |||
} | |||
function saveToWikiPage(geoJSONData) { | function saveToWikiPage(geoJSONData) { | ||
var formattedData = geoJSONData; | var formattedData = geoJSONData; | ||
$.ajax({ | |||
// 保存前に新しいトークンを取得 | |||
getMwToken() | |||
.then(function(token) { | |||
return $.ajax({ | |||
type: "POST", | |||
url: API_BASE_URL + '/api.php', | |||
data: { | |||
action: 'edit', | |||
} | title: '<!--{$geojson}-->', | ||
text: formattedData, | |||
token: token, | |||
format: 'json' | |||
} | |||
}); | |||
}) | |||
.then(function(response) { | |||
if (response.edit && response.edit.result === 'Success') { | if (response.edit && response.edit.result === 'Success') { | ||
alert('データは正常に保存されました'); | alert('データは正常に保存されました'); | ||
701行目: | 730行目: | ||
drawControl.remove(); | drawControl.remove(); | ||
editButton.state('enable-edit'); | editButton.state('enable-edit'); | ||
saveButton.remove(); | saveButton.remove(); | ||
setTimeout(function() { | setTimeout(function() { | ||
707行目: | 736行目: | ||
}, 1000); | }, 1000); | ||
} else { | } else { | ||
throw new Error('Save failed: ' + JSON.stringify(response)); | |||
} | } | ||
} | }) | ||
.catch(function(error) { | |||
console.error("Save error:", error); | console.error("Save error:", error); | ||
alert('Error saving data: ' + error.message); | |||
}); | |||
alert('Error saving data: ' + error); | |||
} | } | ||
map.on(L.Draw.Event.CREATED, function (event) { | map.on(L.Draw.Event.CREATED, function (event) { | ||
var layer = event.layer; | var layer = event.layer; |