w2ui gridでjson書込のサンプルコードが無いぃぃ

もうすぐ、新元号ななるから新元号対応しよう!
わざわざDBに入れるのもなんだかなぁ~!!
w2ui使ってるからjsonファイルだぁー!!
が、w2ui gridでjson書込のサンプルコードが無いぃぃ
ので書いてみた(´・ω・`)
w2uiってあんまり使われて無いのかなぁ~

DB無しで、元号名称と開始年月日の編集できます。
JSでjson読んで配列にでも突っ込んで利用してくだされ!!

拙いコードですが参考になれば。。。

{"total":5,"records":[{"recid":"1","gengou":"明治","sdate":"1868\/01\/25"},{"recid":"2","gengou":"大正","sdate":"1912\/07\/30"},{"recid":"3","gengou":"昭和","sdate":"1926\/12\/25"},{"recid":"4","gengou":"平成","sdate":"1989\/01\/08"},{"recid":"5","gengou":"新元号","sdate":"2019\/05\/01"}]}
<!DOCTYPE html>
<html>
<head>
  <title>元号名称</title>
  <script src="libs/jquery/jquery-3.3.1.min.js"></script>
  <script type="text/javascript" src="dist/w2ui.min.js"></script>
  <link rel="stylesheet" type="text/css" href="dist/w2ui.min.css" />
</head>
<body>

<div id="grid" style="width: 240px; height: 350px; overflow: hidden;"></div>

<script type="text/javascript">
$(function () {
  w2utils.locale('dist/locale/ja-jp.json');
  w2utils.settings.dateStartYear = 1868;  // start year for date-picker
  w2utils.settings.dateEndYear = Number(w2utils.formatDate((new Date()), 'yyyy'))+2;  // end year for date-picker

  $('#grid').w2grid({ 
    name: 'grid', 
    method: 'GET', // need this to avoid 412 error on Safari
    url  : {
      get : 'data/data.json',  //json読込
      remove : 'json.php',
      save : 'json.php'
    },
    show: { 
      toolbar : true,
      footer : true,
      toolbarColumns : false,
      toolbarSearch : false,
      toolbarInput : false,
      toolbarAdd : true,
      toolbarDelete : true,
      toolbarSave : true,
      searchAll : false
    },
    columns: [        
      { field: 'gengou', caption: '元号名称', size: '120px', sortable: true, editable: { type: 'text' } },
      { field: 'sdate', caption: '開始年月日', size: '120px', sortable: true, editable: { type: 'date' } }
    ],
    onAdd: function (event) {
      var len = w2ui['grid'].records.length;
      var g = 0;
      if(len != 0) g = Math.max.apply( null,w2ui['grid'].records.map(function(o){return o.recid;}) );  //max recid
      w2ui['grid'].add( { recid: g + 1, gengou: '元号名称', sdate: '' } );
    }
  });
});
</script>

</body>
</html>

サーバーのPHP

<?php
$_REQUEST = json_decode($_REQUEST['request'],true);

//jsonを配列に読込
$jsonUrl = "data/data.json"; //JSONファイルの場所とファイル名を記述
if(file_exists($jsonUrl)){
  $json = file_get_contents($jsonUrl);
  $obj = json_decode($json,true);
}else{
  $obj = array( "total"=>0, "records"=>array([]) );  //新規json用配列
}

switch ($_REQUEST['cmd']) {
  case 'save':
    if ( !isset($_REQUEST['changes'][0]) ){
      //form save処理
    }else{
      //grid save処理
      for ( $i=0; $i <= count($_REQUEST['changes'])-1; $i++ ){
          foreach ($_REQUEST['changes'][$i] as $k => $v) {
            if ($k == "recid") {$recid = $v; continue;}
            $array_recid = array_column($obj["records"], "recid");  //recid列
            $result = array_search($recid, $array_recid);  //recid検索
            $obj["records"][$result][$k] = $v;  //配列書込
          }
      }
      $obj["records"] = array_values($obj["records"]);  //indexを詰める
      $obj["total"]=count($obj["records"]);  //total書込
      $arr = json_encode($obj, JSON_UNESCAPED_UNICODE);  //json作成
      file_put_contents($jsonUrl , $arr);  //data file 書込

      $res = Array();
      $res['status']  = 'success';
      $res['message'] = 'save';
      $res['postData']= $_REQUEST;
      outputJSON($res);
    }
    break;
  case 'delete':
      for ( $i=0; $i <= count($_REQUEST['selected'])-1; $i++ ){
        $array_recid = array_column($obj["records"], "recid");  //recid列
        $result = array_search($_REQUEST['selected'][$i], $array_recid);  //recid検索
        unset($obj["records"][$result]);  //指定行削除
      }
      $obj["records"] = array_values($obj["records"]);  //indexを詰める
      $obj["total"]=count($obj["records"]);  //total書込
      $arr = json_encode($obj, JSON_UNESCAPED_UNICODE);  //json作成
      file_put_contents($jsonUrl , $arr);  //data file 書込

      $res = Array();
      $res['status']  = 'success';
      $res['message'] = 'delete';
      $res['postData']= $_REQUEST;
      outputJSON($res);
    break;
  default:
    $res = Array();
    $res['status']  = 'error';
    $res['message'] = 'Command "'.$_REQUEST['cmd'].'" is not recognized.';
    $res['postData']= $_REQUEST;
    outputJSON($res);
    break;
}
//w2ui res
function outputJSON($data) {
  header("Content-Type: application/json;charset=utf-8");
  echo json_encode($data);
}