@panneau/field-text 0.6.71-alpha.0 → 0.6.74
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/TextField.js +36 -22
- package/lib/TextField.js +45 -29
- package/lib/index.js +12 -12
- package/package.json +5 -5
package/es/TextField.js
CHANGED
|
@@ -1,19 +1,19 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/extends";
|
|
2
2
|
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
3
3
|
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
|
|
4
|
-
import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
|
|
5
4
|
import _createClass from "@babel/runtime/helpers/createClass";
|
|
5
|
+
import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
|
|
6
6
|
import _inherits from "@babel/runtime/helpers/inherits";
|
|
7
7
|
import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn";
|
|
8
8
|
import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf";
|
|
9
9
|
|
|
10
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object);
|
|
10
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
11
11
|
|
|
12
|
-
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]
|
|
12
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
13
13
|
|
|
14
|
-
function _createSuper(Derived) { return function () { var Super = _getPrototypeOf(Derived), result; if (
|
|
14
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
15
15
|
|
|
16
|
-
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try {
|
|
16
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
17
17
|
|
|
18
18
|
import React, { Component } from 'react';
|
|
19
19
|
import PropTypes from 'prop-types';
|
|
@@ -56,7 +56,8 @@ var propTypes = {
|
|
|
56
56
|
ckeditorConfig: PropTypes.object,
|
|
57
57
|
// eslint-disable-line
|
|
58
58
|
ckeditorCustomConfig: PropTypes.string,
|
|
59
|
-
ckeditorBasePath: PropTypes.string
|
|
59
|
+
ckeditorBasePath: PropTypes.string,
|
|
60
|
+
itemIndex: PropTypes.string
|
|
60
61
|
};
|
|
61
62
|
var defaultProps = {
|
|
62
63
|
type: 'text',
|
|
@@ -82,7 +83,8 @@ var defaultProps = {
|
|
|
82
83
|
readOnly: null,
|
|
83
84
|
ckeditorConfig: null,
|
|
84
85
|
ckeditorCustomConfig: null,
|
|
85
|
-
ckeditorBasePath: 'https://cdn.ckeditor.com/4.7.2/standard/'
|
|
86
|
+
ckeditorBasePath: 'https://cdn.ckeditor.com/4.7.2/standard/',
|
|
87
|
+
itemIndex: null
|
|
86
88
|
};
|
|
87
89
|
|
|
88
90
|
var TextField = /*#__PURE__*/function (_Component) {
|
|
@@ -90,21 +92,6 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
90
92
|
|
|
91
93
|
var _super = _createSuper(TextField);
|
|
92
94
|
|
|
93
|
-
_createClass(TextField, null, [{
|
|
94
|
-
key: "parse",
|
|
95
|
-
value: function parse(value) {
|
|
96
|
-
if (isString(value) || isNumber(value)) {
|
|
97
|
-
return value;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
if (isArray(value)) {
|
|
101
|
-
return value.join(' ');
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
return ''; // Empty string for the input field
|
|
105
|
-
}
|
|
106
|
-
}]);
|
|
107
|
-
|
|
108
95
|
function TextField(props) {
|
|
109
96
|
var _this;
|
|
110
97
|
|
|
@@ -117,6 +104,7 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
117
104
|
_this.importCanceled = false;
|
|
118
105
|
_this.ckeditor = null;
|
|
119
106
|
_this.editor = null;
|
|
107
|
+
_this.editorInstance = null;
|
|
120
108
|
_this.refInput = null;
|
|
121
109
|
_this.refInputGroup = null;
|
|
122
110
|
return _this;
|
|
@@ -149,9 +137,21 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
149
137
|
|
|
150
138
|
editor.on('instanceReady', _this2.onEditorReady);
|
|
151
139
|
editor.on('change', _this2.onEditorChange);
|
|
140
|
+
_this2.editorInstance = editor;
|
|
152
141
|
});
|
|
153
142
|
}
|
|
154
143
|
}
|
|
144
|
+
}, {
|
|
145
|
+
key: "componentDidUpdate",
|
|
146
|
+
value: function componentDidUpdate(newProps) {
|
|
147
|
+
var newValue = newProps.value,
|
|
148
|
+
newItemIndex = newProps.itemIndex;
|
|
149
|
+
var itemIndex = this.props.itemIndex;
|
|
150
|
+
|
|
151
|
+
if (itemIndex !== newItemIndex && this.editorInstance !== null) {
|
|
152
|
+
this.editorInstance.setData(newValue || '');
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
155
|
}, {
|
|
156
156
|
key: "componentWillUnmount",
|
|
157
157
|
value: function componentWillUnmount() {
|
|
@@ -160,6 +160,7 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
160
160
|
|
|
161
161
|
if (type === 'editor') {
|
|
162
162
|
this.ckeditor.remove(this.editor);
|
|
163
|
+
this.editorInstance = null;
|
|
163
164
|
}
|
|
164
165
|
}
|
|
165
166
|
}, {
|
|
@@ -317,6 +318,19 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
317
318
|
className: "form-group-text"
|
|
318
319
|
}, groupProps), inputGroup);
|
|
319
320
|
}
|
|
321
|
+
}], [{
|
|
322
|
+
key: "parse",
|
|
323
|
+
value: function parse(value) {
|
|
324
|
+
if (isString(value) || isNumber(value)) {
|
|
325
|
+
return value;
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
if (isArray(value)) {
|
|
329
|
+
return value.join(' ');
|
|
330
|
+
}
|
|
331
|
+
|
|
332
|
+
return ''; // Empty string for the input field
|
|
333
|
+
}
|
|
320
334
|
}]);
|
|
321
335
|
|
|
322
336
|
return TextField;
|
package/lib/TextField.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var _interopRequireWildcard3 = require("@babel/runtime/helpers/interopRequireWildcard");
|
|
4
|
-
|
|
5
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
6
4
|
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
7
|
Object.defineProperty(exports, "__esModule", {
|
|
8
8
|
value: true
|
|
9
9
|
});
|
|
@@ -13,21 +13,19 @@ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")
|
|
|
13
13
|
|
|
14
14
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
15
15
|
|
|
16
|
-
var _interopRequireWildcard2 = _interopRequireDefault(require("@babel/runtime/helpers/interopRequireWildcard"));
|
|
17
|
-
|
|
18
16
|
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
19
17
|
|
|
20
|
-
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
21
|
-
|
|
22
18
|
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
23
19
|
|
|
20
|
+
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
21
|
+
|
|
24
22
|
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
25
23
|
|
|
26
24
|
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
27
25
|
|
|
28
26
|
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
29
27
|
|
|
30
|
-
var _react =
|
|
28
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
31
29
|
|
|
32
30
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
33
31
|
|
|
@@ -45,13 +43,17 @@ var _field = require("@panneau/field");
|
|
|
45
43
|
|
|
46
44
|
var _core = require("@panneau/core");
|
|
47
45
|
|
|
48
|
-
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object);
|
|
46
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
47
|
+
|
|
48
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
49
49
|
|
|
50
|
-
function
|
|
50
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
51
51
|
|
|
52
|
-
function
|
|
52
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
53
53
|
|
|
54
|
-
function
|
|
54
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
55
|
+
|
|
56
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
55
57
|
|
|
56
58
|
/**
|
|
57
59
|
* Class: TextField
|
|
@@ -84,7 +86,8 @@ var propTypes = {
|
|
|
84
86
|
ckeditorConfig: _propTypes["default"].object,
|
|
85
87
|
// eslint-disable-line
|
|
86
88
|
ckeditorCustomConfig: _propTypes["default"].string,
|
|
87
|
-
ckeditorBasePath: _propTypes["default"].string
|
|
89
|
+
ckeditorBasePath: _propTypes["default"].string,
|
|
90
|
+
itemIndex: _propTypes["default"].string
|
|
88
91
|
};
|
|
89
92
|
var defaultProps = {
|
|
90
93
|
type: 'text',
|
|
@@ -110,7 +113,8 @@ var defaultProps = {
|
|
|
110
113
|
readOnly: null,
|
|
111
114
|
ckeditorConfig: null,
|
|
112
115
|
ckeditorCustomConfig: null,
|
|
113
|
-
ckeditorBasePath: 'https://cdn.ckeditor.com/4.7.2/standard/'
|
|
116
|
+
ckeditorBasePath: 'https://cdn.ckeditor.com/4.7.2/standard/',
|
|
117
|
+
itemIndex: null
|
|
114
118
|
};
|
|
115
119
|
|
|
116
120
|
var TextField = /*#__PURE__*/function (_Component) {
|
|
@@ -118,21 +122,6 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
118
122
|
|
|
119
123
|
var _super = _createSuper(TextField);
|
|
120
124
|
|
|
121
|
-
(0, _createClass2["default"])(TextField, null, [{
|
|
122
|
-
key: "parse",
|
|
123
|
-
value: function parse(value) {
|
|
124
|
-
if ((0, _isString["default"])(value) || (0, _isNumber["default"])(value)) {
|
|
125
|
-
return value;
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
if ((0, _isArray["default"])(value)) {
|
|
129
|
-
return value.join(' ');
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
return ''; // Empty string for the input field
|
|
133
|
-
}
|
|
134
|
-
}]);
|
|
135
|
-
|
|
136
125
|
function TextField(props) {
|
|
137
126
|
var _this;
|
|
138
127
|
|
|
@@ -144,6 +133,7 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
144
133
|
_this.importCanceled = false;
|
|
145
134
|
_this.ckeditor = null;
|
|
146
135
|
_this.editor = null;
|
|
136
|
+
_this.editorInstance = null;
|
|
147
137
|
_this.refInput = null;
|
|
148
138
|
_this.refInputGroup = null;
|
|
149
139
|
return _this;
|
|
@@ -161,7 +151,7 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
161
151
|
if (type === 'editor') {
|
|
162
152
|
window.CKEDITOR_BASEPATH = ckeditorBasePath;
|
|
163
153
|
Promise.resolve().then(function () {
|
|
164
|
-
return (
|
|
154
|
+
return _interopRequireWildcard(require('ckeditor'));
|
|
165
155
|
}).then(function () {
|
|
166
156
|
if (_this2.importCanceled) {
|
|
167
157
|
return;
|
|
@@ -178,9 +168,21 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
178
168
|
|
|
179
169
|
editor.on('instanceReady', _this2.onEditorReady);
|
|
180
170
|
editor.on('change', _this2.onEditorChange);
|
|
171
|
+
_this2.editorInstance = editor;
|
|
181
172
|
});
|
|
182
173
|
}
|
|
183
174
|
}
|
|
175
|
+
}, {
|
|
176
|
+
key: "componentDidUpdate",
|
|
177
|
+
value: function componentDidUpdate(newProps) {
|
|
178
|
+
var newValue = newProps.value,
|
|
179
|
+
newItemIndex = newProps.itemIndex;
|
|
180
|
+
var itemIndex = this.props.itemIndex;
|
|
181
|
+
|
|
182
|
+
if (itemIndex !== newItemIndex && this.editorInstance !== null) {
|
|
183
|
+
this.editorInstance.setData(newValue || '');
|
|
184
|
+
}
|
|
185
|
+
}
|
|
184
186
|
}, {
|
|
185
187
|
key: "componentWillUnmount",
|
|
186
188
|
value: function componentWillUnmount() {
|
|
@@ -189,6 +191,7 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
189
191
|
|
|
190
192
|
if (type === 'editor') {
|
|
191
193
|
this.ckeditor.remove(this.editor);
|
|
194
|
+
this.editorInstance = null;
|
|
192
195
|
}
|
|
193
196
|
}
|
|
194
197
|
}, {
|
|
@@ -346,6 +349,19 @@ var TextField = /*#__PURE__*/function (_Component) {
|
|
|
346
349
|
className: "form-group-text"
|
|
347
350
|
}, groupProps), inputGroup);
|
|
348
351
|
}
|
|
352
|
+
}], [{
|
|
353
|
+
key: "parse",
|
|
354
|
+
value: function parse(value) {
|
|
355
|
+
if ((0, _isString["default"])(value) || (0, _isNumber["default"])(value)) {
|
|
356
|
+
return value;
|
|
357
|
+
}
|
|
358
|
+
|
|
359
|
+
if ((0, _isArray["default"])(value)) {
|
|
360
|
+
return value.join(' ');
|
|
361
|
+
}
|
|
362
|
+
|
|
363
|
+
return ''; // Empty string for the input field
|
|
364
|
+
}
|
|
349
365
|
}]);
|
|
350
366
|
return TextField;
|
|
351
367
|
}(_react.Component);
|
package/lib/index.js
CHANGED
|
@@ -5,24 +5,12 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
Object.defineProperty(exports, "TextLocale", {
|
|
9
|
-
enumerable: true,
|
|
10
|
-
get: function get() {
|
|
11
|
-
return _TextLocaleField["default"];
|
|
12
|
-
}
|
|
13
|
-
});
|
|
14
8
|
Object.defineProperty(exports, "Editor", {
|
|
15
9
|
enumerable: true,
|
|
16
10
|
get: function get() {
|
|
17
11
|
return _EditorField["default"];
|
|
18
12
|
}
|
|
19
13
|
});
|
|
20
|
-
Object.defineProperty(exports, "Textarea", {
|
|
21
|
-
enumerable: true,
|
|
22
|
-
get: function get() {
|
|
23
|
-
return _TextareaField["default"];
|
|
24
|
-
}
|
|
25
|
-
});
|
|
26
14
|
Object.defineProperty(exports, "Email", {
|
|
27
15
|
enumerable: true,
|
|
28
16
|
get: function get() {
|
|
@@ -41,6 +29,18 @@ Object.defineProperty(exports, "Password", {
|
|
|
41
29
|
return _PasswordField["default"];
|
|
42
30
|
}
|
|
43
31
|
});
|
|
32
|
+
Object.defineProperty(exports, "TextLocale", {
|
|
33
|
+
enumerable: true,
|
|
34
|
+
get: function get() {
|
|
35
|
+
return _TextLocaleField["default"];
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
Object.defineProperty(exports, "Textarea", {
|
|
39
|
+
enumerable: true,
|
|
40
|
+
get: function get() {
|
|
41
|
+
return _TextareaField["default"];
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
44
|
exports["default"] = void 0;
|
|
45
45
|
|
|
46
46
|
var _TextField = _interopRequireDefault(require("./TextField"));
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@panneau/field-text",
|
|
3
|
-
"version": "0.6.
|
|
3
|
+
"version": "0.6.74",
|
|
4
4
|
"description": "Text field for Panneau",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"react",
|
|
@@ -48,9 +48,9 @@
|
|
|
48
48
|
},
|
|
49
49
|
"dependencies": {
|
|
50
50
|
"@babel/runtime": "^7.0.0",
|
|
51
|
-
"@panneau/core": "^0.6.
|
|
52
|
-
"@panneau/field": "^0.6.
|
|
53
|
-
"@panneau/field-locale": "^0.6.
|
|
51
|
+
"@panneau/core": "^0.6.73",
|
|
52
|
+
"@panneau/field": "^0.6.74",
|
|
53
|
+
"@panneau/field-locale": "^0.6.74",
|
|
54
54
|
"ckeditor": "^4.7.3",
|
|
55
55
|
"classnames": "^2.2.5",
|
|
56
56
|
"lodash": "^4.17.4",
|
|
@@ -64,5 +64,5 @@
|
|
|
64
64
|
"react": ">=15.0.0 || ^16.0.0",
|
|
65
65
|
"react-dom": ">=15.0.0 || ^16.0.0"
|
|
66
66
|
},
|
|
67
|
-
"gitHead": "
|
|
67
|
+
"gitHead": "9bc3e471a61e368d7bf15c7360d666e88c93762f"
|
|
68
68
|
}
|