View Javadoc
1   /*
2    * Copyright (c) 2002-2025 Gargoyle Software Inc.
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    * https://www.apache.org/licenses/LICENSE-2.0
8    *
9    * Unless required by applicable law or agreed to in writing, software
10   * distributed under the License is distributed on an "AS IS" BASIS,
11   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12   * See the License for the specific language governing permissions and
13   * limitations under the License.
14   */
15  package org.htmlunit.javascript.host.event;
16  
17  import static org.htmlunit.javascript.configuration.SupportedBrowser.FF;
18  import static org.htmlunit.javascript.configuration.SupportedBrowser.FF_ESR;
19  
20  import org.htmlunit.corejs.javascript.ScriptableObject;
21  import org.htmlunit.javascript.JavaScriptEngine;
22  import org.htmlunit.javascript.configuration.JsxClass;
23  import org.htmlunit.javascript.configuration.JsxConstant;
24  import org.htmlunit.javascript.configuration.JsxConstructor;
25  
26  /**
27   * JavaScript object representing a Mutation Event.
28   * For general information on which properties and functions should be supported, see
29   * <a href="http://www.w3.org/TR/DOM-Level-2-Events/events.html#Events-MutationEvent">
30   * DOM Level 2 Events</a>.
31   *
32   * @author Ahmed Ashour
33   * @author Ronald Brill
34   */
35  @JsxClass(FF_ESR)
36  @JsxClass(value = FF, isJSObject = false)
37  public class MutationEvent extends Event {
38  
39      /** Modification. */
40      @JsxConstant
41      public static final int MODIFICATION = 1;
42  
43      /** Addition. */
44      @JsxConstant
45      public static final int ADDITION = 2;
46  
47      /** Removal. */
48      @JsxConstant
49      public static final int REMOVAL = 3;
50  
51      /**
52       * JavaScript constructor.
53       *
54       * @param type the event type
55       * @param details the event details (optional)
56       */
57      @Override
58      @JsxConstructor
59      public void jsConstructor(final String type, final ScriptableObject details) {
60          throw JavaScriptEngine.typeError("Illegal constructor call for MutationEvent");
61      }
62  }