当我提交重力表条目时$entry
始终将我的输入键作为字段ID返回。
问题是,我有多个表单使用gform_after_submission
行动
因为重力表单使用字段ID作为输入键,这意味着我需要单独的函数或数组来处理每个表单以完成相同的操作。因为我的字段ID在每个表单上都是不同的。
是否有办法将重力表单输入字段键更改为自定义id字符串,而不是整数和浮点?
<pre>Array
(
[id] => 63
[status] => active
[form_id] => 1
[ip] => 172.25.0.1
[source_url] => http://localhost/cart/
[currency] => GBP
[post_id] =>
[date_created] => 2020-04-18 11:27:16
[date_updated] => 2020-04-18 11:27:16
[is_starred] => 0
[is_read] => 0
[user_agent] => Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.92 Safari/537.36
[payment_status] =>
[payment_date] =>
[payment_amount] =>
[payment_method] =>
[transaction_id] =>
[is_fulfilled] =>
[created_by] => 1
[transaction_type] =>
[1.1] =>
[3] => collection
[24] =>
[13] => Josh
[14] => Moto
[15] => test@gmail.com
[16] => 01234567890
[17] => 09876543210
[18] => 09876543210
[20.1] => pay-by-phone
[21.1] => confirm-submission
[22.1] => accept-terms
)
</pre>
这只是我所做工作的扩展。请参见下面的我的代码。
add_action(\'gform_after_submission_1\', [ $this, \'create_order\' ], 10, 2 );
public function create_order( $entry, $form ) {
// get the current cart data array
$data = self::data();
// create an order array
$order = [
\'post_author\' => $user_id,
\'post_content\' => json_encode($data,JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES),
\'post_type\' => \'purchase-order\',
\'post_status\' => \'publish\'
];
// create order post using an array and return the post id
$result = wp_insert_post($order);
// if post id and is not a wp error then
if($result && !is_wp_error($result)) {
// get the id
$post_id = $result;
// update personal details
update_field(\'order_first_name\',$entry[\'13\'],$post_id);
// more update field functions...
}
}
所以,正如你们所看到的,我想做的是
update_field
作用
例如,我使用字段id的输入值$entry[\'13\']
.
但我希望字段id是字符串,这样我就可以使用update_field
像这样。。。
update_field(\'order_first_name\',$entry[\'order_first_name\'],$post_id);
返回的
$entry
数组应该是这样的。。。
Array
(
[id] => 63
[status] => active
[form_id] => 1
[ip] => 172.25.0.1
[source_url] => http://localhost/cart/
[currency] => GBP
[post_id] =>
[date_created] => 2020-04-18 11:27:16
[date_updated] => 2020-04-18 11:27:16
[is_starred] => 0
[is_read] => 0
[user_agent] => Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.92 Safari/537.36
[payment_status] =>
[payment_date] =>
[payment_amount] =>
[payment_method] =>
[transaction_id] =>
[is_fulfilled] =>
[created_by] => 1
[transaction_type] =>
[order_install.1] =>
[order_delivery_type] => collection
[order_username] =>
[order_first_name] => Josh
[order_last_name] => Moto
[order_email] => test@gmail.com
[order_telephone] => 01234567890
[order_telephone_2] => 09876543210
[order_whatsapp] => 09876543210
[order_terms_payment.1] => pay-by-phone
[order_terms_confirm.1] => confirm-submission
[order_terms_accept.1] => accept-terms
)
<人力资源>
@DaveWiz 谢谢你的回答,看看我是怎么用的。
/**
* C
* @param array $entry
* @param array $form
* @return void
*/
public static function key_conversion($entry, $form) {
// admin value keys
$order_first_name = \'order_first_name\';
// for each fields
foreach( $form[\'fields\'] as $field ) {
// check case on admin label
switch( $field->adminLabel ) {
// order first name
case $order_first_name:
$entry[$order_first_name] = $entry[ $field->id ];
unset($entry[ $field->id ]);
break;
}
}
}