@descope/web-components-ui 3.3.0 → 3.3.2

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.
Files changed (26) hide show
  1. package/dist/cjs/index.cjs.js +18 -9
  2. package/dist/cjs/index.cjs.js.map +1 -1
  3. package/dist/index.esm.js +37 -11
  4. package/dist/index.esm.js.map +1 -1
  5. package/dist/umd/DescopeDev.js +1 -1
  6. package/dist/umd/DescopeDev.js.map +1 -1
  7. package/dist/umd/descope-date-field-index-js.js +1 -1
  8. package/dist/umd/descope-date-field-index-js.js.map +1 -1
  9. package/dist/umd/descope-hybrid-field-index-js.js +2 -2
  10. package/dist/umd/descope-hybrid-field-index-js.js.map +1 -1
  11. package/dist/umd/index.js +1 -1
  12. package/dist/umd/phone-fields-descope-phone-field-descope-phone-field-internal-index-js.js +1 -1
  13. package/dist/umd/phone-fields-descope-phone-field-descope-phone-field-internal-index-js.js.map +1 -1
  14. package/dist/umd/phone-fields-descope-phone-field-index-js.js +1 -1
  15. package/dist/umd/phone-fields-descope-phone-field-index-js.js.map +1 -1
  16. package/dist/umd/phone-fields-descope-phone-input-box-field-descope-phone-input-box-internal-index-js.js +1 -1
  17. package/dist/umd/phone-fields-descope-phone-input-box-field-descope-phone-input-box-internal-index-js.js.map +1 -1
  18. package/dist/umd/phone-fields-descope-phone-input-box-field-index-js.js +1 -1
  19. package/dist/umd/phone-fields-descope-phone-input-box-field-index-js.js.map +1 -1
  20. package/package.json +32 -32
  21. package/src/components/descope-date-field/DateFieldClass.js +12 -7
  22. package/src/components/descope-hybrid-field/HybridFieldClass.js +4 -2
  23. package/src/components/phone-fields/descope-phone-field/PhoneFieldClass.js +1 -0
  24. package/src/components/phone-fields/descope-phone-field/descope-phone-field-internal/PhoneFieldInternal.js +12 -2
  25. package/src/components/phone-fields/descope-phone-input-box-field/PhoneFieldInputBoxClass.js +1 -0
  26. package/src/components/phone-fields/descope-phone-input-box-field/descope-phone-input-box-internal/PhoneFieldInternalInputBox.js +7 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@descope/web-components-ui",
3
- "version": "3.3.0",
3
+ "version": "3.3.2",
4
4
  "description": "",
5
5
  "main": "dist/cjs/index.cjs.js",
6
6
  "module": "dist/index.esm.js",
@@ -51,10 +51,10 @@
51
51
  "webpack-cli": "^7.0.0",
52
52
  "webpack-dev-server": "^5.0.0",
53
53
  "webpack-subresource-integrity": "5.2.0-rc.1",
54
- "test-drivers": "3.3.0",
55
- "webpack-extract-font-loader": "3.3.0",
56
- "webpack-replace-plugin": "3.3.0",
57
- "rollup-replace-plugin": "3.3.0"
54
+ "rollup-replace-plugin": "3.3.2",
55
+ "test-drivers": "3.3.2",
56
+ "webpack-extract-font-loader": "3.3.2",
57
+ "webpack-replace-plugin": "3.3.2"
58
58
  },
