रिचफेस - रिच स्किन

रिचफेस को एक केंद्रीकृत तरीके से रिच स्किन कहा जाता है। त्वचा पुरानी सीएसएस फाइलों का एक उच्च स्तरीय कार्यान्वयन है, जो कि बैक-एंड डेवलपर के लिए वेबसाइट के लुक और फील को नियंत्रित करने के लिए अधिक सुविधाजनक है। कुछ अंतर्निहित खाल उपलब्ध हैं, जिन्हें आपकी पसंद के अनुसार अनुकूलित किया जा सकता है।

अंतर्निहित त्वचा

RichFaces घटक जार फ़ाइल में उपलब्ध कई अंतर्निहित खाल हैं। निम्नलिखित कुछ अंतर्निहित समृद्ध त्वचा उपलब्ध हैं।

  • Default
  • Plain
  • emeraldTown
  • blueSky
  • wine
  • japanCherry
  • ruby
  • classic
  • deepMarine
  • NULL

निम्नलिखित उदाहरण में, हम "क्लासिक" त्वचा को लागू करेंगे। उपरोक्त किसी भी खाल को लागू करना बहुत आसान है। आगे बढ़ने से पहले, कृपया नीचे दिए गए कोड की लाइन का उपयोग करके "web.xml" फ़ाइल में त्वचा जोड़ें। हम उपरोक्त सूची में से अपनी पसंद की कोई भी त्वचा जोड़ सकते हैं। हमें बस उपयुक्त त्वचा के नाम के साथ <param-value> टैग को संशोधित करने की आवश्यकता है।

<context-param>   
   <param-name>org.richfaces.skin</param-name>
   <param-value>classic</param-value>   
</context-param>

इसे जोड़ने के बाद, कृपया "SkinExample.xhtml" फ़ाइल बनाएं और इसमें कोड की निम्न पंक्ति जोड़ें।

<?xml version = '1.0' encoding = 'UTF-8' ?>    
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"   
   xmlns:f = "http://java.sun.com/jsf/core"   
   xmlns:ui = "http://java.sun.com/jsf/facelets"
   xmlns:a4j = "http://richfaces.org/a4j"   
   xmlns:rich = "http://richfaces.org/rich">   
   
   <f:view>   
      <h:head>   
         <title>Rich Faces Built in Skin</title>   
      </h:head>   
      
      <h:body>   
         <h:form>   
            <rich:panel style = "width:60%"> 
               <rich:tabPanel switchType = "AJAX"> 
                  <rich:tab header = "Name"> 
                     Tutorials Point 
                  </rich:tab> 
                  
                  <rich:tab header = "Features"> 
                     Best Place to learn 
                  </rich:tab> 
               </rich:tabPanel> 
            </rich:panel>           
         </h:form>   
      </h:body>
      
   </f:view>   
</ui:composition>

एक बार जब हम इस पृष्ठ को चलाते हैं, तो ब्राउज़र में आउटपुट निम्न होगा, जहां प्रत्येक टैब एक अलग आउटपुट उत्पन्न करने के लिए गतिशील रूप से प्रचार करता है। एक बार जब आप अगला टैब हिट करते हैं, तो यह एक अलग आउटपुट दिखाएगा।

उपरोक्त उदाहरण में, <अमीर: पैनल> एक पैनल बनाता है जहां हम <अमीर: टैब> का उपयोग करके विभिन्न टैब बना रहे हैं। <अमीर: tabPanel स्विच टाइप = "AJAX"> उपयोग किए गए टैब का AJAX संक्रमण प्रदान करता है।

त्वचा को बनाना / संशोधित करना

त्वचा सीएसएस डिज़ाइन के एक विस्तारित संस्करण के अलावा और कुछ नहीं है, जो रनटाइम पर वेबपेज पर लागू होगी। पिछले अनुभाग में, हमने त्वचा की कुछ बुनियादी अंतर्निहित कार्यक्षमता सीखी। इस खंड में, हम अपनी त्वचा बनाएंगे या मौजूदा त्वचा को संशोधित करेंगे। रिचफेसेस में त्वचा को निम्नलिखित तीन स्तरों पर अनुकूलित किया जा सकता है।

Skin property file- सभी खाल "rechfaces-a4j-4.5.17.Final" जार फ़ाइल के तहत उल्लिखित विभिन्न संपत्ति फ़ाइलों के माध्यम से उत्पन्न होती हैं। हम सभी को एक ही प्रॉपर्टी फाइल बनाने की जरूरत है और इसे अपने सोर्स फोल्डर के नीचे रखें और उसकी प्रॉपर्टी को एडिट करें। हमें वेबसाइट में अपनी नई त्वचा संपत्ति को प्रतिबिंबित करने के लिए अपने "web.xml" को बदलने की आवश्यकता है।

Component style sheet - पसंद की नई सीएसएस फ़ाइल को लागू करें और आवेदन में इसका उपयोग करें।

Overwrite style class - एक सीधे एक्सएचटीएमएल फ़ाइल में शैली के गुणों का उल्लेख करके शैली को ओवरराइट कर सकता है।

चलिए, हम एक उदाहरण पर विचार करते हैं। हम अपनी पिछली "क्लासिक" त्वचा को अनुकूलित करेंगे। "स्रोत" पैकेज के अंदर एक संपत्ति फ़ाइल बनाएँ और इसे "custom.skin.properties" नाम दें। इस संपत्ति फ़ाइल की प्रविष्टियां निम्नलिखित हैं जिन्हें ऊपर उल्लेखित जार फ़ाइल में उपलब्ध अन्य संपत्ति फाइलों से कॉपी किया गया था।

#Colors 
headerBackgroundColor = #black 
headerGradientColor = #DF5858 
headerTextColor = #FFFFFF 
headerWeightFont = bold 

generalBackgroundColor = #f1f1f1 
generalTextColor = #000000 
generalSizeFont = 10px 
generalFamilyFont = Arial, Verdana, sans-serif 

controlTextColor = #000000 
controlBackgroundColor = #ffffff 
additionalBackgroundColor = #F9E4E4 

shadowBackgroundColor = #000000 
shadowOpacity = 1 
panelBorderColor = #C0C0C0 
subBorderColor = #ffffff 

tabBackgroundColor = #EDAEAE 
tabDisabledTextColor = #C47979 
trimColor = #F7C4C4 
tipBackgroundColor = #FAE6B0 
tipBorderColor = #E5973E 

selectControlColor = #FF9409 
generalLinkColor = #CF0000 
hoverLinkColor = #FF0000 
visitedLinkColor = #CF0000 

# Fonts
headerSizeFont = 11px 
headerFamilyFont = Arial, Verdana, sans-serif 
tabSizeFont = 11 
tabFamilyFont = Arial, Verdana, sans-serif 
buttonSizeFont = 11 
CHAPTER 11 ■ SKINS 223 
buttonFamilyFont = Arial, Verdana, sans-serif 

tableBackgroundColor = #FFFFFF 
tableFooterBackgroundColor = #cccccc 
tableSubfooterBackgroundColor = #f1f1f1 
tableBorderColor = #C0C0C0 
tableBorderWidth = 1px 

#Calendar colors 
calendarWeekBackgroundColor = #f5f5f5 
calendarHolidaysBackgroundColor = #FFF1F1 
calendarHolidaysTextColor = #980808 
calendarCurrentBackgroundColor = #808080 
calendarCurrentTextColor = #ffffff 
calendarSpecBackgroundColor = #f1f1f1 
calendarSpecTextColor = #000000 

warningColor = #FFE6E6 
warningBackgroundColor = #FF0000 
editorBackgroundColor = #F1F1F1 
editBackgroundColor = #FEFFDA 

#Gradients 
Gradient Type = plain

कौशल स्तर के आधार पर, हम इस गुण फ़ाइल में किसी भी विशेषता को बदल सकते हैं। हम नई शैली वर्ग जोड़ सकते हैं या मौजूदा को संपादित कर सकते हैं। एक बार जब हम नई संपत्ति फ़ाइल के निर्माण के साथ हो जाते हैं, तो यह "web.xml" फ़ाइल में समान जोड़ने का समय है। निम्नलिखित "web.xml" की प्रविष्टि है, जो हमारी त्वचा को इंगित करना चाहिए।

<context-param> 
   <param-name>org.richfaces.skin</param-name> 
   <param-value>custom</param-value> 
</context-param>

Note - सुनिश्चित करें कि नई संपत्ति फ़ाइल स्रोत निर्देशिका के अंदर मौजूद है, अन्यथा यह "NoClassFound अपवाद" कहकर एक रनटाइम त्रुटि फेंक देगा।

