mirror of https://github.com/fspc/BikeShed-1.git
Jason Denney
12 years ago
11 changed files with 203 additions and 12 deletions
@ -0,0 +1,67 @@ |
|||||
|
class TransactionLogs < Netzke::Basepack::Grid |
||||
|
|
||||
|
def configure(c) |
||||
|
super |
||||
|
|
||||
|
c.model = "ActsAsLoggable::Log" |
||||
|
c.title = "Transaction Payments" |
||||
|
c.data_store = {auto_load: false} |
||||
|
c.scope = lambda { |rel| rel.where(:loggable_type => 'Transaction',:loggable_id => session[:selected_transaction_id]);} |
||||
|
c.strong_default_attrs = { |
||||
|
:loggable_type => 'Transaction', |
||||
|
:loggable_id => session[:selected_transaction_id], |
||||
|
:log_action_type => 'ActsAsLoggable::TransactionAction', |
||||
|
:logger_type => 'User', |
||||
|
:logger_id => controller.current_user.id, |
||||
|
:start_date => Time.now.to_formatted_s(:db), |
||||
|
:end_date => Time.now.to_formatted_s(:db) |
||||
|
} |
||||
|
|
||||
|
c.columns = [ |
||||
|
{ :name => :start_date, :format => "g:ia - D, M j - Y", :width => 165, :default_value => Time.now.to_formatted_s(:db), :text => 'Date' }, |
||||
|
{ :name => :description, :text => "Amount"} , |
||||
|
{ :name => :transaction_action__action, :text => 'Method'}, |
||||
|
{ :name => :logged_by, :getter => lambda{ |rec| |
||||
|
user = User.find_by_id(rec.logger_id) |
||||
|
user.nil? ? "" : "#{user.first_name} #{user.last_name}" |
||||
|
}, |
||||
|
:text => "Processed by" |
||||
|
} |
||||
|
] |
||||
|
|
||||
|
if controller.current_user.user? |
||||
|
c.prohibit_update = true |
||||
|
c.prohibit_create = true |
||||
|
c.prohibit_delete = true |
||||
|
end |
||||
|
|
||||
|
end |
||||
|
|
||||
|
def default_fields_for_forms |
||||
|
customer = nil |
||||
|
item = nil |
||||
|
if session[:selected_transaction_id] |
||||
|
trans = Transaction.find_by_id(session[:selected_transaction_id]) |
||||
|
customer = trans.customer |
||||
|
item = trans.item |
||||
|
end |
||||
|
customer = "No Customer Selected" if customer.nil? |
||||
|
item = "No Item Selected" if item.nil? |
||||
|
[ |
||||
|
{ :no_binding => true, :xtype => 'displayfield', :fieldLabel => "Payment from:", :value => "#{customer.to_s}"}, |
||||
|
{ :no_binding => true, :xtype => 'displayfield', :fieldLabel => "Payment for:", :value => "#{item.to_s}"}, |
||||
|
{ :name => :description, :xtype => 'numberfield', :field_label => 'Amount'}, |
||||
|
#had to hack acts_as_loggable/log.rb to get this to work |
||||
|
{ :name => :transaction_action__action, :field_label => 'Payment Method'} |
||||
|
] |
||||
|
end |
||||
|
|
||||
|
|
||||
|
#override with nil to remove actions |
||||
|
def default_bbar |
||||
|
bbar = [ :search ] |
||||
|
bbar.concat [ :apply, :add_in_form ] if not controller.current_user.user? |
||||
|
bbar |
||||
|
end |
||||
|
|
||||
|
end |
@ -0,0 +1,14 @@ |
|||||
|
{ |
||||
|
initComponent: function(){ |
||||
|
// calling superclass's initComponent
|
||||
|
this.callParent(); |
||||
|
|
||||
|
// setting the 'rowclick' event
|
||||
|
var view = this.getComponent('transactions').getView(); |
||||
|
view.on('itemclick', function(view, record){ |
||||
|
// The beauty of using Ext.Direct: calling 3 endpoints in a row, which results in a single call to the server!
|
||||
|
this.selectTransaction({transaction_id: record.get('id')}); |
||||
|
this.getComponent('transaction_logs').getStore().load(); |
||||
|
}, this); |
||||
|
} |
||||
|
} |
@ -0,0 +1,40 @@ |
|||||
|
class UserTransactions < Netzke::Basepack::Grid |
||||
|
|
||||
|
def configure(c) |
||||
|
super |
||||
|
|
||||
|
c.model = "Transaction" |
||||
|
c.title = "Transactions" |
||||
|
c.scope = lambda { |rel| rel.where(:customer_id => controller.current_user.id, :customer_type => 'User');} |
||||
|
c.data_store = { auto_load: true } |
||||
|
c.columns = [ |
||||
|
:amount, |
||||
|
:item, |
||||
|
{ :name => :bike__serial_number}, |
||||
|
{ :name => :vendor, :getter => lambda { |rec| |
||||
|
user = rec.vendor |
||||
|
user.nil? ? "" : "#{user.first_name} #{user.last_name}" |
||||
|
} |
||||
|
}, |
||||
|
{ :name => :customer, :getter => lambda { |rec| |
||||
|
user = rec.customer |
||||
|
user.nil? ? "" : "#{user.first_name} #{user.last_name}" |
||||
|
} |
||||
|
}, |
||||
|
:created_at |
||||
|
] |
||||
|
|
||||
|
if controller.current_user.user? |
||||
|
c.prohibit_update = true |
||||
|
c.prohibit_create = true |
||||
|
c.prohibit_delete = true |
||||
|
end |
||||
|
end |
||||
|
|
||||
|
#override with nil to remove actions |
||||
|
def default_bbar |
||||
|
bbar = [ :search ] |
||||
|
bbar.concat [ :apply, :add_in_form ] if not controller.current_user.user? |
||||
|
bbar |
||||
|
end |
||||
|
end |
@ -0,0 +1,27 @@ |
|||||
|
class UserTransactionsBorder < Netzke::Base |
||||
|
# Remember regions collapse state and size |
||||
|
include Netzke::Basepack::ItemPersistence |
||||
|
component :user_transactions |
||||
|
component :transaction_logs |
||||
|
|
||||
|
def configure(c) |
||||
|
super |
||||
|
c.header = false |
||||
|
c.title = "Transactions" |
||||
|
c.items = [ |
||||
|
{ netzke_component: :user_transactions, region: :center, height: 300, split: true }, |
||||
|
{ netzke_component: :transaction_logs, region: :south, height: 300, split: true } |
||||
|
] |
||||
|
end |
||||
|
|
||||
|
js_configure do |c| |
||||
|
c.layout = :border |
||||
|
c.border = false |
||||
|
c.mixin :init_component |
||||
|
end |
||||
|
|
||||
|
endpoint :select_transaction do |params, this| |
||||
|
session[:selected_transaction_id] = params[:transaction_id] |
||||
|
end |
||||
|
|
||||
|
end |
@ -0,0 +1,14 @@ |
|||||
|
{ |
||||
|
initComponent: function(){ |
||||
|
// calling superclass's initComponent
|
||||
|
this.callParent(); |
||||
|
|
||||
|
// setting the 'rowclick' event
|
||||
|
var view = this.getComponent('user_transactions').getView(); |
||||
|
view.on('itemclick', function(view, record){ |
||||
|
// The beauty of using Ext.Direct: calling 3 endpoints in a row, which results in a single call to the server!
|
||||
|
this.selectTransaction({transaction_id: record.get('id')}); |
||||
|
this.getComponent('transaction_logs').getStore().load(); |
||||
|
}, this); |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue