address saving almost works
This commit is contained in:
@@ -30,6 +30,8 @@ end
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
helpers Sinatra::Cookies
|
helpers Sinatra::Cookies
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
|
|
||||||
|
|
||||||
helpers do
|
helpers do
|
||||||
def anonymous_id
|
def anonymous_id
|
||||||
@@ -42,4 +42,20 @@ get '/cart/item/display' do
|
|||||||
items = []
|
items = []
|
||||||
items = Item.find(item_ids) if cart.item_in_carts.length > 0
|
items = Item.find(item_ids) if cart.item_in_carts.length > 0
|
||||||
prepare_items_for_mass_display(items)
|
prepare_items_for_mass_display(items)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
get '/cart/delivery_destination' do
|
||||||
|
cart = Cart.find_or_create(anonymous_id, -1)
|
||||||
|
cart.delivery_destination.to_json(:except => [:created_at, :email_verification_code, :phone_verification_code])
|
||||||
|
end
|
||||||
|
|
||||||
|
update_delivery_destination = ->() {
|
||||||
|
cart = Cart.find_or_create(anonymous_id, -1)
|
||||||
|
allowed_keys = ["name", "address", "place", "postal_code", "phone", "email", "note"]
|
||||||
|
params = @json_params.reject { |key,_| !allowed_keys.include?(key) }
|
||||||
|
cart.delivery_destination.update_attributes(params)
|
||||||
|
cart.delivery_destination.save!
|
||||||
|
cart.delivery_destination.to_json
|
||||||
|
}
|
||||||
|
put '/cart/delivery_destination', &update_delivery_destination
|
||||||
|
post '/cart/delivery_destination', &update_delivery_destination
|
||||||
@@ -2,7 +2,6 @@
|
|||||||
|
|
||||||
get '/category' do
|
get '/category' do
|
||||||
Category.order(:name).all.to_json(:include => [:section, :sub_categories, :filter_criterias =>{:include => :filter_criteria_values} ])
|
Category.order(:name).all.to_json(:include => [:section, :sub_categories, :filter_criterias =>{:include => :filter_criteria_values} ])
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
get '/category/:id' do
|
get '/category/:id' do
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
get '/filter/section/:id' do |id_s|
|
get '/filter/section/:id' do |id_s|
|
||||||
# get filter criteria for a section with id
|
# get filter criteria for a section with id
|
||||||
FilterCriteria.where(:owner_type => "Section").where(:owner_id => id_s.to_i).to_json(
|
FilterCriteria.where(:owner_type => "Section").where(:owner_id => id_s.to_i).to_json(
|
||||||
:include => [:filter_criteria_values]
|
:include => [:filter_criteria_values]
|
||||||
|
|||||||
@@ -1,10 +1,13 @@
|
|||||||
class Cart < ActiveRecord::Base
|
class Cart < ActiveRecord::Base
|
||||||
has_many :item_in_carts, -> { order "created_at" }
|
has_many :item_in_carts, -> { order "created_at" }
|
||||||
|
belongs_to :delivery_destination
|
||||||
|
|
||||||
def self.find_or_create(anonymous_id, user_id)
|
def self.find_or_create(anonymous_id, user_id)
|
||||||
cart = Cart.where(user_id: user_id).where(ordered: false).first
|
cart = Cart.where(user_id: user_id).where(ordered: false).first
|
||||||
cart ||= Cart.where(anonymous_id_string: anonymous_id).where(ordered: false).first
|
cart ||= Cart.where(anonymous_id_string: anonymous_id).where(ordered: false).first
|
||||||
safe_user_id = (user_id > 0) ? user_id : nil
|
safe_user_id = (user_id > 0) ? user_id : nil
|
||||||
cart ||= Cart.create!(anonymous_id_string: anonymous_id, user_id: safe_user_id, ordered: false )
|
cart ||= Cart.create!(anonymous_id_string: anonymous_id, user_id: safe_user_id, ordered: false )
|
||||||
|
cart.delivery_destination ||= DeliveryDestination.create!
|
||||||
|
return cart
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
4
front-api/models/delivery_destination.rb
Normal file
4
front-api/models/delivery_destination.rb
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
class DeliveryDestination < ActiveRecord::Base
|
||||||
|
has_one :cart
|
||||||
|
belongs_to :user
|
||||||
|
end
|
||||||
@@ -43,6 +43,11 @@ var CartActions = {
|
|||||||
property: property,
|
property: property,
|
||||||
value: value
|
value: value
|
||||||
});
|
});
|
||||||
|
},
|
||||||
|
confirmDelivery: function() {
|
||||||
|
AppDispatcher.handleAction({
|
||||||
|
actionType: CartConstants.CONFIRM_DELIVERY,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -9,5 +9,6 @@ module.exports = keyMirror({
|
|||||||
TAKE_ITEM_OUT: null ,
|
TAKE_ITEM_OUT: null ,
|
||||||
CART_DATA_LOADED: null,
|
CART_DATA_LOADED: null,
|
||||||
SAVE_CART_STATE_FOR_ITEM: null,
|
SAVE_CART_STATE_FOR_ITEM: null,
|
||||||
CHANGE_DELIVERY_DESTINATION_PROPERTY: null
|
CHANGE_DELIVERY_DESTINATION_PROPERTY: null,
|
||||||
|
CONFIRM_DELIVERY: null
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -34,6 +34,11 @@ var loadCart = function() {
|
|||||||
CartActions.dataLoaded();
|
CartActions.dataLoaded();
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
_deliveryDestination.fetch({
|
||||||
|
success: function() {
|
||||||
|
CartActions.dataLoaded();
|
||||||
|
}
|
||||||
|
})
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -74,7 +79,13 @@ var changeDeliveryDestinationProperty = function (property, value) {
|
|||||||
_deliveryDestination.set(property, value);
|
_deliveryDestination.set(property, value);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var saveDeliveryDestination = function() {
|
||||||
|
_deliveryDestination.save({
|
||||||
|
success: function() {
|
||||||
|
CartActions.dataLoaded();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
// Extend CartStore with EventEmitter to add eventing capabilities
|
// Extend CartStore with EventEmitter to add eventing capabilities
|
||||||
@@ -156,6 +167,8 @@ AppDispatcher.register(function(payload) {
|
|||||||
break;
|
break;
|
||||||
case CartConstants.CHANGE_DELIVERY_DESTINATION_PROPERTY:
|
case CartConstants.CHANGE_DELIVERY_DESTINATION_PROPERTY:
|
||||||
changeDeliveryDestinationProperty(action.propety, action.value)
|
changeDeliveryDestinationProperty(action.propety, action.value)
|
||||||
|
case CartConstants.CONFIRM_DELIVERY:
|
||||||
|
saveDeliveryDestination();
|
||||||
default:
|
default:
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user