001 // Copyright 2008, 2009, 2010, 2011 The Apache Software Foundation 002 // 003 // Licensed under the Apache License, Version 2.0 (the "License"); 004 // you may not use this file except in compliance with the License. 005 // You may obtain a copy of the License at 006 // 007 // http://www.apache.org/licenses/LICENSE-2.0 008 // 009 // Unless required by applicable law or agreed to in writing, software 010 // distributed under the License is distributed on an "AS IS" BASIS, 011 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 012 // See the License for the specific language governing permissions and 013 // limitations under the License. 014 015 package org.apache.tapestry5.services.javascript; 016 017 import org.apache.tapestry5.Asset; 018 import org.apache.tapestry5.dom.Document; 019 import org.apache.tapestry5.dom.Element; 020 import org.apache.tapestry5.internal.TapestryInternalUtils; 021 import org.apache.tapestry5.internal.services.DocumentLinker; 022 import org.apache.tapestry5.ioc.internal.util.InternalUtils; 023 024 /** 025 * Captures the information needed to create a stylesheet link in the final {@link Document}, or 026 * as part of a JSON partial page render response. 027 * 028 * @see DocumentLinker 029 * @see JavaScriptStack 030 * @since 5.2.0 031 */ 032 public final class StylesheetLink 033 { 034 private final String url; 035 036 private final StylesheetOptions options; 037 038 private static final StylesheetOptions BLANK_OPTIONS = new StylesheetOptions(null); 039 040 public StylesheetLink(Asset asset) 041 { 042 this(asset, null); 043 } 044 045 public StylesheetLink(Asset asset, StylesheetOptions options) 046 { 047 this(asset.toClientURL(), options); 048 } 049 050 public StylesheetLink(String url) 051 { 052 this(url, null); 053 } 054 055 public StylesheetLink(String url, StylesheetOptions options) 056 { 057 assert InternalUtils.isNonBlank(url); 058 this.url = url; 059 this.options = options != null ? options : BLANK_OPTIONS; 060 } 061 062 public String getURL() 063 { 064 return url; 065 } 066 067 /** 068 * Returns an instance of {@link StylesheetOptions}. Never returns null (a blank options 069 * object is returned if null is passed to the constructor). 070 */ 071 public StylesheetOptions getOptions() 072 { 073 return options; 074 } 075 076 /** 077 * Invoked to add the stylesheet link to a container element. 078 * 079 * @param container to add the new element to 080 */ 081 public void add(Element container) 082 { 083 String condition = options.getCondition(); 084 boolean hasCondition = InternalUtils.isNonBlank(condition); 085 086 if (hasCondition) 087 { 088 container.raw(String.format("\n<!--[if %s]>\n", condition)); 089 } 090 091 String rel = options.ajaxInsertionPoint ? "stylesheet t-ajax-insertion-point" : "stylesheet"; 092 093 container.element("link", "href", url, "rel", rel, "type", "text/css", "media", options.media); 094 095 if (hasCondition) 096 { 097 container.raw("\n<![endif]-->\n"); 098 } 099 } 100 101 @Override 102 public String toString() 103 { 104 return String.format("StylesheetLink[%s %s]", url, options); 105 } 106 107 @Override 108 public boolean equals(Object obj) 109 { 110 if (obj == this) 111 return true; 112 113 if (obj == null || !(obj instanceof StylesheetLink)) 114 return false; 115 116 StylesheetLink ssl = (StylesheetLink) obj; 117 118 return TapestryInternalUtils.isEqual(url, ssl.url) && TapestryInternalUtils.isEqual(options, ssl.options); 119 } 120 121 }