Skip to content

Commit

Permalink
json file update
Browse files Browse the repository at this point in the history
  • Loading branch information
A1Gard committed Dec 4, 2023
1 parent 1c374b0 commit 5e759b1
Show file tree
Hide file tree
Showing 7 changed files with 105 additions and 26 deletions.
68 changes: 47 additions & 21 deletions app/Http/Controllers/Admin/XlangController.php
Original file line number Diff line number Diff line change
Expand Up @@ -10,23 +10,26 @@
use function Xmen\StarterKit\Helpers\logAdmin;
use function Xmen\StarterKit\Helpers\logAdminBatch;

const PREFIX_PATH = __DIR__ . '/../../../../';
class XlangController extends Controller
{

public function createOrUpdate(Xlang $xlang, XlangSaveRequest $request) {
public function createOrUpdate(Xlang $xlang, XlangSaveRequest $request)
{
$xlang->name = $request->input('name');
$xlang->tag = $request->input('tag');
$xlang->rtl = $request->has('rtl');


if ($request->hasFile('img')) {
$name = time().'.'.request()->img->getClientOriginalExtension();
$name = time() . '.' . request()->img->getClientOriginalExtension();
$xlang->img = $name;
$request->file('img')->storeAs('public/langz', $name);
}
$xlang->save();
return $xlang;
}

/**
* Display a listing of the resource.
*
Expand All @@ -36,8 +39,8 @@ public function index()
{
//
Artisan::call('translator:update');
$langs = Xlang::paginate(99);
return view('admin.langs.langIndex',compact('langs'));
$langs = Xlang::paginate(99);
return view('admin.langs.langIndex', compact('langs'));
}

/**
Expand All @@ -54,25 +57,25 @@ public function create()
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(XlangSaveRequest $request)
{
//
define("TRANSLATE_CONFIG_PATH", __DIR__ . '/../../../../config/translator.php');
define("TRANSLATE_NEW_FILE",__DIR__ . '/../../../../resources/lang/'.$request->tag.'.json' );
define("TRANSLATE_CONFIG_PATH", PREFIX_PATH . 'config/translator.php');
define("TRANSLATE_NEW_FILE", PREFIX_PATH . 'resources/lang/' . $request->tag . '.json');
$config = file_get_contents(TRANSLATE_CONFIG_PATH);
$re = '/\'languages\' \=\> (.*)\,/m';
preg_match_all($re, $config, $matches, PREG_SET_ORDER, 0);
$oldLangs = $matches[0][1];

$newLans = json_encode(array_unique(array_merge(json_decode($oldLangs),[$request->tag])));
$newConfig = (str_replace($oldLangs,$newLans,$config));
file_put_contents(TRANSLATE_CONFIG_PATH,$newConfig);
$newLans = json_encode(array_unique(array_merge(json_decode($oldLangs), [$request->tag])));
$newConfig = (str_replace($oldLangs, $newLans, $config));
file_put_contents(TRANSLATE_CONFIG_PATH, $newConfig);

if (!file_exists(TRANSLATE_NEW_FILE)){
file_put_contents(TRANSLATE_NEW_FILE,'{}');
if (!file_exists(TRANSLATE_NEW_FILE)) {
file_put_contents(TRANSLATE_NEW_FILE, '{}');
}

$xlang = new Xlang();
Expand All @@ -84,7 +87,7 @@ public function store(XlangSaveRequest $request)
/**
* Display the specified resource.
*
* @param \App\Models\Xlang $xlang
* @param \App\Models\Xlang $xlang
* @return \Illuminate\Http\Response
*/
public function show(Xlang $xlang)
Expand All @@ -95,20 +98,20 @@ public function show(Xlang $xlang)
/**
* Show the form for editing the specified resource.
*
* @param \App\Models\Xlang $xlang
* @param \App\Models\Xlang $xlang
* @return \Illuminate\Http\Response
*/
public function edit(Xlang $xlang)
{
//
return view('admin.langs.langForm',compact('xlang'));
return view('admin.langs.langForm', compact('xlang'));
}

/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param \App\Models\Xlang $xlang
* @param \Illuminate\Http\Request $request
* @param \App\Models\Xlang $xlang
* @return \Illuminate\Http\Response
*/
public function update(XlangSaveRequest $request, Xlang $xlang)
Expand All @@ -122,7 +125,7 @@ public function update(XlangSaveRequest $request, Xlang $xlang)
/**
* Remove the specified resource from storage.
*
* @param \App\Models\Xlang $xlang
* @param \App\Models\Xlang $xlang
* @return \Illuminate\Http\Response
*/
public function destroy(Xlang $xlang)
Expand All @@ -133,17 +136,40 @@ public function destroy(Xlang $xlang)
return redirect()->route('admin.lang.index')->with(['message' => __('Lang') . ' ' . __('deleted successfully')]);
}

public function translate(){
public function translate()
{
$langs = Xlang::all();
return view('admin.langs.translateIndex', compact('langs'));
}


public function download($tag)
{
define("TRANSLATE_FILE", PREFIX_PATH . 'resources/lang/' . $tag . '.json');
return response()->download(TRANSLATE_FILE, $tag . '.json');
}

public function upload($tag, Request $request)
{
define("TRANSLATE_FILE", PREFIX_PATH . 'resources/lang/' . $tag . '.json');
if (!$request->hasFile('json')) {
return redirect()->back();
}
$data = (file_get_contents($request->file('json')->getRealPath()));
if (json_decode($data) == null) {
return redirect()->back()->withErrors(__("Invalid json file!"));
}
file_put_contents(TRANSLATE_FILE, $data);
return redirect()->back()->with(['message' => __("Translate updated")]);
}

public function bulk(Request $request) {
public function bulk(Request $request)
{

switch ($request->input('bulk')) {
case 'delete':
$msg = __('transports deleted successfully');
logAdminBatch(__METHOD__.'.'.$request->input('bulk'),XlangController::class,$request->input('id'));
logAdminBatch(__METHOD__ . '.' . $request->input('bulk'), XlangController::class, $request->input('id'));
XlangController::destroy($request->input('id'));
break;
default:
Expand Down
6 changes: 6 additions & 0 deletions public/css/app.css

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

9 changes: 5 additions & 4 deletions resources/lang/fa.json
Original file line number Diff line number Diff line change
Expand Up @@ -255,11 +255,12 @@
"Is pinned news?": "آیا این مطلب سنجاق شود",
"Is pinned posts?": "آیا این مطلب سنجاق شود",
"Key": "کلید",
"LTR": "راست به چپ",
"LTR": "چپ به راست",
"Label": "برچسب",
"Lang": "زبان",
"Language list": "",
"Languages": "",
"Language list": "فهرست زبان‌ها",
"Languages": "زبان‌ها",
"Languages translate": "",
"Last update": "آخرین به‌روز‌رسانی",
"Last video": "واپسین فیلم",
"Leave your comment": "ارسال دیدگاه",
Expand Down Expand Up @@ -614,4 +615,4 @@
"user": "کاربر",
"weight": "وزن",
"yesterday": "دیروز"
}
}
3 changes: 2 additions & 1 deletion resources/lang/ru.json
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,7 @@
"Lang": "",
"Language list": "",
"Languages": "",
"Languages translate": "",
"Last update": "",
"Link": "",
"Login": "",
Expand Down Expand Up @@ -470,4 +471,4 @@
"transports deleted successfully": "",
"updated successfully": "",
"weight": ""
}
}
5 changes: 5 additions & 0 deletions resources/sass/app.scss
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,11 @@ nav {
}
}

