1 |
|
2 | define([
|
3 | 'require',
|
4 | 'exports',
|
5 | 'module',
|
6 | './synthetic',
|
7 | './mouse'
|
8 | ], function (require, exports, module) {
|
9 | var syn = require('./synthetic');
|
10 | require('./mouse');
|
11 | (function checkSupport() {
|
12 | if (!document.body) {
|
13 | return syn.schedule(checkSupport, 1);
|
14 | }
|
15 | window.__synthTest = function () {
|
16 | syn.support.linkHrefJS = true;
|
17 | };
|
18 | var div = document.createElement('div'), checkbox, submit, form, select;
|
19 | div.innerHTML = '<form id=\'outer\'>' + '<input name=\'checkbox\' type=\'checkbox\'/>' + '<input name=\'radio\' type=\'radio\' />' + '<input type=\'submit\' name=\'submitter\'/>' + '<input type=\'input\' name=\'inputter\'/>' + '<input name=\'one\'>' + '<input name=\'two\'/>' + '<a href=\'javascript:__synthTest()\' id=\'synlink\'></a>' + '<select><option></option></select>' + '</form>';
|
20 | document.documentElement.appendChild(div);
|
21 | form = div.firstChild;
|
22 | checkbox = form.childNodes[0];
|
23 | submit = form.childNodes[2];
|
24 | select = form.getElementsByTagName('select')[0];
|
25 | syn.trigger(form.childNodes[6], 'click', {});
|
26 | checkbox.checked = false;
|
27 | checkbox.onchange = function () {
|
28 | syn.support.clickChanges = true;
|
29 | };
|
30 | syn.trigger(checkbox, 'click', {});
|
31 | syn.support.clickChecks = checkbox.checked;
|
32 | checkbox.checked = false;
|
33 | syn.trigger(checkbox, 'change', {});
|
34 | syn.support.changeChecks = checkbox.checked;
|
35 | form.onsubmit = function (ev) {
|
36 | if (ev.preventDefault) {
|
37 | ev.preventDefault();
|
38 | }
|
39 | syn.support.clickSubmits = true;
|
40 | return false;
|
41 | };
|
42 | syn.trigger(submit, 'click', {});
|
43 | form.childNodes[1].onchange = function () {
|
44 | syn.support.radioClickChanges = true;
|
45 | };
|
46 | syn.trigger(form.childNodes[1], 'click', {});
|
47 | syn.bind(div, 'click', function onclick() {
|
48 | syn.support.optionClickBubbles = true;
|
49 | syn.unbind(div, 'click', onclick);
|
50 | });
|
51 | syn.trigger(select.firstChild, 'click', {});
|
52 | syn.support.changeBubbles = syn.eventSupported('change');
|
53 | div.onclick = function () {
|
54 | syn.support.mouseDownUpClicks = true;
|
55 | };
|
56 | syn.trigger(div, 'mousedown', {});
|
57 | syn.trigger(div, 'mouseup', {});
|
58 | document.documentElement.removeChild(div);
|
59 | syn.support.pointerEvents = syn.eventSupported('pointerdown');
|
60 | syn.support.touchEvents = syn.eventSupported('touchstart');
|
61 | syn.support.ready++;
|
62 | }());
|
63 | }); |
\ | No newline at end of file |