Edit File: show.blade.php
@extends('admin.layout.master') @section('content') <!-- // Basic multiple Column Form section start --> <section id="multiple-column-form"> <div class="row"> {{-- start order details --}} @include('admin.assign_delegate_orders.details.main') {{-- end order details --}} {{-- provider details --}} @include('admin.assign_delegate_orders.details.provider') {{-- end provider details --}} {{-- user details --}} @include('admin.assign_delegate_orders.details.user') {{-- end user details --}} <div id="map" style="width: 100%; height: 600px"></div> <!--loop here and put your lat , lng , image , name--> <div class="single-marker lines-between" data-img=""> <input type="text" hidden class="lat" value="{{ $order->lat }}" /> <input type="text" hidden class="lng" value="{{ $order->lng }}" /> </div> @foreach ($delegates as $delegate) <div class="single-marker" data-object="{{ $delegate }}" data-img="{{ $delegate->image }}"> <input type="text" hidden class="lat" value="{{ $delegate->lat }}" /> <input type="text" hidden class="lng" value="{{ $delegate->lng }}" /> </div> @endforeach <div class="col-12 d-flex justify-content-center mt-3"> <a href="{{ url()->previous() }}" type="reset" class="btn btn-outline-warning mr-1 mb-1">{{ __('admin.back') }}</a> </div> </div> </section> @endsection @section('js') <script src="{{ asset('admin/app-assets/vendors/js/extensions/sweetalert2.all.min.js') }}"></script> <script src="{{ asset('admin/app-assets/js/scripts/extensions/sweet-alerts.js') }}"></script> <script src="{{ asset('admin/app-assets/js/scripts/pages/app-email.js') }}"></script> <script async defer src="https://maps.googleapis.com/maps/api/js?key=AIzaSyA9S2ndLXNQAUC10JXWv9ajJljAxcVF-eM&callback=initMap&libraries=places&language=ar" type="text/javascript"></script> <!--<script type="text/javascript">--> <!-- var ltlng = [];--> <!-- let markers = {};--> <!-- var map = new google.maps.Map(document.getElementById("map"), {--> <!-- zoom: 11,--> <!-- center: new google.maps.LatLng(--> <!-- Number($(".lat").val()),--> <!-- Number($(".lng").val())--> <!-- ),--> <!-- mapTypeId: google.maps.MapTypeId.ROADMAP,--> <!-- });--> <!-- var infowindow = new google.maps.InfoWindow();--> <!-- var marker, i;--> <!-- let markersNum = document.querySelectorAll('.single-marker')--> <!-- ltlng = [];--> <!-- let fixedLat = document.querySelector('.lat').value;--> <!-- let fixedLng = document.querySelector('.lng').value;--> <!-- const fixedPoint = new google.maps.LatLng(fixedLat, fixedLng);--> <!-- for (i = 0; i < markersNum.length; i++) {--> <!-- if (document.querySelector('.lines-between')) {--> <!-- ltlng.push(new google.maps.LatLng(markersNum[i].querySelector('.lat').value, markersNum[i].querySelector(--> <!-- '.lng').value));--> // Create a path for each marker to the fixed point <!-- var path = [ltlng[i], fixedPoint];--> //Intialize the Direction Service <!-- var service = new google.maps.DirectionsService();--> <!-- var flightPath = new google.maps.Polyline({--> <!-- path: path,--> <!-- geodesic: true,--> <!-- strokeColor: '#4986E7',--> <!-- strokeOpacity: 2.0,--> <!-- strokeWeight: 4--> <!-- });--> <!-- flightPath.setMap(map);--> <!-- }--> <!-- marker = new google.maps.Marker({--> <!-- position: new google.maps.LatLng(markersNum[i].querySelector('.lat').value, markersNum[i]--> <!-- .querySelector('.lng').value),--> <!-- map: map,--> <!-- draggable: false,--> <!-- });--> <!-- google.maps.event.addListener(--> <!-- marker,--> <!-- "click",--> <!-- (function(marker, i) {--> <!-- marker.setIcon({--> url: markersNum[i].dataset.img, // Path to your custom marker image scaledSize: new google.maps.Size(50, 50), // Adjust the size as needed <!-- origin: new google.maps.Point(0, 0),--> anchor: new google.maps.Point(25, 50), // Adjust the anchor point if necessary <!-- });--> <!-- return function() {--> <!-- let delegate = JSON.parse(markersNum[i].dataset.object)--> <!-- let has_orders = delegate.orders.length ? "{{ __('admin.yes') }}" :--> <!-- "{{ __('admin.no') }}"--> <!-- console.log()--> <!-- infowindow.setContent(--> <!-- `<div class="d-flex justify-content-center">{{ __('admin.name') }}: (${delegate.name})</div>--> <!-- <div class="d-flex justify-content-center mt-1">{{ __('admin.has_order') }}: (${has_orders})</div>--> <!-- ${delegate.orders && delegate.orders.length > 0 ? "<div class='d-flex justify-content-center mt-1'>{{ __('admin.order_num') }}: (#" + delegate.orders[0].order_num + ")</div>" :--> <!-- '<div class="mt-1 text-center"><a href="#" class="btn btn-primary assign-btn" data-delegate_id="' + delegate.id + '">{{ __('admin.assign_to_me') }}</a></div>'}`--> <!-- );--> <!-- infowindow.open(map, marker);--> <!-- };--> <!-- })(marker, i)--> <!-- );--> <!-- }--> <!--</script>--> <script> var markers = {}; function initMap() { var mapOptions = { center: new google.maps.LatLng({{ $order->lat }}, {{ $order->lng }}), zoom: 6, mapTypeId: google.maps.MapTypeId.ROADMAP }; var map = new google.maps.Map(document.getElementById("map"), mapOptions); // Object to store markers by user ID marker = new google.maps.Marker({ position: new google.maps.LatLng({{$order->lat}}, {{$order->lng}}), map: map, title: '# {{$order->order_num}}' }); @foreach($delegates as $key => $user) // Create marker markers['marker_{{$user->id}}'] = new google.maps.Marker({ position: new google.maps.LatLng({{$user->lat}}, {{$user->lng}}), map: map, icon: { url: '{{$user->image}}', scaledSize: new google.maps.Size(50, 50) }, title: '{{$user->name}}' }); // Add click event to marker google.maps.event.addListener(markers['marker_{{$user->id}}'], 'click', (function(marker) { return function() { let order_num = "{{ $user?->orders?->first()?->order_num ?? '' }}"; console.log("order_num=>",order_num) // let userItem = JSON.parse("{{$user->orders}}"); let has_orders = order_num != "" ? "{{ __('admin.yes') }}" : "{{ __('admin.no') }}" var infowindow = new google.maps.InfoWindow({ content:`<div class="d-flex justify-content-center">{{ __('admin.name') }}: ("{{$user->name}}")</div> <div class="d-flex justify-content-center mt-1">{{ __('admin.has_order') }}: (${has_orders})</div> ${order_num != "" ? "<div class='d-flex justify-content-center mt-1'>{{ __('admin.order_num') }}: (#" + order_num + ")</div>" : '<div class="mt-1 text-center"><a href="#" class="btn btn-primary assign-btn" data-delegate_id="{{$user->id}}">{{ __('admin.assign_to_me') }}</a></div>'}` }); infowindow.open(map, marker); } })(markers['marker_{{$user->id}}'])); @endforeach } </script> <script type="module"> import { io } from "https://cdn.socket.io/4.7.5/socket.io.esm.min.js"; const socket = io('https://thunder-way.com:4797',{ query: { sender_id : "1", sender_type : "Admin", sender_name : "admin", avatar : "" } }); // Listen for location updates from the server socket.on('moveMarker', (data) => { console.log("data",data) // Update marker position markers['marker_' + data.sender_id].setPosition(new google.maps.LatLng(data.lat, data.lng)); // Optionally center the map on the new marker position // map.panTo(new google.maps.LatLng(data.lat, data.lng)); }); </script> <script> // $(document).ready(function () { $(document).on("click", '.assign-btn', function(e) { e.preventDefault(); let order_id = "{{ $order->id }}" let delegate_id = $(this).data('delegate_id') let url = '/admin/assign-delegate-orders/' + order_id + '/assign/' + delegate_id $.ajax({ type: "GET", url: url, data: { _token: "{{ csrf_token() }}" }, success: function(response) { Swal.fire({ position: 'top-start', type: response.key, title: response.msg, showConfirmButton: false, timer: 1500, confirmButtonClass: 'btn btn-primary', buttonsStyling: false, }) setTimeout(function() { window.location.replace(response.url) }, 1000); } }) }) // }) </script> @endsection
Back to File Manager