/* vim: set ft=javascript ts=2 et sw=2 tw=80: */ /* Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ */ "use strict"; // Tests that a disabled property remains disabled when the escaping out of // the property editor. const TEST_URI = `
Styled Node
`; add_task(function* () { yield addTab("data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI)); let {inspector, view} = yield openRuleView(); yield selectNode("#testid", inspector); let rule = getRuleViewRuleEditor(view, 1).rule; let prop = rule.textProps[0]; info("Disabling a property"); yield togglePropStatus(view, prop); let newValue = yield executeInContent("Test:GetRulePropertyValue", { styleSheetIndex: 0, ruleIndex: 0, name: "background-color" }); is(newValue, "", "background-color should have been unset."); yield testEditDisableProperty(view, rule, prop, "name", "VK_ESCAPE"); yield testEditDisableProperty(view, rule, prop, "value", "VK_ESCAPE"); yield testEditDisableProperty(view, rule, prop, "value", "VK_TAB"); yield testEditDisableProperty(view, rule, prop, "value", "VK_RETURN"); }); function* testEditDisableProperty(view, rule, prop, fieldType, commitKey) { let field = fieldType === "name" ? prop.editor.nameSpan : prop.editor.valueSpan; let editor = yield focusEditableField(view, field); ok(!prop.editor.element.classList.contains("ruleview-overridden"), "property is not overridden."); is(prop.editor.enable.style.visibility, "hidden", "property enable checkbox is hidden."); let newValue = yield executeInContent("Test:GetRulePropertyValue", { styleSheetIndex: 0, ruleIndex: 0, name: "background-color" }); is(newValue, "", "background-color should remain unset."); let onChangeDone; if (fieldType === "value") { onChangeDone = view.once("ruleview-changed"); } let onBlur = once(editor.input, "blur"); EventUtils.synthesizeKey(commitKey, {}, view.styleWindow); yield onBlur; yield onChangeDone; ok(!prop.enabled, "property is disabled."); ok(prop.editor.element.classList.contains("ruleview-overridden"), "property is overridden."); is(prop.editor.enable.style.visibility, "visible", "property enable checkbox is visible."); ok(!prop.editor.enable.getAttribute("checked"), "property enable checkbox is not checked."); newValue = yield executeInContent("Test:GetRulePropertyValue", { styleSheetIndex: 0, ruleIndex: 0, name: "background-color" }); is(newValue, "", "background-color should remain unset."); }