59
59
  "dependencies": {
60
60
  "@vaadin/checkbox": "24.3.4",
@@ -78,33 +78,33 @@
78
78
  "libphonenumber-js": "^1.11.12",
79
79
  "lodash.debounce": "4.0.8",
80
80
  "lodash.merge": "4.6.2",
81
- "@descope-ui/common": "3.3.0",
82
- "@descope-ui/descope-address-field": "3.3.0",
83
- "@descope-ui/descope-country-subdivision-city-field": "3.3.0",
84
- "@descope-ui/descope-apps-list": "3.3.0",
85
- "@descope-ui/descope-autocomplete-field": "3.3.0",
86
- "@descope-ui/descope-avatar": "3.3.0",
87
- "@descope-ui/descope-badge": "3.3.0",
88
- "@descope-ui/descope-button": "3.3.0",
89
- "@descope-ui/descope-collapsible-container": "3.3.0",
90
- "@descope-ui/descope-enriched-text": "3.3.0",
91
- "@descope-ui/descope-combo-box": "3.3.0",
92
- "@descope-ui/descope-icon": "3.3.0",
93
- "@descope-ui/descope-image": "3.3.0",
94
- "@descope-ui/descope-link": "3.3.0",
95
- "@descope-ui/descope-list": "3.3.0",
96
- "@descope-ui/descope-outbound-app-button": "3.3.0",
97
- "@descope-ui/descope-outbound-apps": "3.3.0",
98
- "@descope-ui/descope-list-item": "3.3.0",
99
- "@descope-ui/descope-password-strength": "3.3.0",
100
- "@descope-ui/descope-ponyhot": "3.3.0",
101
- "@descope-ui/descope-recovery-codes": "3.3.0",
102
- "@descope-ui/descope-text": "3.3.0",
103
- "@descope-ui/descope-timer": "3.3.0",
104
- "@descope-ui/descope-timer-button": "3.3.0",
105
- "@descope-ui/descope-tooltip": "3.3.0",
106
- "@descope-ui/descope-trusted-devices": "3.3.0",
107
- "@descope-ui/descope-attachment": "3.3.0"
81
+ "@descope-ui/descope-address-field": "3.3.2",
82
+ "@descope-ui/descope-country-subdivision-city-field": "3.3.2",
83
+ "@descope-ui/descope-apps-list": "3.3.2",
84
+ "@descope-ui/descope-autocomplete-field": "3.3.2",
85
+ "@descope-ui/descope-avatar": "3.3.2",
86
+ "@descope-ui/descope-badge": "3.3.2",
87
+ "@descope-ui/descope-button": "3.3.2",
88
+ "@descope-ui/descope-combo-box": "3.3.2",
89
+ "@descope-ui/common": "3.3.2",
90
+ "@descope-ui/descope-collapsible-container": "3.3.2",
91
+ "@descope-ui/descope-enriched-text": "3.3.2",
92
+ "@descope-ui/descope-icon": "3.3.2",
93
+ "@descope-ui/descope-image": "3.3.2",
94
+ "@descope-ui/descope-link": "3.3.2",
95
+ "@descope-ui/descope-list": "3.3.2",
96
+ "@descope-ui/descope-outbound-apps": "3.3.2",
97
+ "@descope-ui/descope-outbound-app-button": "3.3.2",
98
+ "@descope-ui/descope-recovery-codes": "3.3.2",
99
+ "@descope-ui/descope-text": "3.3.2",
100
+ "@descope-ui/descope-timer": "3.3.2",
101
+ "@descope-ui/descope-timer-button": "3.3.2",
102
+ "@descope-ui/descope-tooltip": "3.3.2",
103
+ "@descope-ui/descope-list-item": "3.3.2",
104
+ "@descope-ui/descope-trusted-devices": "3.3.2",
105
+ "@descope-ui/descope-attachment": "3.3.2",
106
+ "@descope-ui/descope-password-strength": "3.3.2",
107
+ "@descope-ui/descope-ponyhot": "3.3.2"
108
108
  },
109
109
  "overrides": {
110
110
  "@vaadin/avatar": "24.3.4",
@@ -366,8 +366,10 @@ class RawDateFieldClass extends BaseInputClass {
366
366
  #adjustPopoverPosition() {
367
367
  const popover = this.shadowRoot.querySelector('vaadin-popover').shadowRoot;
368
368
 
369
- // Remove previously added stylesheets
370
- this.#popoverPosStylesheet?.remove();
369
+ // Reset any previous transform so getBoundingClientRect measures the natural position
370
+ this.#popoverPosStylesheet?.replaceSync(
371
+ `vaadin-popover-overlay::part(overlay) { transform: none; }`
372
+ );
371
373
 
372
374
  const windowRect = document.body.getBoundingClientRect();
373
375
  const inputRect = this.getBoundingClientRect();
@@ -385,14 +387,17 @@ class RawDateFieldClass extends BaseInputClass {
385
387
  newOffset = Math.min(Math.abs(offset), availableLeft) * -1;
386
388
  }
387
389
 
388
- injectStyle(
389
- `
390
+ const css = `
390
391
  vaadin-popover-overlay::part(overlay) {
391
392
  transform: translateX(${newOffset}px);
392
393
  }
393
- `,
394
- popover
395
- );
394
+ `;
395
+
396
+ if (this.#popoverPosStylesheet) {
397
+ this.#popoverPosStylesheet.replaceSync(css);
398
+ } else {
399
+ this.#popoverPosStylesheet = injectStyle(css, popover);
400
+ }
396
401
  }
397
402
 
398
403
  #getPopoverContent() {
@@ -40,6 +40,7 @@ const attrs = {
40
40
  'phone-minlength',
41
41
  'phone-format-value',
42
42
  'phone-strict-validation',
43
+ 'phone-input-type',
43
44
  'data-errormessage-value-missing-phone',
44
45
  ],
45
46
  inputBox: [
@@ -48,6 +49,7 @@ const attrs = {
48
49
  'phone-minlength',
49
50
  'phone-format-value',
50
51
  'phone-strict-validation',
52
+ 'phone-input-type',
51
53
  'data-errormessage-value-missing-phone',
52
54
  ],
53
55
  },
@@ -87,8 +89,8 @@ class RawHybridField extends BaseClass {
87
89
  this.attachShadow({ mode: 'open' }).innerHTML = `
88
90
  <div class="wrapper">
89
91
  <descope-email-field external-input="${this.isExternalInput}"></descope-email-field>
90
- <descope-phone-field allow-alphanumeric-input="true"></descope-phone-field>
91
- <descope-phone-input-box-field allow-alphanumeric-input="true"></descope-phone-input-box-field>
92
+ <descope-phone-field allow-alphanumeric-input="true" phone-input-type="text"></descope-phone-field>
93
+ <descope-phone-input-box-field allow-alphanumeric-input="true" phone-input-type="text"></descope-phone-input-box-field>
92
94
  </div>
93
95
  `;
94
96
 
@@ -64,6 +64,7 @@ const customMixin = (superclass) =>
64
64
  'allow-alphanumeric-input',
65
65
  'format-value',
66
66
  'strict-validation',
67
+ 'phone-input-type',
67
68
  ],
68
69
  });
