Postarile unui website sunt printre cele mai importante elemente atunci cand vine vorba de personalizarea site-ului. Prin intermediul acestora putem adapta site-ul pentru orice nisa, aducandu-i functionalitati personalizate. In WordPress nu este recomadat sa editam sau modificam postarile clasice, cele existente implicit in WordPress, deoarece acestea pot fi rescrise odata ce o noua actualizare este disponibila si instalata. In schimb, putem crea postari similare, personalizate, pe care le putem crea in fisierul function.php (de preferabil intr-o tema Child).
Pentru a intelege mai bine ce inseamna postarile personalizate si ce putem face cu ele vom enumera cateva exemple:
- Woocommerce-ul foloseste postari custom pentru produse;
- site-urile de anunturi folosesc astfel de postari personalizate, fie ca este vorba de un site imobiliar sau unul de anunturi pentru diverse nise ale pietei (auto, recrutare pentru angajare, etc.);
- site-urile cu filme folosesc postari custom, iar exemplele pot continua.
Daca creezi Custom Post Types, vei vedea in meniul tabloului principal WordPress o noua sectiune de articole (posts), insa redenumita de tine in functie de scopul pentru care le-ai realizat. De exemplu, daca faci un site despre automobile, vei avea in meniu o noua optiune de postari denumita “automobile”, care va avea asemenea postarilor implicite WordPress subfile precum: “toate automobilele”, “adauga un automobil nou”, “categorii automobile” si “etichete automobile”.
Cum poti creea postari custom?
Pentru a crea postari custom, puteti utiliza si personaliza urmatorul cod PHP, pe care trebuie sa il introduceti in fisierul function.php al temei Child.
if ( ! function_exists('custom_post_type') ) {
// Register Custom Post Type
function custom_post_type() {
$labels = array(
'name' => _x( 'automobile', 'Post Type General Name', 'text_domain' ),
'singular_name' => _x( 'automobil', 'Post Type Singular Name', 'text_domain' ),
'menu_name' => __( 'automobile', 'text_domain' ),
'name_admin_bar' => __( 'automobile', 'text_domain' ),
'archives' => __( 'toate automobilele', 'text_domain' ),
'attributes' => __( 'Item Attributes', 'text_domain' ),
'parent_item_colon' => __( 'Parent Item:', 'text_domain' ),
'all_items' => __( 'Toate automobilele', 'text_domain' ),
'add_new_item' => __( 'Adauga un automobil nou', 'text_domain' ),
'add_new' => __( 'Adauga', 'text_domain' ),
'new_item' => __( 'Adauga automobil', 'text_domain' ),
'edit_item' => __( 'Editeaza automobil', 'text_domain' ),
'update_item' => __( 'Update automobil', 'text_domain' ),
'view_item' => __( 'Vezi automobil', 'text_domain' ),
'view_items' => __( 'Vezi automobilele', 'text_domain' ),
'search_items' => __( 'Cauta automobile', 'text_domain' ),
'not_found' => __( 'Not found', 'text_domain' ),
'not_found_in_trash' => __( 'Not found in Trash', 'text_domain' ),
'featured_image' => __( 'Featured Image', 'text_domain' ),
'set_featured_image' => __( 'Set featured image', 'text_domain' ),
'remove_featured_image' => __( 'Remove featured image', 'text_domain' ),
'use_featured_image' => __( 'Use as featured image', 'text_domain' ),
'insert_into_item' => __( 'Insert into item', 'text_domain' ),
'uploaded_to_this_item' => __( 'Uploaded to this item', 'text_domain' ),
'items_list' => __( 'Items list', 'text_domain' ),
'items_list_navigation' => __( 'Items list navigation', 'text_domain' ),
'filter_items_list' => __( 'Filter items list', 'text_domain' ),
);
$rewrite = array(
'slug' => 'automobile',
'with_front' => true,
'pages' => true,
'feeds' => true,
);
$args = array(
'label' => __( 'automobil', 'text_domain' ),
'description' => __( 'Aceasta este descrierea pentru articolele cu denumirea \"automobile\"', 'text_domain' ),
'labels' => $labels,
'supports' => array( 'title', 'editor', 'thumbnail', 'comments' ),
'taxonomies' => array( 'category', 'post_tag' ),
'hierarchical' => false,
'public' => true,
'show_ui' => true,
'show_in_menu' => true,
'menu_position' => 5,
'menu_icon' => 'dashicons-car',
'show_in_admin_bar' => true,
'show_in_nav_menus' => true,
'can_export' => true,
'has_archive' => true,
'exclude_from_search' => false,
'publicly_queryable' => true,
'rewrite' => $rewrite,
'capability_type' => 'page',
);
register_post_type( 'post_type', $args );
}
add_action( 'init', 'custom_post_type', 0 );
}
Explicarea pe scurt a codului:
- La inceputul codului se specifica ca daca nu exista vreo functie cu numele custom_post_type() (poate fi oricare alt nume ales de dvs.) care sa genereze postari custom, sa fie creata in randurile urmatoare.
- In variabila $labels este generat un array care denumeste etichetele care vor fi folosite in meniul WordPress. De exemplu pentru subfilele “Adauga postare”, “Categorii postari”, “Toate postarile”, etc.
- In variabila $rewrite este generat un array care specifica anumite informatii ce tin de modul de afisare, spre exemplu: ce slug-ul ce va aparea in URL-urile postarilor, daca sa creeze pagini individuale pentru postari, etc.
- In variabila $args sunt structurate informatiii precum: imaginea din meniu (in dreptul optiunii postarilor), pozitia din meniu, continutul postarilor (titlu, descriere, thumbnail, comentarii), arhivarea postarilor, daca acestea sunt publice sau nu, etc.
- In partea de jos a codului este folosit un hook de actiune, prin intermediul caruia ii spunem programului sa adauge aceste informatii din functia custom_post_type() scrisa anterior.
Exemplul de cod de mai sus poate fi personalizat prin inlocuirea cuvantului “automobil / automobile” cu denumirea pe care vreti ca postarile dvs. sa o foloseasca.