neo.mjs 5.5.5 → 5.5.7

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.
@@ -20,9 +20,9 @@ class ServiceWorker extends ServiceBase {
20
20
  */
21
21
  singleton: true,
22
22
  /**
23
- * @member {String} version='5.5.5'
23
+ * @member {String} version='5.5.7'
24
24
  */
25
- version: '5.5.5'
25
+ version: '5.5.7'
26
26
  }
27
27
 
28
28
  /**
@@ -1,5 +1,5 @@
1
+ import EmailField from '../../../../src/form/field/Email.mjs';
1
2
  import FormPageContainer from '../FormPageContainer.mjs';
2
- import TextField from '../../../../src/form/field/Text.mjs';
3
3
 
4
4
  /**
5
5
  * @class Form.view.pages.Page12
@@ -16,11 +16,12 @@ class Page12 extends FormPageContainer {
16
16
  * @member {Object[]} items
17
17
  */
18
18
  items: [{
19
- module : TextField,
19
+ module : EmailField,
20
20
  labelText: 'Page 12 Field 1',
21
- name : 'page12field1'
21
+ name : 'page12field1',
22
+ required : true
22
23
  }, {
23
- module : TextField,
24
+ module : EmailField,
24
25
  labelText: 'Page 12 Field 2',
25
26
  name : 'page12field2'
26
27
  }]
@@ -20,9 +20,9 @@ class ServiceWorker extends ServiceBase {
20
20
  */
21
21
  singleton: true,
22
22
  /**
23
- * @member {String} version='5.5.5'
23
+ * @member {String} version='5.5.7'
24
24
  */
25
- version: '5.5.5'
25
+ version: '5.5.7'
26
26
  }
27
27
 
28
28
  /**
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "neo.mjs",
3
- "version": "5.5.5",
3
+ "version": "5.5.7",
4
4
  "description": "The webworkers driven UI framework",
5
5
  "type": "module",
6
6
  "repository": {
@@ -17,7 +17,7 @@
17
17
  {"id": 13, "cardIndex": 9, "isHeader": false, "isValid": null, "name": "SelectFields"},
18
18
  {"id": 14, "cardIndex": null, "isHeader": true, "isValid": null, "name": "4. Optional data"},
19
19
  {"id": 15, "cardIndex": 10, "isHeader": false, "isValid": null, "name": "ZipCodeFields"},
20
- {"id": 16, "cardIndex": 11, "isHeader": false, "isValid": null, "name": "Page 12"},
20
+ {"id": 16, "cardIndex": 11, "isHeader": false, "isValid": null, "name": "EmailFields"},
21
21
  {"id": 17, "cardIndex": 12, "isHeader": false, "isValid": null, "name": "Page 13"},
22
22
  {"id": 18, "cardIndex": 13, "isHeader": false, "isValid": null, "name": "Page 14"}
23
23
  ]
@@ -40,6 +40,14 @@
40
40
  margin-top : .3em;
41
41
  white-space: break-spaces;
42
42
  word-break : break-word;
43
+
44
+ &.neo-absolute {
45
+ position: absolute;
46
+ }
47
+ }
48
+
49
+ .neo-error-wrapper {
50
+ position: relative;
43
51
  }
44
52
 
45
53
  &.neo-invalid {
@@ -236,12 +236,12 @@ const DefaultConfig = {
236
236
  useVdomWorker: true,
237
237
  /**
238
238
  * buildScripts/injectPackageVersion.mjs will update this value
239
- * @default '5.5.5'
239
+ * @default '5.5.7'
240
240
  * @memberOf! module:Neo
241
241
  * @name config.version
242
242
  * @type String
243
243
  */
244
- version: '5.5.5'
244
+ version: '5.5.7'
245
245
  };
246
246
 
