@workday/canvas-kit-react 14.0.0-alpha.1237-next.0 → 14.0.0-alpha.1239-next.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 (131) hide show
  1. package/badge/lib/CountBadge.tsx +3 -3
  2. package/banner/lib/Banner.tsx +5 -5
  3. package/button/lib/Hyperlink.tsx +3 -3
  4. package/button/lib/SecondaryButton.tsx +8 -5
  5. package/button/lib/parts/ButtonLabelIcon.tsx +1 -1
  6. package/card/lib/Card.tsx +1 -0
  7. package/checkbox/lib/CheckBackground.tsx +1 -1
  8. package/common/lib/styles/errorRing.ts +2 -2
  9. package/common/lib/theming/README.md +1 -1
  10. package/common/lib/types.ts +1 -1
  11. package/dist/commonjs/badge/lib/CountBadge.js +5 -5
  12. package/dist/commonjs/banner/lib/Banner.d.ts +1 -1
  13. package/dist/commonjs/banner/lib/Banner.js +4 -4
  14. package/dist/commonjs/button/lib/ExternalHyperlink.d.ts +1 -1
  15. package/dist/commonjs/button/lib/Hyperlink.d.ts +3 -3
  16. package/dist/commonjs/button/lib/Hyperlink.d.ts.map +1 -1
  17. package/dist/commonjs/button/lib/Hyperlink.js +5 -5
  18. package/dist/commonjs/button/lib/SecondaryButton.d.ts.map +1 -1
  19. package/dist/commonjs/button/lib/SecondaryButton.js +2 -2
  20. package/dist/commonjs/button/lib/parts/ButtonLabelIcon.js +1 -1
  21. package/dist/commonjs/card/lib/Card.d.ts +1 -0
  22. package/dist/commonjs/card/lib/Card.d.ts.map +1 -1
  23. package/dist/commonjs/card/lib/Card.js +1 -1
  24. package/dist/commonjs/checkbox/lib/CheckBackground.d.ts +1 -1
  25. package/dist/commonjs/checkbox/lib/CheckBackground.js +1 -1
  26. package/dist/commonjs/common/lib/styles/errorRing.js +2 -2
  27. package/dist/commonjs/common/lib/types.d.ts +1 -1
  28. package/dist/commonjs/common/lib/types.d.ts.map +1 -1
  29. package/dist/commonjs/common/lib/types.js +1 -1
  30. package/dist/commonjs/expandable/lib/ExpandableAvatar.d.ts.map +1 -1
  31. package/dist/commonjs/expandable/lib/ExpandableAvatar.js +2 -3
  32. package/dist/commonjs/expandable/lib/ExpandableTarget.d.ts.map +1 -1
  33. package/dist/commonjs/expandable/lib/ExpandableTarget.js +1 -1
  34. package/dist/commonjs/form-field/lib/FormField.d.ts +7 -7
  35. package/dist/commonjs/form-field/lib/FormFieldContainer.d.ts +1 -1
  36. package/dist/commonjs/form-field/lib/FormFieldField.d.ts +1 -1
  37. package/dist/commonjs/form-field/lib/FormFieldGroup.d.ts +7 -7
  38. package/dist/commonjs/form-field/lib/FormFieldGroupInput.d.ts +2 -2
  39. package/dist/commonjs/form-field/lib/FormFieldGroupLabel.d.ts +1 -1
  40. package/dist/commonjs/form-field/lib/FormFieldGroupList.d.ts +1 -1
  41. package/dist/commonjs/form-field/lib/FormFieldGroupList.js +1 -1
  42. package/dist/commonjs/form-field/lib/FormFieldHint.d.ts +2 -2
  43. package/dist/commonjs/form-field/lib/FormFieldHint.js +1 -1
  44. package/dist/commonjs/form-field/lib/FormFieldInput.d.ts +1 -1
  45. package/dist/commonjs/form-field/lib/FormFieldLabel.d.ts +1 -1
  46. package/dist/commonjs/form-field/lib/formFieldStencil.d.ts +1 -1
  47. package/dist/commonjs/form-field/lib/formFieldStencil.js +1 -1
  48. package/dist/commonjs/form-field/lib/hooks/useFormFieldHint.d.ts +1 -1
  49. package/dist/commonjs/form-field/lib/hooks/useFormFieldInput.d.ts +2 -2
  50. package/dist/commonjs/form-field/lib/hooks/useFormFieldLabel.d.ts +1 -4
  51. package/dist/commonjs/form-field/lib/hooks/useFormFieldLabel.d.ts.map +1 -1
  52. package/dist/commonjs/form-field/lib/hooks/useFormFieldModel.d.ts +10 -10
  53. package/dist/commonjs/form-field/lib/hooks/useFormFieldModel.js +1 -1
  54. package/dist/commonjs/loading-dots/lib/LoadingDots.d.ts.map +1 -1
  55. package/dist/commonjs/loading-dots/lib/LoadingDots.js +4 -4
  56. package/dist/commonjs/pagination/lib/Pagination/PageButton.js +2 -2
  57. package/dist/commonjs/select/lib/SelectInput.d.ts +1 -1
  58. package/dist/commonjs/select/lib/SelectInput.d.ts.map +1 -1
  59. package/dist/commonjs/select/lib/SelectInput.js +4 -4
  60. package/dist/commonjs/switch/lib/Switch.js +6 -6
  61. package/dist/commonjs/tabs/lib/TabsItem.js +1 -1
  62. package/dist/commonjs/text-area/lib/TextArea.d.ts +1 -1
  63. package/dist/commonjs/text-input/lib/TextInput.d.ts +1 -1
  64. package/dist/commonjs/text-input/lib/TextInput.js +1 -1
  65. package/dist/es6/badge/lib/CountBadge.js +5 -5
  66. package/dist/es6/banner/lib/Banner.d.ts +1 -1
  67. package/dist/es6/banner/lib/Banner.js +4 -4
  68. package/dist/es6/button/lib/ExternalHyperlink.d.ts +1 -1
  69. package/dist/es6/button/lib/Hyperlink.d.ts +3 -3
  70. package/dist/es6/button/lib/Hyperlink.d.ts.map +1 -1
  71. package/dist/es6/button/lib/Hyperlink.js +5 -5
  72. package/dist/es6/button/lib/SecondaryButton.d.ts.map +1 -1
  73. package/dist/es6/button/lib/SecondaryButton.js +2 -2
  74. package/dist/es6/button/lib/parts/ButtonLabelIcon.js +1 -1
  75. package/dist/es6/card/lib/Card.d.ts +1 -0
  76. package/dist/es6/card/lib/Card.d.ts.map +1 -1
  77. package/dist/es6/card/lib/Card.js +1 -1
  78. package/dist/es6/checkbox/lib/CheckBackground.d.ts +1 -1
  79. package/dist/es6/checkbox/lib/CheckBackground.js +1 -1
  80. package/dist/es6/common/lib/styles/errorRing.js +2 -2
  81. package/dist/es6/common/lib/types.d.ts +1 -1
  82. package/dist/es6/common/lib/types.d.ts.map +1 -1
  83. package/dist/es6/common/lib/types.js +1 -1
  84. package/dist/es6/expandable/lib/ExpandableAvatar.d.ts.map +1 -1
  85. package/dist/es6/expandable/lib/ExpandableAvatar.js +2 -3
  86. package/dist/es6/expandable/lib/ExpandableTarget.d.ts.map +1 -1
  87. package/dist/es6/expandable/lib/ExpandableTarget.js +1 -1
  88. package/dist/es6/form-field/lib/FormField.d.ts +7 -7
  89. package/dist/es6/form-field/lib/FormFieldContainer.d.ts +1 -1
  90. package/dist/es6/form-field/lib/FormFieldField.d.ts +1 -1
  91. package/dist/es6/form-field/lib/FormFieldGroup.d.ts +7 -7
  92. package/dist/es6/form-field/lib/FormFieldGroupInput.d.ts +2 -2
  93. package/dist/es6/form-field/lib/FormFieldGroupLabel.d.ts +1 -1
  94. package/dist/es6/form-field/lib/FormFieldGroupList.d.ts +1 -1
  95. package/dist/es6/form-field/lib/FormFieldGroupList.js +1 -1
  96. package/dist/es6/form-field/lib/FormFieldHint.d.ts +2 -2
  97. package/dist/es6/form-field/lib/FormFieldHint.js +1 -1
  98. package/dist/es6/form-field/lib/FormFieldInput.d.ts +1 -1
  99. package/dist/es6/form-field/lib/FormFieldLabel.d.ts +1 -1
  100. package/dist/es6/form-field/lib/formFieldStencil.d.ts +1 -1
  101. package/dist/es6/form-field/lib/formFieldStencil.js +1 -1
  102. package/dist/es6/form-field/lib/hooks/useFormFieldHint.d.ts +1 -1
  103. package/dist/es6/form-field/lib/hooks/useFormFieldInput.d.ts +2 -2
  104. package/dist/es6/form-field/lib/hooks/useFormFieldLabel.d.ts +1 -4
  105. package/dist/es6/form-field/lib/hooks/useFormFieldLabel.d.ts.map +1 -1
  106. package/dist/es6/form-field/lib/hooks/useFormFieldModel.d.ts +10 -10
  107. package/dist/es6/form-field/lib/hooks/useFormFieldModel.js +1 -1
  108. package/dist/es6/loading-dots/lib/LoadingDots.d.ts.map +1 -1
  109. package/dist/es6/loading-dots/lib/LoadingDots.js +4 -4
  110. package/dist/es6/pagination/lib/Pagination/PageButton.js +2 -2
  111. package/dist/es6/select/lib/SelectInput.d.ts +1 -1
  112. package/dist/es6/select/lib/SelectInput.d.ts.map +1 -1
  113. package/dist/es6/select/lib/SelectInput.js +5 -5
  114. package/dist/es6/switch/lib/Switch.js +6 -6
  115. package/dist/es6/tabs/lib/TabsItem.js +1 -1
  116. package/dist/es6/text-area/lib/TextArea.d.ts +1 -1
  117. package/dist/es6/text-input/lib/TextInput.d.ts +1 -1
  118. package/dist/es6/text-input/lib/TextInput.js +1 -1
  119. package/expandable/lib/ExpandableAvatar.tsx +0 -2
  120. package/expandable/lib/ExpandableTarget.tsx +2 -1
  121. package/form-field/lib/FormFieldGroupList.tsx +1 -1
  122. package/form-field/lib/FormFieldHint.tsx +1 -1
  123. package/form-field/lib/formFieldStencil.ts +1 -1
  124. package/form-field/lib/hooks/useFormFieldModel.tsx +2 -2
  125. package/loading-dots/lib/LoadingDots.tsx +10 -1
  126. package/package.json +4 -4
  127. package/pagination/lib/Pagination/PageButton.tsx +1 -1
  128. package/select/lib/SelectInput.tsx +8 -2
  129. package/switch/lib/Switch.tsx +1 -1
  130. package/tabs/lib/TabsItem.tsx +1 -1
  131. package/text-input/lib/TextInput.tsx +1 -1
