IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JSF Java Discussion :

Richfaces et style


Sujet :

JSF Java

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 42
    Par défaut Richfaces et style
    Bonjour
    Je développe en JSF/RichFaces depuis qq semaines, il est tant de s'intégrer à la communauté...
    - répondre à une question: ok;
    - poser une question: me voici :o)

    J'ai donc développé un fichier monprojet.skin.properties que j'ai renseigné dans web.xml (<context-param>
    <param-name>org.richfaces.SKIN</param-name>
    <param-value>monprojet</param-value>
    </context-param>)
    pour définir mon style général, cela fonctionne très bien: par exemple tout mes rich:panel ont un entête avec le même gradient de couleur (jaune)

    Maintenant j'aimerai pouvoir modifier la couleur des entêtes de certains panels, par exemple rouge, mais en gardant un gradient de couleur.

    Je vois quatre pistes, pouvez vous m'orientez?
    - utiliser le headerClass="maClassPanelRouge" pour chaque panel devant être définis. MaClassPanelRouge est définie dans un css, et dans ce cas je ne sais pas comment faire pour conserver mes gradients de couleurs
    - idem, mais définir MaClassPanelRouge dans un xcss. Permet à priori de récupérer les gradients richfaces, mais je n'arrive pas à faire en sorte que mon xcss soit passé au navigateur sous forme de css (il reste en xcss, et le style n'es pas reconnu)
    - créer un autre fichier monprojet2.skin.properties, mais je ne sais pas comment le renseigner dans le web.xml, ni comment l'utiliser ensuite
    - créer un nouveau composant jsf panel2 qui récupérerait d'autre champ dans le properties que les champs standart???

    Merci d'avance pour votre aide

  2. #2
    Rédacteur

    Profil pro
    Inscrit en
    Juin 2003
    Messages
    4 184
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 184
    Par défaut
    Citation Envoyé par Chatastroff Voir le message
    Bonjour

    Je vois quatre pistes, pouvez vous m'orientez?
    - utiliser le headerClass="maClassPanelRouge" pour chaque panel devant être définis. MaClassPanelRouge est définie dans un css, et dans ce cas je ne sais pas comment faire pour conserver mes gradients de couleurs
    Puisque tu veux le faire que pour certains panel, il me semble que c'est la solution la plus simple.
    pour garder ton stle définis dans le skin, faut regarder les héritages dans css..
    je ne sais si ça marche comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    .rich-panel-header .maClassPanelRouge {
     
    }
    au pire tu va redéfinir le style dans la nouvelle classe..

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 42
    Par défaut
    Merci pour cette réponse, bonne idée... mais elle ne fonctionne pas comme je l'aurai aimé. Si je comprend bien, richfaces utilise les paramètres de monprojet.skin.properties pour générer une image qui sert de gradient de fond de header.
    Donc quand je fais
    .rich-panel-header.maClassPanelRouge {
    color:yellow;
    background-color:red;
    }
    il y a en fait un background-image qui se superpose à mon background-color... qui est donc inutile.
    Donc pour l'instant j'utilise la solution bourrin:j'ai mis tout les panel dans la 2ème couleur, j'ai fait une copie d'écran pour récupérer l'image de background... et je l'ai mise dans mon css:
    .rich-panel-header.maClassPanelRouge{
    color:yellow;
    background-image: url(/monprojet/images/texture1.png);
    }

    par contre si quelqu'un sait comment mettre en place les xcss, je suis preneur (ou pour la solution de 2 fichiers de skin simultanement)

  4. #4
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Est ce qu'il ne serait pas plus simple de mettre dans la page qui t'intéresse une redéfinition de la classe de style.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    <style>
    .rich-panel-header.maClassPanelRouge {
        color:#ffffff;
        background-color:navy;
    }
    </style>
    Par défaut, il cherche dans le fichier xxx.css, mais si la page contient la classe, elle devrait être prioritaire.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 42
    Par défaut
    Dans le cas où s'est un style spécifique à une page, c'est sur que c'est le plus simple... mais pour l'homogénéité du site global, je n'utilise pas vraiment des style spécifique à une seule page. C'est plutôt: panneau normaux -> gris, panneaux de commande -> jaune, panneaux d'alerte -> rouge (par exemple)

  6. #6
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Et ce genre de mise en forme serait envisageable ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
     
    <html>
    <head>
    <style>
    DIV{
        border-style:solid;
        border-color:blue;
    }
    SPAN DIV{
        border-style:solid;
        border-color:red;
    }
    </style>
    </head>
     
    <body>
    <form>
        <span>
            <div>
                Mon champ <input type="text" name="Champ1"/><br>
            </div>
        </span>
        <div>
            Texte normal
        </div>
    </form>
    </body>
    </html>
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    42
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 42
    Par défaut
    Oui aussi, mais je préfère mettre pour tout les éléments concerné un style='ma classe'

    Sinon la difficulté avec RichFaces est que tout les éléments de style ne sont pas accessibles en css, il faut normalement du xcss (si j'ai bien compris).


    Donc... si qqun a déjà utilisé les xcss...

Discussions similaires

  1. [richfaces] change le style d'un composant
    Par anisj1m dans le forum JSF
    Réponses: 1
    Dernier message: 19/11/2009, 12h41
  2. [richfaces]Style pour panelMenu
    Par wajdopovitch dans le forum JSF
    Réponses: 1
    Dernier message: 12/08/2009, 10h06
  3. Conflit de style css perso et ce de Richfaces
    Par elbissat dans le forum JSF
    Réponses: 5
    Dernier message: 01/07/2009, 11h13
  4. RichFaces et le Style
    Par midos dans le forum JSF
    Réponses: 13
    Dernier message: 09/07/2008, 09h01
  5. Réponses: 1
    Dernier message: 10/01/2008, 14h09

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo