ユーザーが履歴書とプロフィール画像をアップロードできるセクションがあります。
私はネイティブの添付ファイル機能を使っています、
$attachment_cv_id = media_handle_upload( 'candidate_cv', 0 );
if ( ! is_wp_error( $attachment_cv_id ) ) {
// We link this file to the post
// add_post_meta( $result , 'wpcf-cv-file', wp_get_attachment_url($attachment_cv_id));
} else {
$submit_candidate_errors[] = lang("Hubo error subiendo la CV");
}
Wp-adminのメディアセクションからこのファイルを隠すことができる方法はありますか? (おそらくそのフォルダを変更する)
ありがとう
- 編集 -
私はDaveが提案したように、メタを追加してみました: 'rrhh-file'
$attachment_id = media_handle_upload( 'apply_file', 0 );
if ( ! is_wp_error( $attachment_id ) ) {
// The image was uploaded successfully!
add_post_meta($attachment_id, 'rrhh-file', true);
}
そしてそれが属性を持っていることでさえ:
var_dump(get_post_meta(1200)); // last id I uploaded
die();
プリントアウト:
array(4) {
["_wp_attached_file"]=>
array(1) {
[0]=>
string(20) "2017/06/image001.jpg"
}
["_wp_attachment_metadata"]=>
array(1) {
[0]=>
string(666) "a:5:{s:5:"width";i:523;s:6:"height";i:122;s:4:"file";s:20:"2017/06/image001.jpg";s:5:"sizes";a:2:{s:9:"thumbnail";a:4:{s:4:"file";s:20:"image001-150x122.jpg";s:5:"width";i:150;s:6:"height";i:122;s:9:"mime-type";s:10:"image/jpeg";}s:6:"medium";a:4:{s:4:"file";s:19:"image001-300x70.jpg";s:5:"width";i:300;s:6:"height";i:70;s:9:"mime-type";s:10:"image/jpeg";}}s:10:"image_meta";a:12:{s:8:"aperture";s:1:"0";s:6:"credit";s:0:"";s:6:"camera";s:0:"";s:7:"caption";s:0:"";s:17:"created_timestamp";s:1:"0";s:9:"copyright";s:0:"";s:12:"focal_length";s:1:"0";s:3:"iso";s:1:"0";s:13:"shutter_speed";s:1:"0";s:5:"title";s:0:"";s:11:"orientation";s:1:"1";s:8:"keywords";a:0:{}}}"
}
["rrhh-file"]=> // <-- here
array(1) {
[0]=>
string(1) "1"
}
["_edit_lock"]=>
array(1) {
[0]=>
string(12) "1498731595:1"
}
}
このアクションでは、この添付ファイルはまだメディアライブラリに表示されます。
add_action( 'pre_get_posts', 'wpse_hide_cv_media_list_view' );
function wpse_hide_cv_media_list_view( $query ) {
// Bail if this is not the admin area.
if ( ! is_admin() ) {
return;
}
// Bail if this is not the main query.
if ( ! $query->is_main_query() ) {
return;
}
// Only proceed if this the attachment upload screen.
$screen = get_current_screen();
if ( ! $screen || 'upload' !== $screen->id || 'attachment' !== $screen->post_type ) {
return;
}
// Modify the query.
$query->set( 'meta_query', [
[
'key' => 'rrhh-file',
'compare' => 'NOT EXISTS',
]
]);
return;
}
私が見逃しているものは何か考え?
WordPressには、メディアの表示方法が2つあります。メディアオーバーレイ/モーダルビュー、およびリストビューがあります。これは、[管理]> [メディア]> [ライブラリ]に移動してから、フィルタ選択ボックスの横にあるリストビューアイコンをクリックすることによってトリガーされます。両方の場所で添付ファイルをフィルタリングするには、2つの別々のフックを使用する必要があります。
メディアライブラリの添付ファイルのフィルタリング(モーダルビュー)
ajax_query_attachments_args
フィルタは、メディアオーバーレイ画面で添付ファイルを取得するために使用されるクエリを調整するために使用できます。 ( この答えから / birgireから)
/**
* Hide attachment files from the Media Library's overlay (modal) view
* if they have a certain meta key set.
*
* @param array $args An array of query variables.
*/
add_filter( 'ajax_query_attachments_args', 'wpse_hide_cv_media_overlay_view' );
function wpse_hide_cv_media_overlay_view( $args ) {
// Bail if this is not the admin area.
if ( ! is_admin() ) {
return;
}
// Modify the query.
$args['meta_query'] = [
[
'key' => 'rrhh-file',
'compare' => 'NOT EXISTS',
]
];
return $args;
}
メディアライブラリの添付ファイルのフィルタリング(リスト表示)
リストビュー(古いリストモード、ノンモーダルビュー)の[メディアライブラリ]画面で添付ファイルのクエリを変更するための追加の個別のアプローチが必要です。 pre_get_posts
フックはトリックを行います:
/**
* Hide attachment files from the Media Library's list view
* if they have a certain meta key set.
*
* @param WP_Query $query The WP_Query instance (passed by reference).
*/
add_action( 'pre_get_posts', 'wpse_hide_cv_media_list_view' );
function wpse_hide_cv_media_list_view( $query ) {
// Bail if this is not the admin area.
if ( ! is_admin() ) {
return;
}
// Bail if this is not the main query.
if ( ! $query->is_main_query() ) {
return;
}
// Only proceed if this the attachment upload screen.
$screen = get_current_screen();
if ( ! $screen || 'upload' !== $screen->id || 'attachment' !== $screen->post_type ) {
return;
}
// Modify the query.
$query->set( 'meta_query', [
[
'key' => 'rrhh-file',
'compare' => 'NOT EXISTS',
]
] );
return;
}
どちらの場合も、メタキーrrhh-file
が設定されている添付ファイルを除外するようにメタクエリを設定します。ニーズに合わせてメタクエリまたは条件を変更できます。
メタクエリーは遅いことに注意してください。 1つの代替的なアプローチは、それらがアップロード/作成されたときにこれらの特別なメディアアイテムをカスタム分類法に割り当て、そして税クエリを使ってこれらのアイテムを除外するためにクエリを変更することです。
編集:デバッグ情報
カスタム添付ファイルフィールドをより簡単に編集できるようにするために、次の関数を使用しています。
/**
* Add custom field to media
*/
add_filter( 'attachment_fields_to_edit', 'wpse_cv_attachment_fields', 10, 2 );
function wpse_cv_attachment_fields( $fields, $post ) {
$meta = get_post_meta( $post->ID, 'rrhh-file', true );
$fields['rrhh-file'] = array(
'label' => __( 'RRHH File', 'text-domain' ),
'input' => 'text',
'value' => $meta,
'show_in_edit' => true,
);
return $fields;
}
/**
* Update custom field within media overlay (via ajax)
*/
add_action( 'wp_ajax_save-attachment-compat', 'wpse_cv_media_fields', 0, 1 );
function wpse_cv_media_fields() {
$post_id = $_POST['id'];
$value = isset( $_POST['attachments'][ $post_id ]['rrhh-file'] ) ? $_POST['attachments'][ $post_id ]['rrhh-file'] : false;
if ( '1' === $value ) {
update_post_meta( $post_id, 'rrhh-file', $value );
} else {
delete_post_meta( $post_id, 'rrhh-file' );
}
clean_post_cache( $post_id );
}
/**
* Update media custom field from edit media page (non ajax).
*/
add_action( 'edit_attachment', 'wpse_cv_update_attachment_meta', 1 );
function wpse_cv_update_attachment_meta( $post_id ) {
$value = isset( $_POST['attachments'][ $post_id ]['rrhh-file'] ) ? $_POST['attachments'][ $post_id ]['rrhh-file'] : false;
//exit ( var_dump( $value ) );
if ( '1' === $value ) {
update_post_meta( $post_id, 'rrhh-file', $value );
} else {
delete_post_meta( $post_id, 'rrhh-file' );
}
return;
}
次のSQLを使用して、rrhh-file
フィールドが設定されているかどうかを確認します。
SELECT * FROM wp_postmeta w where meta_key = 'rrhh-file';
pre_get_posts
フックの影響を受けるはずのメディアライブラリをリストモードで表示すると、$query->is_main_query()
はtrue
と$screen
を返しています。これはWP_Screen
オブジェクトです。
WP_Screen Object
(
[action] =>
[base] => upload
[columns:WP_Screen:private] => 0
[id] => upload
[in_admin:protected] => site
[is_network] =>
[is_user] =>
[parent_base] =>
[parent_file] =>
[post_type] => attachment
[taxonomy] =>
[_help_tabs:WP_Screen:private] => Array
(
)
[_help_sidebar:WP_Screen:private] =>
[_screen_reader_content:WP_Screen:private] => Array
(
)
[_options:WP_Screen:private] => Array
(
)
[_show_screen_options:WP_Screen:private] =>
[_screen_settings:WP_Screen:private] =>
)
$query
では、WP_Queryオブジェクトは次のようになります。
WP_Query Object
(
[query] => Array
(
[m] => 0
[cat] => 0
[post_type] => attachment
[posts_per_page] => 20
[post_status] => inherit,private
)
[query_vars] => Array
(
[m] => 0
[cat] => 0
[post_type] => attachment
[posts_per_page] => 20
[post_status] => inherit,private
[error] =>
[p] => 0
[post_parent] =>
[subpost] =>
[subpost_id] =>
[attachment] =>
[attachment_id] => 0
[name] =>
[static] =>
[pagename] =>
[page_id] => 0
[second] =>
[minute] =>
[hour] =>
[day] => 0
[monthnum] => 0
[year] => 0
[w] => 0
[category_name] =>
[tag] =>
[tag_id] =>
[author] =>
[author_name] =>
[feed] =>
[tb] =>
[paged] => 0
[meta_key] =>
[meta_value] =>
[preview] =>
[s] =>
[sentence] =>
[title] =>
[fields] =>
[menu_order] =>
[embed] =>
[category__in] => Array
(
)
[category__not_in] => Array
(
)
[category__and] => Array
(
)
[post__in] => Array
(
)
[post__not_in] => Array
(
)
[post_name__in] => Array
(
)
[tag__in] => Array
(
)
[tag__not_in] => Array
(
)
[tag__and] => Array
(
)
[tag_slug__in] => Array
(
)
[tag_slug__and] => Array
(
)
[post_parent__in] => Array
(
)
[post_parent__not_in] => Array
(
)
[author__in] => Array
(
)
[author__not_in] => Array
(
)
)
[tax_query] => WP_Tax_Query Object
(
[queries] => Array
(
)
[relation] => AND
[table_aliases:protected] => Array
(
)
[queried_terms] => Array
(
)
[primary_table] =>
[primary_id_column] =>
)
[meta_query] =>
[date_query] =>
[post_count] => 0
[current_post] => -1
[in_the_loop] =>
[comment_count] => 0
[current_comment] => -1
[found_posts] => 0
[max_num_pages] => 0
[max_num_comment_pages] => 0
[is_single] =>
[is_preview] =>
[is_page] =>
[is_archive] =>
[is_date] =>
[is_year] =>
[is_month] =>
[is_day] =>
[is_time] =>
[is_author] =>
[is_category] =>
[is_tag] =>
[is_tax] =>
[is_search] =>
[is_feed] =>
[is_comment_feed] =>
[is_trackback] =>
[is_home] =>
[is_404] =>
[is_embed] =>
[is_paged] =>
[is_admin] => 1
[is_attachment] =>
[is_singular] =>
[is_robots] =>
[is_posts_page] =>
[is_post_type_archive] =>
[query_vars_hash:WP_Query:private] => b01f0d78a3a985d46374d4384bba30b7
[query_vars_changed:WP_Query:private] =>
[thumbnails_cached] =>
[stopwords:WP_Query:private] =>
[compat_fields:WP_Query:private] => Array
(
[0] => query_vars_hash
[1] => query_vars_changed
)
[compat_methods:WP_Query:private] => Array
(
[0] => init_query_flags
[1] => parse_tax_query
)
)