.lang-item{
background: #ddd;
border-radius: 7px;
padding: 1rem;
}
.x64 {
width: 64px;
}
Expand Down
38 changes: 38 additions & 0 deletions resources/views/admin/langs/translateIndex.blade.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
@extends('admin.adminlayout')
@section('page_title')
{{__("Languages translate")}}
-
@endsection
@section('content')
<div class="container">

@include('starter-kit::component.err')

<div class="text-center pt-3">
<div class="row">
@foreach($langs as $lang)
<div class="col-md-4">
<div class="lang-item">
<h5>
{{$lang->name}}
</h5>
<a href="{{route('admin.lang.download',$lang->tag)}}" class="btn btn-outline-dark w-100 mb-3 btn-sm">
<i class="ri-download-2-line"></i>
{{__("Download json file")}}
</a>
<form action="{{route('admin.lang.upload',$lang->tag)}}" method="post" enctype="multipart/form-data">
@csrf
<input type="file" name="json" id="file" class="form-control">
<button class="btn btn-outline-primary btn-sm w-100 mt-2">
<i class="ri-upload-2-line"></i>
{{__("Upload file")}}
</button>
</form>

</div>
</div>
@endforeach
</div>
</div>
</div>
@endsection
2 changes: 2 additions & 0 deletions routes/web.php
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,8 @@ function () {
Route::get('/edit/{xlang}', [\App\Http\Controllers\Admin\XlangController::class,'edit'])->name('edit');
Route::post('/update/{xlang}', [\App\Http\Controllers\Admin\XlangController::class,'update'])->name('update');
Route::post('bulk', [\App\Http\Controllers\Admin\XlangController::class, "bulk"])->name('bulk');
Route::get('/download/{tag}', [\App\Http\Controllers\Admin\XlangController::class,'download'])->name('download');
Route::post('/upload/{tag}', [\App\Http\Controllers\Admin\XlangController::class,'upload'])->name('upload');

});

Expand Down

0 comments on commit 5e759b1

Please sign in to comment.