@nectary/components 4.9.1 → 4.10.1
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/avatar/index.js +1 -1
- package/avatar/types.d.ts +19 -1
- package/button/index.js +23 -1
- package/button/types.d.ts +3 -0
- package/button/utils.d.ts +2 -1
- package/button/utils.js +2 -1
- package/card-v2/index.js +1 -1
- package/checkbox/index.js +40 -0
- package/checkbox/types.d.ts +4 -0
- package/date-picker/index.js +31 -1
- package/date-picker/types.d.ts +2 -0
- package/icon/generated-icon-type.d.ts +1 -1
- package/input/index.js +66 -3
- package/input/types.d.ts +3 -1
- package/package.json +3 -3
- package/radio/index.js +32 -1
- package/radio/types.d.ts +6 -1
- package/select-menu/index.js +35 -0
- package/select-menu/types.d.ts +2 -0
- package/textarea/index.js +33 -0
- package/textarea/types.d.ts +2 -0
- package/utils/form.d.ts +8 -0
- package/utils/form.js +36 -0
package/avatar/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { defineCustomElement, getAttribute, getLiteralAttribute, NectaryElement, updateAttribute, updateLiteralAttribute } from '../utils';
|
|
2
2
|
import { DEFAULT_SIZE, sizeValues } from '../utils/size';
|
|
3
|
-
const templateHTML = '<style>:host{display:inline-block;vertical-align:middle;outline:0}#wrapper{position:relative;width:var(--sinch-local-size);height:var(--sinch-local-size);
|
|
3
|
+
const templateHTML = '<style>:host{display:inline-block;vertical-align:middle;outline:0}#wrapper{position:relative;width:var(--sinch-local-size);height:var(--sinch-local-size);border-radius:var(--sinch-comp-avatar-shape-radius);--sinch-local-size:var(--sinch-comp-avatar-size-m)}:host([size="l"]) #wrapper{--sinch-local-size:var(--sinch-comp-avatar-size-l)}:host([size="s"]) #wrapper{--sinch-local-size:var(--sinch-comp-avatar-size-s)}#text{display:block;width:100%;height:100%;font:var(--sinch-comp-avatar-container-font-size-m-text);line-height:calc(var(--sinch-local-size) - 2px);text-transform:uppercase;text-align:center}:host([size="l"]) #text{font:var(--sinch-comp-avatar-container-font-size-l-text);line-height:calc(var(--sinch-local-size) - 2px)}:host([size="s"]) #text{font:var(--sinch-comp-avatar-container-font-size-s-text);line-height:calc(var(--sinch-local-size) - 2px)}#circle{position:relative;width:calc(100% - 2px);height:calc(100% - 2px);left:1px;top:1px;border-radius:50%;-webkit-mask:linear-gradient(#fff,#000);mask:linear-gradient(#fff,#000);background-color:var(--sinch-comp-avatar-container-color-default-background);color:var(--sinch-comp-avatar-container-color-default-foreground)}#image{display:none;position:absolute;left:0;top:0;width:100%;height:100%;object-fit:contain}:host([src]:not([src=""])) #image{display:block}#person{display:none;position:absolute;left:0;top:0;width:100%;height:100%;fill:var(--sinch-comp-avatar-container-color-default-foreground);opacity:.15}:host(:not([src]):is(:not([alt]),[alt=""])) #person{display:block}#status-wrapper{position:absolute;left:calc(85% - 5px);top:calc(85% - 5px);width:10px;height:10px;padding:1px;box-sizing:border-box;border-radius:50%;background-color:var(--sinch-comp-avatar-status-color-border);display:none;pointer-events:none}#status{width:8px;height:8px;border-radius:50%}:host([status=away]) #status-wrapper,:host([status=busy]) #status-wrapper,:host([status=offline]) #status-wrapper,:host([status=online]) #status-wrapper{display:block}:host([status=online]) #status{background-color:var(--sinch-comp-avatar-status-color-online-default-background)}:host([status=away]) #status{background-color:var(--sinch-comp-avatar-status-color-away-default-background)}:host([status=busy]) #status{background-color:var(--sinch-comp-avatar-status-color-busy-default-background)}:host([status=offline]) #status{background-color:var(--sinch-comp-avatar-status-color-offline-default-background)}</style><div id="wrapper"><div id="circle"><span id="text"></span><img id="image" alt=""/><svg id="person" viewBox="0 0 40 40" fill="none"><path d="M29.451 15.785a9.451 9.451 0 1 1-18.902 0 9.452 9.452 0 0 1 18.902 0ZM4.734 40.5c.119-7.085 5.899-12.792 13.012-12.792h4.508c7.113 0 12.893 5.707 13.012 12.792H4.734Z"/></svg></div><div id="status-wrapper"><div id="status"></div></div></div>';
|
|
4
4
|
import { getAvatarColorBg, getAvatarColorFg, statusValues } from './utils';
|
|
5
5
|
const template = document.createElement('template');
|
|
6
6
|
template.innerHTML = templateHTML;
|
package/avatar/types.d.ts
CHANGED
|
@@ -14,11 +14,29 @@ export type TSinchAvatarProps = {
|
|
|
14
14
|
size?: TSinchSize;
|
|
15
15
|
/** Status */
|
|
16
16
|
status?: TSinchAvatarStatus;
|
|
17
|
+
} & {
|
|
18
|
+
style?: {
|
|
19
|
+
'--sinch-comp-avatar-container-color-default-background'?: string;
|
|
20
|
+
'--sinch-comp-avatar-container-color-default-foreground'?: string;
|
|
21
|
+
'--sinch-comp-avatar-status-color-border'?: string;
|
|
22
|
+
'--sinch-comp-avatar-status-color-online-default-background'?: string;
|
|
23
|
+
'--sinch-comp-avatar-status-color-away-default-background'?: string;
|
|
24
|
+
'--sinch-comp-avatar-status-color-busy-default-background'?: string;
|
|
25
|
+
'--sinch-comp-avatar-status-color-offline-default-background'?: string;
|
|
26
|
+
'--sinch-comp-avatar-shape-radius'?: string;
|
|
27
|
+
'--sinch-comp-avatar-size-s'?: string;
|
|
28
|
+
'--sinch-comp-avatar-size-m'?: string;
|
|
29
|
+
'--sinch-comp-avatar-size-l'?: string;
|
|
30
|
+
'--sinch-comp-avatar-container-font-size-s-text'?: string;
|
|
31
|
+
'--sinch-comp-avatar-container-font-size-m-text'?: string;
|
|
32
|
+
'--sinch-comp-avatar-container-font-size-l-text'?: string;
|
|
33
|
+
'--sinch-local-size'?: string;
|
|
34
|
+
};
|
|
17
35
|
};
|
|
18
36
|
export type TSinchAvatarStyle = {
|
|
19
37
|
'--sinch-comp-avatar-container-color-default-background'?: string;
|
|
20
38
|
'--sinch-comp-avatar-container-color-default-foreground'?: string;
|
|
21
|
-
'--sinch-comp-avatar-
|
|
39
|
+
'--sinch-comp-avatar-status-color-border'?: string;
|
|
22
40
|
'--sinch-comp-avatar-status-color-online-default-background'?: string;
|
|
23
41
|
'--sinch-comp-avatar-status-color-away-default-background'?: string;
|
|
24
42
|
'--sinch-comp-avatar-status-color-busy-default-background'?: string;
|
package/button/index.js
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { defineCustomElement, getBooleanAttribute, getAttribute, isAttrTrue, updateBooleanAttribute, updateAttribute, NectaryElement, getReactEventHandler, getLiteralAttribute, updateLiteralAttribute, Context, subscribeContext, isAttrEqual } from '../utils';
|
|
2
|
+
import { requestSubmitForm } from '../utils/form';
|
|
2
3
|
import { DEFAULT_SIZE, sizeExValues } from '../utils/size';
|
|
3
4
|
const templateHTML = '<style>:host{display:inline-block;vertical-align:middle;outline:0;cursor:pointer;user-select:none;--sinch-button-shape-radius-base:var(--sinch-comp-button-shape-radius-size-m);--sinch-local-shadow:var(--sinch-comp-button-shadow-secondary-initial);--sinch-button-border:1px solid;--sinch-button-border-top:var(--sinch-button-border);--sinch-button-border-bottom:var(--sinch-button-border);--sinch-button-border-left:var(--sinch-button-border);--sinch-button-border-right:var(--sinch-button-border);--sinch-button-shape-radius-top-right:unset;--sinch-button-shape-radius-top-left:unset;--sinch-button-shape-radius-bottom-right:unset;--sinch-button-shape-radius-bottom-left:unset}:host([disabled]){cursor:initial}#button{all:initial;display:block;position:relative;width:100%;height:var(--sinch-local-size);user-select:none;--sinch-local-size:var(--sinch-comp-button-size-container-m);--sinch-local-padding:16px;--sinch-local-font:var(--sinch-comp-button-font-size-m-text);--sinch-global-size-icon:var(--sinch-comp-button-size-icon-m);--sinch-global-color-icon:var(--sinch-local-color-icon)}:host([data-size="l"])>#button{--sinch-local-size:var(--sinch-comp-button-size-container-l);--sinch-button-set-size-shape-radius:var(--sinch-comp-button-shape-radius-size-l);--sinch-local-font:var(--sinch-comp-button-font-size-l-text);--sinch-global-size-icon:var(--sinch-comp-button-size-icon-l)}:host([data-size="m"])>#button{--sinch-local-size:var(--sinch-comp-button-size-container-m);--sinch-button-set-size-shape-radius:var(--sinch-comp-button-shape-radius-size-m);--sinch-local-font:var(--sinch-comp-button-font-size-m-text);--sinch-global-size-icon:var(--sinch-comp-button-size-icon-m)}:host([data-size="s"])>#button{--sinch-local-size:var(--sinch-comp-button-size-container-s);--sinch-button-set-size-shape-radius:var(--sinch-comp-button-shape-radius-size-s);--sinch-local-font:var(--sinch-comp-button-font-size-s-text);--sinch-global-size-icon:var(--sinch-comp-button-size-icon-s)}:host([data-size=xs])>#button{--sinch-local-size:var(--sinch-comp-button-size-container-xs);--sinch-local-padding:8px;--sinch-button-set-size-shape-radius:var(--sinch-comp-button-shape-radius-size-xs);--sinch-local-font:var(--sinch-comp-button-font-size-s-text);--sinch-global-size-icon:var(--sinch-comp-button-size-icon-xs)}:host(:is([text=""],:not([text])))>#button{--sinch-local-padding:8px}:host([data-size="s"]:is([text=""],:not([text])))>#button{--sinch-local-padding:4px}:host([data-size=xs]:is([text=""],:not([text])))>#button{--sinch-local-padding:4px}:host([type=primary])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-primary-default-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-primary-default-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-primary-default-text-initial);--sinch-local-color-icon:var(--sinch-comp-button-color-primary-default-icon-initial);--sinch-local-color-outline-focus:var(--sinch-comp-button-color-primary-default-outline-focus);--sinch-local-shadow:var(--sinch-comp-button-shadow-primary-initial)}:host(:not([type]))>#button,:host([type=secondary])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-secondary-default-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-secondary-default-border-initial);--sinch-local-color-outline-focus:var(--sinch-comp-button-color-secondary-default-outline-focus);--sinch-local-color-text:var(--sinch-comp-button-color-secondary-default-text-initial);--sinch-local-color-icon:var(--sinch-comp-button-color-secondary-default-icon-initial)}:host([type=subtle-primary])>#button,:host([type=tertiary])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-primary-default-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-subtle-primary-default-border-initial);--sinch-local-color-outline-focus:var(--sinch-comp-button-color-subtle-primary-default-outline-focus);--sinch-local-color-text:var(--sinch-comp-button-color-subtle-primary-default-text-initial);--sinch-local-color-icon:var(--sinch-comp-button-color-subtle-primary-default-icon-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-initial)}:host(:not([type]):is([text=""],:not([text])))>#button,:host([type=subtle-secondary])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-secondary-default-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-subtle-secondary-default-border-initial);--sinch-local-color-outline-focus:var(--sinch-comp-button-color-subtle-secondary-default-outline-focus);--sinch-local-color-text:var(--sinch-comp-button-color-subtle-secondary-default-text-initial);--sinch-local-color-icon:var(--sinch-comp-button-color-subtle-secondary-default-icon-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-initial)}:host([type=cta-primary])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-cta-primary-default-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-cta-primary-default-border-initial);--sinch-local-color-outline-focus:var(--sinch-comp-button-color-cta-primary-default-outline-focus);--sinch-local-color-text:var(--sinch-comp-button-color-cta-primary-default-text-initial);--sinch-local-color-icon:var(--sinch-comp-button-color-cta-primary-default-icon-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-primary-initial)}:host([type=cta-secondary])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-cta-secondary-default-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-cta-secondary-default-border-initial);--sinch-local-color-outline-focus:var(--sinch-comp-button-color-cta-secondary-default-outline-focus);--sinch-local-color-text:var(--sinch-comp-button-color-cta-secondary-default-text-initial);--sinch-local-color-icon:var(--sinch-comp-button-color-cta-secondary-default-icon-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-secondary-initial)}:host([type=destructive])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-danger-default-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-danger-default-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-danger-default-text-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-danger-initial);--sinch-global-color-icon:var(--sinch-comp-button-color-danger-default-icon-initial)}:host([type=primary]:focus-visible)>#button{--sinch-local-shadow:var(--sinch-comp-button-shadow-primary-focus)}:host(:not([type]):focus-visible)>#button,:host([type=secondary]:focus-visible)>#button{--sinch-local-shadow:var(--sinch-comp-button-shadow-secondary-focus)}:host([type=subtle-primary]:focus-visible)>#button,:host([type=tertiary]:focus-visible)>#button{--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-focus)}:host(:not([type]):is([text=""],:not([text])):focus-visible)>#button,:host([type=subtle-secondary]:focus-visible)>#button{--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-focus)}:host([type=cta-primary]:focus-visible)>#button{--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-primary-focus)}:host([type=cta-secondary]:focus-visible)>#button{--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-secondary-focus)}:host([type=destructive]:focus-visible)>#button{--sinch-local-shadow:var(--sinch-comp-button-shadow-danger-focus)}:host([toggled]:not([disabled])[type=subtle-primary])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-primary-toggled-background-initial)}:host([toggled]:not([disabled]):not([type]):is([text=""],:not([text])))>#button,:host([toggled]:not([disabled])[type=subtle-secondary])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-secondary-toggled-background-initial)}:host([type=primary]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-primary-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-primary-hover)}:host([type=primary]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-primary-default-background-active);--sinch-local-shadow:var(--sinch-comp-button-shadow-primary-active)}:host(:not([type]):hover)>#button,:host([type=secondary]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-secondary-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-secondary-hover)}:host(:not([type]):active)>#button,:host([type=secondary]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-secondary-default-background-active)}:host([type=subtle-primary]:hover)>#button,:host([type=tertiary]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-primary-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-hover)}:host([type=subtle-primary]:active)>#button,:host([type=tertiary]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-primary-default-background-active);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-active)}:host(:not([type]):is([text=""],:not([text])):hover)>#button,:host([type=subtle-secondary]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-secondary-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-hover)}:host(:not([type]):is([text=""],:not([text])):active)>#button,:host([type=subtle-secondary]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-secondary-default-background-active);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-active)}:host([type=cta-primary]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-cta-primary-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-primary-hover)}:host([type=cta-primary]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-cta-primary-default-background-active);--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-primary-active)}:host([type=cta-secondary]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-cta-secondary-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-secondary-hover)}:host([type=cta-secondary]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-cta-secondary-default-background-active);--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-secondary-active)}:host([type=destructive]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-danger-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-danger-hover)}:host([type=destructive]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-danger-default-background-active);--sinch-local-shadow:var(--sinch-comp-button-shadow-danger-active)}:host([toggled]:not([disabled])[type=subtle-primary]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-primary-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-hover)}:host([toggled]:not([disabled])[type=subtle-primary]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-primary-default-background-active);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-active)}:host([toggled]:not([disabled]):not([type]):is([text=""],:not([text])):hover)>#button,:host([toggled]:not([disabled])[type=subtle-secondary]:hover)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-secondary-default-background-hover);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-hover)}:host([toggled]:not([disabled]):not([type]):is([text=""],:not([text])):active)>#button,:host([toggled]:not([disabled])[type=subtle-secondary]:active)>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-secondary-default-background-active);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-active)}:host([type=primary][disabled])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-primary-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-primary-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-primary-disabled-text-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-primary-disabled);--sinch-global-color-icon:var(--sinch-comp-button-color-primary-disabled-icon-initial)}:host(:not([type])[disabled])>#button,:host([type=secondary][disabled])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-secondary-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-secondary-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-secondary-disabled-text-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-secondary-disabled);--sinch-global-color-icon:var(--sinch-comp-button-color-secondary-disabled-icon-initial)}:host([type=subtle-primary][disabled])>#button,:host([type=tertiary][disabled])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-primary-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-subtle-primary-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-subtle-primary-disabled-text-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-disabled);--sinch-global-color-icon:var(--sinch-comp-button-color-subtle-primary-disabled-icon-initial)}:host(:not([type]):is([text=""],:not([text]))[disabled])>#button,:host([type=subtle-secondary][disabled])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-subtle-secondary-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-subtle-secondary-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-subtle-secondary-disabled-text-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-subtle-disabled);--sinch-global-color-icon:var(--sinch-comp-button-color-subtle-secondary-disabled-icon-initial)}:host([type=cta-primary][disabled])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-cta-primary-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-cta-primary-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-cta-primary-disabled-text-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-primary-disabled);--sinch-global-color-icon:var(--sinch-comp-button-color-cta-primary-disabled-icon-initial)}:host([type=cta-secondary][disabled])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-cta-secondary-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-cta-secondary-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-cta-secondary-disabled-text-initial);--sinch-local-shadow:var(--sinch-comp-button-shadow-cta-secondary-disabled);--sinch-global-color-icon:var(--sinch-comp-button-color-cta-secondary-disabled-icon-initial)}:host([type=destructive][disabled])>#button{--sinch-local-color-background:var(--sinch-comp-button-color-danger-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-button-color-danger-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-button-color-danger-disabled-text-initial);--sinch-global-color-icon:var(--sinch-comp-button-color-danger-disabled-icon-initial)}#button::before{content:"";position:absolute;inset:0;background-color:var(--sinch-local-color-background);border-top:var(--sinch-button-border-top);border-bottom:var(--sinch-button-border-bottom);border-right:var(--sinch-button-border-right);border-left:var(--sinch-button-border-left);border-color:var(--sinch-local-color-border);border-top-right-radius:var(--sinch-button-shape-radius-top-right,var(--sinch-button-set-size-shape-radius,var(--sinch-button-shape-radius-base)));border-top-left-radius:var(--sinch-button-shape-radius-top-left,var(--sinch-button-set-size-shape-radius,var(--sinch-button-shape-radius-base)));border-bottom-right-radius:var(--sinch-button-shape-radius-bottom-right,var(--sinch-button-set-size-shape-radius,var(--sinch-button-shape-radius-base)));border-bottom-left-radius:var(--sinch-button-shape-radius-bottom-left,var(--sinch-button-set-size-shape-radius,var(--sinch-button-shape-radius-base)));box-shadow:var(--sinch-local-shadow);pointer-events:none}:host(:not([disabled]):active) #button::before{border-width:2px}:host(:focus-visible) #button::after{position:absolute;content:"";inset:-3px;border:2px solid var(--sinch-local-color-outline-focus);border-top-right-radius:calc(var(--sinch-button-shape-radius-top-right,var(--sinch-button-set-size-shape-radius,var(--sinch-button-shape-radius-base))) + 3px);border-top-left-radius:calc(var(--sinch-button-shape-radius-top-left,var(--sinch-button-set-size-shape-radius,var(--sinch-button-shape-radius-base))) + 3px);border-bottom-right-radius:calc(var(--sinch-button-shape-radius-bottom-right,var(--sinch-button-set-size-shape-radius,var(--sinch-button-shape-radius-base))) + 3px);border-bottom-left-radius:calc(var(--sinch-button-shape-radius-bottom-left,var(--sinch-button-set-size-shape-radius,var(--sinch-button-shape-radius-base))) + 3px);pointer-events:none}#content{position:relative;display:flex;align-items:center;justify-content:center;gap:12px;width:100%;height:100%;padding:0 var(--sinch-local-padding);box-sizing:border-box;pointer-events:none;overflow:hidden}#text{font:var(--sinch-local-font);color:var(--sinch-local-color-text);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;min-width:0}:host(:is([text=""],:not([text]))) :is(#left-icon,#right-icon,#text){display:none}::slotted(*){display:block}</style><div id="button" inert><div id="content"><slot id="left-icon" name="left-icon"></slot><slot id="icon" name="icon"></slot><span id="text"></span><slot id="right-icon" name="right-icon"></slot></div></div>';
|
|
4
|
-
import { typeValues } from './utils';
|
|
5
|
+
import { typeValues, formTypeValues } from './utils';
|
|
5
6
|
const template = document.createElement('template');
|
|
6
7
|
template.innerHTML = templateHTML;
|
|
7
8
|
defineCustomElement('sinch-button', class extends NectaryElement {
|
|
@@ -9,10 +10,13 @@ defineCustomElement('sinch-button', class extends NectaryElement {
|
|
|
9
10
|
#$text;
|
|
10
11
|
#controller = null;
|
|
11
12
|
#sizeContext;
|
|
13
|
+
#internals;
|
|
14
|
+
static formAssociated = true;
|
|
12
15
|
constructor() {
|
|
13
16
|
super();
|
|
14
17
|
const shadowRoot = this.attachShadow();
|
|
15
18
|
shadowRoot.appendChild(template.content.cloneNode(true));
|
|
19
|
+
this.#internals = this.attachInternals();
|
|
16
20
|
this.#$button = shadowRoot.querySelector('#button');
|
|
17
21
|
this.#$text = shadowRoot.querySelector('#text');
|
|
18
22
|
this.#sizeContext = new Context(this.#$button, 'size');
|
|
@@ -24,6 +28,7 @@ defineCustomElement('sinch-button', class extends NectaryElement {
|
|
|
24
28
|
signal
|
|
25
29
|
} = this.#controller;
|
|
26
30
|
this.setAttribute('role', 'button');
|
|
31
|
+
this.#internals.role = 'button';
|
|
27
32
|
this.tabIndex = 0;
|
|
28
33
|
this.addEventListener('click', this.#onButtonClick, {
|
|
29
34
|
signal
|
|
@@ -71,6 +76,7 @@ defineCustomElement('sinch-button', class extends NectaryElement {
|
|
|
71
76
|
updateBooleanAttribute(this, 'disabled', isAttrTrue(newVal));
|
|
72
77
|
}
|
|
73
78
|
this.ariaDisabled = isAttrTrue(newVal).toString();
|
|
79
|
+
this.#internals.ariaDisabled = isAttrTrue(newVal).toString();
|
|
74
80
|
break;
|
|
75
81
|
}
|
|
76
82
|
case 'toggled':
|
|
@@ -79,6 +85,7 @@ defineCustomElement('sinch-button', class extends NectaryElement {
|
|
|
79
85
|
updateBooleanAttribute(this, 'toggled', isAttrTrue(newVal));
|
|
80
86
|
}
|
|
81
87
|
this.ariaPressed = isAttrTrue(newVal).toString();
|
|
88
|
+
this.#internals.ariaPressed = isAttrTrue(newVal).toString();
|
|
82
89
|
break;
|
|
83
90
|
}
|
|
84
91
|
case 'size':
|
|
@@ -126,6 +133,12 @@ defineCustomElement('sinch-button', class extends NectaryElement {
|
|
|
126
133
|
get focusable() {
|
|
127
134
|
return true;
|
|
128
135
|
}
|
|
136
|
+
set formType(value) {
|
|
137
|
+
updateLiteralAttribute(this, formTypeValues, 'form-type', value);
|
|
138
|
+
}
|
|
139
|
+
get formType() {
|
|
140
|
+
return getLiteralAttribute(this, formTypeValues, 'form-type', 'button');
|
|
141
|
+
}
|
|
129
142
|
#onSizeUpdate() {
|
|
130
143
|
if (!this.isDomConnected) {
|
|
131
144
|
return;
|
|
@@ -164,6 +177,15 @@ defineCustomElement('sinch-button', class extends NectaryElement {
|
|
|
164
177
|
e.stopPropagation();
|
|
165
178
|
e.preventDefault();
|
|
166
179
|
} else {
|
|
180
|
+
const form = this.#internals.form;
|
|
181
|
+
if (form !== null) {
|
|
182
|
+
if (this.formType === 'submit') {
|
|
183
|
+
requestSubmitForm(form, this);
|
|
184
|
+
}
|
|
185
|
+
if (this.formType === 'reset') {
|
|
186
|
+
form.reset();
|
|
187
|
+
}
|
|
188
|
+
}
|
|
167
189
|
this.dispatchEvent(new CustomEvent('-click'));
|
|
168
190
|
}
|
|
169
191
|
};
|
package/button/types.d.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { NectaryComponentReactByType, NectaryComponentVanillaByType } from '../types';
|
|
2
2
|
import type { TSinchSizeEx } from '../utils/size';
|
|
3
|
+
export type TSinchButtonFormType = 'submit' | 'reset' | 'button';
|
|
3
4
|
export type TSinchButtonType = 'primary' | 'secondary'
|
|
4
5
|
/** @deprecated */
|
|
5
6
|
| 'tertiary' | 'subtle-primary' | 'subtle-secondary' | 'cta-primary' | 'cta-secondary' | 'destructive';
|
|
@@ -16,6 +17,8 @@ export type TSinchButtonProps = {
|
|
|
16
17
|
disabled?: boolean;
|
|
17
18
|
/** Toggled (pressed) */
|
|
18
19
|
toggled?: boolean;
|
|
20
|
+
/** Makes button participate in forms, `button` by default */
|
|
21
|
+
'form-type'?: TSinchButtonFormType;
|
|
19
22
|
};
|
|
20
23
|
export type TSinchButtonEvents = {
|
|
21
24
|
/** Click event handler */
|
package/button/utils.d.ts
CHANGED
package/button/utils.js
CHANGED
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export const typeValues = ['primary', 'secondary', 'subtle-primary', 'subtle-secondary', 'cta-primary', 'cta-secondary', 'destructive'];
|
|
1
|
+
export const typeValues = ['primary', 'secondary', 'subtle-primary', 'subtle-secondary', 'cta-primary', 'cta-secondary', 'destructive'];
|
|
2
|
+
export const formTypeValues = ['submit', 'reset', 'button'];
|
package/card-v2/index.js
CHANGED
|
@@ -112,7 +112,7 @@ defineCustomElement('sinch-card-v2', class extends NectaryElement {
|
|
|
112
112
|
{
|
|
113
113
|
const bool = isAttrTrue(newVal);
|
|
114
114
|
const titleElement = this.querySelector('sinch-card-v2-title');
|
|
115
|
-
if (titleElement
|
|
115
|
+
if (titleElement !== null) {
|
|
116
116
|
updateBooleanAttribute(titleElement, name, bool);
|
|
117
117
|
}
|
|
118
118
|
break;
|
package/checkbox/index.js
CHANGED
|
@@ -1,15 +1,19 @@
|
|
|
1
1
|
import '../rich-text';
|
|
2
2
|
import { defineCustomElement, getAttribute, getBooleanAttribute, getReactEventHandler, isAttrEqual, isAttrTrue, NectaryElement, updateAttribute, updateBooleanAttribute, updateExplicitBooleanAttribute } from '../utils';
|
|
3
|
+
import { setFormValue } from '../utils/form';
|
|
3
4
|
const templateHTML = '<style>:host{display:inline-block;vertical-align:middle;outline:0}#wrapper{display:flex;flex-direction:row;box-sizing:border-box;width:100%;min-height:24px;--sinch-local-color-background:var(--sinch-comp-checkbox-color-default-background-initial);--sinch-local-color-background-hover:var(--sinch-comp-checkbox-color-default-background-hover);--sinch-local-color-background-active:var(--sinch-comp-checkbox-color-default-background-active);--sinch-local-color-border:var(--sinch-comp-checkbox-color-default-border-initial);--sinch-local-color-border-hover:var(--sinch-comp-checkbox-color-default-border-hover);--sinch-local-color-border-active:var(--sinch-comp-checkbox-color-default-border-active);--sinch-local-color-text:var(--sinch-comp-checkbox-color-default-text-initial)}:host([invalid])>#wrapper{--sinch-local-color-background:var(--sinch-comp-checkbox-color-invalid-background-initial);--sinch-local-color-background-hover:var(--sinch-comp-checkbox-color-invalid-background-hover);--sinch-local-color-background-active:var(--sinch-comp-checkbox-color-invalid-background-active);--sinch-local-color-border:var(--sinch-comp-checkbox-color-invalid-border-initial);--sinch-local-color-border-hover:var(--sinch-comp-checkbox-color-invalid-border-hover);--sinch-local-color-border-active:var(--sinch-comp-checkbox-color-invalid-border-active);--sinch-local-color-text:var(--sinch-comp-checkbox-color-invalid-text-initial)}:host([checked])>#wrapper{--sinch-local-color-background:var(--sinch-comp-checkbox-color-checked-background-initial);--sinch-local-color-background-hover:var(--sinch-comp-checkbox-color-checked-background-hover);--sinch-local-color-background-active:var(--sinch-comp-checkbox-color-checked-background-active);--sinch-local-color-border:var(--sinch-comp-checkbox-color-checked-border-initial);--sinch-local-color-border-hover:var(--sinch-comp-checkbox-color-checked-border-hover);--sinch-local-color-border-active:var(--sinch-comp-checkbox-color-checked-border-active)}:host([disabled])>#wrapper{--sinch-local-color-background:var(--sinch-comp-checkbox-color-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-checkbox-color-disabled-border-initial);--sinch-local-color-text:var(--sinch-comp-checkbox-color-disabled-text-initial)}:host([disabled][checked])>#wrapper{--sinch-local-color-background:var(--sinch-comp-checkbox-color-checked-disabled-background-initial);--sinch-local-color-border:var(--sinch-comp-checkbox-color-checked-disabled-border-initial)}#checkbox{width:18px;height:18px;cursor:pointer}:host([disabled]) #checkbox{cursor:initial}#icon-container{position:relative;width:18px;height:18px;align-self:flex-start;margin-top:3px}#checkbox::before{content:"";position:absolute;inset:-3px;border:2px solid var(--sinch-comp-checkbox-color-default-outline-focus);border-radius:calc(var(--sinch-comp-checkbox-shape-radius) + 3px);transition:opacity .1s linear;opacity:0;box-sizing:border-box;pointer-events:none}:host(:focus-visible) #checkbox::before{opacity:1}#checkbox::after{content:"";position:absolute;width:18px;height:18px;inset:0;margin:auto;background-color:var(--sinch-local-color-background);border:1px solid var(--sinch-local-color-border);border-radius:var(--sinch-comp-checkbox-shape-radius);transition:background-color .1s linear;box-sizing:border-box;pointer-events:none}:host(:hover:not([disabled])) #checkbox::after{background-color:var(--sinch-local-color-background-hover);border-color:var(--sinch-local-color-border-hover)}:host(:active:not([disabled])) #checkbox::after{background-color:var(--sinch-local-color-background-active);border-color:var(--sinch-local-color-border-active)}#icon-checkmark,#icon-indeterminate{position:absolute;left:1px;top:1px;width:16px;height:16px;transition:opacity .1s linear;opacity:0;pointer-events:none;fill:var(--sinch-sys-color-surface-primary-default)}:host(:not([indeterminate])[checked]) #icon-checkmark{opacity:1}:host([indeterminate][checked]) #icon-indeterminate{opacity:1}@media (prefers-reduced-motion){#checkbox::after,#checkbox::before,#icon-checkmark,#icon-indeterminate{transition:none}}#label{flex:1;align-self:center;padding-left:8px;font:var(--sinch-comp-checkbox-font-label);cursor:pointer;--sinch-global-color-text:var(--sinch-local-color-text)}:host(:not([text])) #label,:host([text=""]) #label{display:none}:host([disabled]) #label{cursor:initial}</style><div id="wrapper"><div id="icon-container"><div id="checkbox"></div><svg id="icon-checkmark" viewBox="0 0 24 24" aria-hidden="true"><path d="M9 16.17 5.53 12.7a.996.996 0 1 0-1.41 1.41l4.18 4.18c.39.39 1.02.39 1.41 0L20.29 7.71a.996.996 0 1 0-1.41-1.41L9 16.17Z"/></svg><svg id="icon-indeterminate" viewBox="0 0 24 24" aria-hidden="true"><path d="M18 13H6c-.55 0-1-.45-1-1s.45-1 1-1h12c.55 0 1 .45 1 1s-.45 1-1 1Z"/></svg></div><sinch-rich-text id="label"></sinch-rich-text></div>';
|
|
4
5
|
const template = document.createElement('template');
|
|
5
6
|
template.innerHTML = templateHTML;
|
|
6
7
|
defineCustomElement('sinch-checkbox', class extends NectaryElement {
|
|
7
8
|
#$label;
|
|
8
9
|
#controller = null;
|
|
10
|
+
#internals;
|
|
11
|
+
static formAssociated = true;
|
|
9
12
|
constructor() {
|
|
10
13
|
super();
|
|
11
14
|
const shadowRoot = this.attachShadow();
|
|
12
15
|
shadowRoot.appendChild(template.content.cloneNode(true));
|
|
16
|
+
this.#internals = this.attachInternals();
|
|
13
17
|
this.#$label = shadowRoot.querySelector('#label');
|
|
14
18
|
}
|
|
15
19
|
connectedCallback() {
|
|
@@ -21,6 +25,7 @@ defineCustomElement('sinch-checkbox', class extends NectaryElement {
|
|
|
21
25
|
signal
|
|
22
26
|
};
|
|
23
27
|
this.setAttribute('role', 'checkbox');
|
|
28
|
+
this.#internals.role = 'checkbox';
|
|
24
29
|
this.tabIndex = 0;
|
|
25
30
|
this.addEventListener('click', this.#onClick, options);
|
|
26
31
|
this.addEventListener('focus', this.#onFocus, options);
|
|
@@ -33,6 +38,26 @@ defineCustomElement('sinch-checkbox', class extends NectaryElement {
|
|
|
33
38
|
this.#controller.abort();
|
|
34
39
|
this.#controller = null;
|
|
35
40
|
}
|
|
41
|
+
formAssociatedCallback() {
|
|
42
|
+
setFormValue(this.#internals, this.#getFormValue());
|
|
43
|
+
}
|
|
44
|
+
formResetCallback() {
|
|
45
|
+
this.checked = false;
|
|
46
|
+
setFormValue(this.#internals, '');
|
|
47
|
+
}
|
|
48
|
+
formStateRestoreCallback(state) {
|
|
49
|
+
if (this.#internals.form === null || getBooleanAttribute(this.#internals.form, 'data-form-state-restore') === false) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
if (state !== null) {
|
|
53
|
+
const value = typeof state === 'string' ? state : state.get(this.name);
|
|
54
|
+
this.checked = (value?.toString() ?? '').length > 0;
|
|
55
|
+
setFormValue(this.#internals, this.#getFormValue());
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
#getFormValue() {
|
|
59
|
+
return this.checked ? this.value.length > 0 ? this.value : 'on' : '';
|
|
60
|
+
}
|
|
36
61
|
static get observedAttributes() {
|
|
37
62
|
return ['checked', 'disabled', 'text', 'invalid', 'indeterminate'];
|
|
38
63
|
}
|
|
@@ -51,12 +76,15 @@ defineCustomElement('sinch-checkbox', class extends NectaryElement {
|
|
|
51
76
|
const isChecked = isAttrTrue(newVal);
|
|
52
77
|
updateExplicitBooleanAttribute(this, 'aria-checked', isChecked);
|
|
53
78
|
updateBooleanAttribute(this, 'checked', isChecked);
|
|
79
|
+
this.#internals.ariaChecked = isChecked.toString();
|
|
80
|
+
setFormValue(this.#internals, this.#getFormValue());
|
|
54
81
|
break;
|
|
55
82
|
}
|
|
56
83
|
case 'disabled':
|
|
57
84
|
{
|
|
58
85
|
const isDisabled = isAttrTrue(newVal);
|
|
59
86
|
updateExplicitBooleanAttribute(this, 'aria-disabled', isDisabled);
|
|
87
|
+
this.#internals.ariaDisabled = isDisabled.toString();
|
|
60
88
|
updateBooleanAttribute(this, 'disabled', isDisabled);
|
|
61
89
|
break;
|
|
62
90
|
}
|
|
@@ -68,6 +96,18 @@ defineCustomElement('sinch-checkbox', class extends NectaryElement {
|
|
|
68
96
|
}
|
|
69
97
|
}
|
|
70
98
|
}
|
|
99
|
+
set name(value) {
|
|
100
|
+
updateAttribute(this, 'name', value);
|
|
101
|
+
}
|
|
102
|
+
get name() {
|
|
103
|
+
return getAttribute(this, 'name', '');
|
|
104
|
+
}
|
|
105
|
+
set value(value) {
|
|
106
|
+
updateAttribute(this, 'value', value);
|
|
107
|
+
}
|
|
108
|
+
get value() {
|
|
109
|
+
return getAttribute(this, 'value', '');
|
|
110
|
+
}
|
|
71
111
|
set checked(isChecked) {
|
|
72
112
|
updateBooleanAttribute(this, 'checked', isChecked);
|
|
73
113
|
}
|
package/checkbox/types.d.ts
CHANGED
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
import type { NectaryComponentReactByType, NectaryComponentVanillaByType } from '../types';
|
|
2
2
|
export type TSinchCheckboxProps = {
|
|
3
|
+
/** Identification for uncontrolled form submissions */
|
|
4
|
+
name?: string;
|
|
5
|
+
/** Value for uncontrolled form submissions, default: `on` if checked */
|
|
6
|
+
value?: string;
|
|
3
7
|
/** Checked */
|
|
4
8
|
checked?: boolean;
|
|
5
9
|
/** Indeterminate */
|
package/date-picker/index.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import '../icon';
|
|
2
2
|
import '../text';
|
|
3
3
|
import { defineCustomElement, getAttribute, getBooleanAttribute, getReactEventHandler, getRect, getTargetAttribute, isAttrTrue, NectaryElement, packCsv, setClass, unpackCsv, updateAttribute, updateBooleanAttribute } from '../utils';
|
|
4
|
+
import { setFormValue } from '../utils/form';
|
|
4
5
|
const templateHTML = '<style>:host{display:block;outline:0}#content{width:fit-content;box-sizing:border-box;padding:16px;display:flex;flex-direction:column;gap:8px}#month{display:flex;flex-direction:column;row-gap:8px}.week{display:flex;flex-direction:row;column-gap:8px}.week.empty{display:none}.day{all:initial;font:var(--sinch-comp-date-picker-font-day);width:24px;height:24px;line-height:22px;color:var(--sinch-comp-date-picker-day-color-default-text-initial);background-color:var(--sinch-comp-date-picker-day-color-default-background-initial);border:1px solid var(--sinch-comp-date-picker-day-color-default-border-initial);border-radius:var(--sinch-comp-date-picker-day-shape-radius);text-align:center;box-sizing:border-box;user-select:none;cursor:pointer}.day:focus-visible{outline:1px solid var(--sinch-comp-date-picker-day-color-default-outline-focus);outline-offset:1px}.day:disabled{cursor:initial;color:var(--sinch-comp-date-picker-day-color-disabled-text-initial)}.day:enabled:hover{background-color:var(--sinch-comp-date-picker-day-color-default-background-hover)}.day:enabled.range{background-color:var(--sinch-comp-date-picker-day-color-default-range-background)}.day:enabled.selected{color:var(--sinch-comp-date-picker-day-color-checked-text-initial);background-color:var(--sinch-comp-date-picker-day-color-checked-background-initial);border-color:var(--sinch-comp-date-picker-day-color-checked-border-initial)}.day.today{font:var(--sinch-comp-date-picker-font-today);color:var(--sinch-comp-date-picker-today-color-default-text-initial);background-color:var(--sinch-comp-date-picker-today-color-default-background-initial);border-color:var(--sinch-comp-date-picker-today-color-default-border-initial)}.day.today:hover{background-color:var(--sinch-comp-date-picker-today-color-default-background-hover)}.day.today:disabled{color:var(--sinch-comp-date-picker-today-color-disabled-text-initial);border-color:var(--sinch-comp-date-picker-today-color-disabled-border-initial)}.day.today.selected{color:var(--sinch-comp-date-picker-today-color-checked-text-initial);background-color:var(--sinch-comp-date-picker-today-color-checked-background-initial);border-color:var(--sinch-comp-date-picker-today-color-checked-border-initial)}#week-day-names{display:flex;flex-direction:row;gap:8px;height:24px}.week-day-name{font:var(--sinch-comp-date-picker-font-weekday);color:var(--sinch-comp-date-picker-weekday-color-default-text-initial);text-align:center;width:24px;height:24px;line-height:24px;user-select:none;text-transform:uppercase}#content-header{display:flex;flex-direction:row;height:32px;align-items:center}#date{flex:1;text-align:center;text-transform:capitalize;--sinch-com-text-font:var(--sinch-comp-date-picker-font-header);--sinch-global-color-text:var(--sinch-comp-date-picker-header-color-default-text-initial)}#prev-year{margin-left:-4px}#next-year{margin-right:-4px}</style><div id="content"><div id="content-header"><sinch-button id="prev-year" size="s"><sinch-icon icons-version="2" name="fa-angles-left" id="icon-prev-year" slot="icon"></sinch-icon></sinch-button><sinch-button id="prev-month" size="s"><sinch-icon icons-version="2" name="fa-angle-left" id="icon-prev-month" slot="icon"></sinch-icon></sinch-button><sinch-text id="date" type="m" emphasized aria-live="polite"></sinch-text><sinch-button id="next-month" size="s"><sinch-icon icons-version="2" name="fa-angle-right" id="icon-next-month" slot="icon"></sinch-icon></sinch-button><sinch-button id="next-year" size="s"><sinch-icon icons-version="2" name="fa-angles-right" id="icon-next-year" slot="icon"></sinch-icon></sinch-button></div><div id="week-day-names"><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div><div class="week-day-name"></div></div><div id="month"><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div><div class="week"><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button><button class="day"></button></div></div></div>';
|
|
5
6
|
import { areDatesEqual, canGoNextMonth, canGoNextYear, canGoPrevMonth, canGoPrevYear, clampMaxDate, clampMinDate, cloneDate, dateToIso, decMonth, decYear, getCalendarMonth, getDayNames, getMonthNames, incMonth, incYear, isDateBetween, isDateOnScreen, isoToDate, isValidDate, sortDates, today } from './utils';
|
|
6
7
|
const template = document.createElement('template');
|
|
@@ -23,10 +24,15 @@ defineCustomElement('sinch-date-picker', class extends NectaryElement {
|
|
|
23
24
|
#monthNames;
|
|
24
25
|
#controller = null;
|
|
25
26
|
#isHoverSubscribed = false;
|
|
27
|
+
#internals;
|
|
28
|
+
static formAssociated = true;
|
|
26
29
|
constructor() {
|
|
27
30
|
super();
|
|
28
|
-
const shadowRoot = this.attachShadow(
|
|
31
|
+
const shadowRoot = this.attachShadow({
|
|
32
|
+
delegatesFocus: true
|
|
33
|
+
});
|
|
29
34
|
shadowRoot.appendChild(template.content.cloneNode(true));
|
|
35
|
+
this.#internals = this.attachInternals();
|
|
30
36
|
this.#$prevMonth = shadowRoot.querySelector('#prev-month');
|
|
31
37
|
this.#$nextMonth = shadowRoot.querySelector('#next-month');
|
|
32
38
|
this.#$prevYear = shadowRoot.querySelector('#prev-year');
|
|
@@ -62,6 +68,23 @@ defineCustomElement('sinch-date-picker', class extends NectaryElement {
|
|
|
62
68
|
this.#controller.abort();
|
|
63
69
|
this.#controller = null;
|
|
64
70
|
}
|
|
71
|
+
formAssociatedCallback() {
|
|
72
|
+
setFormValue(this.#internals, this.value);
|
|
73
|
+
}
|
|
74
|
+
formResetCallback() {
|
|
75
|
+
this.value = '';
|
|
76
|
+
setFormValue(this.#internals, '');
|
|
77
|
+
}
|
|
78
|
+
formStateRestoreCallback(state) {
|
|
79
|
+
if (this.#internals.form === null || getBooleanAttribute(this.#internals.form, 'data-form-state-restore') === false) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
if (state !== null) {
|
|
83
|
+
const value = typeof state === 'string' ? state : state.get(this.name);
|
|
84
|
+
this.value = value?.toString() ?? '';
|
|
85
|
+
setFormValue(this.#internals, value?.toString() ?? '');
|
|
86
|
+
}
|
|
87
|
+
}
|
|
65
88
|
static get observedAttributes() {
|
|
66
89
|
return ['value', 'min', 'max', 'locale', 'range', 'prev-year-aria-label', 'next-year-aria-label', 'prev-month-aria-label', 'next-month-aria-label'];
|
|
67
90
|
}
|
|
@@ -132,6 +155,12 @@ defineCustomElement('sinch-date-picker', class extends NectaryElement {
|
|
|
132
155
|
}
|
|
133
156
|
}
|
|
134
157
|
}
|
|
158
|
+
set name(value) {
|
|
159
|
+
updateAttribute(this, 'name', value);
|
|
160
|
+
}
|
|
161
|
+
get name() {
|
|
162
|
+
return getAttribute(this, 'name', '');
|
|
163
|
+
}
|
|
135
164
|
set locale(value) {
|
|
136
165
|
updateAttribute(this, 'locale', value);
|
|
137
166
|
}
|
|
@@ -273,6 +302,7 @@ defineCustomElement('sinch-date-picker', class extends NectaryElement {
|
|
|
273
302
|
};
|
|
274
303
|
#onValueChange() {
|
|
275
304
|
const value = this.value;
|
|
305
|
+
setFormValue(this.#internals, this.value);
|
|
276
306
|
this.#date1 = null;
|
|
277
307
|
this.#date2 = null;
|
|
278
308
|
if (this.range) {
|
package/date-picker/types.d.ts
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import type { NectaryComponentReactByType, NectaryComponentVanillaByType, TRect } from '../types';
|
|
2
2
|
export type TSinchDatePickerProps = {
|
|
3
|
+
/** Identification for uncontrolled form submissions */
|
|
4
|
+
name?: string;
|
|
3
5
|
/** Date value in ISO 8601 format */
|
|
4
6
|
value: string;
|
|
5
7
|
/** Date min limit in ISO 8601 format */
|