diff --git a/front-api/controllers/cart.rb b/front-api/controllers/cart.rb index 6774025..08a10f9 100644 --- a/front-api/controllers/cart.rb +++ b/front-api/controllers/cart.rb @@ -1,9 +1,9 @@ -create_the_cart = -> () { +create_the_cart = lambda do # -1 is a placeholder for user id when we implement users # auid will still be used in case user is not logged in Cart.find_or_create(anonymous_id, logged_in_user_id).to_json -} +end post '/cart', &create_the_cart put '/cart', &create_the_cart @@ -16,22 +16,19 @@ get '/cart/item' do Cart.just_find(anonymous_id, logged_in_user_id).item_in_carts.to_json end -update_cart_item = ->() { +update_cart_item = lambda do cart_id = Cart.just_find(anonymous_id, logged_in_user_id).id - item_id = @json_params["item_id"].to_i - count = @json_params["count"].to_i + item_id = @json_params['item_id'].to_i + count = @json_params['count'].to_i ItemInCart.update_state(cart_id, item_id, count).to_json -} +end put '/cart/item', &update_cart_item post '/cart/item', &update_cart_item - # gets list of items in cart without count get '/cart/item/display' do cart = Cart.just_find(anonymous_id, logged_in_user_id) - item_ids = cart.item_in_carts.map do |x| - x.item_id - end + item_ids = cart.item_in_carts.map(&:item_id) items = [] items = Item.find(item_ids) if cart.item_in_carts.length > 0 prepare_items_for_mass_display(items) @@ -39,32 +36,32 @@ end get '/cart/delivery_destination' do cart = Cart.just_find(anonymous_id, logged_in_user_id) - cart.delivery_destination.to_json(:except => [:created_at, :email_verification_code, :phone_verification_code]) + cart.delivery_destination.to_json(except: [:created_at, :email_verification_code, :phone_verification_code]) end -update_delivery_destination = ->() { +update_delivery_destination = lambda do cart = Cart.just_find(anonymous_id, logged_in_user_id) - allowed_keys = ["name", "address", "place", "postal_code", "phone", "email", "note", "payment_method", "gift", - "recipient_name", "recipient_address", "recipient_place", "recipient_postal_code", "recipient_phone", "recipient_email"] + allowed_keys = %w(name address place postal_code phone email note payment_method gift + recipient_name recipient_address recipient_place recipient_postal_code recipient_phone recipient_email) - params = @json_params.reject { |key,_| !allowed_keys.include?(key) } + params = @json_params.reject { |key, _| !allowed_keys.include?(key) } cart.delivery_destination.update_attributes(params) cart.delivery_destination.save! - cart.delivery_destination.to_json(:except => [:created_at, :email_verification_code, :phone_verification_code]) -} + cart.delivery_destination.to_json(except: [:created_at, :email_verification_code, :phone_verification_code]) +end put '/cart/delivery_destination', &update_delivery_destination post '/cart/delivery_destination', &update_delivery_destination def report_to_trello(cart) Thread.new do @cart = cart - board = Trello::Board.find(RibicaConfig.TRELLO_BOARD_NAME) + board = Trello::Board.find(RibicaConfig::TRELLO_BOARD_NAME) list = board.lists.first card = Trello::Card.new card.list_id = list.id card.name = cart.title - card.pos = "bottom" - card.desc = erb(:cart_trello, :layout => false) + card.pos = 'bottom' + card.desc = erb(:cart_trello, layout: false) card.save end end @@ -72,22 +69,21 @@ end def send_order_email(cart) Thread.new do client = SendGrid::Client.new( - api_user: RibicaConfig.SENDGRID_API_USER, - api_key: RibicaConfig.SENDGRID_API_KEY + api_user: RibicaConfig::SENDGRID_API_USER, + api_key: RibicaConfig::SENDGRID_API_KEY ) email = SendGrid::Mail.new do |m| - m.to = RibicaConfig.BACKOFFICE_ORDER_EMAIL_TO - m.from = RibicaConfig.BACKOFFICE_ORDER_EMAIL_FROM - m.from_name = "Prodavnica Ribica" + m.to = RibicaConfig::BACKOFFICE_ORDER_EMAIL_TO + m.from = RibicaConfig::BACKOFFICE_ORDER_EMAIL_FROM + m.from_name = 'Prodavnica Ribica' m.subject = "Nova Narudžba: #{cart.id}" - m.html = "Mušterija naručila nešto.
Pogledati #{RibicaConfig.ROOT_ADDRESS}/backoffice/carts/#{cart.id}" + m.html = "Mušterija naručila nešto.
Pogledati #{RibicaConfig::ROOT_ADDRESS}/backoffice/carts/#{cart.id}" end client.send(email) end end - post '/cart/confirmation' do anonymous = anonymous_id cart = Cart.just_find(anonymous, logged_in_user_id) @@ -98,48 +94,50 @@ post '/cart/confirmation' do # since there is no more ordered cart this needs to be done # in order for next call of Cart#just_find to be ready Cart.find_or_create(anonymous, logged_in_user_id) + report_to_trello(cart) send_order_email(cart) - "OK".to_json + + 'OK'.to_json end post '/payment/confirmation' do - data = JSON.parse params[:custom] + data = JSON.parse params[:custom] - puts "Data #{data.inspect}" + puts "Data #{data.inspect}" - anonymous = data["anonymous_id_string"] - user = data["user_id"] - user ||= -1 - user = user.to_i + anonymous = data['anonymous_id_string'] + user = data['user_id'] + user ||= -1 + user = user.to_i - cart = Cart.just_find(anonymous, user) - if cart.item_in_carts.length > 0 - cart.ordered = true - cart.save! - end + cart = Cart.just_find(anonymous, user) + if cart.item_in_carts.length > 0 + cart.ordered = true + cart.save! + end - Cart.find_or_create(anonymous, user) - report_to_trello(cart) - send_order_email(cart) - "OK".to_json + Cart.find_or_create(anonymous, user) + report_to_trello(cart) + send_order_email(cart) + 'OK'.to_json end get '/pikpay/confirmation' do - anonymous = params["anonymous_id_string"] - user = params["user_id"] - user ||= -1 - user = user.to_i + anonymous = params['anonymous_id_string'] + user = params['user_id'] + user ||= -1 + user = user.to_i - cart = Cart.just_find(anonymous, user) - if cart.item_in_carts.length > 0 - cart.ordered = true - cart.save! - end + cart = Cart.just_find(anonymous, user) + if cart.item_in_carts.length > 0 + cart.ordered = true + cart.save! + end - Cart.find_or_create(anonymous, user) - report_to_trello(cart) - send_order_email(cart) + Cart.find_or_create(anonymous, user) + report_to_trello(cart) + send_order_email(cart) - redirect "#{RibicaConfig::ROOT_ADDRESS}/hvala" + redirect "#{RibicaConfig::ROOT_ADDRESS}/hvala" end diff --git a/front-api/views/cart_trello.erb b/front-api/views/cart_trello.erb index 8f1bfa4..75b176a 100644 --- a/front-api/views/cart_trello.erb +++ b/front-api/views/cart_trello.erb @@ -55,3 +55,4 @@ Dostava **UKUPNO:** <%= Helper.money(c.total) %> [Pogledati OVAJ LINK](https://www.ribica.ba/backoffice/carts/<%= @cart.id %>) +<% end %>