forked from phcode-dev/staging.phcode.dev
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathInlineWidget.js
More file actions
104 lines (89 loc) · 3.43 KB
/
InlineWidget.js
File metadata and controls
104 lines (89 loc) · 3.43 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/*
* GNU AGPL-3.0 License
*
* Copyright (c) 2021 - present core.ai . All rights reserved.
* Original work Copyright (c) 2012 - 2021 Adobe Systems Incorporated. All rights reserved.
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License
* for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see https://opensource.org/licenses/AGPL-3.0.
*
*/
define(function (require, exports, module) {
"use strict";
// Load dependent modules
var EditorManager = require("editor/EditorManager");
/**
* @constructor
*
*/
function InlineWidget() {
var self = this;
// create the outer wrapper div
this.htmlContent = window.document.createElement("div");
this.$htmlContent = $(this.htmlContent).addClass("inline-widget");
this.$htmlContent.append("<div class='shadow top' />")
.append("<div class='shadow bottom' />");
this.$htmlContent.on("keydown", function (e) {
if (e.keyCode === 27) {
self.close();
e.stopImmediatePropagation();
}
});
}
InlineWidget.prototype.htmlContent = null;
InlineWidget.prototype.$htmlContent = null;
InlineWidget.prototype.id = null;
InlineWidget.prototype.hostEditor = null;
/**
* Initial height of inline widget in pixels. Can be changed later via hostEditor.setInlineWidgetHeight()
* @type {number}
*/
InlineWidget.prototype.height = 0;
/**
* Closes this inline widget and all its contained Editors
*/
InlineWidget.prototype.close = function () {
var shouldMoveFocus = this._editorHasFocus();
EditorManager.closeInlineWidget(this.hostEditor, this, shouldMoveFocus);
// closeInlineWidget() causes our onClosed() handler to be called
};
/**
* Called any time inline is closed, whether manually or automatically
*/
InlineWidget.prototype.onClosed = function () {
// do nothing - base implementation
};
/**
* Called once content is parented in the host editor's DOM. Useful for performing tasks like setting
* focus or measuring content, which require htmlContent to be in the DOM tree.
*/
InlineWidget.prototype.onAdded = function () {
// do nothing - base implementation
};
/**
* @param {Editor} hostEditor
*/
InlineWidget.prototype.load = function (hostEditor) {
this.hostEditor = hostEditor;
// TODO: incomplete impelementation. It's not clear yet if InlineTextEditor
// will fuction as an abstract class or as generic inline editor implementation
// that just shows a range of text. See CSSInlineEditor.css for an implementation of load()
};
/**
* Called when the editor containing the inline is made visible.
*/
InlineWidget.prototype.onParentShown = function () {
// do nothing - base implementation
};
exports.InlineWidget = InlineWidget;
});