247
247
  Object.assign(DefaultConfig, {
@@ -38,6 +38,11 @@ class CheckBox extends Base {
38
38
  * @member {String|null} error_=null
39
39
  */
40
40
  error_: null,
41
+ /**
42
+ * Useful for fields inside a css grid where errors should live outside the layout
43
+ * @member {Boolean} errorPositionAbsolute_=false
44
+ */
45
+ errorPositionAbsolute_: false,
41
46
  /**
42
47
  * @member {Function} errorTextGroupRequired='Required'
43
48
  */
@@ -126,7 +131,9 @@ class CheckBox extends Base {
126
131
  {tag: 'i', cls: ['neo-checkbox-icon']},
127
132
  {tag: 'span', cls: ['neo-checkbox-value-label']}
128
133
  ]},
129
- {cls: ['neo-error'], removeDom: true}
134
+ {cls: ['neo-error-wrapper'], removeDom: true, cn: [
135
+ {cls: ['neo-error']}
136
+ ]}
130
137
  ]}
131
138
  }
132
139
 
@@ -189,6 +196,21 @@ class CheckBox extends Base {
189
196
  this.updateError(value)
190
197
  }
191
198
 
199
+ /**
200
+ * Triggered after the errorPositionAbsolute config got changed
201
+ * @param {Boolean} value
202
+ * @param {Boolean} oldValue
203
+ * @protected
204
+ */
205
+ afterSetErrorPositionAbsolute(value, oldValue) {
206
+ let me = this,
207
+ cls = me.vdom.cn[1].cn[0].cls;
208
+
209
+ NeoArray[value ? 'add' : 'remove'](cls, 'neo-absolute');
210
+
211
+ me.update()
212
+ }
213
+
192
214
  /**
193
215
  * Triggered after the required groupRequired got changed
194
216
  * @param {Boolean} value
@@ -463,7 +485,7 @@ class CheckBox extends Base {
463
485
  let me = this,
464
486
  cls = me.cls,
465
487
  showError = value && me.showErrorTexts,
466
- errorNode;
488
+ errorNode, errorWrapper;
467
489
 
468
490
  if (!(me.clean && !me.mounted)) {
469
491
  me._error = value; // silent update
@@ -471,7 +493,8 @@ class CheckBox extends Base {
471
493
  NeoArray[value ? 'add' : 'remove'](cls, 'neo-invalid');
472
494
  me.cls = cls;
473
495
 
474
- errorNode = me.vdom.cn[1];
496
+ errorWrapper = me.vdom.cn[1];
497
+ errorNode = errorWrapper.cn[0];
475
498
 
476
499
  if (showError) {
477
500
  errorNode.html = value;
@@ -479,7 +502,7 @@ class CheckBox extends Base {
479
502
  delete errorNode.html;
480
503
  }
481
504
 
482
- errorNode.removeDom = !showError;
505
+ errorWrapper.removeDom = !showError;
483
506
 
484
507
  !silent && me.update()
485
508
  }
@@ -5,6 +5,14 @@ import Text from './Text.mjs';
5
5
  * @extends Neo.form.field.Text
6
6
  */
7
7
  class Email extends Text {
8
+ /**
9
+ * See: https://html.spec.whatwg.org/multipage/input.html#valid-e-mail-address
10
+ * @member {RegExp} emailRegex
11
+ * @protected
12
+ * @static
13
+ */
14
+ static emailRegex = /^[a-z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*$/i
15
+
8
16
  static config = {
9
17
  /**
10
18
  * @member {String} className='Neo.form.field.Email'
@@ -16,11 +24,36 @@ class Email extends Text {
16
24
  * @protected
17
25
  */
18
26
  ntype: 'emailfield',
27
+ /**
28
+ * @member {String} errorTextValidEmail='Not a valid email address'
29
+ */
30
+ errorTextValidEmail: 'Not a valid email address',
19
31
  /**
20
32
  * @member {String} inputType='email'
21
33
  */
22
34
  inputType: 'email'
23
35
  }
36
+
37
+ /**
38
+ * Checks for client-side field errors
39
+ * @param {Boolean} silent=true
40
+ * @returns {Boolean} Returns true in case there are no client-side errors
41
+ */
42
+ validate(silent=true) {
43
+ let me = this,
44
+ returnValue = super.validate(silent);
45
+
46
+ if (returnValue) {
47
+ if (!Email.emailRegex.test(me.value)) {
48
+ me._error = me.errorTextValidEmail;
49
+ returnValue = false;
50
+ }
51
+ }
52
+
53
+ !returnValue && !me.clean && me.updateError(me._error, silent);
54
+
55
+ return returnValue
56
+ }
24
57
  }
25
58
 
26
59
  Neo.applyClassConfig(Email);