@descope/web-components-ui 1.43.0 → 1.45.0

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 (47) hide show
  1. package/dist/cjs/index.cjs.js +124 -55
  2. package/dist/cjs/index.cjs.js.map +1 -1
  3. package/dist/index.esm.js +530 -256
  4. package/dist/index.esm.js.map +1 -1
  5. package/dist/umd/3620.js +1 -1
  6. package/dist/umd/3620.js.map +1 -1
  7. package/dist/umd/5348.js +2 -0
  8. package/dist/umd/5348.js.map +1 -0
  9. package/dist/umd/6477.js +149 -0
  10. package/dist/umd/6477.js.map +1 -0
  11. package/dist/umd/9365.js +1 -1
  12. package/dist/umd/9365.js.map +1 -1
  13. package/dist/umd/DescopeDev.js +1 -1
  14. package/dist/umd/DescopeDev.js.map +1 -1
  15. package/dist/umd/descope-hybrid-field-index-js.js +3 -3
  16. package/dist/umd/descope-hybrid-field-index-js.js.map +1 -1
  17. package/dist/umd/descope-passcode-index-js.js +1 -1
  18. package/dist/umd/descope-passcode-index-js.js.map +1 -1
  19. package/dist/umd/descope-timer-button.js +1 -1
  20. package/dist/umd/descope-timer-button.js.map +1 -1
  21. package/dist/umd/descope-timer.js +1 -1
  22. package/dist/umd/descope-timer.js.map +1 -1
  23. package/dist/umd/index.js +1 -1
  24. package/dist/umd/index.js.map +1 -1
  25. package/dist/umd/phone-fields-descope-phone-field-descope-phone-field-internal-index-js.js +1 -1
  26. package/dist/umd/phone-fields-descope-phone-field-descope-phone-field-internal-index-js.js.map +1 -1
  27. package/dist/umd/phone-fields-descope-phone-field-index-js.js +1 -1
  28. package/dist/umd/phone-fields-descope-phone-field-index-js.js.map +1 -1
  29. package/dist/umd/phone-fields-descope-phone-input-box-field-descope-phone-input-box-internal-index-js.js +2 -2
  30. package/dist/umd/phone-fields-descope-phone-input-box-field-descope-phone-input-box-internal-index-js.js.map +1 -1
  31. package/dist/umd/phone-fields-descope-phone-input-box-field-index-js.js +2 -113
  32. package/dist/umd/phone-fields-descope-phone-input-box-field-index-js.js.LICENSE.txt +0 -6
  33. package/dist/umd/phone-fields-descope-phone-input-box-field-index-js.js.map +1 -1
  34. package/package.json +7 -6
  35. package/src/components/descope-hybrid-field/HybridFieldClass.js +6 -0
  36. package/src/components/descope-passcode/PasscodeClass.js +2 -0
  37. package/src/components/phone-fields/descope-phone-field/PhoneFieldClass.js +10 -2
  38. package/src/components/phone-fields/descope-phone-field/descope-phone-field-internal/PhoneFieldInternal.js +229 -125
  39. package/src/components/phone-fields/descope-phone-input-box-field/PhoneFieldInputBoxClass.js +42 -24
  40. package/src/components/phone-fields/descope-phone-input-box-field/descope-phone-input-box-internal/PhoneFieldInternalInputBox.js +176 -79
  41. package/src/components/phone-fields/descope-phone-input-box-field/index.js +0 -1
  42. package/src/components/phone-fields/helpers.js +7 -0
  43. package/src/mixins/index.js +1 -0
  44. package/src/mixins/inputOverrideValidConstraints.js +12 -0
  45. package/dist/umd/6424.js +0 -149
  46. package/dist/umd/6424.js.map +0 -1
  47. /package/dist/umd/{6424.js.LICENSE.txt → 6477.js.LICENSE.txt} +0 -0
@@ -4372,6 +4372,19 @@ const externalInputMixin =
4372
4372
  }
4373
4373
  };
4374
4374
 
