filter($request->all())->get(); return CustomFieldResource::collection($customFields); } /** * Store a newly created resource in storage. */ public function store(CreateOrUpdateRequest $request) { if (Auth::user()->super_admin) { $namingRule = NamingRule::query()->where("id", $request->group)->first(); if (!in_array($request->group, config("custom-field.groups")) && !$namingRule) { return $this->forbidden("Operation without permission"); } } else { $namingRule = NamingRule::query()->where("company_id", Auth::user()->company_id)->where("id", $request->group)->first(); if (! $namingRule) { return $this->forbidden('Naming rule does not exist'); } } CustomField::query()->updateOrCreate([ 'group' => $request->group, 'key' => $request->key, ], $request->all()); return $this->created(); } public function groups() { $nameRuleGroups=NamingRule::query()->get()->pluck('id')->toArray(); $allGroups=config("custom-field.groups"); if(!empty($nameRuleGroups)){ $notNameRule = []; foreach ($allGroups as $group) { if (!in_array($group, $nameRuleGroups)) { $notNameRule[] = $group; } } return $this->success([ 'data' => $notNameRule ]); } return $this->success([ 'data'=> $allGroups ]); } public function nameRuleGroups() { $nameRuleGroupsIds = NamingRule::query()->pluck('id')->toArray(); $allGroups = config("custom-field.groups"); $intersectIds = array_intersect($allGroups, $nameRuleGroupsIds); if (empty($intersectIds)) { return $this->success([]); } $inGroups = NamingRule::query()->whereIn('id', $intersectIds)->get(); return NamingRuleSimpleResource::collection($inGroups); } /** * Display the specified resource. */ public function show(string $id) { $field = CustomField::query()->findOrFail($id); return new CustomFieldResource($field); } /** * Update the specified resource in storage. */ public function update(Request $request, string $id) { // } /** * Remove the specified resource from storage. */ public function destroy(string $id) { // } }