angular2
Version:
Angular 2 - a web framework for modern web apps
114 lines • 15.6 kB
JavaScript
"use strict";
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var dom_adapter_1 = require('angular2/src/platform/dom/dom_adapter');
var lang_1 = require('angular2/src/facade/lang');
var collection_1 = require('angular2/src/facade/collection');
var event_manager_1 = require('./event_manager');
var di_1 = require('angular2/src/core/di');
var modifierKeys = ['alt', 'control', 'meta', 'shift'];
var modifierKeyGetters = {
'alt': function (event) { return event.altKey; },
'control': function (event) { return event.ctrlKey; },
'meta': function (event) { return event.metaKey; },
'shift': function (event) { return event.shiftKey; }
};
var KeyEventsPlugin = (function (_super) {
__extends(KeyEventsPlugin, _super);
function KeyEventsPlugin() {
_super.call(this);
}
KeyEventsPlugin.prototype.supports = function (eventName) {
return lang_1.isPresent(KeyEventsPlugin.parseEventName(eventName));
};
KeyEventsPlugin.prototype.addEventListener = function (element, eventName, handler) {
var parsedEvent = KeyEventsPlugin.parseEventName(eventName);
var outsideHandler = KeyEventsPlugin.eventCallback(element, collection_1.StringMapWrapper.get(parsedEvent, 'fullKey'), handler, this.manager.getZone());
return this.manager.getZone().runOutsideAngular(function () {
return dom_adapter_1.DOM.onAndCancel(element, collection_1.StringMapWrapper.get(parsedEvent, 'domEventName'), outsideHandler);
});
};
KeyEventsPlugin.parseEventName = function (eventName) {
var parts = eventName.toLowerCase().split('.');
var domEventName = parts.shift();
if ((parts.length === 0) ||
!(lang_1.StringWrapper.equals(domEventName, 'keydown') ||
lang_1.StringWrapper.equals(domEventName, 'keyup'))) {
return null;
}
var key = KeyEventsPlugin._normalizeKey(parts.pop());
var fullKey = '';
modifierKeys.forEach(function (modifierName) {
if (collection_1.ListWrapper.contains(parts, modifierName)) {
collection_1.ListWrapper.remove(parts, modifierName);
fullKey += modifierName + '.';
}
});
fullKey += key;
if (parts.length != 0 || key.length === 0) {
// returning null instead of throwing to let another plugin process the event
return null;
}
var result = collection_1.StringMapWrapper.create();
collection_1.StringMapWrapper.set(result, 'domEventName', domEventName);
collection_1.StringMapWrapper.set(result, 'fullKey', fullKey);
return result;
};
KeyEventsPlugin.getEventFullKey = function (event) {
var fullKey = '';
var key = dom_adapter_1.DOM.getEventKey(event);
key = key.toLowerCase();
if (lang_1.StringWrapper.equals(key, ' ')) {
key = 'space'; // for readability
}
else if (lang_1.StringWrapper.equals(key, '.')) {
key = 'dot'; // because '.' is used as a separator in event names
}
modifierKeys.forEach(function (modifierName) {
if (modifierName != key) {
var modifierGetter = collection_1.StringMapWrapper.get(modifierKeyGetters, modifierName);
if (modifierGetter(event)) {
fullKey += modifierName + '.';
}
}
});
fullKey += key;
return fullKey;
};
KeyEventsPlugin.eventCallback = function (element, fullKey, handler, zone) {
return function (event) {
if (lang_1.StringWrapper.equals(KeyEventsPlugin.getEventFullKey(event), fullKey)) {
zone.runGuarded(function () { return handler(event); });
}
};
};
/** @internal */
KeyEventsPlugin._normalizeKey = function (keyName) {
// TODO: switch to a StringMap if the mapping grows too much
switch (keyName) {
case 'esc':
return 'escape';
default:
return keyName;
}
};
KeyEventsPlugin = __decorate([
di_1.Injectable(),
__metadata('design:paramtypes', [])
], KeyEventsPlugin);
return KeyEventsPlugin;
}(event_manager_1.EventManagerPlugin));
exports.KeyEventsPlugin = KeyEventsPlugin;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key_events.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-BRJer1J9.tmp/angular2/src/platform/dom/events/key_events.ts"],"names":[],"mappings":"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","sourcesContent":["import {DOM} from 'angular2/src/platform/dom/dom_adapter';\nimport {\n  isPresent,\n  isBlank,\n  StringWrapper,\n  RegExpWrapper,\n  NumberWrapper\n} from 'angular2/src/facade/lang';\nimport {StringMapWrapper, ListWrapper} from 'angular2/src/facade/collection';\nimport {EventManagerPlugin} from './event_manager';\nimport {NgZone} from 'angular2/src/core/zone/ng_zone';\nimport {Injectable} from 'angular2/src/core/di';\n\nvar modifierKeys = ['alt', 'control', 'meta', 'shift'];\nvar modifierKeyGetters: {[key: string]: (event: KeyboardEvent) => boolean} = {\n  'alt': (event: KeyboardEvent) => event.altKey,\n  'control': (event: KeyboardEvent) => event.ctrlKey,\n  'meta': (event: KeyboardEvent) => event.metaKey,\n  'shift': (event: KeyboardEvent) => event.shiftKey\n};\n\n@Injectable()\nexport class KeyEventsPlugin extends EventManagerPlugin {\n  constructor() { super(); }\n\n  supports(eventName: string): boolean {\n    return isPresent(KeyEventsPlugin.parseEventName(eventName));\n  }\n\n  addEventListener(element: HTMLElement, eventName: string, handler: Function): Function {\n    var parsedEvent = KeyEventsPlugin.parseEventName(eventName);\n\n    var outsideHandler = KeyEventsPlugin.eventCallback(\n        element, StringMapWrapper.get(parsedEvent, 'fullKey'), handler, this.manager.getZone());\n\n    return this.manager.getZone().runOutsideAngular(() => {\n      return DOM.onAndCancel(element, StringMapWrapper.get(parsedEvent, 'domEventName'),\n                             outsideHandler);\n    });\n  }\n\n  static parseEventName(eventName: string): {[key: string]: string} {\n    var parts: string[] = eventName.toLowerCase().split('.');\n\n    var domEventName = parts.shift();\n    if ((parts.length === 0) ||\n        !(StringWrapper.equals(domEventName, 'keydown') ||\n          StringWrapper.equals(domEventName, 'keyup'))) {\n      return null;\n    }\n\n    var key = KeyEventsPlugin._normalizeKey(parts.pop());\n\n    var fullKey = '';\n    modifierKeys.forEach(modifierName => {\n      if (ListWrapper.contains(parts, modifierName)) {\n        ListWrapper.remove(parts, modifierName);\n        fullKey += modifierName + '.';\n      }\n    });\n    fullKey += key;\n\n    if (parts.length != 0 || key.length === 0) {\n      // returning null instead of throwing to let another plugin process the event\n      return null;\n    }\n    var result = StringMapWrapper.create();\n    StringMapWrapper.set(result, 'domEventName', domEventName);\n    StringMapWrapper.set(result, 'fullKey', fullKey);\n    return result;\n  }\n\n  static getEventFullKey(event: KeyboardEvent): string {\n    var fullKey = '';\n    var key = DOM.getEventKey(event);\n    key = key.toLowerCase();\n    if (StringWrapper.equals(key, ' ')) {\n      key = 'space';  // for readability\n    } else if (StringWrapper.equals(key, '.')) {\n      key = 'dot';  // because '.' is used as a separator in event names\n    }\n    modifierKeys.forEach(modifierName => {\n      if (modifierName != key) {\n        var modifierGetter = StringMapWrapper.get(modifierKeyGetters, modifierName);\n        if (modifierGetter(event)) {\n          fullKey += modifierName + '.';\n        }\n      }\n    });\n    fullKey += key;\n    return fullKey;\n  }\n\n  static eventCallback(element: HTMLElement, fullKey: any, handler: Function,\n                       zone: NgZone): Function {\n    return (event) => {\n      if (StringWrapper.equals(KeyEventsPlugin.getEventFullKey(event), fullKey)) {\n        zone.runGuarded(() => handler(event));\n      }\n    };\n  }\n\n  /** @internal */\n  static _normalizeKey(keyName: string): string {\n    // TODO: switch to a StringMap if the mapping grows too much\n    switch (keyName) {\n      case 'esc':\n        return 'escape';\n      default:\n        return keyName;\n    }\n  }\n}\n"]}
;