4375
+ const inputOverrideValidConstraintsMixin = (superclass) =>
4376
+ class InputOverrideValidConstraintsMixinClass extends superclass {
4377
+ init() {
4378
+ super.init?.();
4379
+
4380
+ // vaadin uses `validConstraints` (required, pattern, minlength, maxlength) to determine if it should validate
4381
+ // the input or not. We want to override this behavior, so we can enforce validation even if these attributes are not present.
4382
+ if (this.baseElement._hasValidConstraints) {
4383
+ this.baseElement._hasValidConstraints = () => true;
4384
+ }
4385
+ }
4386
+ };
4387
+
4375
4388
  const {
4376
4389
  host: host$r,
4377
4390
  label: label$9,
@@ -7356,6 +7369,7 @@ const PasscodeClass = compose$1(
7356
7369
  },
7357
7370
  }),
7358
7371
  draggableMixin,
7372
+ inputOverrideValidConstraintsMixin,
7359
7373
  composedProxyInputMixin({ proxyProps: ['value', 'selectionStart'] }),
7360
7374
  componentNameValidationMixin,
7361
7375
  customMixin$b
@@ -9849,7 +9863,6 @@ const customMixin$a = (superclass) =>
9849
9863
  includeAttrs: [
9850
9864
  'size',
9851
9865
  'bordered',
9852
- 'invalid',
9853
9866
  'minlength',
9854
9867
  'maxlength',
9855
9868
  'default-code',
@@ -9862,6 +9875,8 @@ const customMixin$a = (superclass) =>
9862
9875
  'label',
9863
9876
  'label-type',
9864
9877
  'allow-alphanumeric-input',
9878
+ 'format-value',
9879
+ 'strict-validation',
9865
9880
  ],
9866
9881
  });
9867
9882
  }
@@ -10010,6 +10025,7 @@ const PhoneFieldClass = compose$1(
10010
10025
  },
10011
10026
  }),
10012
10027
  draggableMixin,
10028
+ inputOverrideValidConstraintsMixin,
10013
10029
  composedProxyInputMixin({ proxyProps: ['value', 'selectionStart'] }),
10014
10030
  customMixin$a
