| 
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80 | 
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
 | 
-
-
+
+
 | 
### Open the Grammalecte panel for a node
If you have disabled the spinning button, you can launch the Grammalecte panel with your custom button.
    oGrammalecteAPI.openPanelForNode("node_id")
    oGrammalecteAPI.openPanelForNode(node)
The node can be a textarea, an editable node or an iframe.
If the node is an iframe, the content won’t be modified by Grammalecte.
The node can be a textarea, an editable node or an iframe. **The node must have an identifier**.
If the node is an iframe, the content won’t be modified by Grammalecte, but events with results may be received (see below).
### Prevent Grammalecte to modify the node content
If you don’t want Grammalecte to modify directly the node content, add the property: `data-grammalecte_result_via_event="true"`.
With this property, Grammalecte will send an event to the node each times the text is modified within the panel. | 
| 
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124125
126
127
128
129
130
131
132
133 | 
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
 | 
-
+
-
+
-
+
 | 
### Open the Grammalecte panel for any text
    oGrammalecteAPI.openPanelForText("your text")
    oGrammalecteAPI.openPanelForText("your text", "node_id")
    oGrammalecteAPI.openPanelForText("your text", node)
With the second parameter, Grammalecte will send an event to the node each times the text is modified within the panel.
With the second parameter, Grammalecte will send an event to the node each times the text is modified within the panel. **The node must have an identifier**.
### Parse a node and get errors
    oGrammalecteAPI.parseNode("node_id")
    oGrammalecteAPI.parseNode(node)The node can be a textarea, an editable node or an iframe. The node must have an identifier.
The node can be a textarea, an editable node or an iframe. **The node must have an identifier**.
Results (for each paragraph) will be sent in a succession of events at the node.
    node.addEventListener("GrammalecteResult", function (event) {
        const detail = (typeof(event.detail) === 'string') && JSON.parse(event.detail);
        if (detail.sType  &&  detail.sType == "proofreading") {
            let oResult = detail.oResult; // null when the text parsing is finished
            ...
        }
    }
For the last event, `oResult` will be `null`.
### Parse text and get errors
    oGrammalecteAPI.parseText("your text", "node_id")
    oGrammalecteAPI.parseText("your text", node)Like with `oGrammalecteAPI.parseNode()`, results (for each paragraph) will be sent in a succession of events at the node.
**The node must have an identifier**.
### Get spelling suggestions
    oGrammalecteAPI.getSpellingSuggestions(word, destination)
    oGrammalecteAPI.getSpellingSuggestions(word, destination, request_identifier)The node must have an identifier. |