69
70
  }
@@ -8,12 +8,19 @@ export const componentName = getComponentName('phone-field-internal');
8
8
 
9
9
  const commonAttrs = ['disabled', 'size', 'bordered', 'readonly'];
10
10
  const countryAttrs = ['country-input-placeholder', 'default-code', 'restrict-countries'];
11
- const phoneAttrs = ['phone-input-placeholder', 'maxlength', 'autocomplete', 'name'];
11
+ const phoneAttrs = [
12
+ 'phone-input-placeholder',
13
+ 'maxlength',
14
+ 'autocomplete',
15
+ 'name',
16
+ 'phone-input-type',
17
+ ];
12
18
  const labelTypeAttrs = ['label-type', 'country-input-label', 'label'];
13
19
  const mapAttrs = {
14
20
  'country-input-label': 'label',
15
21
  'country-input-placeholder': 'placeholder',
16
22
  'phone-input-placeholder': 'placeholder',
23
+ 'phone-input-type': 'type',
17
24
  };
18
25
 
19
26
  const inputRelatedAttrs = [].concat(commonAttrs, countryAttrs, phoneAttrs, labelTypeAttrs);
@@ -49,7 +56,10 @@ class PhoneFieldInternal extends BaseInputClass {
49
56
  this.inputs = [this.comboBox, this.textField];
50
57
 
51
58
  forwardAttrs(this, this.comboBox, { includeAttrs: ['label-type'] });
52
- forwardAttrs(this, this.textField, { includeAttrs: ['label-type', 'required'] });
59
+ forwardAttrs(this, this.textField, {
60
+ includeAttrs: ['label-type', 'required', 'phone-input-type'],
61
+ mapAttrs: { 'phone-input-type': 'type' },
62
+ });
53
63
 
54
64
  // override combo box setter to display dialCode value in input
55
65
  this.comboBox.customValueTransformFn = (val) => {
@@ -63,6 +63,7 @@ const customMixin = (superclass) =>
63
63
  'format-value',
64
64
  'strict-validation',
65
65
  'data-errormessage-type-mismatch',
66
+ 'phone-input-type',
66
67
  ],
67
68
  });
68
69
  }
@@ -15,9 +15,11 @@ const observedAttributes = [
15
15
  'maxlength',
16
16
  'autocomplete',
17
17
  'label-type',
18
+ 'phone-input-type',
18
19
  ];
19
20
  const mapAttrs = {
20
21
  'phone-input-placeholder': 'placeholder',
22
+ 'phone-input-type': 'type',
21
23
  };
22
24
 
23
25
  const BaseInputClass = createBaseInputClass({ componentName, baseSelector: 'div' });
@@ -111,6 +113,11 @@ class PhoneFieldInternal extends BaseInputClass {
111
113
  this.handleFocusEventsDispatching([this.textField]);
112
114
 
113
115
  forwardAttrs(this.textField, this, { includeAttrs: ['has-value'] });
116
+
117
+ forwardAttrs(this, this.textField, {
118
+ includeAttrs: ['phone-input-type'],
119
+ mapAttrs: { 'phone-input-type': 'type' },
120
+ });
114
121
  }
115
122
 
116
123
  getValidity() {