123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- <html>
- <head>
- </head>
- <body>
- <script>(function(){
- var props = {};
- function addObject(obj) {
- if (obj == null) return;
- try {
- Object.getOwnPropertyNames(obj).forEach(add);
- } catch(ex) {}
- if (obj.prototype) {
- Object.getOwnPropertyNames(obj.prototype).forEach(add);
- }
- if (typeof obj == "function") {
- try {
- Object.getOwnPropertyNames(new obj).forEach(add);
- } catch(ex) {}
- }
- }
- function add(name) {
- props[name] = true;
- }
- Object.getOwnPropertyNames(window).forEach(function(thing){
- addObject(window[thing]);
- });
- try {
- addObject(new Event("click"));
- addObject(new Event("contextmenu"));
- addObject(new Event("mouseup"));
- addObject(new Event("mousedown"));
- addObject(new Event("keydown"));
- addObject(new Event("keypress"));
- addObject(new Event("keyup"));
- addObject(new Event("input"));
- addObject(new Event("touchstart"));
- addObject(new Event("touchmove"));
- addObject(new Event("touchend"));
- addObject(new Event("touchcancel"));
- addObject(new Event("pointerdown"));
- addObject(new Event("pointermove"));
- addObject(new Event("pointerup"));
- addObject(new Event("pointercancel"));
- addObject(new Event("pointerenter"));
- addObject(new Event("pointerleave"));
- } catch(ex) {}
- var ta = document.createElement("textarea");
- ta.style.width = "100%";
- ta.style.height = "20em";
- ta.style.boxSizing = "border-box";
- ta.value = 'export var domprops = ' + JSON.stringify(Object.keys(props).sort(cmp), null, 4);
- document.body.appendChild(ta);
- function cmp(a, b) {
- a = a.toLowerCase();
- b = b.toLowerCase();
- return a < b ? -1 : a > b ? 1 : 0;
- }
- })();</script>
- </body>
- </html>
|