Lluís Puig Ferrer
Lluís Puig Ferrer

Reputation: 1146

Laravel: Update data without select file again

I have a table called projects with this fields:

TABLE INFORMATION

id, slug, order, public, pathheader and pathhome.

CREATE VIEW

The form to store the data looks like this:

<div id="formcreateproject">
        <form  enctype="multipart/form-data" id="myFormProject" name="myFormProject">
         <input type="hidden" name="_token" value="{{ Session::token() }}">

          <div class="form-group">
            <label name="title">Slug:</label>
            <input type="text" id="slug" name="slug" placeholder="ejemplo-de-slug" class="form-control form-control-sm"><br>
      <!--      <label name="order">Order:</label>
            <input type="number" id="order" name="order" class="form-control form-control-sm">-->
            <!--<label name="public">Public:</label>-->
              <table>
                <tr>
                  <td>
                      <img src="" id="img" class="img" style="width:100%;height:200px;background-color:#ccc;border:2px solid gray;" onerror="this.src=''">
                      <input type="file" name="pathheader" id="pathheader"  class="form-control-file" aria-describedby="fileHelp" style="display:none;">
                  </td>
                  <td>
                      <img src="" id="img2" class="img2" style="width:100%;height:200px;background-color:#ccc;border:2px solid gray;" onerror="this.src=''">
                      <input type="file" name="pathhome" id="pathhome" class="form-control-file" aria-describedby="fileHelp" style="display:none;"><br>
                  </td>
                </tr>
                <tr>
                  <td>
                      <input type="button" name="" value="Seleccionar header" id="browse_file" class="btn btn-danger form-control">
                  </td>
                  <td>
                      <input type="button" name="" value="Seleccionar home" id="browse_file2" class="btn btn-danger form-control">
                  </td>
                </tr>
              </table><br>
            <input type="submit" value="Crear Proyecto" id="createprojectsubmit" class="btn btn-danger btn-md">
            <br><br><br>

          </div>
        </form>

      </div>

FUNCTION TO SAVE THE DATA

And the function looks like this:

 public function storeProject(Request $request)
        {

        $project = new Project();
        $project->slug = $request->input("slug");
        //$project->order = $request->input("order");
        $project->order = DB::table('projects')
                      ->where('order', DB::raw("(select max(`order`) from projects)"))
                      ->first()
                      ->order + 1; 
        $project->public = 0;
        $project->pathheader = $request->file('pathheader');
        $project->pathhome = $request->file('pathhome');

        \Storage::disk('projects')->makeDirectory($project->slug);
        \Storage::disk('projects')->putFileAs($project->slug,$project->pathheader,'header.jpg');
        \Storage::disk('projects')->putFileAs($project->slug,$project->pathhome,'home.jpg');
        $project->save();
        }

This works really good, and save me values like: /tmp/phQX0ddm in pathheader and pathhome.

VIEW TO UPDATE THE DATA

<div class="form-group">
                <label><strong>Slug</strong></label>
                  <textarea type="text" class="form-control form-control-sm" id="slug" name="slug" rows="1" required style="resize:none;">{{$project->slug}}</textarea>
              </div>

                  <div class="form-group">
                      <label><strong>Order</strong></label>
                      <textarea type="number" class="form-control form-control-sm" id="order" name="order" rows="1">{{$project->order}}</textarea>
                </div>

            <div class="form-group">
                <label><strong>Public</strong></label>
                <textarea type="text" class="form-control form-control-sm" id="public" name="public" value="" rows="1">{{$project->public}}</textarea>
            </div>

            <div class="form-group">
           <table>
                <tr>
                  <td>
                      @if (Storage::disk('projects')->has($project->slug))
                      <img src="{{ asset('/storage/projects/'.$project->slug.'/header.jpg') }}" id="img" class="img" style="width:100%;height:200px;background-color:#ccc;border:2px solid gray;">
                      @else
                      <img src="" id="img" class="img" style="width:100%;height:200px;background-color:#ccc;border:2px solid gray;">
                      @endif
                      <input type="file" name="pathheader" id="pathheader" class="form-control-file" aria-describedby="fileHelp" style="display:none;">
                  </td>
                  <td>
                      @if (Storage::disk('projects')->has($project->slug))
                      <img src="{{ asset('/storage/projects/'.$project->slug.'/home.jpg') }}" id="img" class="img" style="width:100%;height:200px;background-color:#ccc;border:2px solid gray;">
                      @else
                      <img src="" id="img2" class="img2" style="width:100%;height:200px;background-color:#ccc;border:2px solid gray;">
                      @endif
                      <input type="file" name="pathhome" id="pathhome" class="form-control-file" aria-describedby="fileHelp" style="display:none;"><br>
                  </td>
                </tr>
                <tr>
                  <td>
                      <input type="button" name="" value="Seleccionar header" id="browse_file" class="btn btn-danger form-control">
                  </td>
                  <td>
                      <input type="button" name="" value="Seleccionar home" id="browse_file2" class="btn btn-danger form-control">
                  </td>
                </tr>
     </table>

FUNCTION TO UPDATE THE DATA

public function updateProject(Request $request, $id) 

//Actualizar la informacion de un trabajador
    {
        $project = Project::find($id);
        $project->slug = $request->input('slug');
        $project->order = $request->input('order');
        $project->public = $request->input('public');
        if($request->hasFile('pathheader')){
            $project->pathheader = $request->file('pathheader');
            \Storage::disk('projects')->putFileAs($project->slug,$project->pathheader,'header.jpg');
        }
        $project->pathheader = Project::find($id)->pathheader;
        if($request->hasFile('pathhome')){
            $project->pathhome = $request->file('pathhome');
            \Storage::disk('projects')->putFileAs($project->slug,$project->pathhome,'home.jpg');
        }
        $project->pathhome = Project::find($id)->pathhome;
        $project->save();
    }

The problem is, if I don't select again the file when I update the data, image isn't loaded.

How can I fix this? My first idea was take the value of pathhome and pathheader and put it on function controller to update the data again with same values, but doesn't work.

I hope someone can help me, I will be really really appreciated.

Upvotes: 1

Views: 983

Answers (3)

AddWeb Solution Pvt Ltd
AddWeb Solution Pvt Ltd

Reputation: 21681

I think you should try this :

$project->pathheader = DB::table('projects')
                            ->where('id',$id)
                            ->where('pathheader',  DB::raw("(select pathheader from projects)"))
                            ->first();

Hope this work for you !!!

Upvotes: 0

Jaseel P V
Jaseel P V

Reputation: 310

You can try this query

$pathheader = DB::table('projects')->select('pathheader')->where('id','=',$id)‌​->first(); 

I think this is what you seeking for

Upvotes: 0

Mihai Matei
Mihai Matei

Reputation: 24276

You can use the Project model like:

$pathheader = Project::find($id)->pathheader;

Upvotes: 2

Related Questions