UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

113 lines 16.6 kB
'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.run(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":["angular2/src/platform/dom/events/key_events.ts"],"names":["KeyEventsPlugin","KeyEventsPlugin.constructor","KeyEventsPlugin.supports","KeyEventsPlugin.addEventListener","KeyEventsPlugin.parseEventName","KeyEventsPlugin.getEventFullKey","KeyEventsPlugin.eventCallback","KeyEventsPlugin._normalizeKey"],"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.run(() => 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"]}