Ir al contenido principal

Rails - Basic Steps VI

Commands

  • time_ago_in_words()  - As the name said put a date in words
  • redirect_to - Redirect to an URL
  • params[:attribute] - Get in the controller the parameters from the session

Authentication

  • In the controller root_app\app\controllers\*.rb
    • At the beginning of the file add :  before_action :authenticate, except: [:index, :show]
      • Where authenticate is a method, that need to be defined
    • Then add at the final of the file the method definition
        def authenticate
            authenticate_or_request_with_http_basic do |name, password|
              name == "admin" && password == "123"
            end
        end

    Ajax (Video 8 6:56 min)

    • In the View root_app\views\post\show.html.erb
      • In the form tag, add a parameter to the form_for method:   remote: true
    • In the Controller root_app\controller\comment_controllers
      • Add the line:  format_js
      • If after that you do not specified any file, the default file to consider is method_name.js.erb
    • Create a JS cretate.js.erb 
      • Create a file in root_app\views\comments and named create.js.erb
        • Add the code
    var new_comment = $("<%= escape_javascript( render(:partial => @comment))%>").hide();
    $('#comments').prepend(new_comment);
    $('#comments_<%= @comment.id %>').fadeIn('slow');
    $('#new_comment')[0].reset();

    escape_javascript() - Ruby validate that the code is valid javascript
    • Return to root_app\views\comment\ and Create partial template for the part you want to create dynamically _comment.html.erb
      • Add the following lines (this code come from the View) :
    <%= div_for comment do %>
          <p>
               <strong> Posted <%= time_ago_in_words(comment.created_at) %>  ago  </strong>
               <br/>
               <%= h(comment.body)  %>
          </p>
    <% end %>





    • In the View root_app\views\post\show.html.erb



    • Replace the code for show comments for:
    • <%= render :partial => @post.comments.reverse  %>



      Comentarios

      Entradas populares de este blog

      Android - Basic Steps (Service)

      Service Run in the main thread of the hosting application Android can kill the Service if need the resources Purpose Supporting inter-application method execution Performing background processing Start a Service Call Context.startService(Intent intent)\ To call from a Fragment use getActivity().getApplicationContext().startService( intentService); Executing the service After call startService(...)  In the Service is executed the method onStartCommand(...) If the method returns the constant START_NOT_STICKY then Android will not restart the service automatically if the the process is killedp Foreground To execute the service foreground call the method startForeground() Use this if the user is aware of the process Bind to a Service Call the method Context.bindService( Intent service ServiceConnection con int flags ) Send Toast from the Service On the method onStartCommand receive the message   ...

      Android - Basic Steps (Location & Maps)

      Location Is composed by Latitude Longitude Time-stamp Accuracy Altitude Speed Bearing LocationProvider Types: Network  Wifi access points Cell phone towers GPS Passive Piggyback on the readings requested by other application Permissions Network  android.permission.ACCESS_COARSE_LOCATION android.permission.ACCESS_FINE_LOCATION GPS android.permission.ACCESS_FINE_LOCATION Passive Provider android.permission.ACCESS_FINE_LOCATION LocationManager System service for accessing location data getSystemService( Context.LOCATION_SERVICE ) Functions Determine the last known user location Register for location update Register to receive intents when the device nears or move away from a given geographic area LocationListener Defines callbacks methods that are called when Location or LocationProvider status change. Methods onLocationChanged(...) onProviderDisabled(...) onProviderEnabled(...) onStatusChan...

      IIS - Permisions

      IIS Permissions To enable the Active Directory connection in the IIS, follow the next steps: Go to IIS Go to Application Pool Select your App Pool Select Advanced Settings in the right side In the section Process Model Select in Identity value the property " NetworkService " You don´t need to restart your application