{"id":11402,"date":"2022-01-14T10:00:00","date_gmt":"2022-01-14T01:00:00","guid":{"rendered":"https:\/\/www.gigas-jp.com\/appnews\/?p=11402"},"modified":"2022-01-13T20:21:06","modified_gmt":"2022-01-13T11:21:06","slug":"laravel8%e3%81%a7fullcalendar%e3%81%a8ajax%e3%82%92%e4%bd%bf%e3%81%a3%e3%81%a6%e3%82%a4%e3%83%99%e3%83%b3%e3%83%88%e3%82%92%e4%bd%9c%e6%88%90%e3%81%99%e3%82%8b","status":"publish","type":"post","link":"https:\/\/www.gigas-jp.com\/appnews\/archives\/11402","title":{"rendered":"Laravel8\u3067Fullcalendar\u3068AJAX\u3092\u4f7f\u3063\u3066\u30a4\u30d9\u30f3\u30c8\u3092\u4f5c\u6210\u3059\u308b"},"content":{"rendered":"\n<figure class=\"wp-block-image size-full is-resized\"><img loading=\"lazy\" src=\"https:\/\/www.gigas-jp.com\/appnews\/wp-content\/uploads\/sites\/4\/2022\/01\/Screen-Shot-2022-01-13-at-14.20.28-1.png\" alt=\"\" class=\"wp-image-11404\" width=\"765\" height=\"388\" \/><\/figure>\n\n\n\n<p>\u4eca\u9031\u306f\u3001Laravel 8\u30a2\u30d7\u30ea\u306bFullcalendar JavaScript\u30a4\u30d9\u30f3\u30c8\u30ab\u30ec\u30f3\u30c0\u30fc\u30d7\u30e9\u30b0\u30a4\u30f3\u3092\u4f7f\u7528\u3057\u3066\u30a4\u30d9\u30f3\u30c8\u3092\u4f5c\u6210\u30fb\u524a\u9664\u3059\u308b\u65b9\u6cd5\u3092\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u4eca\u56de\u306f\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3092\u30b9\u30ad\u30c3\u30d7\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u8a2d\u5b9a\u5f8c\u3001\u30a4\u30d9\u30f3\u30c8\u306e\u4f5c\u6210\u3001\u524a\u9664\u3092\u884c\u3046\u305f\u3081\u306b\u3001\u65b0\u3057\u3044\u30ab\u30ec\u30f3\u30c0\u30fc\u3092\u4f5c\u6210\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u305d\u306e\u305f\u3081\u306b<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>php artisan make:controller FullCalenderController<\/code><\/pre>\n\n\n\n<p>\u305d\u3057\u3066\u3001app\\Http\\Controllers\u306e\u4e2d\u306e\u3001FullCalenderController.php\u3067\u3001Fullcalendar\u30a4\u30d9\u30f3\u30c8\u306e\u30d3\u30e5\u30fc\u3068CD\u30aa\u30da\u30ec\u30fc\u30b7\u30e7\u30f3\u3092\u8a2d\u5b9a\u3059\u308b\u3053\u3068\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>public function index(Request $request)\n    {\n        if($request-&gt;ajax()) {  \n            $data = Event::whereDate('start', '&gt;=', $request-&gt;start)\n                -&gt;whereDate('end',   '&lt;=', $request-&gt;end)\n                -&gt;get(&#091;'id', 'title', 'start', 'end']);\n            return response()-&gt;json($data);\n        }\n        return view('welcome');\n    }<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code>\u3053\u306e\u95a2\u6570\u306f\u3001\u4f5c\u6210\u3057\u305f\u30a4\u30d9\u30f3\u30c8\u304c\u8868\u793a\u3055\u308c\u3066\u3044\u308b\u3053\u3068\u3092\u53d6\u5f97\u3057\u307e\u3059\u3002<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code>public function calendarEvents(Request $request)\n    {\n \n        switch ($request-&gt;type) {\n           case 'create':\n              $event = CrudEvents::create(&#091;\n                  'event_name' =&gt; $request-&gt;event_name,\n                  'event_start' =&gt; $request-&gt;event_start,\n                  'event_end' =&gt; $request-&gt;event_end,\n              ]);\n \n              return response()-&gt;json($event);\n             break;\n  \n  \n           case 'delete':\n              $event = CrudEvents::find($request-&gt;id)-&gt;delete();\n  \n              return response()-&gt;json($event);\n             break;\n             \n           default:\n             # ...\n             break;\n        }\n    }<\/code><\/pre>\n\n\n\n<p>\u30ea\u30af\u30a8\u30b9\u30c8\u30bf\u30a4\u30d7\u306f<strong>create<\/strong>\u3067\u3001create case\u3092\u5165\u529b\u3059\u308b\u3068\u3001\u30a4\u30d9\u30f3\u30c8\u304c\u4f5c\u6210\u3055\u308c\u3001json\u5f62\u5f0f\u3067\u8fd4\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u30ea\u30af\u30a8\u30b9\u30c8\u30bf\u30a4\u30d7\u306f<strong>delete<\/strong>\u3067\u3001delete case\u3092\u5165\u529b\u3059\u308b\u3068\u3001\u4f5c\u6210\u3055\u308c\u305f\u30a4\u30d9\u30f3\u30c8\u3092\u524a\u9664\u3057\u3066\u3001json\u5f62\u5f0f\u3067\u8fd4\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>Controller\u304c\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3055\u308c\u305f\u306e\u3067\u3001\u6b21\u306f routes\/web.php \u30d5\u30a1\u30a4\u30eb\u306b\u79fb\u52d5\u3057\u307e\u3059\u3002\u3053\u306e\u30d5\u30a1\u30a4\u30eb\u3067\u306f\u3001\u30eb\u30fc\u30c8\u3092\u4f5c\u6210\u3059\u308b\u305f\u3081\u306b FullCalenderController\u3092\u4f7f\u7528\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>Route::get('calendar-event', &#091;FullCalenderController::class, 'index']);\nRoute::post('calendar-crud-ajax', &#091;FullCalenderController::class, 'calendarEvents']);<\/code><\/pre>\n\n\n\n<p>\u6700\u5f8c\u306b\u3001laravel blade\u306e\u30d3\u30e5\u30fc\u30d5\u30a1\u30a4\u30eb\u3067\u30d5Full calender\u3092\u8868\u793a\u3057\u3001jQuery\u306eAJAX\u30ea\u30af\u30a8\u30b9\u30c8\u3067\u30a4\u30d9\u30f3\u30c8\u306e\u4f5c\u6210\u3001\u524a\u9664\u3092\u884c\u3046\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>&lt;script src=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/jquery\/3.1.1\/jquery.min.js\"&gt;&lt;\/script&gt;\n &lt;script src=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/moment.js\/2.29.1\/moment.min.js\"&gt;&lt;\/script&gt;\n &lt;script src=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/fullcalendar\/3.10.2\/fullcalendar.min.js\"&gt;&lt;\/script&gt;\n &lt;script src=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/toastr.js\/latest\/toastr.min.js\"&gt;&lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>\u30ab\u30ec\u30f3\u30c0\u30fc\u306e\u65e5\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u3001\u5165\u529b\u30bf\u30a4\u30d7\u306e\u30d5\u30a3\u30fc\u30eb\u30c9\u304c\u8868\u793a\u3055\u308c\u3001OK\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u3001ajax\u30ea\u30af\u30a8\u30b9\u30c8\u3067\u30b3\u30f3\u30c8\u30ed\u30fc\u30e9\u306b\u79fb\u52d5\u3057\u3001ajax\u30ea\u30af\u30a8\u30b9\u30c8\u3067\u623b\u308a\u3001\u30a4\u30d9\u30f3\u30c8\u304c\u4f5c\u6210\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u307e\u305f\u3001\u4f5c\u6210\u3057\u305f\u30a4\u30d9\u30f3\u30c8\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u3001\u30a2\u30e9\u30fc\u30c8\u30dc\u30c3\u30af\u30b9\u304c\u8868\u793a\u3055\u308c\u3001OK\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u3001\u4f5c\u6210\u3057\u305f\u30a4\u30d9\u30f3\u30c8\u304c\u524a\u9664\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3053\u306e\u72b6\u614b\u306b\u5bfe\u3057\u3066<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>$(document).ready(function () {\n\n            var SITEURL = \"{{ url('\/') }}\";\n\n            $.ajaxSetup({\n                headers: {\n                    'X-CSRF-TOKEN': $('meta&#091;name=\"csrf-token\"]').attr('content')\n                }\n            });\n\n            var calendar = $('#full_calendar_events').fullCalendar({\n                editable: true,\n                editable: true,\n                events: SITEURL + \"\/calendar-event\",\n                displayEventTime: true,\n                eventRender: function (event, element, view) {\n                    if (event.allDay === 'true') {\n                        event.allDay = true;\n                    } else {\n                        event.allDay = false;\n                    }\n                },\n                selectable: true,\n                selectHelper: true,\n                select: function (event_start, event_end, allDay) {\n                    var event_name = prompt('Event Name:');\n                    if (event_name) {\n                        var event_start = $.fullCalendar.formatDate(event_start, \"Y-MM-DD HH:mm:ss\");\n                        var event_end = $.fullCalendar.formatDate(event_end, \"Y-MM-DD HH:mm:ss\");\n                        $.ajax({\n                            url: SITEURL + \"\/calendar-crud-ajax\",\n                            data: {\n                                event_name: event_name,\n                                event_start: event_start,\n                                event_end: event_end,\n                                type: 'create'\n                            },\n                            type: \"POST\",\n                            success: function (data) {\n                                displayMessage(\"Event created.\");\n\n                                calendar.fullCalendar('renderEvent', {\n                                    id: data.id,\n                                    title: event_name,\n                                    start: event_start,\n                                    end: event_end,\n                                    allDay: allDay\n                                }, true);\n                                calendar.fullCalendar('unselect');\n                            }\n                        });\n                    }\n                },\n                \n                eventClick: function (event) {\n                    var eventDelete = confirm(\"Are you sure?\");\n                    if (eventDelete) {\n                        $.ajax({\n                            type: \"POST\",\n                            url: SITEURL + '\/calendar-crud-ajax',\n                            data: {\n                                id: event.id,\n                                type: 'delete'\n                            },\n                            success: function (response) {\n                                calendar.fullCalendar('removeEvents', event.id);\n                                displayMessage(\"Event removed\");\n                            }\n                        });\n                    }\n                }\n            });\n        });\n\n        function displayMessage(message) {\n            toastr.success(message, 'Event');            \n        }\n\n    &lt;\/script&gt;<\/code><\/pre>\n\n\n\n<p>\u958b\u767a\u30b5\u30fc\u30d0\u30fc\u306e\u5b9f\u884c<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>php artisan serve<\/code><\/pre>\n\n\n\n<p>\u7d50\u679c\u306f\u4e0a\u90e8\u306b\u8868\u793a\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u6700\u5f8c\u307e\u3067\u304a\u8aad\u307f\u3044\u305f\u3060\u304d\u3001\u3042\u308a\u304c\u3068\u3046\u3054\u3056\u3044\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<p>By Ami<\/p>\n\n\n\n<p><\/p>\n<div class='wp_social_bookmarking_light'>\n            <div class=\"wsbl_google_plus_one\"><g:plusone size=\"medium\" annotation=\"none\" href=\"https:\/\/www.gigas-jp.com\/appnews\/archives\/11402\" ><\/g:plusone><\/div>\n            <div class=\"wsbl_hatena_button\"><a href=\"\/\/b.hatena.ne.jp\/entry\/https:\/\/www.gigas-jp.com\/appnews\/archives\/11402\" class=\"hatena-bookmark-button\" data-hatena-bookmark-title=\"Laravel8\u3067Fullcalendar\u3068AJAX\u3092\u4f7f\u3063\u3066\u30a4\u30d9\u30f3\u30c8\u3092\u4f5c\u6210\u3059\u308b\" data-hatena-bookmark-layout=\"standard\" title=\"\u3053\u306e\u30a8\u30f3\u30c8\u30ea\u30fc\u3092\u306f\u3066\u306a\u30d6\u30c3\u30af\u30de\u30fc\u30af\u306b\u8ffd\u52a0\"> <img src=\"\/\/b.hatena.ne.jp\/images\/entry-button\/button-only@2x.png\" alt=\"\u3053\u306e\u30a8\u30f3\u30c8\u30ea\u30fc\u3092\u306f\u3066\u306a\u30d6\u30c3\u30af\u30de\u30fc\u30af\u306b\u8ffd\u52a0\" width=\"20\" height=\"20\" style=\"border: none;\" \/><\/a><script type=\"text\/javascript\" src=\"\/\/b.hatena.ne.jp\/js\/bookmark_button.js\" charset=\"utf-8\" async=\"async\"><\/script><\/div>\n            <div class=\"wsbl_twitter\"><a href=\"https:\/\/twitter.com\/share\" class=\"twitter-share-button\" data-url=\"https:\/\/www.gigas-jp.com\/appnews\/archives\/11402\" data-text=\"Laravel8\u3067Fullcalendar\u3068AJAX\u3092\u4f7f\u3063\u3066\u30a4\u30d9\u30f3\u30c8\u3092\u4f5c\u6210\u3059\u308b\" data-via=\"GIGASJAPAN_APPS\" data-lang=\"ja\">Tweet<\/a><\/div>\n            <div class=\"wsbl_facebook_like\"><div id=\"fb-root\"><\/div><fb:like href=\"https:\/\/www.gigas-jp.com\/appnews\/archives\/11402\" layout=\"button_count\" action=\"like\" width=\"100\" share=\"false\" show_faces=\"false\" ><\/fb:like><\/div>\n            <div class=\"wsbl_facebook_send\"><div id=\"fb-root\"><\/div><fb:send href=\"https:\/\/www.gigas-jp.com\/appnews\/archives\/11402\" colorscheme=\"light\" ><\/fb:send><\/div>\n    <\/div>\n<br class='wp_social_bookmarking_light_clear' \/>\n","protected":false},"excerpt":{"rendered":"<p>\u4eca\u9031\u306f\u3001Laravel 8\u30a2\u30d7\u30ea\u306bFullcalendar JavaScript\u30a4\u30d9\u30f3\u30c8\u30ab\u30ec\u30f3\u30c0\u30fc\u30d7\u30e9\u30b0\u30a4\u30f3\u3092\u4f7f\u7528\u3057\u3066\u30a4\u30d9\u30f3\u30c8\u3092\u4f5c\u6210\u30fb\u524a\u9664\u3059\u308b\u65b9\u6cd5\u3092\u7d39\u4ecb\u3057\u307e\u3059\u3002 \u4eca\u56de\u306f\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3092\u30b9\u30ad\u30c3\u30d7\u3057\u307e\u3059\u3002 \u30d7\u30ed\u30b8 [&hellip;]<\/p>\n","protected":false},"author":19,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[100],"tags":[],"acf":[],"_links":{"self":[{"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/posts\/11402"}],"collection":[{"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/users\/19"}],"replies":[{"embeddable":true,"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/comments?post=11402"}],"version-history":[{"count":4,"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/posts\/11402\/revisions"}],"predecessor-version":[{"id":11410,"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/posts\/11402\/revisions\/11410"}],"wp:attachment":[{"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/media?parent=11402"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/categories?post=11402"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.gigas-jp.com\/appnews\/wp-json\/wp\/v2\/tags?post=11402"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}