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