आगे बढ़ो और "SkinExample.xhtml" नाम की पिछली फ़ाइल चलाएं। निम्नलिखित ब्राउज़र में आउटपुट होगा, जहां हम यह देख पाएंगे कि वेबसाइट का पूरा लुक और अहसास बदलकर "रूबी" हो गया है क्योंकि रूबी.प्रोपरेटी फ़ाइल से एक नई प्रॉपर्टी फाइल कॉपी की गई थी।

रनटाइम पर त्वचा को बदलना

इस उदाहरण में, हम समय के साथ त्वचा को बदल देंगे। निम्नलिखित की तरह एक त्वचा वर्ग बनाएँ।

import javax.faces.bean.ManagedBean; 
import javax.faces.bean.RequestScoped;  

@ManagedBean   
@RequestScoped 

public class skinBean {  
   private String skin;  
   public skinBean() { 
      this.skin="plane"; 
   }
   public String getSkin() { 
      return skin; 
   } 
   public void setSkin(String skin) { 
      this.skin = skin; 
   } 
}

फिर रनटाइम पर त्वचा के नाम को पॉप्युलेट करने के लिए "web.xml" फाइल को निम्नानुसार बदलें।

<context-param>   
   <param-name>org.richfaces.skin</param-name>
   <param-value>#{skinBean.skin}</param-value>
</context-param>

ऐसा करने के बाद, हमें JSF एप्लिकेशन की कॉन्फ़िगरेशन फ़ाइलों को बदलने की आवश्यकता है। फ़ाइलें वेब-इन्फो फ़ोल्डर के तहत स्थित हो सकती हैं। इसमें निम्नलिखित बीन संपत्ति जोड़ें।

<managed-bean> 
   <managed-bean-name>skinBean</managed-bean-name> 
   <managed-bean-class>SkinBean</managed-bean-class>> 
   <managed-bean-scope>session</managed-bean-scope> 
   
   <managed-property> 
      <property-name>skin</property-name> 
      <value>plain</value> 
   </managed-property> 
</managed-bean>

निम्नलिखित xhtml फ़ाइल कोड है।

<?xml version = "1.0" encoding = "UTF-8"?>  
<!DOCTYPE html> 
<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html" 
   xmlns:a4j = "http://richfaces.org/a4j" 
   xmlns:f = "http://java.sun.com/jsf/core" 
   xmlns:rich = "http://richfaces.org/rich">
   
   <h:head> 
      <title>TODO supply a title</title> 
   </h:head> 
   
   <h:body> 
      <h:form> 
         <div style = "display: block; float: left"> 
            <h:selectOneRadio value = "#{skinBean.skin}" border = "0" 
               layout = "pageDirection" title = "Changing skin" style = "font-size: 8; 
               font-family: comic" onchange = "submit()"> 
               <f:selectItem itemLabel = "plain" itemValue = "plain" /> 
               <f:selectItem itemLabel = "emeraldTown" itemValue = "emeraldTown" /> 
               <f:selectItem itemLabel = "blueSky" itemValue = "blueSky" /> 
               <f:selectItem itemLabel = "wine" itemValue = "wine" /> 
               <f:selectItem itemLabel = "japanCherry" itemValue = "japanCherry" /> 
               <f:selectItem itemLabel = "ruby" itemValue = "ruby" /> 
               <f:selectItem itemLabel = "deepMarine" itemValue = "deepMarine" /> 
            </h:selectOneRadio> 
         </div> 
         
         <div style = "display: block; float: left"> 
            <rich:panel > 
               <rich:panelMenu style = "font-family: monospace; font-size: 12;"> 
                  Changing skin in runtime 
               </rich:panelMenu> 
  
               <rich:panelMenu  style = "font-family: monospace; font-size: 12;"> 
                  This is a result of the modification "blueSky" skin 
               </rich:panelMenu> 
            </rich:panel> 
         </div> 
      </h:form> 
   </h:body> 
   
</html>

कोड का उपरोक्त टुकड़ा ब्राउज़र में निम्न आउटपुट का उत्पादन करेगा।

उपरोक्त उदाहरण में, शुरू में हम "सादे" का चयन कर रहे हैं, इसलिए यह सादे की ओर इशारा करता है। एक बार जब आप रेडियो बटन के माध्यम से प्रचार करते हैं, तो यह तदनुसार रंग बदल देगा।