Mostra emoticon diversi quando inserisci ":)"


9

Se si entra :)in WordPress, lo sostituisce automaticamente con:

inserisci qui la descrizione dell'immagine

C'è un modo per usare una faccina diversa per il :)


Ciao Krish, potresti fornire maggiori dettagli su ciò che hai già provato (e perché non ha funzionato)?
Kraftner,

Risposte:


14

Sostituendo l'emoji di :) in 😎

Le emoticon dei contenuti vengono convertite con:

add_filter( 'the_content', 'convert_smilies' );

dove questa parte della convert_smilies()funzione è importante:

$content = preg_replace_callback( $wp_smiliessearch, 'translate_smiley', $content );

Se guardiamo dentro translate_smiley(), troviamo quanto segue :

// Don't convert smilies that aren't images - they're probably emoji.
if ( ! in_array( $ext, $image_exts ) ) {
     return $img;
}

prima che smilies_srcvenga applicato il filtro.

Quindi questo filtro non è disponibile nel caso dello :)smiley.

Abbiamo le faccine inizializzate con:

add_action( 'init', 'smilies_init', 5 );

e nella descrizione della funzione per smilies_init()possiamo leggere quanto segue :

I plug-in possono sovrascrivere l'elenco di smiley predefinito impostando $wpsmiliestrans un array, con la chiave il codice digitato dal blogger e il valore del file immagine.

Ecco l' $wpsmiliestransarray globale :

$wpsmiliestrans = array(
    ':mrgreen:' => 'mrgreen.png',
    ':neutral:' => "\xf0\x9f\x98\x90",
    ':twisted:' => "\xf0\x9f\x98\x88",
    ':arrow:' => "\xe2\x9e\xa1",
    ':shock:' => "\xf0\x9f\x98\xaf",
    ':smile:' => "\xf0\x9f\x99\x82",
    ':???:' => "\xf0\x9f\x98\x95",
    ':cool:' => "\xf0\x9f\x98\x8e",
    ':evil:' => "\xf0\x9f\x91\xbf",
    ':grin:' => "\xf0\x9f\x98\x80",
    ':idea:' => "\xf0\x9f\x92\xa1",
    ':oops:' => "\xf0\x9f\x98\xb3",
    ':razz:' => "\xf0\x9f\x98\x9b",
    ':roll:' => 'rolleyes.png',
    ':wink:' => "\xf0\x9f\x98\x89",
    ':cry:' => "\xf0\x9f\x98\xa5",
    ':eek:' => "\xf0\x9f\x98\xae",
    ':lol:' => "\xf0\x9f\x98\x86",
    ':mad:' => "\xf0\x9f\x98\xa1",
    ':sad:' => "\xf0\x9f\x99\x81",
    '8-)' => "\xf0\x9f\x98\x8e",
    '8-O' => "\xf0\x9f\x98\xaf",
    ':-(' => "\xf0\x9f\x99\x81",
    ':-)' => "\xf0\x9f\x99\x82",
    ':-?' => "\xf0\x9f\x98\x95",
    ':-D' => "\xf0\x9f\x98\x80",
    ':-P' => "\xf0\x9f\x98\x9b",
    ':-o' => "\xf0\x9f\x98\xae",
    ':-x' => "\xf0\x9f\x98\xa1",
    ':-|' => "\xf0\x9f\x98\x90",
    ';-)' => "\xf0\x9f\x98\x89",
    // This one transformation breaks regular text with frequency.
    //     '8)' => "\xf0\x9f\x98\x8e",
    '8O' => "\xf0\x9f\x98\xaf",
    ':(' => "\xf0\x9f\x99\x81",
    ':)' => "\xf0\x9f\x99\x82",
    ':?' => "\xf0\x9f\x98\x95",
    ':D' => "\xf0\x9f\x98\x80",
    ':P' => "\xf0\x9f\x98\x9b",
    ':o' => "\xf0\x9f\x98\xae",
    ':x' => "\xf0\x9f\x98\xa1",
    ':|' => "\xf0\x9f\x98\x90",
    ';)' => "\xf0\x9f\x98\x89",
    ':!:' => "\xe2\x9d\x97",
    ':?:' => "\xe2\x9d\x93",
);

o il display ksorted più bello:

Array
(
    [;-)] => 😉
    [;)] => 😉
    [:|] => 😐
    [:x] => 😡
    [:wink:] => 😉
    [:twisted:] => 😈
    [:smile:] => 🙂
    [:shock:] => 😯
    [:sad:] => 🙁
    [:roll:] => rolleyes.png
    [:razz:] => 😛
    [:oops:] => 😳
    [:o] => 😮
    [:neutral:] => 😐
    [:mrgreen:] => mrgreen.png
    [:mad:] => 😡
    [:lol:] => 😆
    [:idea:] => 💡
    [:grin:] => 😀
    [:evil:] => 👿
    [:eek:] => 😮
    [:cry:] => 😥
    [:cool:] => 😎
    [:arrow:] => 
    [:P] => 😛
    [:D] => 😀
    [:???:] => 😕
    [:?:] => 
    [:?] => 😕
    [:-|] => 😐
    [:-x] => 😡
    [:-o] => 😮
    [:-P] => 😛
    [:-D] => 😀
    [:-?] => 😕
    [:-)] => 🙂
    [:-(] => 🙁
    [:)] => 🙂
    [:(] => 🙁
    [:!:] => 
    [8O] => 😯
    [8-O] => 😯
    [8-)] => 😎
)

Quindi, se capisco correttamente il commento di base sopra, allora potremmo fare quanto segue:

/**
 * :) as the cool emoji
 */
add_action( 'init', function() use ( &$wpsmiliestrans )
{
    if( is_array( $wpsmiliestrans ) && get_option( 'use_smilies' ) )
        $wpsmiliestrans[':)'] = $wpsmiliestrans[':cool:'];

}, 6 );

ma questo funziona solo con le emoticon predefinite, perché $wp_smiliessearchfunzioni.

Ma non mi piace questo approccio suggerito, che modifica l'array globale! Spero che ce ne sia un altro migliore!

Plugin demo - 🎅

Ho provato a presentare una domanda per questo. Non sono sicuro che esista già, ma eccolo qui:

<?php
/**
 * Plugin Name: Santa's Smile In December
 * Description: Change the emoji of :) to the Santa Claus emoji, but only in December
 * Plugin URI:  https://wordpress.stackexchange.com/a/218496/26350
 */
add_action( 'init', function() use ( &$wpsmiliestrans )
{
    // :) as Santa Claus
    if( 
           is_array( $wpsmiliestrans ) 
        && get_option( 'use_smilies' ) 
        && 12 == current_time( 'n' ) 
    )
        $wpsmiliestrans[':)'] = "\xF0\x9F\x8E\x85";

}, 6 );

Grazie a Ismael Miguel per il commento globale , ho riscritto gli snippet di conseguenza.

Ecco il biglietto appena creato n. 35905 di Pieter Goosen , relativo a un nuovo smilies_transfiltro.

Aggiornamento - WordPress 4.7+

Il nuovo filtro sarà disponibile in WordPress 4.7+, ma il suo nome sarà smiliesnon smilies_trans.

I nostri esempi precedenti possono essere scritti come:

add_filter( 'smilies', function( $smilies )
{
    if( isset( $smilies[':cool:'] ) )
        $smilies[':)'] = $smilies[':cool:'];

    return $smilies;
} );

o esplicitamente con:

add_filter( 'smilies', function( $smilies )
{
    $smilies[':)'] = "\xf0\x9f\x98\x8e";

    return $smilies;
} );

Il plugin demo diventa:

<?php
/**
 * Plugin Name: Santa's Smile In December
 * Description: Change the emoji of :) to the Santa Claus emoji, but only in December
 * Plugin URI:  https://wordpress.stackexchange.com/a/218496/26350
 */

add_filter( 'smilies', function( $smilies )
{
    // :) as Santa Claus
    if( get_option( 'use_smilies' ) && 12 == current_time( 'n' ) )
        $smilies[':)'] = "\xF0\x9F\x8E\x85";

    return $smilies;
} );

Non abbiamo più bisogno di fare casini con l' $wpsmiliestransarray globale !


Le faccine funzionerebbero con tutti i font allora?
rob_st,

Strano quanto siano diverse le faccine tra la mia scheda e il mio PC. :-) Ad ogni modo, jip, anche a te non piace modificare in giro con i globi, ma questo sembra il migliore che riuscirai a ottenere da questo affare. Penso che potremmo esaminare l'aggiunta di un filtro adeguato nel core che possiamo usare per filtrare le emoticon invece di alterare un globale schifoso. ;-)
Pieter Goosen il

1
biglietto trac # 35905 inviato. Consente di incrociare le dita per ottenere un filtro adeguato
Pieter Goosen,

1
Che ne dici add_action( 'init', function() use (&$wpsmiliestrans){ $wpsmiliestrans[':)'] = "\xf0\x9f\x98\x8e"; }, 6 );?
Ismael Miguel,

1
È una promessa - in realtà uso molto la useparola chiave nelle mie risposte qui, ma è un buon promemoria per quanto riguarda i globi, grazie ancora (:) <- forse potremmo usare uno smiley simmetrico per una migliore accessibilità per tutti @IsmaelMiguel
birgire

3

Secondo il codice WordPress sull'uso delle faccine :

Carica le immagini che vuoi con lo stesso nome sul tuo server (ad esempio in wp-content / images / smilies) e inseriscile nella funzione.php del tuo tema:

add_filter ('smilies_src', 'my_custom_smilies_src', 10, 3);
   funzione my_custom_smilies_src ($ img_src, $ img, $ siteurl) {
       return $ siteurl. '/ wp-content / images / smilies /'.$ img;
   }
Ciò sostituirà http://example.com/wp-includes/images/smilies/icon_question.gif con http://example.com/wp-content/images/smilies/icon_question.gif


Non sai perché la demo del Codex sta assumendo 10 argomenti di input, anziché 3? Ma penso che questo sia annullato dagli Emoji.
birgire,

1
Suppongo che sia pensato per essere la priorità, quindi l'ordine sembra errato. L'ho cambiato nel Codice, sperando che non ci sbagliassimo :-)
rob_st

Ho corretto la tua modifica nel codice e corretto il tuo codice nella tua risposta. Gli argomenti consentiti dovrebbero essere 3, impostandolo su 1fallirà il tuo codice come $img, $siteurlverrà ignorato e quindi non sarà definito nel tuo filtro :-)
Pieter Goosen
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.