big update - restarted app including jquery
4
ninja-store/public/javascripts/jquery-1.7.2.min.js
vendored
Normal file
125
ninja-store/public/javascripts/jquery-ui-1.8.20.custom.min.js
vendored
Normal file
879
ninja-store/public/javascripts/jsrender.js
Normal file
@@ -0,0 +1,879 @@
|
||||
/*! JsRender v1.0pre: http://github.com/BorisMoore/jsrender */
|
||||
/*
|
||||
* Optimized version of jQuery Templates, for rendering to string.
|
||||
* Does not require jQuery, or HTML DOM
|
||||
* Integrates with JsViews (http://github.com/BorisMoore/jsviews)
|
||||
* Copyright 2012, Boris Moore
|
||||
* Released under the MIT License.
|
||||
*/
|
||||
// informal pre beta commit counter: 15
|
||||
|
||||
this.jsviews || this.jQuery && jQuery.views || (function(global, undefined) {
|
||||
|
||||
//========================== Top-level vars ==========================
|
||||
|
||||
var versionNumber = "v1.0pre",
|
||||
|
||||
$, rTag, rTmplString, extend,
|
||||
delimOpenChar0 = "{", delimOpenChar1 = "{", delimCloseChar0 = "}", delimCloseChar1 = "}", sub = {},
|
||||
FALSE = false, TRUE = true,
|
||||
jQuery = global.jQuery,
|
||||
|
||||
rPath = /^(?:null|true|false|\d[\d.]*|([\w$]+|~([\w$]+)|#(view|([\w$]+))?)([\w$.]*?)(?:[.[]([\w$]+)\]?)?|(['"]).*\8)$/g,
|
||||
// nil object helper view viewProperty pathTokens leafToken string
|
||||
|
||||
rParams = /(\()(?=|\s*\()|(?:([([])\s*)?(?:([#~]?[\w$.]+)?\s*((\+\+|--)|\+|-|&&|\|\||===|!==|==|!=|<=|>=|[<>%*!:?\/]|(=))\s*|([#~]?[\w$.]+)([([])?)|(,\s*)|(\(?)\\?(?:(')|("))|(?:\s*([)\]])([([]?))|(\s+)/g,
|
||||
// lftPrn lftPrn2 path operator err eq path2 prn comma lftPrn2 apos quot rtPrn prn2 space
|
||||
// (left paren? followed by (path? followed by operator) or (path followed by paren?)) or comma or apos or quot or right paren or space
|
||||
|
||||
rNewLine = /\r?\n/g,
|
||||
rUnescapeQuotes = /\\(['"])/g,
|
||||
rEscapeQuotes = /\\?(['"])/g,
|
||||
rBuildHash = /\x08(~)?([^\x08]+)\x08/g,
|
||||
|
||||
autoViewKey = 0,
|
||||
autoTmplName = 0,
|
||||
escapeMapForHtml = {
|
||||
"&": "&",
|
||||
"<": "<",
|
||||
">": ">"
|
||||
},
|
||||
tmplAttr = "data-jsv-tmpl",
|
||||
fnDeclStr = "var j=j||" + (jQuery ? "jQuery." : "js") + "views,",
|
||||
htmlSpecialChar = /[\x00"&'<>]/g,
|
||||
slice = Array.prototype.slice,
|
||||
|
||||
render = {},
|
||||
|
||||
// jsviews object ($.views if jQuery is loaded)
|
||||
jsv = {
|
||||
jsviews: versionNumber,
|
||||
sub: sub, // subscription, e.g. JsViews integration
|
||||
debugMode: TRUE,
|
||||
render: render,
|
||||
templates: templates,
|
||||
tags: tags,
|
||||
helpers: helpers,
|
||||
converters: converters,
|
||||
View: View,
|
||||
delimiters: setDelimiters,
|
||||
_convert: convert,
|
||||
_err: function(e) {
|
||||
return jsv.debugMode ? ("<br/><b>Error:</b> <em> " + (e.message || e) + ". </em>") : '""';
|
||||
},
|
||||
_tmplFn: tmplFn,
|
||||
_tag: renderTag
|
||||
};
|
||||
//========================== Top-level functions ==========================
|
||||
|
||||
//===================
|
||||
// jsviews.delimiters
|
||||
//===================
|
||||
|
||||
function setDelimiters(openChars, closeChars) {
|
||||
// Set the tag opening and closing delimiters. Default is "{{" and "}}"
|
||||
// openChar, closeChars: opening and closing strings, each with two characters
|
||||
|
||||
if (!jsv.rTag || arguments.length) {
|
||||
delimOpenChar0 = openChars ? "\\" + openChars.charAt(0) : delimOpenChar0; // Escape the characters - since they could be regex special characters
|
||||
delimOpenChar1 = openChars ? "\\" + openChars.charAt(1) : delimOpenChar1;
|
||||
delimCloseChar0 = closeChars ? "\\" + closeChars.charAt(0) : delimCloseChar0;
|
||||
delimCloseChar1 = closeChars ? "\\" + closeChars.charAt(0) : delimCloseChar1;
|
||||
|
||||
// Build regex with new delimiters
|
||||
jsv.rTag = rTag // make rTag available to JsViews (or other components) for parsing binding expressions
|
||||
// tag (followed by / space or }) or cvtr+colon or html or code
|
||||
= "(?:(?:(\\w+(?=[\\/\\s" + delimCloseChar0 + "]))|(?:(\\w+)?(:)|(>)|(\\*)))"
|
||||
// params
|
||||
+ "\\s*((?:[^" + delimCloseChar0 + "]|" + delimCloseChar0 + "(?!" + delimCloseChar1 + "))*?)";
|
||||
|
||||
// slash or closeBlock }}
|
||||
rTag = new RegExp(delimOpenChar0 + delimOpenChar1 + rTag + "(\\/)?|(?:\\/(\\w+)))" + delimCloseChar0 + delimCloseChar1, "g");
|
||||
|
||||
// Default rTag: tag converter colon html code params slash closeBlock
|
||||
// /{{(?:(?:(\w+(?=[\/\s}]))|(?:(\w+)?(:)|(>)|(\*)))\s*((?:[^}]|}(?!}))*?)(\/)?|(?:\/(\w+)))}}
|
||||
|
||||
rTmplString = new RegExp("<.*>|" + openChars + ".*" + closeChars);
|
||||
}
|
||||
return [delimOpenChar0, delimOpenChar1, delimCloseChar0, delimCloseChar1];
|
||||
}
|
||||
|
||||
//=================
|
||||
// View._hlp
|
||||
//=================
|
||||
|
||||
function getHelper(helper) {
|
||||
// Helper method called as view._hlp() from compiled template, for helper functions or template parameters ~foo
|
||||
var view = this,
|
||||
tmplHelpers = view.tmpl.helpers || {};
|
||||
|
||||
helper = (view.ctx[helper] !== undefined ? view.ctx : tmplHelpers[helper] !== undefined ? tmplHelpers : helpers[helper] !== undefined ? helpers : {})[helper];
|
||||
return typeof helper !== "function" ? helper : function() {
|
||||
return helper.apply(view, arguments);
|
||||
};
|
||||
}
|
||||
|
||||
//=================
|
||||
// jsviews.convert
|
||||
//=================
|
||||
|
||||
function convert(converter, view, tmpl, text) {
|
||||
var tmplConverters = tmpl.converters;
|
||||
converter = tmplConverters && tmplConverters[converter] || converters[converter];
|
||||
return converter ? converter.call(view, text) : text;
|
||||
}
|
||||
|
||||
//=================
|
||||
// jsviews.tag
|
||||
//=================
|
||||
|
||||
function renderTag(tag, parentView, parentTmpl, converter, content, tagObject) {
|
||||
// Called from within compiled template function, to render a nested tag
|
||||
// Returns the rendered tag
|
||||
var ret,
|
||||
tmplTags = parentTmpl.tags,
|
||||
nestedTemplates = parentTmpl.templates,
|
||||
tmpl = tagObject.props && tagObject.props.tmpl,
|
||||
args = arguments,
|
||||
tagFn = tmplTags && tmplTags[tag] || tags[tag];
|
||||
|
||||
if (!tagFn) {
|
||||
return "";
|
||||
}
|
||||
// Set the tmpl property to the content of the block tag, unless set as an override property on the tag
|
||||
content = content && parentTmpl.tmpls[content - 1];
|
||||
tmpl = tmpl || content || undefined;
|
||||
|
||||
tagObject.tmpl =
|
||||
"" + tmpl === tmpl // if a string
|
||||
? nestedTemplates && nestedTemplates[tmpl] || templates[tmpl] || templates(tmpl)
|
||||
: tmpl;
|
||||
|
||||
tagObject.isTag = TRUE;
|
||||
tagObject.converter = converter;
|
||||
tagObject.view = parentView;
|
||||
tagObject.renderContent = renderContent;
|
||||
|
||||
ret = tagFn.apply(tagObject, args.length > 6 ? slice.call(args, 6) : []);
|
||||
return ret || (ret == undefined ? "" : ret.toString()); // (If ret is the value 0 or false, will render to string)
|
||||
}
|
||||
|
||||
//=================
|
||||
// View constructor
|
||||
//=================
|
||||
|
||||
function View(context, path, parentView, data, template, key, onRender, isArray) {
|
||||
// Constructor for view object in view hierarchy. (Augmented by JsViews if JsViews is loaded)
|
||||
var views,
|
||||
self = {
|
||||
tmpl: template,
|
||||
path: path,
|
||||
parent: parentView,
|
||||
data: data,
|
||||
ctx: context,
|
||||
// If the data is an array, this is an 'Array View' with a views array for each child 'Instance View'
|
||||
// If the data is not an array, this is an 'Instance View' with a views 'map' object for any child nested views
|
||||
views: isArray ? [] : {},
|
||||
isArray: isArray, // is an 'Array View' owning a data array, with child views for each item
|
||||
_hlp: getHelper,
|
||||
_onRender: onRender
|
||||
};
|
||||
|
||||
if (parentView) {
|
||||
views = parentView.views;
|
||||
if (parentView.isArray) {
|
||||
// Parent is an 'Array View'. Add this view to its views array
|
||||
views.splice(
|
||||
// self.key = self.key - the index in the parent view array
|
||||
self.key = self.index = key !== undefined
|
||||
? key
|
||||
: views.length,
|
||||
0, self);
|
||||
} else {
|
||||
// Parent is an 'Instance View'. Add this view to its views object
|
||||
// self.key = is the key in the parent view map
|
||||
views[self.key = "_" + autoViewKey++] = self;
|
||||
// self.index = is index of the parent
|
||||
self.index = parentView.index;
|
||||
}
|
||||
}
|
||||
return self;
|
||||
}
|
||||
|
||||
//=================
|
||||
// Registration
|
||||
//=================
|
||||
|
||||
function addToStore(self, store, name, item, process) {
|
||||
// Add item to named store such as templates, helpers, converters...
|
||||
var key, onStore;
|
||||
if (name && typeof name === "object" && !name.nodeType) {
|
||||
// If name is a map, iterate over map and call store for key
|
||||
for (key in name) {
|
||||
store(key, name[key]);
|
||||
}
|
||||
return self;
|
||||
}
|
||||
if (!name || item === undefined) {
|
||||
if (process) {
|
||||
item = process(undefined, item || name);
|
||||
}
|
||||
} else if ("" + name === name) { // name must be a string
|
||||
if (item === null) {
|
||||
// If item is null, delete this entry
|
||||
delete store[name];
|
||||
} else if (item = process ? process(name, item) : item) {
|
||||
store[name] = item;
|
||||
}
|
||||
}
|
||||
if (onStore = sub.onStoreItem) {
|
||||
// e.g. JsViews integration
|
||||
onStore(store, name, item, process);
|
||||
}
|
||||
return item;
|
||||
}
|
||||
|
||||
function templates(name, tmpl) {
|
||||
// Register templates
|
||||
// Setter: Use $.view.tags( name, tagFn ) or $.view.tags({ name: tagFn, ... }) to add additional tags to the registered tags collection.
|
||||
// Getter: Use var tagFn = $.views.tags( name ) or $.views.tags[name] or $.views.tags.name to return the function for the registered tag.
|
||||
// Remove: Use $.view.tags( name, null ) to remove a registered tag from $.view.tags.
|
||||
|
||||
// When registering for {{foo a b c==d e=f}}, tagFn should be a function with the signature:
|
||||
// function(a,b). The 'this' pointer will be a hash with properties c and e.
|
||||
return addToStore(this, templates, name, tmpl, compile);
|
||||
}
|
||||
|
||||
function tags(name, tagFn) {
|
||||
// Register template tags
|
||||
// Setter: Use $.view.tags( name, tagFn ) or $.view.tags({ name: tagFn, ... }) to add additional tags to the registered tags collection.
|
||||
// Getter: Use var tagFn = $.views.tags( name ) or $.views.tags[name] or $.views.tags.name to return the function for the registered tag.
|
||||
// Remove: Use $.view.tags( name, null ) to remove a registered tag from $.view.tags.
|
||||
|
||||
// When registering for {{foo a b c==d e=f}}, tagFn should be a function with the signature:
|
||||
// function(a,b). The 'this' pointer will be a hash with properties c and e.
|
||||
return addToStore(this, tags, name, tagFn);
|
||||
}
|
||||
|
||||
function helpers(name, helperFn) {
|
||||
// Register helper functions for use in templates (or in data-link expressions if JsViews is loaded)
|
||||
// Setter: Use $.view.helpers( name, helperFn ) or $.view.helpers({ name: helperFn, ... }) to add additional helpers to the registered helpers collection.
|
||||
// Getter: Use var helperFn = $.views.helpers( name ) or $.views.helpers[name] or $.views.helpers.name to return the function.
|
||||
// Remove: Use $.view.helpers( name, null ) to remove a registered helper function from $.view.helpers.
|
||||
// Within a template, access the helper using the syntax: {{... ~myHelper(...) ...}}.
|
||||
return addToStore(this, helpers, name, helperFn);
|
||||
}
|
||||
|
||||
function converters(name, converterFn) {
|
||||
// Register converter functions for use in templates (or in data-link expressions if JsViews is loaded)
|
||||
// Setter: Use $.view.converters( name, converterFn ) or $.view.converters({ name: converterFn, ... }) to add additional converters to the registered converters collection.
|
||||
// Getter: Use var converterFn = $.views.converters( name ) or $.views.converters[name] or $.views.converters.name to return the converter function.
|
||||
// Remove: Use $.view.converters( name, null ) to remove a registered converter from $.view.converters.
|
||||
// Within a template, access the converter using the syntax: {{myConverter:...}}.
|
||||
return addToStore(this, converters, name, converterFn);
|
||||
}
|
||||
|
||||
//=================
|
||||
// renderContent
|
||||
//=================
|
||||
|
||||
function renderContent(data, context, path, key, parentView, onRender) {
|
||||
// Render template against data as a tree of subviews (nested template), or as a string (top-level template).
|
||||
// tagName parameter for internal use only. Used for rendering templates registered as tags (which may have associated presenter objects)
|
||||
var i, l, dataItem, newView, itemWrap, itemsWrap, itemResult, parentContext, tmpl, onRender, props, swapContent, isLayout,
|
||||
self = this,
|
||||
result = "";
|
||||
|
||||
if (key === TRUE) {
|
||||
swapContent = TRUE;
|
||||
key = 0;
|
||||
}
|
||||
if (self.isTag) {
|
||||
// This is a call from renderTag
|
||||
tmpl = self.tmpl;
|
||||
if (self.props && self.ctx) {
|
||||
extend(self.ctx, self.props);
|
||||
}
|
||||
if (self.ctx && context) {
|
||||
context = extend(self.ctx, context);
|
||||
}
|
||||
context = self.ctx || context;
|
||||
parentView = parentView || self.view;
|
||||
path = path || self.path;
|
||||
key = key || self.key;
|
||||
props = self.props;
|
||||
} else {
|
||||
tmpl = self.jquery && self[0] // This is a call from $(selector).render
|
||||
|| self; // This is a call from tmpl.render
|
||||
}
|
||||
if (tmpl) {
|
||||
if (parentView) {
|
||||
parentContext = parentView.ctx;
|
||||
if (data === parentView) {
|
||||
// Inherit the data from the parent view.
|
||||
// This may be the contents of an {{if}} block
|
||||
// Set isLayout = true so we don't iterate the if block if the data is an array.
|
||||
data = parentView.data;
|
||||
isLayout = TRUE;
|
||||
}
|
||||
onRender = onRender || parentView._onRender;
|
||||
} else {
|
||||
parentContext = jsv.helpers;
|
||||
}
|
||||
|
||||
// Set additional context on views created here, (as modified context inherited from the parent, and to be inherited by child views)
|
||||
// Note: If no jQuery, extend does not support chained copies - so limit extend() to two parameters
|
||||
// TODO could make this a reusable helper for merging context.
|
||||
context = (context && context !== parentContext)
|
||||
? extend(extend({}, parentContext), context)
|
||||
: parentContext;
|
||||
|
||||
if (!tmpl.fn) {
|
||||
tmpl = templates[tmpl] || templates(tmpl);
|
||||
}
|
||||
|
||||
if (tmpl) {
|
||||
if ($.isArray(data) && !isLayout) {
|
||||
// Create a view for the array, whose child views correspond to each data item.
|
||||
// (Note: if key and parentView are passed in along with parent view, treat as
|
||||
// insert -e.g. from view.addViews - so parentView is already the view item for array)
|
||||
newView = swapContent ? parentView : (key !== undefined && parentView) || View(context, path, parentView, data, tmpl, key, onRender, TRUE);
|
||||
for (i = 0, l = data.length; i < l; i++) {
|
||||
// Create a view for each data item.
|
||||
dataItem = data[i];
|
||||
itemResult = tmpl.fn(dataItem, View(context, path, newView, dataItem, tmpl, (key || 0) + i, onRender), jsv);
|
||||
result += onRender ? onRender(itemResult, tmpl, props) : itemResult;
|
||||
}
|
||||
} else {
|
||||
// Create a view for singleton data object.
|
||||
newView = swapContent ? parentView : View(context, path, parentView, data, tmpl, key, onRender);
|
||||
newView._onRender = onRender;
|
||||
result += tmpl.fn(data, newView, jsv);
|
||||
}
|
||||
return onRender ? onRender(result, tmpl, props, newView.key, path) : result;
|
||||
}
|
||||
}
|
||||
return ""; // No tmpl. Could throw...
|
||||
}
|
||||
|
||||
//===========================
|
||||
// Build and compile template
|
||||
//===========================
|
||||
|
||||
// Generate a reusable function that will serve to render a template against data
|
||||
// (Compile AST then build template function)
|
||||
|
||||
function syntaxError(message, e) {
|
||||
throw (e ? (e.name + ': "' + e.message + '"') : "Syntax error") + (message ? (" \n" + message) : "");
|
||||
}
|
||||
|
||||
function tmplFn(markup, tmpl, bind) {
|
||||
// Compile markup to AST (abtract syntax tree) then build the template function code from the AST nodes
|
||||
// Used for compiling templates, and also by JsViews to build functions for data link expressions
|
||||
var newNode, node, i, l, code, hasTag, hasEncoder, getsValue, hasConverter, hasViewPath, tag, converter, params, hash, nestedTmpl, allowCode,
|
||||
tmplOptions = tmpl ? {
|
||||
allowCode: allowCode = tmpl.allowCode,
|
||||
debug: tmpl.debug
|
||||
} : {},
|
||||
nested = tmpl && tmpl.tmpls,
|
||||
astTop = [],
|
||||
loc = 0,
|
||||
stack = [],
|
||||
content = astTop,
|
||||
current = [, , , astTop],
|
||||
nestedIndex = 0;
|
||||
|
||||
//==== nested functions ====
|
||||
function pushPreceedingContent(shift) {
|
||||
shift -= loc;
|
||||
if (shift) {
|
||||
content.push(markup.substr(loc, shift).replace(rNewLine, "\\n"));
|
||||
}
|
||||
}
|
||||
|
||||
function parseTag(all, tagName, converter, colon, html, code, params, slash, closeBlock, index) {
|
||||
// tag converter colon html code params slash closeBlock
|
||||
// /{{(?:(?:(\w+(?=[\/!\s\}!]))|(?:(\w+)?(:)|(?:(>)|(\*)))((?:[^\}]|}(?!}))*?)(\/)?|(?:\/(\w+)))}}/g;
|
||||
// Build abstract syntax tree (AST): [ tagName, converter, params, content, hash, contentMarkup ]
|
||||
if (html) {
|
||||
colon = ":";
|
||||
converter = "html";
|
||||
}
|
||||
var hash = "",
|
||||
passedCtx = "",
|
||||
// Block tag if not self-closing and not {{:}} or {{>}} (special case) and not a data-link expression (has bind parameter)
|
||||
block = !slash && !colon && !bind;
|
||||
|
||||
//==== nested helper function ====
|
||||
|
||||
tagName = tagName || colon;
|
||||
pushPreceedingContent(index);
|
||||
loc = index + all.length; // location marker - parsed up to here
|
||||
if (code) {
|
||||
if (allowCode) {
|
||||
content.push(["*", params.replace(rUnescapeQuotes, "$1")]);
|
||||
}
|
||||
} else if (tagName) {
|
||||
if (tagName === "else") {
|
||||
current[5] = markup.substring(current[5], index); // contentMarkup for block tag
|
||||
current = stack.pop();
|
||||
content = current[3];
|
||||
block = TRUE;
|
||||
}
|
||||
params = (params
|
||||
? parseParams(params, bind)
|
||||
.replace(rBuildHash, function(all, isCtx, keyValue) {
|
||||
if (isCtx) {
|
||||
passedCtx += keyValue + ",";
|
||||
} else {
|
||||
hash += keyValue + ",";
|
||||
}
|
||||
return "";
|
||||
})
|
||||
: "");
|
||||
hash = hash.slice(0, -1);
|
||||
params = params.slice(0, -1);
|
||||
newNode = [
|
||||
tagName,
|
||||
converter || "",
|
||||
params,
|
||||
block && [],
|
||||
"{" + (hash ? ("props:{" + hash + "},") : "") + "path:'" + params + "'" + (passedCtx ? ",ctx:{" + passedCtx.slice(0, -1) + "}" : "") + "}"
|
||||
];
|
||||
if (block) {
|
||||
stack.push(current);
|
||||
current = newNode;
|
||||
current[5] = loc; // Store current location of open tag, to be able to add contentMarkup when we reach closing tag
|
||||
}
|
||||
content.push(newNode);
|
||||
} else if (closeBlock) {
|
||||
//if ( closeBlock !== current[ 0 ]) {
|
||||
// throw "unmatched close tag: /" + closeBlock + ". Expected /" + current[ 0 ];
|
||||
//}
|
||||
current[5] = markup.substring(current[5], index); // contentMarkup for block tag
|
||||
current = stack.pop();
|
||||
}
|
||||
if (!current) {
|
||||
throw "Expected block tag";
|
||||
}
|
||||
content = current[3];
|
||||
}
|
||||
//==== /end of nested functions ====
|
||||
|
||||
markup = markup.replace(rEscapeQuotes, "\\$1");
|
||||
|
||||
// Build the AST (abstract syntax tree) under astTop
|
||||
markup.replace(rTag, parseTag);
|
||||
|
||||
pushPreceedingContent(markup.length);
|
||||
|
||||
// Use the AST (astTop) to build the template function
|
||||
l = astTop.length;
|
||||
code = (l ? "" : '"";');
|
||||
|
||||
for (i = 0; i < l; i++) {
|
||||
// AST nodes: [ tagName, converter, params, content, hash, contentMarkup ]
|
||||
node = astTop[i];
|
||||
if ("" + node === node) { // type string
|
||||
code += '"' + node + '"+';
|
||||
} else if (node[0] === "*") {
|
||||
code = code.slice(0, i ? -1 : -3) + ";" + node[1] + (i + 1 < l ? "ret+=" : "");
|
||||
} else {
|
||||
tag = node[0];
|
||||
converter = node[1];
|
||||
params = node[2];
|
||||
content = node[3];
|
||||
hash = node[4];
|
||||
markup = node[5];
|
||||
if (content) {
|
||||
// Create template object for nested template
|
||||
nestedTmpl = TmplObject(markup, tmplOptions, tmpl, nestedIndex++);
|
||||
// Compile to AST and then to compiled function
|
||||
tmplFn(markup, nestedTmpl);
|
||||
nested.push(nestedTmpl);
|
||||
}
|
||||
hasViewPath = hasViewPath || hash.indexOf("view") > -1;
|
||||
code += (tag === ":"
|
||||
? (converter === "html"
|
||||
? (hasEncoder = TRUE, "e(" + params)
|
||||
: converter
|
||||
? (hasConverter = TRUE, 'c("' + converter + '",view,this,' + params)
|
||||
: (getsValue = TRUE, "((v=" + params + ')!=u?v:""')
|
||||
)
|
||||
: (hasTag = TRUE, 't("' + tag + '",view,this,"' + (converter || "") + '",'
|
||||
+ (content ? nested.length : '""') // For block tags, pass in the key (nested.length) to the nested content template
|
||||
+ "," + hash + (params ? "," : "") + params))
|
||||
+ ")+";
|
||||
}
|
||||
}
|
||||
code = fnDeclStr
|
||||
+ (getsValue ? "v," : "")
|
||||
+ (hasTag ? "t=j._tag," : "")
|
||||
+ (hasConverter ? "c=j._convert," : "")
|
||||
+ (hasEncoder ? "e=j.converters.html," : "")
|
||||
+ "ret; try{\n\n"
|
||||
+ (tmplOptions.debug ? "debugger;" : "")
|
||||
+ (allowCode ? 'ret=' : 'return ')
|
||||
+ code.slice(0, -1) + ";\n\n"
|
||||
+ (allowCode ? "return ret;" : "")
|
||||
+ "}catch(e){return j._err(e);}";
|
||||
|
||||
try {
|
||||
code = new Function("data, view, j, b, u", code);
|
||||
} catch (e) {
|
||||
syntaxError("Error in compiled template code:\n" + code, e);
|
||||
}
|
||||
|
||||
// Include only the var references that are needed in the code
|
||||
if (tmpl) {
|
||||
tmpl.fn = code;
|
||||
}
|
||||
return code;
|
||||
}
|
||||
|
||||
function parseParams(params, bind) {
|
||||
var named,
|
||||
fnCall = {},
|
||||
parenDepth = 0,
|
||||
quoted = FALSE, // boolean for string content in double quotes
|
||||
aposed = FALSE; // or in single quotes
|
||||
|
||||
function parseTokens(all, lftPrn0, lftPrn, path, operator, err, eq, path2, prn, comma, lftPrn2, apos, quot, rtPrn, prn2, space) {
|
||||
// rParams = /(?:([([])\s*)?(?:([#~]?[\w$.]+)?\s*((\+\+|--)|\+|-|&&|\|\||===|!==|==|!=|<=|>=|[<>%*!:?\/]|(=))\s*|([#~]?[\w$.^]+)([([])?)|(,\s*)|(\(?)\\?(?:(')|("))|(?:\s*([)\]])([([]?))|(\s+)/g,
|
||||
// lftPrn path operator err eq path2 prn comma lftPrn3 apos quot rtPrn prn2 space
|
||||
// (left paren? followed by (path? followed by operator) or (path followed by paren?)) or comma or apos or quot or right paren or space
|
||||
operator = operator || "";
|
||||
lftPrn = lftPrn || lftPrn0 || lftPrn2;
|
||||
path = path || path2;
|
||||
prn = prn || prn2 || "";
|
||||
operator = operator || "";
|
||||
var bindParam = bind && prn !== "(";
|
||||
|
||||
function parsePath(all, object, helper, view, viewProperty, pathTokens, leafToken) {
|
||||
// rPath = /^(?:null|true|false|\d[\d.]*|([\w$]+|~([\w$]+)|#(view|([\w$]+))?)([\w$.]*?)(?:[.[]([\w$]+)\]?)?|(['"]).*\8)$/g,
|
||||
// object helper view viewProperty pathTokens leafToken string
|
||||
if (object) {
|
||||
var leaf,
|
||||
ret = (helper
|
||||
? 'view._hlp("' + helper + '")'
|
||||
: view
|
||||
? "view"
|
||||
: "data")
|
||||
+ (leafToken
|
||||
? (viewProperty
|
||||
? "." + viewProperty
|
||||
: helper
|
||||
? ""
|
||||
: (view ? "" : "." + object)
|
||||
) + (pathTokens || "")
|
||||
: (leafToken = helper ? "" : view ? viewProperty || "" : object, ""));
|
||||
|
||||
leaf = (leafToken ? "." + leafToken : "")
|
||||
if (!bindParam) {
|
||||
ret = ret + leaf;
|
||||
}
|
||||
ret = ret.slice(0, 9) === "view.data"
|
||||
? ret.slice(5) // convert #view.data... to data...
|
||||
: ret;
|
||||
if (bindParam) {
|
||||
ret = "b(" + ret + ',"' + leafToken + '")' + leaf;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
return all;
|
||||
}
|
||||
|
||||
if (err) {
|
||||
syntaxError();
|
||||
} else {
|
||||
return (aposed
|
||||
// within single-quoted string
|
||||
? (aposed = !apos, (aposed ? all : '"'))
|
||||
: quoted
|
||||
// within double-quoted string
|
||||
? (quoted = !quot, (quoted ? all : '"'))
|
||||
:
|
||||
(
|
||||
(lftPrn
|
||||
? (parenDepth++, lftPrn)
|
||||
: "")
|
||||
+ (space
|
||||
? (parenDepth
|
||||
? ""
|
||||
: named
|
||||
? (named = FALSE, "\b")
|
||||
: ","
|
||||
)
|
||||
: eq
|
||||
// named param
|
||||
? (parenDepth && syntaxError(), named = TRUE, '\b' + path + ':')
|
||||
: path
|
||||
// path
|
||||
? (path.replace(rPath, parsePath)
|
||||
+ (prn
|
||||
? (fnCall[++parenDepth] = TRUE, prn)
|
||||
: operator)
|
||||
)
|
||||
: operator
|
||||
? operator
|
||||
: rtPrn
|
||||
// function
|
||||
? ((fnCall[parenDepth--] = FALSE, rtPrn)
|
||||
+ (prn
|
||||
? (fnCall[++parenDepth] = TRUE, prn)
|
||||
: "")
|
||||
)
|
||||
: comma
|
||||
? (fnCall[parenDepth] || syntaxError(), ",") // We don't allow top-level literal arrays or objects
|
||||
: lftPrn0
|
||||
? ""
|
||||
: (aposed = apos, quoted = quot, '"')
|
||||
))
|
||||
);
|
||||
}
|
||||
}
|
||||
params = (params + " ").replace(rParams, parseTokens);
|
||||
return params;
|
||||
}
|
||||
|
||||
function compile(name, tmpl, parent, options) {
|
||||
// tmpl is either a template object, a selector for a template script block, the name of a compiled template, or a template object
|
||||
// options is the set of template properties, c
|
||||
var tmplOrMarkup, elem, key, nested, nestedItem;
|
||||
|
||||
//==== nested functions ====
|
||||
function tmplOrMarkupFromStr(value) {
|
||||
// If value is of type string - treat as selector, or name of compiled template
|
||||
// Return the template object, if already compiled, or the markup string
|
||||
|
||||
if (("" + value === value) || value.nodeType > 0) {
|
||||
try {
|
||||
elem = value.nodeType > 0
|
||||
? value
|
||||
: !rTmplString.test(value)
|
||||
// If value is a string and does not contain HTML or tag content, then test as selector
|
||||
&& jQuery && jQuery(value)[0];
|
||||
// If selector is valid and returns at least one element, get first element
|
||||
// If invalid, jQuery will throw. We will stay with the original string.
|
||||
} catch (e) { }
|
||||
|
||||
if (elem) {
|
||||
if (!elem.type) {
|
||||
// If elem is not a script element, return undefined
|
||||
return;
|
||||
}
|
||||
// It is a script element
|
||||
// Create a name for data linking if none provided
|
||||
value = templates[elem.getAttribute(tmplAttr)];
|
||||
if (!value) {
|
||||
// Not already compiled and cached, so compile and cache the name
|
||||
name = name || "_" + autoTmplName++;
|
||||
elem.setAttribute(tmplAttr, name);
|
||||
value = compile(name, elem.innerHTML, parent, options); // Use tmpl as options
|
||||
templates[name] = value;
|
||||
}
|
||||
}
|
||||
return value;
|
||||
}
|
||||
// If value is not a string, return undefined
|
||||
}
|
||||
|
||||
//==== Compile the template ====
|
||||
tmpl = tmpl || "";
|
||||
tmplOrMarkup = tmplOrMarkupFromStr(tmpl);
|
||||
|
||||
// If tmpl is a template object, use it for options
|
||||
options = options || (tmpl.markup ? tmpl : {});
|
||||
options.name = name;
|
||||
nested = options.templates;
|
||||
|
||||
// If tmpl is not a markup string or a selector string, then it must be a template object
|
||||
// In that case, get it from the markup property of the object
|
||||
if (!tmplOrMarkup && tmpl.markup && (tmplOrMarkup = tmplOrMarkupFromStr(tmpl.markup))) {
|
||||
if (tmplOrMarkup.fn && (tmplOrMarkup.debug !== tmpl.debug || tmplOrMarkup.allowCode !== tmpl.allowCode)) {
|
||||
// if the string references a compiled template object, but the debug or allowCode props are different, need to recompile
|
||||
tmplOrMarkup = tmplOrMarkup.markup;
|
||||
}
|
||||
}
|
||||
if (tmplOrMarkup !== undefined) {
|
||||
if (name && !parent) {
|
||||
render[name] = function() {
|
||||
return tmpl.render.apply(tmpl, arguments);
|
||||
};
|
||||
}
|
||||
if (tmplOrMarkup.fn || tmpl.fn) {
|
||||
// tmpl is already compiled, so use it, or if different name is provided, clone it
|
||||
if (tmplOrMarkup.fn) {
|
||||
if (name && name !== tmplOrMarkup.name) {
|
||||
tmpl = extend(extend({}, tmplOrMarkup), options);
|
||||
} else {
|
||||
tmpl = tmplOrMarkup;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// tmplOrMarkup is a markup string, not a compiled template
|
||||
// Create template object
|
||||
tmpl = TmplObject(tmplOrMarkup, options, parent, 0);
|
||||
// Compile to AST and then to compiled function
|
||||
tmplFn(tmplOrMarkup, tmpl);
|
||||
}
|
||||
for (key in nested) {
|
||||
// compile nested template declarations
|
||||
nestedItem = nested[key];
|
||||
if (nestedItem.name !== key) {
|
||||
nested[key] = compile(key, nestedItem, tmpl);
|
||||
}
|
||||
}
|
||||
return tmpl;
|
||||
}
|
||||
}
|
||||
//==== /end of function compile ====
|
||||
|
||||
function TmplObject(markup, options, parent, key) {
|
||||
// Template object constructor
|
||||
|
||||
// nested helper function
|
||||
function extendStore(storeName) {
|
||||
if (parent[storeName]) {
|
||||
// Include parent items except if overridden by item of same name in options
|
||||
tmpl[storeName] = extend(extend({}, parent[storeName]), options[storeName]);
|
||||
}
|
||||
}
|
||||
|
||||
options = options || {};
|
||||
var tmpl = {
|
||||
markup: markup,
|
||||
tmpls: [],
|
||||
links: [],
|
||||
render: renderContent
|
||||
};
|
||||
|
||||
if (parent) {
|
||||
if (parent.templates) {
|
||||
tmpl.templates = extend(extend({}, parent.templates), options.templates);
|
||||
}
|
||||
tmpl.parent = parent;
|
||||
tmpl.name = parent.name + "[" + key + "]";
|
||||
tmpl.key = key;
|
||||
}
|
||||
|
||||
extend(tmpl, options);
|
||||
if (parent) {
|
||||
extendStore("templates");
|
||||
extendStore("tags");
|
||||
extendStore("helpers");
|
||||
extendStore("converters");
|
||||
}
|
||||
return tmpl;
|
||||
}
|
||||
|
||||
//========================== Initialize ==========================
|
||||
|
||||
if (jQuery) {
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
// jQuery is loaded, so make $ the jQuery object
|
||||
$ = jQuery;
|
||||
$.templates = templates;
|
||||
$.render = render;
|
||||
$.views = jsv;
|
||||
$.fn.render = renderContent;
|
||||
|
||||
} else {
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
// jQuery is not loaded.
|
||||
|
||||
$ = global.jsviews = jsv;
|
||||
$.extend = function(target, source) {
|
||||
var name;
|
||||
target = target || {};
|
||||
for (name in source) {
|
||||
target[name] = source[name];
|
||||
}
|
||||
return target;
|
||||
};
|
||||
|
||||
$.isArray = Array && Array.isArray || function(obj) {
|
||||
return Object.prototype.toString.call(obj) === "[object Array]";
|
||||
};
|
||||
}
|
||||
|
||||
extend = $.extend;
|
||||
|
||||
function replacerForHtml(ch) {
|
||||
// Original code from Mike Samuel <msamuel@google.com>
|
||||
return escapeMapForHtml[ch]
|
||||
// Intentional assignment that caches the result of encoding ch.
|
||||
|| (escapeMapForHtml[ch] = "&#" + ch.charCodeAt(0) + ";");
|
||||
}
|
||||
|
||||
//========================== Register tags ==========================
|
||||
|
||||
tags({
|
||||
"if": function() {
|
||||
var ifTag = this,
|
||||
view = ifTag.view;
|
||||
|
||||
view.onElse = function(tagObject, args) {
|
||||
var i = 0,
|
||||
l = args.length;
|
||||
|
||||
while (l && !args[i++]) {
|
||||
// Only render content if args.length === 0 (i.e. this is an else with no condition) or if a condition argument is truey
|
||||
if (i === l) {
|
||||
return "";
|
||||
}
|
||||
}
|
||||
view.onElse = undefined; // If condition satisfied, so won't run 'else'.
|
||||
tagObject.path = "";
|
||||
return tagObject.renderContent(view);
|
||||
// Test is satisfied, so render content, while remaining in current data context
|
||||
// By passing the view, we inherit data context from the parent view, and the content is treated as a layout template
|
||||
// (so if the data is an array, it will not iterate over the data
|
||||
};
|
||||
return view.onElse(this, arguments);
|
||||
},
|
||||
"else": function() {
|
||||
var view = this.view;
|
||||
return view.onElse ? view.onElse(this, arguments) : "";
|
||||
},
|
||||
"for": function() {
|
||||
var i,
|
||||
self = this,
|
||||
result = "",
|
||||
args = arguments,
|
||||
l = args.length;
|
||||
|
||||
if (l === 0) {
|
||||
// If no parameters, render once, with #data undefined
|
||||
l = 1;
|
||||
}
|
||||
for (i = 0; i < l; i++) {
|
||||
result += self.renderContent(args[i]);
|
||||
}
|
||||
return result;
|
||||
},
|
||||
"*": function(value) {
|
||||
return value;
|
||||
}
|
||||
});
|
||||
|
||||
//========================== Register global helpers ==========================
|
||||
|
||||
// helpers({ // Global helper functions
|
||||
// // TODO add any useful built-in helper functions
|
||||
// });
|
||||
|
||||
//========================== Register converters ==========================
|
||||
|
||||
converters({
|
||||
html: function(text) {
|
||||
// HTML encoding helper: Replace < > & and ' and " by corresponding entities.
|
||||
// inspired by Mike Samuel <msamuel@google.com>
|
||||
return text != undefined ? String(text).replace(htmlSpecialChar, replacerForHtml) : "";
|
||||
}
|
||||
});
|
||||
|
||||
//========================== Define default delimiters ==========================
|
||||
setDelimiters();
|
||||
|
||||
})(this);
|
||||
|
After Width: | Height: | Size: 180 B |
|
After Width: | Height: | Size: 178 B |
|
After Width: | Height: | Size: 120 B |
|
After Width: | Height: | Size: 105 B |
|
After Width: | Height: | Size: 111 B |
|
After Width: | Height: | Size: 110 B |
|
After Width: | Height: | Size: 119 B |
|
After Width: | Height: | Size: 101 B |
|
After Width: | Height: | Size: 4.3 KiB |
|
After Width: | Height: | Size: 4.3 KiB |
|
After Width: | Height: | Size: 4.3 KiB |
|
After Width: | Height: | Size: 4.3 KiB |
|
After Width: | Height: | Size: 4.3 KiB |
565
ninja-store/public/stylesheets/smoothness/jquery-ui-1.8.20.custom.css
vendored
Normal file
@@ -0,0 +1,565 @@
|
||||
/*!
|
||||
* jQuery UI CSS Framework 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Theming/API
|
||||
*/
|
||||
|
||||
/* Layout helpers
|
||||
----------------------------------*/
|
||||
.ui-helper-hidden { display: none; }
|
||||
.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); }
|
||||
.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
|
||||
.ui-helper-clearfix:before, .ui-helper-clearfix:after { content: ""; display: table; }
|
||||
.ui-helper-clearfix:after { clear: both; }
|
||||
.ui-helper-clearfix { zoom: 1; }
|
||||
.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }
|
||||
|
||||
|
||||
/* Interaction Cues
|
||||
----------------------------------*/
|
||||
.ui-state-disabled { cursor: default !important; }
|
||||
|
||||
|
||||
/* Icons
|
||||
----------------------------------*/
|
||||
|
||||
/* states and images */
|
||||
.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }
|
||||
|
||||
|
||||
/* Misc visuals
|
||||
----------------------------------*/
|
||||
|
||||
/* Overlays */
|
||||
.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
|
||||
|
||||
|
||||
/*!
|
||||
* jQuery UI CSS Framework 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Theming/API
|
||||
*
|
||||
* To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Verdana,Arial,sans-serif&fwDefault=normal&fsDefault=1.1em&cornerRadius=4px&bgColorHeader=cccccc&bgTextureHeader=03_highlight_soft.png&bgImgOpacityHeader=75&borderColorHeader=aaaaaa&fcHeader=222222&iconColorHeader=222222&bgColorContent=ffffff&bgTextureContent=01_flat.png&bgImgOpacityContent=75&borderColorContent=aaaaaa&fcContent=222222&iconColorContent=222222&bgColorDefault=e6e6e6&bgTextureDefault=02_glass.png&bgImgOpacityDefault=75&borderColorDefault=d3d3d3&fcDefault=555555&iconColorDefault=888888&bgColorHover=dadada&bgTextureHover=02_glass.png&bgImgOpacityHover=75&borderColorHover=999999&fcHover=212121&iconColorHover=454545&bgColorActive=ffffff&bgTextureActive=02_glass.png&bgImgOpacityActive=65&borderColorActive=aaaaaa&fcActive=212121&iconColorActive=454545&bgColorHighlight=fbf9ee&bgTextureHighlight=02_glass.png&bgImgOpacityHighlight=55&borderColorHighlight=fcefa1&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=02_glass.png&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=01_flat.png&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=01_flat.png&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px
|
||||
*/
|
||||
|
||||
|
||||
/* Component containers
|
||||
----------------------------------*/
|
||||
.ui-widget { font-family: Verdana,Arial,sans-serif; font-size: 1.1em; }
|
||||
.ui-widget .ui-widget { font-size: 1em; }
|
||||
.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Verdana,Arial,sans-serif; font-size: 1em; }
|
||||
.ui-widget-content { border: 1px solid #aaaaaa; background: #ffffff url(images/ui-bg_flat_75_ffffff_40x100.png) 50% 50% repeat-x; color: #222222; }
|
||||
.ui-widget-content a { color: #222222; }
|
||||
.ui-widget-header { border: 1px solid #aaaaaa; background: #cccccc url(images/ui-bg_highlight-soft_75_cccccc_1x100.png) 50% 50% repeat-x; color: #222222; font-weight: bold; }
|
||||
.ui-widget-header a { color: #222222; }
|
||||
|
||||
/* Interaction states
|
||||
----------------------------------*/
|
||||
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #d3d3d3; background: #e6e6e6 url(images/ui-bg_glass_75_e6e6e6_1x400.png) 50% 50% repeat-x; font-weight: normal; color: #555555; }
|
||||
.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #555555; text-decoration: none; }
|
||||
.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #999999; background: #dadada url(images/ui-bg_glass_75_dadada_1x400.png) 50% 50% repeat-x; font-weight: normal; color: #212121; }
|
||||
.ui-state-hover a, .ui-state-hover a:hover { color: #212121; text-decoration: none; }
|
||||
.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #aaaaaa; background: #ffffff url(images/ui-bg_glass_65_ffffff_1x400.png) 50% 50% repeat-x; font-weight: normal; color: #212121; }
|
||||
.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121; text-decoration: none; }
|
||||
.ui-widget :active { outline: none; }
|
||||
|
||||
/* Interaction Cues
|
||||
----------------------------------*/
|
||||
.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fcefa1; background: #fbf9ee url(images/ui-bg_glass_55_fbf9ee_1x400.png) 50% 50% repeat-x; color: #363636; }
|
||||
.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; }
|
||||
.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #fef1ec url(images/ui-bg_glass_95_fef1ec_1x400.png) 50% 50% repeat-x; color: #cd0a0a; }
|
||||
.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a; }
|
||||
.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a; }
|
||||
.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
|
||||
.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
|
||||
.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
|
||||
|
||||
/* Icons
|
||||
----------------------------------*/
|
||||
|
||||
/* states and images */
|
||||
.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png); }
|
||||
.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); }
|
||||
.ui-widget-header .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); }
|
||||
.ui-state-default .ui-icon { background-image: url(images/ui-icons_888888_256x240.png); }
|
||||
.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_454545_256x240.png); }
|
||||
.ui-state-active .ui-icon {background-image: url(images/ui-icons_454545_256x240.png); }
|
||||
.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png); }
|
||||
.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_cd0a0a_256x240.png); }
|
||||
|
||||
/* positioning */
|
||||
.ui-icon-carat-1-n { background-position: 0 0; }
|
||||
.ui-icon-carat-1-ne { background-position: -16px 0; }
|
||||
.ui-icon-carat-1-e { background-position: -32px 0; }
|
||||
.ui-icon-carat-1-se { background-position: -48px 0; }
|
||||
.ui-icon-carat-1-s { background-position: -64px 0; }
|
||||
.ui-icon-carat-1-sw { background-position: -80px 0; }
|
||||
.ui-icon-carat-1-w { background-position: -96px 0; }
|
||||
.ui-icon-carat-1-nw { background-position: -112px 0; }
|
||||
.ui-icon-carat-2-n-s { background-position: -128px 0; }
|
||||
.ui-icon-carat-2-e-w { background-position: -144px 0; }
|
||||
.ui-icon-triangle-1-n { background-position: 0 -16px; }
|
||||
.ui-icon-triangle-1-ne { background-position: -16px -16px; }
|
||||
.ui-icon-triangle-1-e { background-position: -32px -16px; }
|
||||
.ui-icon-triangle-1-se { background-position: -48px -16px; }
|
||||
.ui-icon-triangle-1-s { background-position: -64px -16px; }
|
||||
.ui-icon-triangle-1-sw { background-position: -80px -16px; }
|
||||
.ui-icon-triangle-1-w { background-position: -96px -16px; }
|
||||
.ui-icon-triangle-1-nw { background-position: -112px -16px; }
|
||||
.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
|
||||
.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
|
||||
.ui-icon-arrow-1-n { background-position: 0 -32px; }
|
||||
.ui-icon-arrow-1-ne { background-position: -16px -32px; }
|
||||
.ui-icon-arrow-1-e { background-position: -32px -32px; }
|
||||
.ui-icon-arrow-1-se { background-position: -48px -32px; }
|
||||
.ui-icon-arrow-1-s { background-position: -64px -32px; }
|
||||
.ui-icon-arrow-1-sw { background-position: -80px -32px; }
|
||||
.ui-icon-arrow-1-w { background-position: -96px -32px; }
|
||||
.ui-icon-arrow-1-nw { background-position: -112px -32px; }
|
||||
.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
|
||||
.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
|
||||
.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
|
||||
.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
|
||||
.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
|
||||
.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
|
||||
.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
|
||||
.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
|
||||
.ui-icon-arrowthick-1-n { background-position: 0 -48px; }
|
||||
.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
|
||||
.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
|
||||
.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
|
||||
.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
|
||||
.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
|
||||
.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
|
||||
.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
|
||||
.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
|
||||
.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
|
||||
.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
|
||||
.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
|
||||
.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
|
||||
.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
|
||||
.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
|
||||
.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
|
||||
.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
|
||||
.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
|
||||
.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
|
||||
.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
|
||||
.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
|
||||
.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
|
||||
.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
|
||||
.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
|
||||
.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
|
||||
.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
|
||||
.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
|
||||
.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
|
||||
.ui-icon-arrow-4 { background-position: 0 -80px; }
|
||||
.ui-icon-arrow-4-diag { background-position: -16px -80px; }
|
||||
.ui-icon-extlink { background-position: -32px -80px; }
|
||||
.ui-icon-newwin { background-position: -48px -80px; }
|
||||
.ui-icon-refresh { background-position: -64px -80px; }
|
||||
.ui-icon-shuffle { background-position: -80px -80px; }
|
||||
.ui-icon-transfer-e-w { background-position: -96px -80px; }
|
||||
.ui-icon-transferthick-e-w { background-position: -112px -80px; }
|
||||
.ui-icon-folder-collapsed { background-position: 0 -96px; }
|
||||
.ui-icon-folder-open { background-position: -16px -96px; }
|
||||
.ui-icon-document { background-position: -32px -96px; }
|
||||
.ui-icon-document-b { background-position: -48px -96px; }
|
||||
.ui-icon-note { background-position: -64px -96px; }
|
||||
.ui-icon-mail-closed { background-position: -80px -96px; }
|
||||
.ui-icon-mail-open { background-position: -96px -96px; }
|
||||
.ui-icon-suitcase { background-position: -112px -96px; }
|
||||
.ui-icon-comment { background-position: -128px -96px; }
|
||||
.ui-icon-person { background-position: -144px -96px; }
|
||||
.ui-icon-print { background-position: -160px -96px; }
|
||||
.ui-icon-trash { background-position: -176px -96px; }
|
||||
.ui-icon-locked { background-position: -192px -96px; }
|
||||
.ui-icon-unlocked { background-position: -208px -96px; }
|
||||
.ui-icon-bookmark { background-position: -224px -96px; }
|
||||
.ui-icon-tag { background-position: -240px -96px; }
|
||||
.ui-icon-home { background-position: 0 -112px; }
|
||||
.ui-icon-flag { background-position: -16px -112px; }
|
||||
.ui-icon-calendar { background-position: -32px -112px; }
|
||||
.ui-icon-cart { background-position: -48px -112px; }
|
||||
.ui-icon-pencil { background-position: -64px -112px; }
|
||||
.ui-icon-clock { background-position: -80px -112px; }
|
||||
.ui-icon-disk { background-position: -96px -112px; }
|
||||
.ui-icon-calculator { background-position: -112px -112px; }
|
||||
.ui-icon-zoomin { background-position: -128px -112px; }
|
||||
.ui-icon-zoomout { background-position: -144px -112px; }
|
||||
.ui-icon-search { background-position: -160px -112px; }
|
||||
.ui-icon-wrench { background-position: -176px -112px; }
|
||||
.ui-icon-gear { background-position: -192px -112px; }
|
||||
.ui-icon-heart { background-position: -208px -112px; }
|
||||
.ui-icon-star { background-position: -224px -112px; }
|
||||
.ui-icon-link { background-position: -240px -112px; }
|
||||
.ui-icon-cancel { background-position: 0 -128px; }
|
||||
.ui-icon-plus { background-position: -16px -128px; }
|
||||
.ui-icon-plusthick { background-position: -32px -128px; }
|
||||
.ui-icon-minus { background-position: -48px -128px; }
|
||||
.ui-icon-minusthick { background-position: -64px -128px; }
|
||||
.ui-icon-close { background-position: -80px -128px; }
|
||||
.ui-icon-closethick { background-position: -96px -128px; }
|
||||
.ui-icon-key { background-position: -112px -128px; }
|
||||
.ui-icon-lightbulb { background-position: -128px -128px; }
|
||||
.ui-icon-scissors { background-position: -144px -128px; }
|
||||
.ui-icon-clipboard { background-position: -160px -128px; }
|
||||
.ui-icon-copy { background-position: -176px -128px; }
|
||||
.ui-icon-contact { background-position: -192px -128px; }
|
||||
.ui-icon-image { background-position: -208px -128px; }
|
||||
.ui-icon-video { background-position: -224px -128px; }
|
||||
.ui-icon-script { background-position: -240px -128px; }
|
||||
.ui-icon-alert { background-position: 0 -144px; }
|
||||
.ui-icon-info { background-position: -16px -144px; }
|
||||
.ui-icon-notice { background-position: -32px -144px; }
|
||||
.ui-icon-help { background-position: -48px -144px; }
|
||||
.ui-icon-check { background-position: -64px -144px; }
|
||||
.ui-icon-bullet { background-position: -80px -144px; }
|
||||
.ui-icon-radio-off { background-position: -96px -144px; }
|
||||
.ui-icon-radio-on { background-position: -112px -144px; }
|
||||
.ui-icon-pin-w { background-position: -128px -144px; }
|
||||
.ui-icon-pin-s { background-position: -144px -144px; }
|
||||
.ui-icon-play { background-position: 0 -160px; }
|
||||
.ui-icon-pause { background-position: -16px -160px; }
|
||||
.ui-icon-seek-next { background-position: -32px -160px; }
|
||||
.ui-icon-seek-prev { background-position: -48px -160px; }
|
||||
.ui-icon-seek-end { background-position: -64px -160px; }
|
||||
.ui-icon-seek-start { background-position: -80px -160px; }
|
||||
/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
|
||||
.ui-icon-seek-first { background-position: -80px -160px; }
|
||||
.ui-icon-stop { background-position: -96px -160px; }
|
||||
.ui-icon-eject { background-position: -112px -160px; }
|
||||
.ui-icon-volume-off { background-position: -128px -160px; }
|
||||
.ui-icon-volume-on { background-position: -144px -160px; }
|
||||
.ui-icon-power { background-position: 0 -176px; }
|
||||
.ui-icon-signal-diag { background-position: -16px -176px; }
|
||||
.ui-icon-signal { background-position: -32px -176px; }
|
||||
.ui-icon-battery-0 { background-position: -48px -176px; }
|
||||
.ui-icon-battery-1 { background-position: -64px -176px; }
|
||||
.ui-icon-battery-2 { background-position: -80px -176px; }
|
||||
.ui-icon-battery-3 { background-position: -96px -176px; }
|
||||
.ui-icon-circle-plus { background-position: 0 -192px; }
|
||||
.ui-icon-circle-minus { background-position: -16px -192px; }
|
||||
.ui-icon-circle-close { background-position: -32px -192px; }
|
||||
.ui-icon-circle-triangle-e { background-position: -48px -192px; }
|
||||
.ui-icon-circle-triangle-s { background-position: -64px -192px; }
|
||||
.ui-icon-circle-triangle-w { background-position: -80px -192px; }
|
||||
.ui-icon-circle-triangle-n { background-position: -96px -192px; }
|
||||
.ui-icon-circle-arrow-e { background-position: -112px -192px; }
|
||||
.ui-icon-circle-arrow-s { background-position: -128px -192px; }
|
||||
.ui-icon-circle-arrow-w { background-position: -144px -192px; }
|
||||
.ui-icon-circle-arrow-n { background-position: -160px -192px; }
|
||||
.ui-icon-circle-zoomin { background-position: -176px -192px; }
|
||||
.ui-icon-circle-zoomout { background-position: -192px -192px; }
|
||||
.ui-icon-circle-check { background-position: -208px -192px; }
|
||||
.ui-icon-circlesmall-plus { background-position: 0 -208px; }
|
||||
.ui-icon-circlesmall-minus { background-position: -16px -208px; }
|
||||
.ui-icon-circlesmall-close { background-position: -32px -208px; }
|
||||
.ui-icon-squaresmall-plus { background-position: -48px -208px; }
|
||||
.ui-icon-squaresmall-minus { background-position: -64px -208px; }
|
||||
.ui-icon-squaresmall-close { background-position: -80px -208px; }
|
||||
.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
|
||||
.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
|
||||
.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
|
||||
.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
|
||||
.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
|
||||
.ui-icon-grip-diagonal-se { background-position: -80px -224px; }
|
||||
|
||||
|
||||
/* Misc visuals
|
||||
----------------------------------*/
|
||||
|
||||
/* Corner radius */
|
||||
.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; -khtml-border-top-left-radius: 4px; border-top-left-radius: 4px; }
|
||||
.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; -khtml-border-top-right-radius: 4px; border-top-right-radius: 4px; }
|
||||
.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; -khtml-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; }
|
||||
.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; -khtml-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; }
|
||||
|
||||
/* Overlays */
|
||||
.ui-widget-overlay { background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .30;filter:Alpha(Opacity=30); }
|
||||
.ui-widget-shadow { margin: -8px 0 0 -8px; padding: 8px; background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .30;filter:Alpha(Opacity=30); -moz-border-radius: 8px; -khtml-border-radius: 8px; -webkit-border-radius: 8px; border-radius: 8px; }/*!
|
||||
* jQuery UI Resizable 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Resizable#theming
|
||||
*/
|
||||
.ui-resizable { position: relative;}
|
||||
.ui-resizable-handle { position: absolute;font-size: 0.1px; display: block; }
|
||||
.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; }
|
||||
.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; }
|
||||
.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; }
|
||||
.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; }
|
||||
.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; }
|
||||
.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; }
|
||||
.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; }
|
||||
.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; }
|
||||
.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/*!
|
||||
* jQuery UI Selectable 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Selectable#theming
|
||||
*/
|
||||
.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; }
|
||||
/*!
|
||||
* jQuery UI Accordion 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Accordion#theming
|
||||
*/
|
||||
/* IE/Win - Fix animation bug - #4615 */
|
||||
.ui-accordion { width: 100%; }
|
||||
.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; }
|
||||
.ui-accordion .ui-accordion-li-fix { display: inline; }
|
||||
.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; }
|
||||
.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; }
|
||||
.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; }
|
||||
.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; }
|
||||
.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; }
|
||||
.ui-accordion .ui-accordion-content-active { display: block; }
|
||||
/*!
|
||||
* jQuery UI Autocomplete 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Autocomplete#theming
|
||||
*/
|
||||
.ui-autocomplete { position: absolute; cursor: default; }
|
||||
|
||||
/* workarounds */
|
||||
* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */
|
||||
|
||||
/*
|
||||
* jQuery UI Menu 1.8.20
|
||||
*
|
||||
* Copyright 2010, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Menu#theming
|
||||
*/
|
||||
.ui-menu {
|
||||
list-style:none;
|
||||
padding: 2px;
|
||||
margin: 0;
|
||||
display:block;
|
||||
float: left;
|
||||
}
|
||||
.ui-menu .ui-menu {
|
||||
margin-top: -3px;
|
||||
}
|
||||
.ui-menu .ui-menu-item {
|
||||
margin:0;
|
||||
padding: 0;
|
||||
zoom: 1;
|
||||
float: left;
|
||||
clear: left;
|
||||
width: 100%;
|
||||
}
|
||||
.ui-menu .ui-menu-item a {
|
||||
text-decoration:none;
|
||||
display:block;
|
||||
padding:.2em .4em;
|
||||
line-height:1.5;
|
||||
zoom:1;
|
||||
}
|
||||
.ui-menu .ui-menu-item a.ui-state-hover,
|
||||
.ui-menu .ui-menu-item a.ui-state-active {
|
||||
font-weight: normal;
|
||||
margin: -1px;
|
||||
}
|
||||
/*!
|
||||
* jQuery UI Button 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Button#theming
|
||||
*/
|
||||
.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */
|
||||
.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */
|
||||
button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */
|
||||
.ui-button-icons-only { width: 3.4em; }
|
||||
button.ui-button-icons-only { width: 3.7em; }
|
||||
|
||||
/*button text element */
|
||||
.ui-button .ui-button-text { display: block; line-height: 1.4; }
|
||||
.ui-button-text-only .ui-button-text { padding: .4em 1em; }
|
||||
.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; }
|
||||
.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; }
|
||||
.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; }
|
||||
.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; }
|
||||
/* no icon support for input elements, provide padding by default */
|
||||
input.ui-button { padding: .4em 1em; }
|
||||
|
||||
/*button icon element(s) */
|
||||
.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; }
|
||||
.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; }
|
||||
.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; }
|
||||
.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
|
||||
.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; }
|
||||
|
||||
/*button sets*/
|
||||
.ui-buttonset { margin-right: 7px; }
|
||||
.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; }
|
||||
|
||||
/* workarounds */
|
||||
button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */
|
||||
/*!
|
||||
* jQuery UI Dialog 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Dialog#theming
|
||||
*/
|
||||
.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; }
|
||||
.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; }
|
||||
.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; }
|
||||
.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; }
|
||||
.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; }
|
||||
.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; }
|
||||
.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; }
|
||||
.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; }
|
||||
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; }
|
||||
.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; }
|
||||
.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; }
|
||||
.ui-draggable .ui-dialog-titlebar { cursor: move; }
|
||||
/*!
|
||||
* jQuery UI Slider 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Slider#theming
|
||||
*/
|
||||
.ui-slider { position: relative; text-align: left; }
|
||||
.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; }
|
||||
.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; }
|
||||
|
||||
.ui-slider-horizontal { height: .8em; }
|
||||
.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; }
|
||||
.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; }
|
||||
.ui-slider-horizontal .ui-slider-range-min { left: 0; }
|
||||
.ui-slider-horizontal .ui-slider-range-max { right: 0; }
|
||||
|
||||
.ui-slider-vertical { width: .8em; height: 100px; }
|
||||
.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; }
|
||||
.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; }
|
||||
.ui-slider-vertical .ui-slider-range-min { bottom: 0; }
|
||||
.ui-slider-vertical .ui-slider-range-max { top: 0; }/*!
|
||||
* jQuery UI Tabs 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Tabs#theming
|
||||
*/
|
||||
.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
|
||||
.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; }
|
||||
.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; }
|
||||
.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; }
|
||||
.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; }
|
||||
.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; }
|
||||
.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */
|
||||
.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; }
|
||||
.ui-tabs .ui-tabs-hide { display: none !important; }
|
||||
/*!
|
||||
* jQuery UI Datepicker 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Datepicker#theming
|
||||
*/
|
||||
.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; }
|
||||
.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; }
|
||||
.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
|
||||
.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
|
||||
.ui-datepicker .ui-datepicker-prev { left:2px; }
|
||||
.ui-datepicker .ui-datepicker-next { right:2px; }
|
||||
.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
|
||||
.ui-datepicker .ui-datepicker-next-hover { right:1px; }
|
||||
.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; }
|
||||
.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
|
||||
.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; }
|
||||
.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
|
||||
.ui-datepicker select.ui-datepicker-month,
|
||||
.ui-datepicker select.ui-datepicker-year { width: 49%;}
|
||||
.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
|
||||
.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; }
|
||||
.ui-datepicker td { border: 0; padding: 1px; }
|
||||
.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; }
|
||||
.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; }
|
||||
.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
|
||||
.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }
|
||||
|
||||
/* with multiple calendars */
|
||||
.ui-datepicker.ui-datepicker-multi { width:auto; }
|
||||
.ui-datepicker-multi .ui-datepicker-group { float:left; }
|
||||
.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
|
||||
.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
|
||||
.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
|
||||
.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
|
||||
.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
|
||||
.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
|
||||
.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
|
||||
.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; }
|
||||
|
||||
/* RTL support */
|
||||
.ui-datepicker-rtl { direction: rtl; }
|
||||
.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
|
||||
.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
|
||||
.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
|
||||
.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
|
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
|
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
|
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
|
||||
.ui-datepicker-rtl .ui-datepicker-group { float:right; }
|
||||
.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
|
||||
.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
|
||||
|
||||
/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
|
||||
.ui-datepicker-cover {
|
||||
display: none; /*sorry for IE5*/
|
||||
display/**/: block; /*sorry for IE5*/
|
||||
position: absolute; /*must have*/
|
||||
z-index: -1; /*must have*/
|
||||
filter: mask(); /*must have*/
|
||||
top: -4px; /*must have*/
|
||||
left: -4px; /*must have*/
|
||||
width: 200px; /*must have*/
|
||||
height: 200px; /*must have*/
|
||||
}/*!
|
||||
* jQuery UI Progressbar 1.8.20
|
||||
*
|
||||
* Copyright 2012, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Progressbar#theming
|
||||
*/
|
||||
.ui-progressbar { height:2em; text-align: left; overflow: hidden; }
|
||||
.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; }
|
||||