Unsupported Release
This documentation relates to an old, unsupported version of DSpace, version 1.7.x. Looking for another version? See all documentation.
As of January 2014, the DSpace 1.7.x platform is no longer supported. We recommend upgrading to a more recent version of DSpace.
Mirage XMLUI Theme
Overall Benefits
- Clean new look and feel.
- Increased browser compatibility. The whole theme renders perfectly in today's modern browsers (Internet Explorer 7 and higher, Firefox, Safari, Chrome, ...)
- Easier to customize.
- Enhanced Performance
Configuration Parameters
Property Name |
Default Value |
Type |
Description |
||
---|---|---|---|---|---|
solr.log.server |
${dspace.baseUrl}/solr/statistics |
String |
Is used by the SolrLogger Client class to connect to the Solr server over http and perform updates and queries. In most cases, this can (and should) be set to localhost (or 127.0.0.1). wget http://127.0.0.1/solr/statistics/select?q=*:* Assuming you get an HTTP 200 OK response, then you should set |
||
<ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="8d3968ba-83d6-4bef-95a6-3e1064be2f04"><ac:plain-text-body><![CDATA[ |
solr.spiderips.urls |
http://iplists.com/google.txt, \ http://iplists.com/inktomi.txt, \ http://iplists.com/lycos.txt, \ http://iplists.com/infoseek.txt, \ http://iplists.com/altavista.txt, \ http://iplists.com/excite.txt, \ http://iplists.com/misc.txt, \ http://iplists.com/non_engines.txt |
String |
List of URLs to download spiders files into [dspace]/config/spiders. These files contain lists of known spider IPs and are utilized by the SolrLogger to flag usage events with an "isBot" field, or ignore them entirely. dspace stats-util -h <ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="04f63cda-ff60-4b1c-a13f-c595c532b0ee"><ac:plain-text-body><![CDATA[from your [dspace]/bin directory |
]]></ac:plain-text-body></ac:structured-macro> |
<ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="b2761906-8401-42b3-9e69-9b47fdd100aa"><ac:plain-text-body><![CDATA[ |
solr.dbfile |
${dspace.dir}/config/GeoLiteCity.dat |
String |
The following referes to the GeoLiteCity database file utilized by the LocationUtils to calculate the location of client requests based on IP address. During the Ant build process (both fresh_install and update) this file will be downloaded from [http://www.maxmind.com/app/geolitecity] if a new version has been published or it is absent from your [dspace]/config directory. |
]]></ac:plain-text-body></ac:structured-macro> |
solr.resolver.timeout |
200 |
Integer |
Timeout in milliseconds for DNS resolution of origin hosts/IPs. Setting this value too high may result in solr exhausting your connection pool. |
||
<ac:structured-macro ac:name="unmigrated-wiki-markup" ac:schema-version="1" ac:macro-id="9f347c1d-8a5a-41ca-94ad-b753cc4e3dc3"><ac:plain-text-body><![CDATA[ |
useProxies |
true |
boolean |
Will cause Statistics loging to look for X-Forward URI to detect clients IP that have accessed it through a Proxy service. Allows detection of client IP when accessing DSpace. [Note: This setting is found in the DSpace Logging sesction of dspace.cfg] |
]]></ac:plain-text-body></ac:structured-macro> |
statistics.item.authorization.admin |
true |
boolean |
Enables access control restriction on DSpace Statistics pages, Restrictions are based on access rights to Community, Collection and Item Pages. This will require the user to sign on to see that statistics. Setting the statistics to "false" will make them publicly available. |
||
solr.statistics.logBots |
true |
boolean |
If false, and IP is detected as a spider, the event is not logged. |
||
solr.statistics.query.filter.spiderIp |
false |
boolean |
If true, statistics queries will filter out spider IPs -- use with caution, as this often results in extremely long query strings. |
||
solr.statistics.query.filter.isBot |
true |
boolean |
If true, statistics queries will filter out events flagged with the "isBot" field. This is the recommended method of filtering spiders from statistics. |
Technical Features
Look & Feel
- The Simple Item Display underwent a full redesign to provide visitors with a clearer overview of available metadata and associated files.
- Item list views can now be displayed in two distinct different styles. Switching between these styles is possible with the new dspace.cfg parameter 'xmlui.theme.mirage.item-list.emphasis'
- The 'metadata' list style includes item abstracts in the listing and is suited for scientific articles.
- The 'file' list style immediately shows you whether files are attached to the items, by displaying a large thumbnail icon for each of the items.
Structural enhancements for easier customization.
- Based on the new restructured dri2xhtml base templates. Templates in the theme, overriding the new base templates, are located in the same folder hierarchy to ensure full transparancy.
- Automated browser feature detection for improved browser compatibility.
- In other themes, user agent detection is used to identify which browser version your user is using. Based on the result of this detection, the theme would use a different cascaded style sheet (CSS) to render a compatible page for the visitor. This approach has 2 major issues:
- User agent detection isn't very reliable
- Maintaining these different CSS files is a maintenance nightmare for developers, especially when using features from newer browsers.
- Mirage applies two novel techniques to resolve these issues
- For compatibility with older Internet Explorer browsers, conditional comments give the body tag a class corresponding to the version of IE
- modernizr is used to detect which css features are available in the user's browser. This way you can target all browsers that support a certain feature using css classes, and rules affecting the same element can be put together in the same place for all browsers.
- In other themes, user agent detection is used to identify which browser version your user is using. Based on the result of this detection, the theme would use a different cascaded style sheet (CSS) to render a compatible page for the visitor. This approach has 2 major issues:
- CSS files are now split up according to function instead of browser. style.css will now fit most needs for customization. Following additional CSS files are included, but will rarely need to be changed:
- reset.css ensures that browser-specific initializations are being reset.
- base.css contains a few base styles
- helper.css contains helper classes to deal with specific functionality.
- handheld.css and print.css enable you to define styles for handheld devices and printing of pages.
- jQuery and jQueryUI are included by default. To avoid conflicts the authority control javascript has been rewritten to use jQuery instead of Prototype and Script.aculo.us.
Enhanced Performance
- Concatenation and Minification techniques for css and js files.
- The IncludePageMeta has been extended to generate URL's to the concatenated version of all css files using the same media tag.
- The ConcatenationReader has been created to return concatenated and minified versions of the css and js files.
- Once js and css files have been minified and concatenated, they are being properly cached. As a result, the minification and concatenation operations only need to happen once, and do not include performance overhead.
- Caution: when minification is enabled, all code-comments will be removed. This could be a problem for comments containing copyright notices, so for files with those comments you should disable minification by adding '?nominify' after the url e.g.
<map:parameter name="javascript" value="lib/js/jquery-ui-1.8.5.custom.min.js?nominify"/> - Disabled by default, these features need to be enabled in the configuration using the properties 'xmlui.theme.enableConcatenation' and 'xmlui.theme.enableMinification'
- These features can be enabled for other themes as well, but will require an alteration of the theme's sitemap.
- Javascript references are included at the bottom of the page instead of the top. This optimizes page load times in general.