2010-04-01 00:56:16 +00:00
|
|
|
angularService("$window", bind(window, identity, window));
|
2010-04-04 00:04:36 +00:00
|
|
|
angularService("$document", function(window){
|
|
|
|
|
return jqLite(window.document);
|
|
|
|
|
}, {inject:['$window']});
|
2010-04-01 00:56:16 +00:00
|
|
|
|
2010-04-02 18:10:36 +00:00
|
|
|
var URL_MATCH = /^(file|ftp|http|https):\/\/(\w+:{0,1}\w*@)?([\w\.]*)(:([0-9]+))?([^\?#]+)(\?([^#]*))?((#([^\?]*))?(\?([^\?]*))?)$/;
|
|
|
|
|
var DEFAULT_PORTS = {'http': 80, 'https': 443, 'ftp':21};
|
2010-04-04 00:04:36 +00:00
|
|
|
angularService("$location", function(browser){
|
2010-04-05 18:46:53 +00:00
|
|
|
var scope = this, location = {parse:parse, toString:toString};
|
|
|
|
|
function parse(url){
|
2010-04-01 00:56:16 +00:00
|
|
|
if (isDefined(url)) {
|
2010-04-01 21:10:28 +00:00
|
|
|
var match = URL_MATCH.exec(url);
|
2010-04-02 18:10:36 +00:00
|
|
|
if (match) {
|
|
|
|
|
location.href = url;
|
|
|
|
|
location.protocol = match[1];
|
|
|
|
|
location.host = match[3] || '';
|
|
|
|
|
location.port = match[5] || DEFAULT_PORTS[location.href] || null;
|
|
|
|
|
location.path = match[6];
|
|
|
|
|
location.search = parseKeyValue(match[8]);
|
|
|
|
|
location.hash = match[9];
|
|
|
|
|
if (location.hash) location.hash = location.hash.substr(1);
|
|
|
|
|
location.hashPath = match[11] || '';
|
|
|
|
|
location.hashSearch = parseKeyValue(match[13]);
|
|
|
|
|
}
|
2010-04-01 00:56:16 +00:00
|
|
|
}
|
2010-04-05 18:46:53 +00:00
|
|
|
}
|
|
|
|
|
function toString() {
|
|
|
|
|
var hashKeyValue = toKeyValue(location.hashSearch),
|
|
|
|
|
hash = (location.hashPath ? location.hashPath : '') + (hashKeyValue ? '?' + hashKeyValue : '');
|
2010-04-04 03:19:55 +00:00
|
|
|
return location.href.split('#')[0] + '#' + (hash ? hash : '');
|
2010-04-04 00:04:36 +00:00
|
|
|
}
|
|
|
|
|
browser.watchUrl(function(url){
|
2010-04-05 18:46:53 +00:00
|
|
|
parse(url);
|
|
|
|
|
scope.$root.$eval();
|
2010-04-01 00:56:16 +00:00
|
|
|
});
|
2010-04-05 18:46:53 +00:00
|
|
|
parse(browser.getUrl());
|
2010-04-01 00:56:16 +00:00
|
|
|
this.$onEval(PRIORITY_LAST, function(){
|
2010-04-05 18:46:53 +00:00
|
|
|
var href = toString();
|
2010-04-02 18:10:36 +00:00
|
|
|
if (href != location.href) {
|
2010-04-04 00:04:36 +00:00
|
|
|
browser.setUrl(href);
|
2010-04-02 18:10:36 +00:00
|
|
|
location.href = href;
|
|
|
|
|
}
|
2010-04-01 00:56:16 +00:00
|
|
|
});
|
2010-04-01 21:10:28 +00:00
|
|
|
return location;
|
2010-04-04 00:04:36 +00:00
|
|
|
}, {inject: ['$browser']});
|
|
|
|
|
|
2010-04-06 03:53:33 +00:00
|
|
|
angularService("$hover", function(browser) {
|
|
|
|
|
var tooltip, self = this, error, width = 300, arrowWidth = 10;
|
|
|
|
|
browser.hover(function(element, show){
|
2010-04-08 00:24:24 +00:00
|
|
|
if (show && (error = element.attr(NG_EXCEPTION) || element.attr(NG_VALIDATION_ERROR))) {
|
2010-04-06 03:53:33 +00:00
|
|
|
if (!tooltip) {
|
|
|
|
|
tooltip = {
|
|
|
|
|
callout: jqLite('<div id="ng-callout"></div>'),
|
|
|
|
|
arrow: jqLite('<div></div>'),
|
|
|
|
|
title: jqLite('<div class="ng-title"></div>'),
|
|
|
|
|
content: jqLite('<div class="ng-content"></div>')
|
|
|
|
|
};
|
|
|
|
|
tooltip.callout.append(tooltip.arrow);
|
|
|
|
|
tooltip.callout.append(tooltip.title);
|
|
|
|
|
tooltip.callout.append(tooltip.content);
|
|
|
|
|
self.$browser.body.append(tooltip.callout);
|
|
|
|
|
}
|
|
|
|
|
var docRect = self.$browser.body[0].getBoundingClientRect(),
|
|
|
|
|
elementRect = element[0].getBoundingClientRect(),
|
|
|
|
|
leftSpace = docRect.right - elementRect.right - arrowWidth;
|
|
|
|
|
tooltip.title.text(element.hasClass("ng-exception") ? "EXCEPTION:" : "Validation error...");
|
|
|
|
|
tooltip.content.text(error);
|
|
|
|
|
if (leftSpace < width) {
|
|
|
|
|
tooltip.arrow.addClass('ng-arrow-right');
|
|
|
|
|
tooltip.arrow.css({left: (width + 1)+'px'});
|
|
|
|
|
tooltip.callout.css({
|
|
|
|
|
left: (elementRect.left - arrowWidth - width - 4) + "px",
|
|
|
|
|
top: (elementRect.top - 3) + "px",
|
|
|
|
|
width: width + "px"
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
tooltip.arrow.addClass('ng-arrow-left');
|
|
|
|
|
tooltip.callout.css({
|
|
|
|
|
left: (elementRect.right + arrowWidth) + "px",
|
|
|
|
|
top: (elementRect.top - 3) + "px",
|
|
|
|
|
width: width + "px"
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
} else if (tooltip) {
|
|
|
|
|
tooltip.callout.remove();
|
|
|
|
|
tooltip = null;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}, {inject:['$browser']});
|
2010-04-07 21:13:10 +00:00
|
|
|
|
|
|
|
|
angularService("$invalidWidgets", function(){
|
|
|
|
|
var invalidWidgets = [];
|
|
|
|
|
invalidWidgets.markValid = function(element){
|
|
|
|
|
var index = indexOf(invalidWidgets, element);
|
|
|
|
|
if (index != -1)
|
|
|
|
|
invalidWidgets.splice(index, 1);
|
|
|
|
|
};
|
|
|
|
|
invalidWidgets.markInvalid = function(element){
|
|
|
|
|
var index = indexOf(invalidWidgets, element);
|
|
|
|
|
if (index === -1)
|
|
|
|
|
invalidWidgets.push(element);
|
|
|
|
|
};
|
|
|
|
|
return invalidWidgets;
|
|
|
|
|
});
|