- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个显示交易搜索结果的页面,并且我有一个基于一列( token )的搜索过滤器,单击此后应设置搜索条件,并且应在 post 方法中将搜索参数作为表单数据传递。但目前,它被附加到 URL 中。请帮助我
_ payment_transaction.html.erb
<div class="block">
<% if @transactions_exceed_limit %>
<div class="row">
<div class="block-title" id="max-fetch-results-message">
<h4 class="text-primary">Your search returned too many results, so only the first <%=
TransactionSearchController::MAX_FETCH_SIZE %> results have been displayed.</h4>
</div>
</div>
<% end %>
<div class="row" style="width:100% !important;">
<div class="col-md-4">
<div class="block-title">
<% if @integratedApi == false %>
<h3><strong> <%= @transactions.count %> results found</strong></h3>
<%else %>
<h3><strong> <%= @total_records %> results found</strong></h3>
<%end %>
</div>
</div>
<div class="col-md-8">
<div id="csvButton">
<%= form_tag(csv_path(params.except('controller', 'action').merge(format: "csv")), method: "post") do %>
<%= submit_tag "Download CSV", class: 'btn btn--charcoal-ghost', id: 'download_csv' %>
<% end %>
</div>
</div>
</div>
<div class="row" style="margin-bottom: 5px">
<hr class="line">
</div>
<div class="row">
<div class="table-responsive tb-responsive tble-responsive">
<table class="table table-condensed table-hover" id="search-result-table" style="margin-left:2%">
<thead>
<tr>
<th>Transaction Id</th>
<th>Order Id</th>
<th>Store Id</th>
<th>Transaction Date</th>
<th>Transaction Type</th>
<th>Tender Type</th>
<th>Token</th>
<th>Amount</th>
<th>Currency</th>
<th>Response </br>Code</th>
</tr>
</thead>
<tbody>
<% if @integratedApi %>
<% @transactions.each do |transaction| %>
<tr>
<td><%= link_to transaction[:paymentTransactionId], details_path(:id=> transaction), {:remote => true, 'data-toggle' => "modal", 'data-target' => '#modal-window'} %></td>
<td><%= transaction[:paymentSessionId]%></td>
<td><%= transaction[:storeId]%></td>
<td><%= transaction[:createTimestamp].in_time_zone(@timezone).strftime('%B %d, %Y - %l:%M %p') %></td>
<td><%= @transaction_types[transaction[:transactionType]] %></td>
<td><%= @tenders[transaction[:tenderType]][1] %></td>
<td><%= link_to transaction[:paymentAcctUniqueId], params.merge(account_id: transaction[:paymentAcctUniqueId], show_results: "true",clickAccount:"Y"), id: "act_id" %></td>
<td><%= PaymentsHelper.amount_with_currency_symbol transaction[:transactionAmount], transaction[:isoCurrencyCode]%></td>
<td><%= transaction[:isoCurrencyCode]%></td>
<td><%=transaction[:responseCode]%></td>
</tr>
<% end %>
<% else %>
<% @transactions.each do |transaction| %>
<tr>
<td><%= link_to transaction['payment_transaction_id'], details_path(payment_transaction_id: transaction['payment_transaction_id']), {:remote => true, 'data-toggle' => "modal", 'data-target' => '#modal-window'} %></td>
<td><%= transaction['payment_session_id'] %></td>
<td><%= transaction['store_id'] %></td>
<td><%= transaction['create_timestamp'].in_time_zone(@timezone).strftime('%B %d, %Y - %l:%M %p') %></td>
<td><%= @transaction_types[transaction['transaction_type']] %></td>
<td><%= @tenders[transaction['tender_type']][1] %></td>
<% if (@tenders[transaction['tender_type']][0]).in?(['PLCC', 'GC', 'CC', 'CBCC']) %>
<td><%= link_to transaction['payment_acct_unique_id'], params.merge(account_id: transaction['payment_acct_unique_id'], show_results: "true",clickAccount:"Y"), id: "act_id" %></td>
<% else %>
<td><%= transaction['payment_acct_unique_id'] %></td>
<% end %>
<% if show_settlement_type? %>
<td><%= PaymentsHelper.settlement_amount_with_currency_symbol transaction['transaction_amount'], transaction['iso_currency_code'],transaction['settlement_type'] %></td>
<% else %>
<td><%= PaymentsHelper.amount_with_currency_symbol transaction['transaction_amount'], transaction['iso_currency_code'] %></td>
<% end %>
<td><%= transaction['iso_currency_code'] %></td>
<% if transaction['transaction_status'] == ('F') %>
<td>Payment Service Error</td>
<% else %>
<td><%= transaction['response_code'] %></td>
<% end %>
<% end %>
</tr>
<% end %>
</tbody>
</table>
</div>
</div>
<div id="modal-window" class="modal fade" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true"></div>
</div>
搜索.html.erb
<script type="text/javascript">
pt_default_time_gap = <%= ENV['PAYPTL_TRANSACTION_SEARCH_DEFAULT_TIME_GAP_IN_DAYS']%>;
pt_max_time_gap = <%= ENV['PAYPTL_TRANSACTION_SEARCH_MAX_TIME_GAP_IN_DAYS']%>;
pt_max_from_date_time_gap = <%= ENV['PAYPTL_TRANSACTION_SEARCH_MAX_TIME_GAP_FROM_CURRENT_DATE_IN_DAYS']%>;
</script>
<% provide(:title, 'Transaction Search') %>
<div id="load"></div>
<% content_for :sub_header do %>
<%= form_tag({controller: "transaction_search", action: "search"}, method: "post", style: "margin-bottom: 20px;", id: "search_crit_form") do %>
<%= render "search_criteria" %>
<div class="row" id="advanced_filters" style="display:none;">
<%= render "transaction_search/advance_filters" %>
</div>
<% end %>
<% end %>
<div id="contents">
<div class="row" style="margin-bottom:5px;margin-top: 15px" id="search_results">
<div class="search_results_pane" id="search_results_table">
<% if @transactions.present? %>
<%= render partial: "transaction_search/payment_transaction", object: @transactions %>
<% else %>
<div class="block">
<div class="block-title" id="emptyResults">
<h2 class="text-primary"><strong>No Results </strong> Found</h2>
</div>
</div>
<% end %>
</div>
</div>
</div>
transaction_search_controller.rb
require 'base64'
require 'rest-client'
require 'xmlrpc'
require 'nokogiri'
require 'date'
require 'will_paginate/array'
class TransactionSearchController < ApplicationController
include PaymentsHelper
include ApplicationHelper
protect_from_forgery except: :details
before_filter :authenticate_user!, :can_view_payments_txns?
before_action :set_store_and_timezone
before_action :tenders_and_transaction_types, only: [:search, :details]
before_action :settlement_status, only: [:details]
DEFAULT_TIME_GAP_IN_DAYS = "#{ENV['PAYPTL_TRANSACTION_SEARCH_DEFAULT_TIME_GAP_IN_DAYS']}".to_i.freeze
DATE_FORMAT = '%Y/%m/%d %H:%M'.freeze
SHOW_MOCK_TRANSACTION = ("#{ENV['PAYPTL_TRANSACTION_SEARCH_EXCLUDE_MOCK_TXS']}" == "true").freeze
PAYMENTS_URI = "#{ENV['PAYPTL_PAYMENT_SERVICE_PROTECT_PAN_URI']}".freeze
PAYMENTS_USERNAME = "#{ENV['PAYPTL_PAYMENT_SERVICE_PROTECT_PAN_USERNAME']}".freeze
PAYMENTS_PASSWORD = "#{ENV['PAYPTL_PAYMENT_SERVICE_PROTECT_PAN_PASSWORD']}".freeze
MAX_FETCH_SIZE = "#{ENV['PAYPTL_TRANSACTION_MAX_FETCH_SIZE']}".to_i.freeze
MAX_FETCH_SIZE_CSV = "#{ENV['PAYPTL_TRANSACTION_MAX_FETCH_SIZE_CSV']}".to_i.freeze
TRANSACTION_SEARCH_REST_API_ENABLED_FLAG = "#{ENV['PAYPTL_TRANSACTION_SEARCH_REST_API_ENABLED_FLAG']}"
PTF_CLIENT_MANAGEMENT_SERVICE_URL = "#{ENV['PAYPTL_PTF_CLIENT_MANAGEMENT_SERVICE_URL']}"
def search
@integratedApi=false
if TRANSACTION_SEARCH_REST_API_ENABLED_FLAG == 'Y'
@integratedApi=true
payload = Hash.new
if params[:per_page].present?
@selected_per_page = params[:per_page]
else
@selected_per_page = 2000
end
params[:page] = params[:page] || 1
payload['storeIds'] = params[:store_ids]
params[:start_date] = params[:start_date] || Time.now.utc.to_date.days_ago(DEFAULT_TIME_GAP_IN_DAYS - 1).beginning_of_day.strftime(DATE_FORMAT)
params[:end_date] = params[:end_date] || Time.now.utc.to_date.end_of_day.strftime(DATE_FORMAT)
payload['startDate'] = params[:start_date]
payload['endDate'] = params[:end_date]
payload['pageNum'] = params[:page]
payload['perPage'] = @selected_per_page
payload['paymentSessionId'] = params[:payment_session_id] if params[:payment_session_id].present?
payload['paymentAcctUniqueId'] = params[:account_id] if params[:account_id].present?
payload['transactionTypes'] = params[:transaction_types] if params[:transaction_types].present?
payload['tenderTypes'] = params[:tender_types] if params[:tender_types].present?
payload['transactionStatuses'] = params[:transaction_statuses] if params[:transaction_statuses].present?
payload['isoCurrencyCode'] = params[:iso_currency_code] if params[:iso_currency_code].present?
payload['transactionAmount'] = params[:transaction_amount] if params[:transaction_amount].present?
@transaction_search_results = get_transaction_search_details(PTF_CLIENT_MANAGEMENT_SERVICE_URL + "/payments/transaction/search", payload)
if @transaction_search_results.present? && @transaction_search_results.kind_of?(Hash) && @transaction_search_results.has_key?(:transactions)
@total_records = @transaction_search_results[:totalCount]
@total_records = @total_records.nil? ? 0 : @total_records.to_i
@transactions = @transaction_search_results[:transactions]
end
else
if @store_list.empty?
flash.now[:danger] = 'No Store Mapped'
end
params[:per_page] = params[:per_page] || 20
params[:page] = params[:page] || 1
params[:start_date] = params[:start_date] || Time.now.utc.to_date.days_ago(DEFAULT_TIME_GAP_IN_DAYS - 1).beginning_of_day.strftime(DATE_FORMAT)
params[:end_date] = params[:end_date] || Time.now.utc.to_date.end_of_day.strftime(DATE_FORMAT)
results
end
end
def get_transaction_search_details(rest_url, payload)
begin
rest_resource = RestClient::Resource.new(rest_url,ENV['PAYPTL_PTF_CLIENT_MANAGEMENT_SERVICE_USER_NAME'], ENV['PAYPTL_PTF_CLIENT_MANAGEMENT_SERVICE_PASSWORD'])
Rails.logger.debug("Calling Transaction Search URL:#{rest_url}\n Payload:#{payload.to_json}")
@transaction_search_response = rest_resource.post payload.to_json, :content_type => 'application/json'
if @transaction_search_response.code == Rack::Utils::SYMBOL_TO_STATUS_CODE[:ok]
return JSON.parse(@transaction_search_response, :symbolize_names => true)
else
Rails.logger.error("Transaction search return status code #{@transaction_search_response.code} for payload #{payload}")
end
rescue => e
Rails.logger.error(e.message)
flash.now[:danger] = 'Unable to fetch data, Please try later'
end
end
def results
start_date = Time.strptime(params[:start_date], DATE_FORMAT).utc.beginning_of_day
end_date = Time.strptime(params[:end_date], DATE_FORMAT).utc.end_of_day
condition = Hash.new
@accountId=params[:account_id]
condition[:store_id] = @store_for_service
condition[:payment_session_id] = params[:payment_session_id] if params[:payment_session_id].present?
condition[:transaction_test_ind] = [0, nil] if !SHOW_MOCK_TRANSACTION
condition[:transaction_type] = params[:transaction_types] if params[:transaction_types].present?
condition[:transaction_amount] = params[:transaction_amount] if params[:transaction_amount].present?
condition[:iso_currency_code] = params[:iso_currency_code] if params[:iso_currency_code].present?
condition[:tender_type] = params[:tender_types] if params[:tender_types].present?
condition[:transaction_status] = params[:transaction_statuses] if params[:transaction_statuses].present?
@page=params[:page]
if(@accountId!=nil && @accountId!='')
condition[:payment_acct_unique_id] = @accountId
if(params[:clickAccount]=='Y')
@page=1
params[:clickAccount]='N'
end
end
condition[:transaction_status] = params[:transaction_statuses] if params[:transaction_statuses].present?
if params[:action] == 'csvexport'
@transactions_export_csv = PaymentTransactionFlat.where(:create_timestamp => start_date..end_date).where(condition).order(create_timestamp: :desc).limit(MAX_FETCH_SIZE_CSV)
else
@transactions = PaymentTransactionFlat.where(:create_timestamp => start_date..end_date).where(condition).order(create_timestamp: :desc).limit(MAX_FETCH_SIZE + 1)
if @transactions.present?
@transactions = @transactions.to_a
if @transactions.count > MAX_FETCH_SIZE
@transactions = @transactions[0..(MAX_FETCH_SIZE - 1)]
@transactions_exceed_limit = true
end
=begin
@transactions = @transactions.paginate(:per_page => params[:per_page], :page => @page, :total_entries => @transactions.count)
=end
end
end
end
def details
@integratedApi=false
if TRANSACTION_SEARCH_REST_API_ENABLED_FLAG == 'Y'
@integratedApi=true
@transaction = params[:id]
else
@transaction = PaymentTransactionFlat.transaction_details(params[:payment_transaction_id])
if @transaction.present?
@settlement = PaymentTransactionFlat.settlement_transaction(@transaction['payment_transaction_id']).first
@response_cc_auth = PaymentTransactionFlat.response_cc_auth(@transaction['payment_transaction_id']).first
if @settlement.present?
@auth_transaction = PaymentTransactionFlat.authorization_transaction(@settlement['auth_pmt_transaction_id']).first
@customer_billing_address = PaymentTransactionFlat.customer_billing_address(@settlement['auth_pmt_transaction_id']).first
@settlement_history = PaymentTransactionFlat.settlement_transaction_history(@settlement['payment_transaction_id'])
end
end
end
end
def retrieve_payload(account_number, tender_class)
builder = Nokogiri::XML::Builder.new do |xml|
xml.ProtectPanRequest('xmlns' => 'http://api.gsicommerce.com/schema/checkout/1.0') do
xml.PaymentAccountNumber_ account_number
xml.TenderClass tender_class
end
end
return builder.to_xml
end
def retrieve_account_number(account_number)
if account_number.present? && account_number =~ /^[0-9]+$/
rest_client = RestClient::Resource.new(PAYMENTS_URI, PAYMENTS_USERNAME, PAYMENTS_PASSWORD)
PaymentsHelper::TENDER_CLASS.each do |key, value|
begin
response = rest_client.post retrieve_payload(account_number, value), :content_type => 'application/xml'
parsed_response = Hash.from_xml(response)
account_number = parsed_response.try(:[], 'ProtectPanReply').try(:[], 'Token') || account_number
break
rescue RestClient::RequestFailed
next
end
end
end
account_number
end
# Code for CSV generation
# Enable the CSV library
require 'csv'
# Action for generating the CSV
def csvexport
respond_to do |format|
format.csv do
send_data export_to_csv(results),
filename: 'transactions.csv',
type: 'text/csv; charset=utf-8; header=present',
disposition: 'attachment'
end
end
end
# Method for generating the csv file
def export_to_csv(records)
# Header names used in CSV file
csv_header = ['Transaction Id', 'Order Id', 'Store Id', 'Transaction Date', 'Transaction Type', 'Tender Type', 'Token', 'Amount', 'Currency', 'Response Code']
CSV.generate do |csv|
csv << csv_header
records.each do |record| # Quick fix for CSV download problem to export only specified columns
csv << [record['payment_transaction_id'], record['payment_session_id'], record['store_id'], record['create_timestamp'].in_time_zone(@timezone).strftime('%B %d, %Y - %l:%M %p'), record['transaction_type'],
record['tender_type'], record['payment_acct_unique_id'],
if record['transaction_amount'].to_s.present?
record['settlement_type'].to_s.casecmp("C")== 0 ? '-$' +
record['transaction_amount'].to_s : '$' + record['transaction_amount'].to_s else ' ' end, record['iso_currency_code'],
record['response_code'] == ('F') ? 'Payment Service Error' : record['response_code']]
end
end
end
def get_store_timezone
render json: ActiveSupport::TimeZone.find_tzinfo(get_timezone(@selected_store)), status: :ok
end
private
def set_store_and_timezone
params[:store_ids] = get_default_store if params[:store_ids].blank?
@selected_store = params[:store_ids]
@store_for_service = replace_with_store_mappings(@selected_store, ApplicationHelper::PAYMENTS_SERVICE)
@timezone = get_timezone @selected_store
zone_map = JSON.parse((ActiveSupport::TimeZone.find_tzinfo @timezone).to_json)
@moment_timezone = zone_map['identifier']
end
def tenders_and_transaction_types
@tenders = Rails.cache.fetch(:payment_tenders) {PaymentRecord.tenders}
@transaction_types = Rails.cache.fetch(:payment_transaction_types) {PaymentRecord.transaction_types}
end
def settlement_status
@settlement_statuses = Rails.cache.fetch(:payment_settlement_statuses) {PaymentRecord.settlement_status}
end
end
最佳答案
link_to 始终会将参数放入查询字符串中,因为它正在创建 get 样式的 HTML 链接 - 即使您放置 :method => :post 只是附加一个额外的 ("special ") 参数_method。
Rails 提供的 button_to 帮助程序可以根据您的要求工作,它将使其成为表单帖子。
请点击下面给出的链接了解更多详细信息:
https://apidock.com/rails/ActionView/Helpers/UrlHelper/button_to
关于javascript - 如何在rails link_to 的表单数据中传递查询参数而不是将其附加在url中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54229502/
sanitize 是什么意思在 Rails 中是什么意思? 我正在阅读 CanCanCan 的文档.它说: When using strong_parameters or Rails 4+, you
在过去的几个月里,我感觉自己对 Ruby on Rails (RoR) 开发的了解达到了极限。我为大/小客户和 friend /爱好项目开发了大大小小的应用程序。我知道如何开发这些应用程序,但开始感觉
我昨天参加了一个关于扩展 Rails 的聚会,其中一个主题是 Hexagonal Rails。然而,我只做了一年的 Rails,对 MVC 结构非常满意(也许太舒服了),所以我不太了解适配器和消息队列
我使用多个 Rails 应用程序,一些在 Rails 3.2/Ruby 2.0 上,一些在 Rails 2.3/Ruby 1.8.7 上。 他们的共同点是,随着他们的成长和添加更多的依赖项/ gem
这个问题在这里已经有了答案: Using Rails-UJS in JS modules (Rails 6 with webpacker) (5 个答案) 关闭 3 年前。 我正在尝试使用 UJS
我正在开发一个当前使用 Rails 1.2 的 Rails 应用程序,所以我现在离最新的稳定版本(Rails 2.3)还有很长的路要走。 我应该如何进行迁移到更新版本的 Rails 的过程? 我应该一
尝试按照 Ryan Bates Backbone.js 教程构建抽奖应用程序,但我已经遇到了第一段代码的问题。在 application.js 的 init 函数中,他初始化了 Raffler 路由的
我正在使用 Rails 3.2 并且我有一个数据库表,我想在其中找到符合以下条件的所有行: a = true and b = true and ( 0 true, :b =>
我有一个用户类和一个联系人,其中联系人是用户的子类。这两个类都存储在用户表中。 我的联系人可能有也可能没有电子邮件地址,而我的用户需要一个电子邮件地址(我的用户模型定义中有 validates_pre
我正在编写一个教程,我在其中演示了一些 rails 命令。在我的机器上 rails和 script/rails两者都同样有效。有“首选”形式吗?两者中哪一个更普遍? 最佳答案 当您运行 rails 时
我正在寻找有关通过我的应用程序前进的最佳方式的建议,这是我首次开始集成Elasticsearch。我是一名初学者,但是热衷于深入研究,以便原谅任何明显的错误! 我遵循了http://www.sitep
我刚刚用 Rails new 启动了一个新的 Rails 应用程序,将默认数据库设置更改为 PostgresSQL。我用 bin/rails s 启动服务器,结果很奇怪 2016-04-21 05:0
我收到一个参数并希望它是这样的字符串: "abc,efg" 或者像这样的数组 ["abc","efg"] 在第一种情况下,我想将它转换成一个数组,什么是好的方法? 这是我的想法 if params[:
我刚刚用 Rails new 启动了一个新的 Rails 应用程序,将默认数据库设置更改为 PostgresSQL。我用 bin/rails s 启动服务器,结果很奇怪 2016-04-21 05:0
我收到一个参数并希望它是这样的字符串: "abc,efg" 或者像这样的数组 ["abc","efg"] 在第一种情况下,我想将它转换成一个数组,什么是好的方法? 这是我的想法 if params[:
我有 Rails 4,这是我的默认版本(我仍然希望它是)。但我不想在我的电脑上添加 rails 3.2。在以下命令中:gem install rails -v 3.2.16 我有这个警告: railt
您好,我想使用 Sheevaplug 构建一个“Rails Brick”来自 Marvell(操作系统是开箱即用的 Ubuntu,但您可以在其上安装其他发行版)。它将成为家庭服务器和静音、低成本(99
我需要能够从 Rails 控制台发送我的 Rails 应用程序的 Postgres 数据库中所有未接受的邀请。 (我有一个名为 Invitations 的表,其中包含一个名为 accepted 的 b
validate :cannot_modify_if_locked, on: :update def cannot_modify_if_locked if self.locked erro
我正在学习教程(学习 Rails 播客),需要更改以下路由语法,以便它与 Rails 3.0 兼容。谁能帮忙? map.view_page ':name', :controller => 'viewe
我是一名优秀的程序员,十分优秀!