10015
10031
  )(
@@ -10170,7 +10186,7 @@ const textVars$1 = TextFieldClass.cssVarList;
10170
10186
  const componentName$H = getComponentName$1('phone-input-box-field');
10171
10187
 
10172
10188
  const customMixin$9 = (superclass) =>
10173
- class PhoneInputBoxFieldMixinClass extends superclass {
10189
+ class PhoneFieldInputBoxMixinClass extends superclass {
10174
10190
  static get CountryCodes() {
10175
10191
  return CountryCodes;
10176
10192
  }
@@ -10194,8 +10210,6 @@ const customMixin$9 = (superclass) =>
10194
10210
  forwardAttrs$1(this.shadowRoot.host, this.inputElement, {
10195
10211
  includeAttrs: [
10196
10212
  'size',
10197
- 'bordered',
10198
- 'invalid',
10199
10213
  'minlength',
10200
10214
  'maxlength',
10201
10215
  'default-code',
@@ -10204,6 +10218,10 @@ const customMixin$9 = (superclass) =>
10204
10218
  'label',
10205
10219
  'label-type',
10206
10220
  'allow-alphanumeric-input',
10221
+ 'restrict-countries',
10222
+ 'format-value',
10223
+ 'strict-validation',
10224
+ 'data-errormessage-type-mismatch',
10207
10225
  ],
10208
10226
  });
10209
10227
  }
@@ -10219,7 +10237,8 @@ const {
10219
10237
  inputElement: inputElement$1,
10220
10238
  requiredIndicator: requiredIndicator$3,
10221
10239
  inputField: inputField$1,
10222
- inputFieldInternal,
10240
+ internalComponent,
10241
+ internalComponentAfter,
10223
10242
  phoneInput,
10224
10243
  errorMessage: errorMessage$5,
10225
10244
  helperText: helperText$3,
@@ -10230,8 +10249,11 @@ const {
10230
10249
  inputElement: { selector: 'input' },
10231
10250
  requiredIndicator: { selector: '[required]::part(required-indicator)::after' },
10232
10251
  inputField: { selector: () => 'vaadin-text-field::part(input-field)' },
10233
- inputFieldInternal: {
10234
- selector: () => 'descope-phone-field-internal-input-box vaadin-text-field::part(input-field)',
10252
+ internalComponent: {
10253
+ selector: 'descope-phone-field-internal-input-box',
10254
+ },
10255
+ internalComponentAfter: {
10256
+ selector: 'descope-phone-field-internal-input-box::after',
10235
10257
  },
10236
10258
  phoneInput: { selector: () => 'descope-text-field' },
10237
10259
  helperText: { selector: '::part(helper-text)' },
@@ -10254,14 +10276,6 @@ const PhoneFieldInputBoxClass = compose$1(
10254
10276
  hostMinWidth: { ...host$g, property: 'min-width' },
10255
10277
  hostDirection: { ...host$g, property: 'direction' },
10256
10278
 
10257
- inputBorderStyle: { ...inputFieldInternal, property: 'border-style' },
10258
- inputBorderWidth: { ...inputFieldInternal, property: 'border-width' },
10259
- inputBorderColor: { ...inputFieldInternal, property: 'border-color' },
10260
- inputBorderRadius: [
10261
- { ...inputField$1, property: 'border-radius' },
10262
- { ...inputFieldInternal, property: 'border-radius' },
10263
- ],
10264
-
10265
10279
  inputHorizontalPadding: [
10266
10280
  { ...phoneInput, property: 'padding-left' },
10267
10281
  { ...phoneInput, property: 'padding-right' },
@@ -10286,10 +10300,18 @@ const PhoneFieldInputBoxClass = compose$1(
10286
10300
 
10287
10301
  inputPlaceholderTextColor: { ...phoneInput, property: textVars$1.inputPlaceholderColor },
10288
10302
 
10289
- inputOutlineStyle: { ...inputField$1, property: 'outline-style' },
10290
- inputOutlineColor: { ...inputField$1, property: 'outline-color' },
10291
- inputOutlineWidth: { ...inputField$1, property: 'outline-width' },
10292
- inputOutlineOffset: { ...inputField$1, property: 'outline-offset' },
10303
+ inputBorderStyle: { ...internalComponentAfter, property: 'border-style' },
10304
+ inputBorderWidth: { ...internalComponentAfter, property: 'border-width' },
10305
+ inputBorderColor: { ...internalComponentAfter, property: 'border-color' },
10306
+ inputBorderRadius: [
10307
+ { ...internalComponent, property: 'border-radius' },
10308
+ { ...internalComponentAfter, property: 'border-radius' },
10309
+ ],
10310
+
10311
+ inputOutlineStyle: { ...internalComponent, property: 'outline-style' },
10312
+ inputOutlineColor: { ...internalComponent, property: 'outline-color' },
10313
+ inputOutlineWidth: { ...internalComponent, property: 'outline-width' },
10314
+ inputOutlineOffset: { ...internalComponent, property: 'outline-offset' },
10293
10315
 
10294
10316
  labelPosition: { ...label$3, property: 'position' },
10295
10317
  labelTopPosition: { ...label$3, property: 'top' },
@@ -10308,6 +10330,7 @@ const PhoneFieldInputBoxClass = compose$1(
10308
10330
  },
10309
10331
  }),
10310
10332
  draggableMixin,
10333
+ inputOverrideValidConstraintsMixin,
10311
10334
  composedProxyInputMixin({ proxyProps: ['value', 'selectionStart'] }),
10312
10335
  customMixin$9
10313
10336
  )(
@@ -10339,7 +10362,6 @@ const PhoneFieldInputBoxClass = compose$1(
10339
10362
  vaadin-text-field::part(input-field) {
10340
10363
  padding: 0;
10341
10364
  background: transparent;
10342
- overflow: hidden;
10343
10365
  -webkit-mask-image: none;
10344
10366
  }
10345
10367
  descope-phone-field-internal-input-box {
@@ -10350,14 +10372,20 @@ const PhoneFieldInputBoxClass = compose$1(
10350
10372
  descope-phone-field-internal-input-box > div {
10351
10373
  width: 100%;
10352
10374
  }
10353
- descope-phone-field-internal-input-box .separator {
10354
- flex: 0;
10355
- border: none;
10356
- }
10357
10375
  descope-phone-field-internal-input-box descope-text-field {
10358
10376
  ${textVars$1.inputOutlineWidth}: 0;
10359
10377
  ${textVars$1.inputOutlineOffset}: 0;
10360
10378
  }
10379
+ descope-phone-field-internal-input-box::after {
10380
+ content: '';
10381
+ position: absolute;
10382
+ width: 100%;
10383
+ height: 100%;
10384
+ top: 0;
10385
+ left: 0;
10386
+ box-sizing: border-box;
10387
+ pointer-events: none;
10388
+ }
10361
10389
  descope-text-field {
10362
10390
  flex-grow: 1;
10363
10391
  width: 100%;
@@ -18606,6 +18634,8 @@ const attrs = {
18606
18634
  'restrict-countries',
18607
18635
  'default-code',
18608
18636
  'phone-minlength',
18637
+ 'phone-format-value',
18638
+ 'phone-strict-validation',
18609
18639
  'data-errormessage-value-missing-phone',
18610
18640
  ],
18611
18641
  inputBox: [
@@ -18613,6 +18643,8 @@ const attrs = {
18613
18643
  'restrict-countries',
18614
18644
  'default-code',
18615
18645
  'phone-minlength',
18646
+ 'phone-format-value',
18647
+ 'phone-strict-validation',
18616
18648
  'data-errormessage-value-missing-phone',
18617
18649
  ],
18618
18650
  },
@@ -18626,6 +18658,8 @@ const attrMap = {
18626
18658
  phone: {
18627
18659
  'phone-input-label': 'label',
18628
18660
  'phone-minlength': 'minlength',
18661
+ 'phone-format-value': 'format-value',
18662
+ 'phone-strict-validation': 'strict-validation',
18629
18663
  'data-errormessage-value-missing-phone': 'data-errormessage-value-missing',
18630
18664
  },
18631
18665
  };
@@ -19838,7 +19872,7 @@ var addressField$1 = /*#__PURE__*/Object.freeze({
19838
19872
  vars: vars$3
19839
19873
  });
19840
19874
 
19841
- var clockIcon = "";
19875
+ var clockIcon = "";
19842
19876
 
19843
19877
  const fmt = (val, pad = 2) => String(val).padStart(pad, '0');
19844
19878
 
@@ -19859,7 +19893,7 @@ const formatTime = (ms = 0) => {
19859
19893
 
19860
19894
  const componentName$3 = getComponentName('timer');
19861
19895
 
19862
- const observedAttributes$1 = ['seconds', 'hide-icon'];
19896
+ const observedAttributes$1 = ['seconds', 'hide-icon', 'paused'];
19863
19897
 
19864
19898
  const BaseClass$2 = createBaseClass$1({
19865
19899
  componentName: componentName$3,
@@ -19917,57 +19951,63 @@ class RawTimer extends BaseClass$2 {
19917
19951
  return Math.max(0, secs);
19918
19952
  }
19919
19953
 
19954
+ // we use `pause` attribute for allowing preview mode by executing `pause`
19955
+ get isPaused() {
19956
+ return this.getAttribute('paused') === 'true';
19957
+ }
19958
+
19920
19959
  init() {
19921
19960
  super.init?.();
19922
19961
 
19923
19962
  this.#timeRemains = this.seconds;
19924
19963
  }
19925
19964
 
19926
- start() {
19927
- this.dispatchEvent(new CustomEvent('timer-started', { bubbles: true }));
19928
-
19929
- this.startInterval();
19930
- }
19931
-
19932
- startInterval() {
19965
+ startInterval() {
19933
19966
  const intervalCycle = () => {
19967
+ this.#decreaseInterval();
19968
+ if (!this.#timeRemains) this.stop();
19934
19969
  this.#updateDisplay(this.#timeRemains);
19935
-
19936
- if (!this.#timeRemains) {
19937
- this.stop();
19938
- } else {
19939
- this.#decreaseInterval();
19940
- }
19941
19970
  };
19942
19971
 
19943
- intervalCycle();
19944
-
19945
19972
  if (this.#timeRemains) {
19946
19973
  this.#intervalId = setInterval(intervalCycle, DEFAULT_INTERVAL);
19974
+ } else {
19975
+ this.stop();
19947
19976
  }
19948
19977
  }
19949
19978
 
19979
+ stopInterval() {
19980
+ clearInterval(this.#intervalId);
19981
+ }
19982
+
19950
19983
  #decreaseInterval() {
19951
- this.#timeRemains = Math.max(this.#timeRemains - DEFAULT_INTERVAL, 0);
19984
+ this.#timeRemains = this.#timeRemains - DEFAULT_INTERVAL;
19952
19985
  }
19953
19986
 
19954
19987
  reset() {
19955
19988
  this.#timeRemains = this.seconds;
19956
- this.start();
19989
+ this.#updateDisplay(this.#timeRemains);
19990
+
19991
+ if (this.isPaused) return;
19992
+
19993
+ this.dispatchEvent(new CustomEvent('timer-started', { bubbles: true }));
19994
+ this.startInterval();
19957
19995
  }
19958
19996
 
19959
19997
  stop() {
19960
- this.pause();
19998
+ this.stopInterval();
19961
19999
  this.#timeRemains = 0;
19962
20000
  this.#updateDisplay(this.#timeRemains);
19963
20001
  this.dispatchEvent(new CustomEvent('timer-ended', { bubbles: true }));
19964
20002
  }
19965
20003
 
19966
20004
  pause() {
19967
- clearInterval(this.#intervalId);
20005
+ this.setAttribute('paused', 'true');
20006
+ this.stopInterval();
19968
20007
  }
19969
20008
 
19970
20009
  resume() {
20010
+ this.removeAttribute('paused');
19971
20011
  this.startInterval();
19972
20012
  }
19973
20013
 
@@ -19979,6 +20019,19 @@ class RawTimer extends BaseClass$2 {
19979
20019
  this.icon.classList.toggle('hidden', val === 'true');
19980
20020
  }
19981
20021
 
20022
+ #handlePause(paused) {
20023
+ setTimeout(() => {
20024
+ if (paused) {
20025
+ this.pause();
20026
+ } else {
20027
+ // we want to prevent a another interval from starting in case previous interval was not yet cleared
20028
+ if (!this.#intervalId) {
20029
+ this.resume();
20030
+ }
20031
+ }
20032
+ });
20033
+ }
20034
+
19982
20035
  attributeChangedCallback(attrName, oldValue, newValue) {
19983
20036
  super.attributeChangedCallback?.(attrName, oldValue, newValue);
19984
20037
 
@@ -19989,28 +20042,31 @@ class RawTimer extends BaseClass$2 {
19989
20042
  if (attrName === 'hide-icon') {
19990
20043
  this.#toggleIcon(newValue);
19991
20044
  }
20045
+ if (attrName === 'paused') {
20046
+ this.#handlePause(newValue === 'true');
20047
+ }
19992
20048
  }
19993
20049
  }
19994
20050
  }
19995
20051
 
19996
20052
  const { host: host$1, icon, timer: timer$2 } = {
19997
20053
  host: { selector: () => ':host' },
19998
- icon: { selector: '.icon' },
19999
- timer: { selector: '.timer' },
20054
+ icon: { selector: () => '.icon' },
20055
+ timer: { selector: () => '.timer' },
20000
20056
  };
20001
20057
 
20002
20058
  const TimerClass = compose(
20003
20059
  createStyleMixin$1({
20004
20060
  mappings: {
20005
- backgroundColor: {},
20006
- fontSize: [{}, { ...icon }],
20061
+ fontSize: {},
20007
20062
  iconSize: [
20008
20063
  { ...icon, property: 'width' },
20009
20064
  { ...icon, property: 'height' },
20010
20065
  ],
20011
20066
  fontFamily: {},
20067
+ minHeight: {},
20012
20068
  fontWeight: { ...timer$2 },
20013
- lineHeight: { property: 'min-height' },
20069
+ lineHeight: { ...timer$2 },
20014
20070
  textColor: { ...timer$2, property: 'color' },
20015
20071
  gap: {},
20016
20072
  textAlign: { property: 'justify-content' },
@@ -20030,7 +20086,8 @@ const timer = {
20030
20086
  [vars$2.hostDirection]: globalRefs$1.direction,
20031
20087
  [vars$2.gap]: '0.25em',
20032
20088
  [vars$2.fontFamily]: globalRefs$1.fonts.font1.family,
20033
- [vars$2.lineHeight]: '2em',
20089
+ [vars$2.minHeight]: '1.5em',
20090
+ [vars$2.lineHeight]: '1em',
20034
20091
  [vars$2.fontWeight]: globalRefs$1.fonts.font1.fontWeight,
20035
20092
  [vars$2.textColor]: globalRefs$1.colors.surface.contrast,
20036
20093
  [vars$2.iconColor]: globalRefs$1.colors.surface.contrast,
@@ -20078,6 +20135,7 @@ const mapButtonAttrs = {
20078
20135
  const timerAttrs = [
20079
20136
  'timer-seconds',
20080
20137
  'timer-hide-icon',
20138
+ 'timer-paused',
20081
20139
  'size',
20082
20140
  'text-align',
20083
20141
  'full-width',
@@ -20086,6 +20144,7 @@ const timerAttrs = [
20086
20144
  const mapTimerAttrs = {
20087
20145
  'timer-seconds': 'seconds',
20088
20146
  'timer-hide-icon': 'hide-icon',
20147
+ 'timer-paused': 'paused',
20089
20148
  };
20090
20149
 
20091
20150
  const BaseClass$1 = createBaseClass$1({
@@ -20100,7 +20159,7 @@ class RawTimerButton extends BaseClass$1 {
20100
20159
  this.attachShadow({ mode: 'open' }).innerHTML = `
20101
20160
  <div class="wrapper">
20102
20161
  <descope-timer class="timer"></descope-timer>
20103
- <descope-button class="button">
20162
+ <descope-button class="button" disabled="true">
20104
20163
  <slot></slot>
20105
20164
  </descope-button>
20106
20165
  </div>
@@ -20146,6 +20205,14 @@ class RawTimerButton extends BaseClass$1 {
20146
20205
  includeAttrs: timerAttrs,
20147
20206
  mapAttrs: mapTimerAttrs,
20148
20207
  });
20208
+
20209
+ // When we sync attributes, the `disabled` attribute is being compared to the attribute
20210
+ // on Vaadin component; since the Vaadin component has no `disabled` attribute, we sync
20211
+ // that back to our component.
20212
+ // This is pending a more generic fix in the way we sync attibutes.
20213
+ this.button.shadowRoot
20214
+ .querySelector('vaadin-button')
20215
+ .setAttribute('disabled', 'true');
20149
20216
  }
20150
20217
 
20151
20218
  onTimerStarted() {
@@ -20161,9 +20228,11 @@ class RawTimerButton extends BaseClass$1 {
20161
20228
  }
20162
20229
 
20163
20230
  toggleButtonDisable(isDisabled) {
20164
- isDisabled
20165
- ? this.button.setAttribute('disabled', 'true')
20166
- : this.button.removeAttribute('disabled');
20231
+ setTimeout(() => {
20232
+ isDisabled
20233
+ ? this.button.setAttribute('disabled', 'true')
20234
+ : this.button.removeAttribute('disabled');
20235
+ });
20167
20236
  }
20168
20237
  }
20169
20238