@@ -5,7 +5,7 @@ import { handleCsProp, keyframes, createStencil, calc, px2rem, cssVar, } from '@
5
5
  /**
6
6
  * Keyframe for the dots loading animation.
7
7
  */
8
- const keyframesLoading = keyframes({ name: "17azdh", styles: "0%, 80%, 100%{transform:scale(0);}40%{transform:scale(1);}" });
8
+ const keyframesLoading = keyframes({ name: "fc6cw", styles: "0%, 80%, 100%{transform:scale(0);}40%{transform:scale(1);}0%, 79%, 100%{opacity:0.6;}27%{opacity:1;}53%{opacity:0.8;}" });
9
9
  export const loadingDotsStencil = createStencil({
10
10
  vars: {
11
11
  animationDurationMs: '40ms',
@@ -14,13 +14,13 @@ export const loadingDotsStencil = createStencil({
14
14
  parts: {
15
15
  loadingAnimationDot: 'loading-animation-dot',
16
16
  },
17
- base: { name: "3kbrl0", styles: "--animationDurationMs-loading-dots-c7a3f7:40ms;--loadingDotColor-loading-dots-c7a3f7:var(--cnvs-sys-color-bg-muted-strong);box-sizing:border-box;display:inline-flex;gap:var(--cnvs-sys-space-x2);[data-part=\"loading-animation-dot\"]{background-color:var(--loadingDotColor-loading-dots-c7a3f7);width:var(--cnvs-sys-space-x4);height:var(--cnvs-sys-space-x4);font-size:var(--cnvs-sys-space-zero);border-radius:var(--cnvs-sys-shape-round);outline:0.125rem solid transparent;transform:scale(0);display:inline-block;animation-name:animation-17azdh;animation-duration:calc(var(--animationDurationMs-loading-dots-c7a3f7) * 35);animation-iteration-count:infinite;animation-timing-function:ease-in-out;animation-fill-mode:both;&:nth-child(1){animation-delay:0ms;}&:nth-child(2){animation-delay:calc(var(--animationDurationMs-loading-dots-c7a3f7) * 4);}&:nth-child(3){animation-delay:calc(var(--animationDurationMs-loading-dots-c7a3f7) * 8);}}" },
17
+ base: { name: "45fneq", styles: "--animationDurationMs-loading-dots-89a0c0:40ms;--loadingDotColor-loading-dots-89a0c0:var(--cnvs-sys-color-bg-muted-strong);box-sizing:border-box;display:inline-flex;gap:var(--cnvs-sys-space-x2);[data-part=\"loading-animation-dot\"]{background-color:var(--loadingDotColor-loading-dots-89a0c0);width:var(--cnvs-sys-space-x4);height:var(--cnvs-sys-space-x4);font-size:var(--cnvs-sys-space-zero);border-radius:var(--cnvs-sys-shape-round);outline:0.125rem solid transparent;transform:scale(0);display:inline-block;animation-name:animation-fc6cw;animation-duration:calc(var(--animationDurationMs-loading-dots-89a0c0) * 35);animation-iteration-count:infinite;animation-timing-function:ease-in-out;animation-fill-mode:both;&:nth-child(1){animation-delay:0ms;}&:nth-child(2){animation-delay:calc(var(--animationDurationMs-loading-dots-89a0c0) * 4);}&:nth-child(3){animation-delay:calc(var(--animationDurationMs-loading-dots-89a0c0) * 8);}}" },
18
18
  modifiers: {
19
19
  variant: {
20
- inverse: { name: "40brbb", styles: "[data-part=\"loading-animation-dot\"]{background-color:var(--cnvs-sys-color-bg-muted-softer, var(--loadingDotColor-loading-dots-c7a3f7));}" }
20
+ inverse: { name: "4ia8r", styles: "[data-part=\"loading-animation-dot\"]{background-color:var(--cnvs-sys-color-bg-default, var(--loadingDotColor-loading-dots-89a0c0));}" }
21
21
  }
22
22
  }
23
- }, "loading-dots-c7a3f7");
23
+ }, "loading-dots-89a0c0");
24
24
  /**
25
25
  * A simple component that displays three horizontal dots, to be used when some data is loading.
26
26
  */
@@ -7,10 +7,10 @@ import { createStencil, handleCsProp } from '@workday/canvas-kit-styling';
7
7
  import { PaginationContext } from './usePaginationModel';
8
8
  export const paginationPageButtonStencil = createStencil({
9
9
  extends: buttonStencil,
10
- base: { name: "5ahyy", styles: "box-sizing:border-box;min-width:var(--cnvs-sys-space-x8);padding:var(--cnvs-sys-space-zero);font-weight:var(--cnvs-sys-font-weight-normal);--label-button-65cb05:var(--cnvs-sys-color-fg-default);&:hover, &.hover{--background-button-65cb05:var(--cnvs-sys-color-bg-alt-default);--label-button-65cb05:var(--cnvs-sys-color-fg-strong);}&:active, &.active, &:focus-visible, &.focus{--label-button-65cb05:var(--cnvs-sys-color-fg-strong);}&:disabled, &.disabled{--background-button-65cb05:var(--cnvs-sys-color-fg-disabled);}" },
10
+ base: { name: "1lksxu", styles: "box-sizing:border-box;min-width:var(--cnvs-sys-space-x8);padding:var(--cnvs-sys-space-zero);font-weight:var(--cnvs-sys-font-weight-normal);--label-button-65cb05:var(--cnvs-sys-color-fg-default);&:hover, &.hover{--background-button-65cb05:var(--cnvs-sys-color-bg-alt-soft);--label-button-65cb05:var(--cnvs-sys-color-fg-strong);}&:active, &.active, &:focus-visible, &.focus{--label-button-65cb05:var(--cnvs-sys-color-fg-strong);}&:disabled, &.disabled{--background-button-65cb05:var(--cnvs-sys-color-fg-disabled);}" },
11
11
  modifiers: {
12
12
  toggled: {
13
- true: { name: "2sqcgq", styles: "font-weight:var(--cnvs-sys-font-weight-bold);--background-button-65cb05:var(--cnvs-brand-primary-base);--label-button-65cb05:var(--cnvs-sys-color-fg-inverse);&:hover, &.hover, &:active, &.active, &:focus-visible, &.focus{--background-button-65cb05:var(--cnvs-brand-primary-base);--label-button-65cb05:var(--cnvs-sys-color-fg-inverse);}&:disabled, &.disabled{--background-button-65cb05:var(--cnvs-sys-color-fg-disabled);}" }
13
+ true: { name: "11kh3n", styles: "font-weight:var(--cnvs-sys-font-weight-bold);--background-button-65cb05:var(--cnvs-brand-primary-base);--label-button-65cb05:var(--cnvs-sys-color-fg-inverse);&:hover, &.hover, &:active, &.active, &:focus-visible, &.focus{--background-button-65cb05:var(--cnvs-brand-primary-base);--label-button-65cb05:var(--cnvs-sys-color-fg-inverse);}&:disabled, &.disabled{--background-button-65cb05:var(--cnvs-sys-color-fg-disabled);}" }
14
14
  }
15
15
  }
16
16
  }, "pagination-page-button-88d20c");
@@ -25,7 +25,7 @@ export declare const selectInputStencil: import("@workday/canvas-kit-styling").S
25
25
  backgroundColor: "--cnvs-brand-error-lightest";
26
26
  };
