본문으로 이동

미디어위키:Gadget-JSONEditor.js: 두 판 사이의 차이

리버티게임(개발), 모두가 만들어가는 자유로운 게임
Senouis (토론 | 기여)
잔글편집 요약 없음
Senouis (토론 | 기여)
잔글편집 요약 없음
 
(같은 사용자의 중간 판 48개는 보이지 않습니다)
2번째 줄: 2번째 줄:
function LoadJSONEditor() {
function LoadJSONEditor() {
   if (document.getElementsByClassName("jsoneditor-container").length === 0) return;
   if (document.getElementsByClassName("jsoneditor-container").length === 0) return;
   Promise.all([
   var targetJSON = "https://dev.libertygame.work/index.php/RPG_in_City/game.json?action=raw";
   "https://cdn.jsdelivr.net/npm/@json-editor/json-editor@latest/dist/jsoneditor.min.js",
   mw.loader.getScript("https://cdn.jsdelivr.net/npm/@json-editor/json-editor@latest/dist/jsoneditor.min.js").then(function() {
  "https://dev.libertygame.work/index.php/%EB%A6%AC%EB%B2%84%ED%8B%B0%EA%B2%8C%EC%9E%84:%EA%B2%8C%EC%9E%84_%EB%A9%94%ED%83%80%EB%8D%B0%EC%9D%B4%ED%84%B0/%EC%8A%A4%ED%82%A4%EB%A7%88.json?action=raw"
    fetch("https://dev.libertygame.work/index.php/%EB%A6%AC%EB%B2%84%ED%8B%B0%EA%B2%8C%EC%9E%84:%EA%B2%8C%EC%9E%84_%EB%A9%94%ED%83%80%EB%8D%B0%EC%9D%B4%ED%84%B0/%EC%8A%A4%ED%82%A4%EB%A7%88.json?action=raw")
  ]).then(function (result) {
    .then(function(result){return result.json(); })
  var jsonEditorContainer = document.querySelector('.json-editor-container');
    .then(function (result) {
  var value = document.querySelector('#value');
  const jsonEditorContainer = document.querySelector('.json-editor-container');
  const editorvalue = document.querySelector('#value');
  var schema = result[1];
  var schema = result;
  var editor = new result[0].JSONEditor(jsonEditorContainer, {
  fetch(targetJSON).then(function(result){return result.json(); }).then(function (response) {
    schema: schema,
  const editor = new JSONEditor(jsonEditorContainer, {
    theme: 'bootstrap4',
  mode: 'tree',
    show_errors: 'always',
    schema: schema,
    iconlib: 'fontawesome5',
    theme: 'bootstrap4',
    keep_oneof_values: false
    iconlib: 'fontawesome5',
    keep_oneof_values: false
  }, response);
  editor.on('change', function () {
    editorvalue.value = JSON.stringify(editor.getValue(), null, 2);
  });
 
  }).catch('JSON 에디터 로딩 후 JSON 타겟 가져오기 실패');
  }).catch(function (e) {
  console.log("JSON 에디터 로딩 중 장애 발생" + e.message);
  });
  });
  editor.on('change', function () {
    value.value = JSON.stringify(editor.getValue());
  });
  document.querySelector('.set-value').addEventListener('click', function () {
    editor.setValue({ test: 0 });
  });
  }).catch(function (e) {
  console.log("JSON 에디터 로딩 중 장애 발생" + e.message);
   });
   });
}
}


$(LoadJSONEditor);
$(LoadJSONEditor);

2024년 12월 22일 (일) 16:45 기준 최신판

function LoadJSONEditor() {
  if (document.getElementsByClassName("jsoneditor-container").length === 0) return;
  var targetJSON = "https://dev.libertygame.work/index.php/RPG_in_City/game.json?action=raw";
  	mw.loader.getScript("https://cdn.jsdelivr.net/npm/@json-editor/json-editor@latest/dist/jsoneditor.min.js").then(function() {
  	  fetch("https://dev.libertygame.work/index.php/%EB%A6%AC%EB%B2%84%ED%8B%B0%EA%B2%8C%EC%9E%84:%EA%B2%8C%EC%9E%84_%EB%A9%94%ED%83%80%EB%8D%B0%EC%9D%B4%ED%84%B0/%EC%8A%A4%ED%82%A4%EB%A7%88.json?action=raw")
  	  .then(function(result){return result.json(); })
  	  .then(function (result) {
		  const jsonEditorContainer = document.querySelector('.json-editor-container');
		  const editorvalue = document.querySelector('#value');
		
		  var schema = result;
		  fetch(targetJSON).then(function(result){return result.json(); }).then(function (response) {
			  const editor = new JSONEditor(jsonEditorContainer, {
			  	mode: 'tree',
			    schema: schema,
			    theme: 'bootstrap4',
			    iconlib: 'fontawesome5',
			    keep_oneof_values: false
			  }, response);
			
			  editor.on('change', function () {
			    editorvalue.value = JSON.stringify(editor.getValue(), null, 2);
			  });
			  
		  }).catch('JSON 에디터 로딩 후 JSON 타겟 가져오기 실패');
	  }).catch(function (e) {
	  	console.log("JSON 에디터 로딩 중 장애 발생" + e.message);
	  });
  });
}

$(LoadJSONEditor);