27
27
  };
28
- alert: ({ visualInputPart }: {} & import("@workday/canvas-kit-styling").StencilVarsParts<{
28
+ caution: ({ visualInputPart }: {} & import("@workday/canvas-kit-styling").StencilVarsParts<{
29
29
  readonly caret: "select-caret-icon";
30
30
  readonly caretContainer: "select-caret-container";
31
31
  readonly startIconContainer: "select-start-icon-container";
@@ -1 +1 @@
1
- {"version":3,"file":"SelectInput.d.ts","sourceRoot":"","sources":["../../../../select/lib/SelectInput.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAC,MAAM,8BAA8B,CAAC;AAE9D,OAAO,EAAgB,OAAO,EAAC,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAa,SAAS,EAAC,MAAM,sCAAsC,CAAC;AAK3E,OAAO,EAAqB,YAAY,EAAC,MAAM,kCAAkC,CAAC;AAGlF,MAAM,WAAW,gBAAiB,SAAQ,YAAY,CAAC,OAAO,SAAS,EAAE,KAAK,CAAC,EAAE,OAAO;IACtF;;;;OAIG;IACH,cAAc,CAAC,EAAE,gBAAgB,CAAC;CACnC;AAED,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oBA8D7B,CAAC;AAEH,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0BtB,CAAC"}
1
+ {"version":3,"file":"SelectInput.d.ts","sourceRoot":"","sources":["../../../../select/lib/SelectInput.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAC,MAAM,8BAA8B,CAAC;AAE9D,OAAO,EAAgB,OAAO,EAAC,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAa,SAAS,EAAC,MAAM,sCAAsC,CAAC;AAK3E,OAAO,EAAqB,YAAY,EAAC,MAAM,kCAAkC,CAAC;AAGlF,MAAM,WAAW,gBAAiB,SAAQ,YAAY,CAAC,OAAO,SAAS,EAAE,KAAK,CAAC,EAAE,OAAO;IACtF;;;;OAIG;IACH,cAAc,CAAC,EAAE,gBAAgB,CAAC;CACnC;AAED,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oBAoE7B,CAAC;AAEH,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0BtB,CAAC"}
@@ -2,7 +2,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { caretDownSmallIcon } from '@workday/canvas-system-icons-web';
3
3
  import { createStencil } from '@workday/canvas-kit-styling';
4
4
  import { InputGroup, TextInput } from '@workday/canvas-kit-react/text-input';
5
- import { SystemIcon } from '@workday/canvas-kit-react/icon';
5
+ import { SystemIcon, systemIconStencil } from '@workday/canvas-kit-react/icon';
6
6
  import { useSelectInput } from './hooks/useSelectInput';
7
7
  import { useSelectModel } from './hooks/useSelectModel';
8
8
  import { createSubcomponent } from '@workday/canvas-kit-react/common';
@@ -17,14 +17,14 @@ export const selectInputStencil = createStencil({
17
17
  hiddenInput: 'select-hidden-input',
18
18
  visualInput: 'select-visual-input',
19
19
  },
20
- base: { name: "6r5et", styles: "box-sizing:border-box;[data-part=\"select-hidden-input\"]{position:absolute;top:var(--cnvs-sys-space-zero);bottom:var(--cnvs-sys-space-zero);left:var(--cnvs-sys-space-zero);right:var(--cnvs-sys-space-zero);opacity:var(--cnvs-sys-opacity-zero);cursor:default;pointer-events:none;min-width:100%;width:100%;}[data-part=\"select-start-icon\"], [data-part=\"select-end-icon\"], [data-part=\"select-caret-container\"], [data-part=\"select-start-icon-container\"]{position:absolute;pointer-events:none;}[data-part=\"select-visual-input\"]{caret-color:transparent;background-color:var(--cnvs-sys-color-bg-default);color:var(--cnvs-sys-color-text-default);cursor:default;&::placeholder{color:var(--cnvs-sys-color-text-default);}&::selection{background-color:transparent;}}" },
20
+ base: { name: "23gcfb", styles: "box-sizing:border-box;[data-part=\"select-hidden-input\"]{position:absolute;top:var(--cnvs-sys-space-zero);bottom:var(--cnvs-sys-space-zero);left:var(--cnvs-sys-space-zero);right:var(--cnvs-sys-space-zero);opacity:var(--cnvs-sys-opacity-zero);cursor:default;pointer-events:none;min-width:100%;width:100%;}[data-part=\"select-start-icon\"], [data-part=\"select-end-icon\"], [data-part=\"select-caret-container\"], [data-part=\"select-start-icon-container\"]{position:absolute;pointer-events:none;}[data-part=\"select-visual-input\"]{caret-color:transparent;background-color:var(--cnvs-sys-color-bg-default);color:var(--cnvs-sys-color-text-default);cursor:default;&::placeholder{color:var(--cnvs-sys-color-text-default);}&::selection{background-color:transparent;}}&:has(:disabled, .disabled){[data-part=\"select-caret-icon\"]{--color-system-icon-3a4847:var(--cnvs-sys-color-fg-disabled);}}" },
21
21
  modifiers: {
22
22
  error: {
23
- error: { name: "3chqdl", styles: "[data-part=\"select-visual-input\"]{background-color:var(--cnvs-brand-error-lightest);}" },
24
- alert: { name: "1bcehf", styles: "[data-part=\"select-visual-input\"]{background-color:var(--cnvs-brand-alert-lightest);}" }
23
+ error: { name: "321opo", styles: "[data-part=\"select-visual-input\"]{background-color:var(--cnvs-brand-error-lightest);}" },
24
+ caution: { name: "1wknpi", styles: "[data-part=\"select-visual-input\"]{background-color:var(--cnvs-brand-alert-lightest);}" }
25
25
  }
26
26
  }
27
- }, "select-input-b33740");
27
+ }, "select-input-9444aa");
28
28
  export const SelectInput = createSubcomponent(TextInput)({
29
29
  modelHook: useSelectModel,
30
30
  elemPropsHook: useSelectInput,
@@ -17,7 +17,7 @@ const switchInputStencil = createStencil({
17
17
  modifiers: {
18
18
  error: {
19
19
  error: { name: "166muk", styles: "& ~ div:first-of-type{box-shadow:\n 0 0 0 0.125rem var(--cnvs-sys-color-border-inverse),\n 0 0 0 var(--cnvs-sys-space-x1) var(--cnvs-brand-common-error-inner),\n 0 0 0 0.3125rem transparent;}" },
20
- alert: { name: "rktku", styles: "& ~ div:first-of-type{box-shadow:\n 0 0 0 0.125rem var(--cnvs-sys-color-border-inverse),\n 0 0 0 var(--cnvs-sys-space-x1) var(--cnvs-brand-common-alert-inner),\n 0 0 0 0.3125rem var(--cnvs-brand-common-alert-outer);}" }
20
+ caution: { name: "20t65f", styles: "& ~ div:first-of-type{box-shadow:\n 0 0 0 0.125rem var(--cnvs-sys-color-border-inverse),\n 0 0 0 var(--cnvs-sys-space-x1) var(--cnvs-brand-common-alert-inner),\n 0 0 0 0.3125rem var(--cnvs-brand-common-alert-outer);}" }
21
21
  }
22
22
  }
23
23
  }, "switch-input-7f69d7");
@@ -28,8 +28,8 @@ const SwitchInput = createComponent('input')({
28
28
  },
29
29
  });
30
30
  const switchBackgroundStencil = createStencil({
31
- base: { name: "3q226t", styles: "box-sizing:border-box;position:absolute;display:flex;align-items:center;pointer-events:none;margin-top:var(--cnvs-sys-space-x1);width:var(--cnvs-sys-space-x8);height:var(--cnvs-sys-space-x4);border-radius:var(--cnvs-sys-shape-round);padding:var(--cnvs-sys-space-zero) 0.125rem;transition:background-color 200ms ease;background-color:var(--cnvs-sys-color-bg-muted-soft);" }
32
- }, "switch-background-507b18");
31
+ base: { name: "3egbg5", styles: "box-sizing:border-box;position:absolute;display:flex;align-items:center;pointer-events:none;margin-top:var(--cnvs-sys-space-x1);width:var(--cnvs-sys-space-x8);height:var(--cnvs-sys-space-x4);border-radius:var(--cnvs-sys-shape-round);padding:var(--cnvs-sys-space-zero) 0.125rem;transition:background-color 200ms ease;background-color:var(--cnvs-sys-color-bg-muted-soft);" }
32
+ }, "switch-background-96fe08");
33
33
  const SwitchBackground = createComponent('div')({
34
34
  displayName: 'SwitchBackground',
35
35
  Component: ({ children, ...elemProps }, ref, Element) => {
@@ -37,13 +37,13 @@ const SwitchBackground = createComponent('div')({
37
37
  },
38
38
  });
39
39
  const switchCircleStencil = createStencil({
40
- base: { name: "1q1chx", styles: "box-sizing:border-box;width:var(--cnvs-sys-space-x3);height:var(--cnvs-sys-space-x3);border-radius:var(--cnvs-sys-shape-round);box-shadow:var(--cnvs-sys-depth-1);transition:transform 150ms ease;pointer-events:none;background-color:var(--cnvs-brand-primary-accent);transform:translateX(var(--cnvs-sys-space-zero));" },
40
+ base: { name: "49jzlb", styles: "box-sizing:border-box;width:var(--cnvs-sys-space-x3);height:var(--cnvs-sys-space-x3);border-radius:var(--cnvs-sys-shape-round);box-shadow:var(--cnvs-sys-depth-1);transition:transform 150ms ease;pointer-events:none;background-color:var(--cnvs-brand-primary-accent);transform:translateX(var(--cnvs-sys-space-zero));" },
41
41
  modifiers: {
42
42
  checked: {
43
- true: { name: "29npze", styles: "transform:translateX(var(--cnvs-sys-space-x4));:dir(rtl){transform:translateX(calc(var(--cnvs-sys-space-x4) * -1));}" }
43
+ true: { name: "28li63", styles: "transform:translateX(var(--cnvs-sys-space-x4));:dir(rtl){transform:translateX(calc(var(--cnvs-sys-space-x4) * -1));}" }
44
44
  }
45
45
  }
46
- }, "switch-circle-d4f7c1");
46
+ }, "switch-circle-cac9b6");
47
47
  const SwitchCircle = createComponent('div')({
48
48
  displayName: 'SwitchCircle',
49
49
  Component: ({ checked, ...elemProps }, ref, Element) => {
@@ -9,7 +9,7 @@ import { useTabsModel } from './useTabsModel';
9
9
  import { buttonStencil } from '@workday/canvas-kit-react/button';
10
10
  import { system, brand } from '@workday/canvas-tokens-web';
11
11
  const tabItemStencil = createStencil({
12
- base: { name: "2whux4", styles: "box-sizing:border-box;font-family:var(--cnvs-sys-font-family-default), Helvetica Neue, Helvetica, Arial, sans-serif;font-weight:var(--cnvs-sys-font-weight-medium);line-height:var(--cnvs-sys-line-height-subtext-large);font-size:var(--cnvs-sys-font-size-subtext-large);letter-spacing:var(--cnvs-base-letter-spacing-150);border:none;background-color:transparent;flex:0 0 auto;min-width:var(--cnvs-sys-space-zero);align-items:center;padding:var(--cnvs-sys-space-x3) var(--cnvs-sys-space-x4);height:3.25rem;cursor:pointer;color:var(--cnvs-sys-color-fg-muted-default);position:relative;border-radius:var(--cnvs-sys-space-x1) var(--cnvs-sys-space-x1) var(--cnvs-sys-space-zero) var(--cnvs-sys-space-zero);transition:background 150ms ease, color 150ms ease;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;--color-system-icon-3a4847:var(--cnvs-sys-color-fg-muted-soft);&:has(span){display:flex;gap:var(--cnvs-sys-space-x2);}&:hover, &.hover, &:focus-visible, &.focus{background-color:var(--cnvs-sys-color-bg-alt-default);color:var(--cnvs-sys-color-fg-contrast-default);--color-system-icon-3a4847:var(--cnvs-sys-color-fg-contrast-default);}&:focus-visible, &.focus{outline:0.125rem solid transparent;box-shadow:inset 0 0 0 2px var(--cnvs-brand-common-focus-outline, rgba(8,117,225,1)), inset 0 0 0 2px var(--cnvs-sys-color-border-inverse, rgba(255,255,255,1));--boxShadowInner-button-65cb05:var(--cnvs-sys-color-border-inverse);--boxShadowOuter-button-65cb05:var(--cnvs-brand-common-focus-outline);--color-system-icon-3a4847:var(--cnvs-sys-color-icon-strong);}&:disabled, &.disabled, &[aria-disabled]{color:var(--cnvs-sys-color-text-disabled);--color-system-icon-3a4847:var(--cnvs-sys-color-fg-disabled);&:hover{cursor:auto;background-color:var(--cnvs-sys-color-bg-transparent-default);--color-system-icon-3a4847:var(--cnvs-sys-color-fg-disabled);}}&[aria-selected=true]{color:var(--cnvs-brand-primary-base);cursor:default;--color-system-icon-3a4847:var(--cnvs-brand-primary-base);&:after{position:absolute;border-bottom:var(--cnvs-sys-space-x1) solid transparent;border-radius:var(--cnvs-sys-shape-x1) var(--cnvs-sys-shape-x1) var(--cnvs-sys-shape-zero) var(--cnvs-sys-shape-zero);background-color:var(--cnvs-brand-primary-base);bottom:var(--cnvs-sys-space-zero);content:'';left:var(--cnvs-sys-space-zero);margin-block-start:calc(calc(var(--cnvs-sys-space-x2) / var(--cnvs-sys-space-x1)) * -1);width:100%;}&:hover, &.hover, &:focus-visible, &.focus{background-color:var(--cnvs-sys-color-bg-transparent-default);color:var(--cnvs-brand-primary-base);}}" }
12
+ base: { name: "2n2p4s", styles: "box-sizing:border-box;font-family:var(--cnvs-sys-font-family-default), Helvetica Neue, Helvetica, Arial, sans-serif;font-weight:var(--cnvs-sys-font-weight-medium);line-height:var(--cnvs-sys-line-height-subtext-large);font-size:var(--cnvs-sys-font-size-subtext-large);letter-spacing:var(--cnvs-base-letter-spacing-150);border:none;background-color:transparent;flex:0 0 auto;min-width:var(--cnvs-sys-space-zero);align-items:center;padding:var(--cnvs-sys-space-x3) var(--cnvs-sys-space-x4);height:3.25rem;cursor:pointer;color:var(--cnvs-sys-color-fg-muted-default);position:relative;border-radius:var(--cnvs-sys-space-x1) var(--cnvs-sys-space-x1) var(--cnvs-sys-space-zero) var(--cnvs-sys-space-zero);transition:background 150ms ease, color 150ms ease;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;--color-system-icon-3a4847:currentColor;&:has(span){display:flex;gap:var(--cnvs-sys-space-x2);}&:hover, &.hover, &:focus-visible, &.focus{background-color:var(--cnvs-sys-color-bg-alt-default);color:var(--cnvs-sys-color-fg-contrast-default);--color-system-icon-3a4847:var(--cnvs-sys-color-fg-contrast-default);}&:focus-visible, &.focus{outline:0.125rem solid transparent;box-shadow:inset 0 0 0 2px var(--cnvs-brand-common-focus-outline, rgba(8,117,225,1)), inset 0 0 0 2px var(--cnvs-sys-color-border-inverse, rgba(255,255,255,1));--boxShadowInner-button-65cb05:var(--cnvs-sys-color-border-inverse);--boxShadowOuter-button-65cb05:var(--cnvs-brand-common-focus-outline);--color-system-icon-3a4847:var(--cnvs-sys-color-icon-strong);}&:disabled, &.disabled, &[aria-disabled]{color:var(--cnvs-sys-color-text-disabled);--color-system-icon-3a4847:var(--cnvs-sys-color-fg-disabled);&:hover{cursor:auto;background-color:var(--cnvs-sys-color-bg-transparent-default);--color-system-icon-3a4847:var(--cnvs-sys-color-fg-disabled);}}&[aria-selected=true]{color:var(--cnvs-brand-primary-base);cursor:default;--color-system-icon-3a4847:var(--cnvs-brand-primary-base);&:after{position:absolute;border-bottom:var(--cnvs-sys-space-x1) solid transparent;border-radius:var(--cnvs-sys-shape-x1) var(--cnvs-sys-shape-x1) var(--cnvs-sys-shape-zero) var(--cnvs-sys-shape-zero);background-color:var(--cnvs-brand-primary-base);bottom:var(--cnvs-sys-space-zero);content:'';left:var(--cnvs-sys-space-zero);margin-block-start:calc(calc(var(--cnvs-sys-space-x2) / var(--cnvs-sys-space-x1)) * -1);width:100%;}&:hover, &.hover, &:focus-visible, &.focus{background-color:var(--cnvs-sys-color-bg-transparent-default);color:var(--cnvs-brand-primary-base);}}" }
13
13
  }, "tab-item-116136");
14
14
  export const StyledTabItem = createComponent('button')({
15
15
  displayName: 'StyledTabItem',
@@ -55,7 +55,7 @@ export declare const textAreaStencil: import("@workday/canvas-kit-styling").Sten
55
55
  outlineOffset: string;
56
56
  };
57
57
  };
58
- alert: {
58
+ caution: {
59
59
  borderColor: "--cnvs-brand-common-alert-outer";
60
60
  boxShadow: `inset 0 0 0 ${string} --cnvs-brand-common-alert-inner`;
61
61
  backgroundColor: "--cnvs-brand-alert-lightest";
@@ -33,7 +33,7 @@ export declare const textInputStencil: import("@workday/canvas-kit-styling").Ste
33
33
  outlineOffset: string;
34
34
  };
35
35
  };
36
- alert: {
36
+ caution: {
37
37
  borderColor: "--cnvs-brand-common-alert-outer";
38
38
  boxShadow: `inset 0 0 0 ${string} --cnvs-brand-common-alert-inner`;
39
39
  backgroundColor: "--cnvs-brand-alert-lightest";
@@ -15,7 +15,7 @@ export const textInputStencil = createStencil({
15
15
  },
16
16
  error: {
17
17
  error: { name: "15ahlp", styles: "border-color:var(--cnvs-brand-common-error-inner);border-width:0.125rem;background-color:var(--cnvs-brand-error-lightest);&:is(:hover, .hover, :disabled, .disabled, :focus-visible:not([disabled]), .focus:not([disabled])){border-color:var(--cnvs-brand-common-error-inner);}&:is(:focus-visible, .focus):not([disabled]){box-shadow:0 0 0 2px var(--cnvs-sys-color-border-inverse), 0 0 0 4px var(--cnvs-brand-common-focus-outline);outline-offset:0.125rem;}" },
18
- alert: { name: "1q9wmz", styles: "border-color:var(--cnvs-brand-common-alert-outer);box-shadow:inset 0 0 0 0.125rem var(--cnvs-brand-common-alert-inner);background-color:var(--cnvs-brand-alert-lightest);&:is(:hover, .hover, :disabled, .disabled, :focus-visible:not([disabled]), .focus:not([disabled])){border-color:var(--cnvs-brand-common-alert-outer);}&:is(:focus-visible, .focus):not([disabled]){box-shadow:inset 0 0 0 0.125rem var(--cnvs-brand-common-alert-inner),\n 0 0 0 2px var(--cnvs-sys-color-border-inverse),\n 0 0 0 4px var(--cnvs-brand-common-focus-outline);}outline-offset:0.125rem;" }
18
+ caution: { name: "2er8do", styles: "border-color:var(--cnvs-brand-common-alert-outer);box-shadow:inset 0 0 0 0.125rem var(--cnvs-brand-common-alert-inner);background-color:var(--cnvs-brand-alert-lightest);&:is(:hover, .hover, :disabled, .disabled, :focus-visible:not([disabled]), .focus:not([disabled])){border-color:var(--cnvs-brand-common-alert-outer);}&:is(:focus-visible, .focus):not([disabled]){box-shadow:inset 0 0 0 0.125rem var(--cnvs-brand-common-alert-inner),\n 0 0 0 2px var(--cnvs-sys-color-border-inverse),\n 0 0 0 4px var(--cnvs-brand-common-focus-outline);}outline-offset:0.125rem;" }
19
19
  }
20
20
  },
21
21
  defaultModifiers: {
@@ -1,6 +1,5 @@
1
1
  import {createComponent} from '@workday/canvas-kit-react/common';
2
2
  import {Avatar, AvatarProps, avatarStencil} from '@workday/canvas-kit-preview-react/avatar';
3
- import {system} from '@workday/canvas-tokens-web';
4
3
  import {createStencil} from '@workday/canvas-kit-styling';
5
4
  import {mergeStyles} from '@workday/canvas-kit-react/layout';
6
5
 
@@ -9,7 +8,6 @@ export interface ExpandableAvatarProps extends AvatarProps {}
9
8
  export const expandableAvatarStencil = createStencil({
10
9
  extends: avatarStencil,
11
10
  base: {
12
- marginInlineEnd: system.space.x2,
13
11
  flexShrink: 0,
14
12
  },
15
13
  });
@@ -30,8 +30,9 @@ export const expandableTargetStencil = createStencil({
30
30
  borderRadius: system.shape.x1,
31
31
  borderWidth: 0,
32
32
  display: 'flex',
33
- alignItems: 'flex-start',
33
+ alignItems: 'center',
34
34
  flexDirection: 'row',
35
+ gap: system.space.x2,
35
36
  justifyContent: 'start',
36
37
  padding: system.space.x2,
37
38
  cursor: 'pointer',
@@ -26,7 +26,7 @@ const formFieldGroupListStencil = createStencil({
26
26
  backgroundColor: brand.error.lightest,
27
27
  boxShadow: `inset 0 0 0 ${px2rem(2)} ${brand.common.errorInner}`,
28
28
  },
29
- alert: {
29
+ caution: {
30
30
  backgroundColor: brand.alert.lightest,
31
31
  boxShadow: `inset 0 0 0 ${px2rem(1)} ${brand.common.alertOuter}, inset 0 0 0 ${px2rem(3)} ${
32
32
  brand.common.alertInner
@@ -16,7 +16,7 @@ export const formFieldHintStencil = createStencil({
16
16
  error: {
17
17
  color: brand.error.base,
18
18
  },
19
- alert: {
19
+ caution: {
20
20
  color: system.color.text.caution.default,
21
21
  },
22
22
  },
@@ -40,7 +40,7 @@ export const formFieldStencil = createStencil({
40
40
  },
41
41
  error: {
42
42
  error: {},
43
- alert: {},
43
+ caution: {},
44
44
  },
45
45
  },
46
46
  defaultModifiers: {
@@ -5,9 +5,9 @@ export const useFormFieldModel = createModelHook({
5
5
  /**
6
6
  * Optional flag to denote if this field has an error or warning to display.
7
7
  * If value is `error`: `aria-invalid` is added to the `FormField.Input` and the red error ring is added.
8
- * If value is `alert`: A visual orange warning ring is added to the `FormField.Input`.
8
+ * If value is `cautiion`: A visual orange warning ring is added to the `FormField.Input`.
9
9
  */
10
- error: undefined as undefined | 'error' | 'alert',
10
+ error: undefined as undefined | 'error' | 'caution',
11
11
  /**
12
12
  * Optional `id` provided to `FormField`'s subcomponents as HTML attributes:
13
13
  * - `FormField.Input` will set `aria-describedby` to `hint-${id}`
@@ -20,6 +20,15 @@ const keyframesLoading = keyframes({
20
20
  '40%': {
21
21
  transform: 'scale(1)',
22
22
  },
23
+ '0%, 79%, 100%': {
24
+ opacity: 0.6,
25
+ },
26
+ '27%': {
27
+ opacity: 1,
28
+ },
29
+ '53%': {
30
+ opacity: 0.8,
31
+ },
23
32
  });
24
33
 
25
34
  export interface LoadingDotsProps extends CSProps {
@@ -76,7 +85,7 @@ export const loadingDotsStencil = createStencil({
76
85
  variant: {
77
86
  inverse: ({loadingDotColor, loadingAnimationDotPart}) => ({
78
87
  [loadingAnimationDotPart]: {
79
- backgroundColor: cssVar(system.color.bg.muted.softer, loadingDotColor),
88
+ backgroundColor: cssVar(system.color.bg.default, loadingDotColor),
80
89
  },
81
90
  }),
82
91
  },
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@workday/canvas-kit-react",
3
- "version": "14.0.0-alpha.1237-next.0",
3
+ "version": "14.0.0-alpha.1239-next.0",
4
4
  "description": "The parent module that contains all Workday Canvas Kit React components",
5
5
  "author": "Workday, Inc. (https://www.workday.com)",
6
6
  "license": "Apache-2.0",
@@ -52,8 +52,8 @@
52
52
  "@popperjs/core": "^2.5.4",
53
53
  "@tanstack/react-virtual": "^3.13.9",
54
54
  "@workday/canvas-colors-web": "^2.0.0",
55
- "@workday/canvas-kit-popup-stack": "^14.0.0-alpha.1237-next.0",
56
- "@workday/canvas-kit-styling": "^14.0.0-alpha.1237-next.0",
55
+ "@workday/canvas-kit-popup-stack": "^14.0.0-alpha.1239-next.0",
56
+ "@workday/canvas-kit-styling": "^14.0.0-alpha.1239-next.0",
57
57
  "@workday/canvas-system-icons-web": "^3.0.35",
58
58
  "@workday/canvas-tokens-web": "3.0.0-alpha.12",
59
59
  "@workday/design-assets-types": "^0.2.10",
@@ -68,5 +68,5 @@
68
68
  "@workday/canvas-accent-icons-web": "^3.0.0",
69
69
  "@workday/canvas-applet-icons-web": "^2.0.0"
70
70
  },
71
- "gitHead": "8a03bc6fdf11ecb2672ad937247aaf18b7cee0ec"
71
+ "gitHead": "fdb8b845a09a86de1fb0a383fb3c5def6016e064"
72
72
  }
@@ -15,7 +15,7 @@ export const paginationPageButtonStencil = createStencil({
15
15
  [buttonStencil.vars.label]: system.color.fg.default,
16
16
 
17
17
  '&:hover, &.hover': {
18
- [buttonStencil.vars.background]: system.color.bg.alt.default,
18
+ [buttonStencil.vars.background]: system.color.bg.alt.soft,
19
19
  [buttonStencil.vars.label]: system.color.fg.strong,
20
20
  },
21
21
 
@@ -2,7 +2,7 @@ import {CanvasSystemIcon} from '@workday/design-assets-types';
2
2
  import {caretDownSmallIcon} from '@workday/canvas-system-icons-web';
3
3
  import {createStencil, CSProps} from '@workday/canvas-kit-styling';
4
4
  import {InputGroup, TextInput} from '@workday/canvas-kit-react/text-input';
5
- import {SystemIcon} from '@workday/canvas-kit-react/icon';
5
+ import {SystemIcon, systemIconStencil} from '@workday/canvas-kit-react/icon';
6
6
 
7
7
  import {useSelectInput} from './hooks/useSelectInput';
8
8
  import {useSelectModel} from './hooks/useSelectModel';
@@ -35,6 +35,7 @@ export const selectInputStencil = createStencil({
35
35
  visualInputPart,
36
36
  caretContainerPart,
37
37
  startIconContainerPart,
38
+ caretPart,
38
39
  }) => ({
39
40
  [hiddenInputPart]: {
40
41
  position: 'absolute',
@@ -65,6 +66,11 @@ export const selectInputStencil = createStencil({
65
66
  backgroundColor: 'transparent',
66
67
  },
67
68
  },
69
+ '&:has(:disabled, .disabled)': {
70
+ [caretPart]: {
71
+ [systemIconStencil.vars.color]: system.color.fg.disabled,
72
+ },
73
+ },
68
74
  }),
69
75
  modifiers: {
70
76
  error: {
@@ -73,7 +79,7 @@ export const selectInputStencil = createStencil({
73
79
  backgroundColor: brand.error.lightest,
74
80
  },
75
81
  }),
76
- alert: ({visualInputPart}) => ({
82
+ caution: ({visualInputPart}) => ({
77
83
  [visualInputPart]: {
78
84
  backgroundColor: brand.alert.lightest,
79
85
  },
@@ -97,7 +97,7 @@ const switchInputStencil = createStencil({
97
97
  0 0 0 ${px2rem(5)} transparent`,
98
98
  },
99
99
  },
100
- alert: {
100
+ caution: {
101
101
  '& ~ div:first-of-type': {
102
102
  boxShadow: `
103
103
  0 0 0 ${px2rem(2)} ${system.color.border.inverse},
@@ -101,7 +101,7 @@ const tabItemStencil = createStencil({
101
101
  whiteSpace: 'nowrap',
102
102
  textOverflow: 'ellipsis',
103
103
  overflow: 'hidden',
104
- [systemIconStencil.vars.color]: system.color.fg.muted.soft,
104
+ [systemIconStencil.vars.color]: 'currentColor',
105
105
 
106
106
  '&:has(span)': {
107
107
  display: 'flex',
@@ -82,7 +82,7 @@ export const textInputStencil = createStencil({
82
82
  outlineOffset: px2rem(2),
83
83
  },
84
84
  },
85
- alert: {
85
+ caution: {
86
86
  borderColor: brand.common.alertOuter,
87
87
  boxShadow: `inset 0 0 0 ${px2rem(2)} ${brand.common.alertInner}`,
88
88
  backgroundColor: brand.alert.lightest,