@pine-ds/core 3.4.1 → 3.4.3

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 (179) hide show
  1. package/components/pds-box2.js +7 -3
  2. package/components/pds-box2.js.map +1 -1
  3. package/components/pds-button2.js +1 -1
  4. package/components/pds-button2.js.map +1 -1
  5. package/components/pds-checkbox2.js +44 -6
  6. package/components/pds-checkbox2.js.map +1 -1
  7. package/components/pds-switch.js +47 -4
  8. package/components/pds-switch.js.map +1 -1
  9. package/components/utils.js +38 -5
  10. package/components/utils.js.map +1 -1
  11. package/dist/cjs/loader.cjs.js +1 -1
  12. package/dist/cjs/pds-box.cjs.entry.js +7 -3
  13. package/dist/cjs/pds-box.cjs.entry.js.map +1 -1
  14. package/dist/cjs/pds-box.entry.cjs.js.map +1 -1
  15. package/dist/cjs/pds-button.cjs.entry.js +2 -2
  16. package/dist/cjs/pds-button.cjs.entry.js.map +1 -1
  17. package/dist/cjs/pds-button.entry.cjs.js.map +1 -1
  18. package/dist/cjs/pds-checkbox.cjs.entry.js +42 -4
  19. package/dist/cjs/pds-checkbox.cjs.entry.js.map +1 -1
  20. package/dist/cjs/pds-checkbox.entry.cjs.js.map +1 -1
  21. package/dist/cjs/pds-input.cjs.entry.js +1 -1
  22. package/dist/cjs/pds-link.cjs.entry.js +1 -1
  23. package/dist/cjs/pds-switch.cjs.entry.js +44 -3
  24. package/dist/cjs/pds-switch.cjs.entry.js.map +1 -1
  25. package/dist/cjs/pds-switch.entry.cjs.js.map +1 -1
  26. package/dist/cjs/pds-text.cjs.entry.js +1 -1
  27. package/dist/cjs/pds-textarea.cjs.entry.js +1 -1
  28. package/dist/cjs/pine-core.cjs.js +1 -1
  29. package/dist/cjs/utils-7jx8T2mW.js +79 -0
  30. package/dist/cjs/utils-7jx8T2mW.js.map +1 -0
  31. package/dist/collection/components/pds-accordion/stories/pds-accordion.stories.js +1 -1
  32. package/dist/collection/components/pds-alert/stories/pds-alert.stories.js +6 -6
  33. package/dist/collection/components/pds-box/pds-box.js +10 -6
  34. package/dist/collection/components/pds-box/pds-box.js.map +1 -1
  35. package/dist/collection/components/pds-box/stories/pds-box.stories.js +2 -2
  36. package/dist/collection/components/pds-button/pds-button.css +1 -0
  37. package/dist/collection/components/pds-button/stories/pds-button.stories.js +4 -4
  38. package/dist/collection/components/pds-checkbox/pds-checkbox.js +44 -3
  39. package/dist/collection/components/pds-checkbox/pds-checkbox.js.map +1 -1
  40. package/dist/collection/components/pds-checkbox/stories/pds-checkbox.stories.js +6 -6
  41. package/dist/collection/components/pds-chip/stories/pds-chip.stories.js +2 -2
  42. package/dist/collection/components/pds-copytext/stories/pds-copytext.stories.js +3 -3
  43. package/dist/collection/components/pds-image/stories/pds-image.stories.js +1 -1
  44. package/dist/collection/components/pds-input/stories/pds-input.stories.js +37 -37
  45. package/dist/collection/components/pds-link/stories/pds-link.stories.js +2 -2
  46. package/dist/collection/components/pds-loader/stories/pds-loader.stories.js +3 -3
  47. package/dist/collection/components/pds-modal/stories/pds-modal.stories.js +9 -9
  48. package/dist/collection/components/pds-progress/stories/pds-progress.stories.js +2 -2
  49. package/dist/collection/components/pds-radio/stories/pds-radio.stories.js +6 -6
  50. package/dist/collection/components/pds-row/stories/pds-row.stories.js +16 -12
  51. package/dist/collection/components/pds-select/stories/pds-select.stories.js +19 -19
  52. package/dist/collection/components/pds-sortable/stories/pds-sortable.stories.js +4 -4
  53. package/dist/collection/components/pds-switch/pds-switch.js +47 -3
  54. package/dist/collection/components/pds-switch/pds-switch.js.map +1 -1
  55. package/dist/collection/components/pds-switch/stories/pds-switch.stories.js +5 -5
  56. package/dist/collection/components/pds-table/stories/pds-table.stories.js +12 -12
  57. package/dist/collection/components/pds-textarea/stories/pds-textarea.stories.js +15 -15
  58. package/dist/collection/components/pds-toast/stories/pds-toast.stories.js +2 -2
  59. package/dist/collection/components/pds-tooltip/stories/pds-tooltip.stories.js +14 -14
  60. package/dist/collection/utils/utils.js +37 -4
  61. package/dist/collection/utils/utils.js.map +1 -1
  62. package/dist/docs.json +5 -14
  63. package/dist/esm/loader.js +1 -1
  64. package/dist/esm/pds-box.entry.js +7 -3
  65. package/dist/esm/pds-box.entry.js.map +1 -1
  66. package/dist/esm/pds-button.entry.js +2 -2
  67. package/dist/esm/pds-button.entry.js.map +1 -1
  68. package/dist/esm/pds-checkbox.entry.js +42 -4
  69. package/dist/esm/pds-checkbox.entry.js.map +1 -1
  70. package/dist/esm/pds-input.entry.js +1 -1
  71. package/dist/esm/pds-link.entry.js +1 -1
  72. package/dist/esm/pds-switch.entry.js +44 -3
  73. package/dist/esm/pds-switch.entry.js.map +1 -1
  74. package/dist/esm/pds-text.entry.js +1 -1
  75. package/dist/esm/pds-textarea.entry.js +1 -1
  76. package/dist/esm/pine-core.js +1 -1
  77. package/dist/esm/utils-tJa4KYNO.js +74 -0
  78. package/dist/esm/utils-tJa4KYNO.js.map +1 -0
  79. package/dist/esm-es5/loader.js +1 -1
  80. package/dist/esm-es5/pds-box.entry.js +1 -1
  81. package/dist/esm-es5/pds-box.entry.js.map +1 -1
  82. package/dist/esm-es5/pds-button.entry.js +1 -1
  83. package/dist/esm-es5/pds-button.entry.js.map +1 -1
  84. package/dist/esm-es5/pds-checkbox.entry.js +1 -1
  85. package/dist/esm-es5/pds-checkbox.entry.js.map +1 -1
  86. package/dist/esm-es5/pds-input.entry.js +1 -1
  87. package/dist/esm-es5/pds-link.entry.js +1 -1
  88. package/dist/esm-es5/pds-switch.entry.js +1 -1
  89. package/dist/esm-es5/pds-switch.entry.js.map +1 -1
  90. package/dist/esm-es5/pds-text.entry.js +1 -1
  91. package/dist/esm-es5/pds-textarea.entry.js +1 -1
  92. package/dist/esm-es5/pine-core.js +1 -1
  93. package/dist/esm-es5/utils-tJa4KYNO.js +2 -0
  94. package/dist/esm-es5/utils-tJa4KYNO.js.map +1 -0
  95. package/dist/pine-core/{p-088828ce.entry.js → p-042ee55c.entry.js} +2 -2
  96. package/dist/pine-core/{p-6cc09a2f.system.entry.js → p-19d08886.system.entry.js} +2 -2
  97. package/dist/pine-core/p-19d08886.system.entry.js.map +1 -0
  98. package/dist/pine-core/{p-0d8a2a39.system.entry.js → p-280a0ec1.system.entry.js} +2 -2
  99. package/dist/pine-core/p-380d1056.entry.js +2 -0
  100. package/dist/pine-core/p-380d1056.entry.js.map +1 -0
  101. package/dist/pine-core/p-3EWr6ZgL.system.js.map +1 -0
  102. package/dist/pine-core/p-4a658a86.system.entry.js +2 -0
  103. package/dist/pine-core/p-4a658a86.system.entry.js.map +1 -0
  104. package/dist/pine-core/p-65275835.system.entry.js +2 -0
  105. package/dist/pine-core/p-65275835.system.entry.js.map +1 -0
  106. package/dist/pine-core/{p-568296f0.system.entry.js → p-6bd5811c.system.entry.js} +2 -2
  107. package/dist/pine-core/{p-9afcab0c.system.entry.js → p-8096b988.system.entry.js} +2 -2
  108. package/dist/pine-core/p-8096b988.system.entry.js.map +1 -0
  109. package/dist/pine-core/p-8896d43a.entry.js +2 -0
  110. package/dist/pine-core/p-8896d43a.entry.js.map +1 -0
  111. package/dist/pine-core/p-B0PUl1_1.system.js.map +1 -0
  112. package/dist/pine-core/p-BG6uGRQj.system.js +2 -0
  113. package/dist/pine-core/p-BG6uGRQj.system.js.map +1 -0
  114. package/dist/pine-core/p-BdBU6s5P.system.js.map +1 -0
  115. package/dist/pine-core/{p-Ce_XeYF6.system.js.map → p-BmoX08WO.system.js.map} +1 -1
  116. package/dist/pine-core/{p-DJu23j_m.system.js.map → p-CmJBNVRO.system.js.map} +1 -1
  117. package/dist/pine-core/{p-CbQ4EQA9.system.js.map → p-DQ-QGnGf.system.js.map} +1 -1
  118. package/dist/pine-core/p-De9tROL-.system.js +1 -1
  119. package/dist/pine-core/{p-Dm_a1Ag0.system.js.map → p-KkT5zjJU.system.js.map} +1 -1
  120. package/dist/pine-core/p-Rj3B0bRw.system.js.map +1 -0
  121. package/dist/pine-core/{p-2b48499b.entry.js → p-a2d16624.entry.js} +2 -2
  122. package/dist/pine-core/{p-d06351b9.system.entry.js → p-a7cb24c3.system.entry.js} +2 -2
  123. package/dist/pine-core/{p-8a02c581.entry.js → p-b649d711.entry.js} +2 -2
  124. package/dist/pine-core/{p-fcdbb73f.entry.js → p-c7075f11.entry.js} +2 -2
  125. package/dist/pine-core/p-c7075f11.entry.js.map +1 -0
  126. package/dist/pine-core/p-c721e8cf.entry.js +2 -0
  127. package/dist/pine-core/p-c721e8cf.entry.js.map +1 -0
  128. package/dist/pine-core/{p-f2da93ea.entry.js → p-f35a5afa.entry.js} +2 -2
  129. package/dist/pine-core/{p-5c87077e.system.entry.js → p-ffe867ef.system.entry.js} +2 -2
  130. package/dist/pine-core/p-tJa4KYNO.js +2 -0
  131. package/dist/pine-core/p-tJa4KYNO.js.map +1 -0
  132. package/dist/pine-core/pds-box.entry.esm.js.map +1 -1
  133. package/dist/pine-core/pds-button.entry.esm.js.map +1 -1
  134. package/dist/pine-core/pds-checkbox.entry.esm.js.map +1 -1
  135. package/dist/pine-core/pds-switch.entry.esm.js.map +1 -1
  136. package/dist/pine-core/pine-core.esm.js +1 -1
  137. package/dist/types/components/pds-box/pds-box.d.ts +2 -1
  138. package/dist/types/components/pds-checkbox/pds-checkbox.d.ts +6 -0
  139. package/dist/types/components/pds-switch/pds-switch.d.ts +6 -0
  140. package/dist/types/components.d.ts +4 -4
  141. package/dist/types/utils/utils.d.ts +10 -3
  142. package/hydrate/index.js +165 -50
  143. package/hydrate/index.mjs +165 -50
  144. package/package.json +2 -2
  145. package/dist/cjs/utils-jWx-Mf12.js +0 -45
  146. package/dist/cjs/utils-jWx-Mf12.js.map +0 -1
  147. package/dist/esm/utils-DkabwBZT.js +0 -41
  148. package/dist/esm/utils-DkabwBZT.js.map +0 -1
  149. package/dist/esm-es5/utils-DkabwBZT.js +0 -2
  150. package/dist/esm-es5/utils-DkabwBZT.js.map +0 -1
  151. package/dist/pine-core/p-17c2f3fb.entry.js +0 -2
  152. package/dist/pine-core/p-17c2f3fb.entry.js.map +0 -1
  153. package/dist/pine-core/p-69e95bc4.system.entry.js +0 -2
  154. package/dist/pine-core/p-69e95bc4.system.entry.js.map +0 -1
  155. package/dist/pine-core/p-6cc09a2f.system.entry.js.map +0 -1
  156. package/dist/pine-core/p-7de61adb.entry.js +0 -2
  157. package/dist/pine-core/p-7de61adb.entry.js.map +0 -1
  158. package/dist/pine-core/p-81cf9a46.system.entry.js +0 -2
  159. package/dist/pine-core/p-81cf9a46.system.entry.js.map +0 -1
  160. package/dist/pine-core/p-9afcab0c.system.entry.js.map +0 -1
  161. package/dist/pine-core/p-BDQFLOLJ.system.js.map +0 -1
  162. package/dist/pine-core/p-BhPuKJbQ.system.js +0 -2
  163. package/dist/pine-core/p-BhPuKJbQ.system.js.map +0 -1
  164. package/dist/pine-core/p-CaD_7MzD.system.js.map +0 -1
  165. package/dist/pine-core/p-CnDggyDA.system.js.map +0 -1
  166. package/dist/pine-core/p-DkabwBZT.js +0 -2
  167. package/dist/pine-core/p-DkabwBZT.js.map +0 -1
  168. package/dist/pine-core/p-bfd08c9c.entry.js +0 -2
  169. package/dist/pine-core/p-bfd08c9c.entry.js.map +0 -1
  170. package/dist/pine-core/p-cHtb875x.system.js.map +0 -1
  171. package/dist/pine-core/p-fcdbb73f.entry.js.map +0 -1
  172. /package/dist/pine-core/{p-088828ce.entry.js.map → p-042ee55c.entry.js.map} +0 -0
  173. /package/dist/pine-core/{p-0d8a2a39.system.entry.js.map → p-280a0ec1.system.entry.js.map} +0 -0
  174. /package/dist/pine-core/{p-568296f0.system.entry.js.map → p-6bd5811c.system.entry.js.map} +0 -0
  175. /package/dist/pine-core/{p-2b48499b.entry.js.map → p-a2d16624.entry.js.map} +0 -0
  176. /package/dist/pine-core/{p-d06351b9.system.entry.js.map → p-a7cb24c3.system.entry.js.map} +0 -0
  177. /package/dist/pine-core/{p-8a02c581.entry.js.map → p-b649d711.entry.js.map} +0 -0
  178. /package/dist/pine-core/{p-f2da93ea.entry.js.map → p-f35a5afa.entry.js.map} +0 -0
  179. /package/dist/pine-core/{p-5c87077e.system.entry.js.map → p-ffe867ef.system.entry.js.map} +0 -0
@@ -16,7 +16,7 @@ const BaseTemplate = (args) => html`
16
16
  align-self="${args.alignSelf}"
17
17
  auto="${args.auto}"
18
18
  background-color="${args.backgroundColor}"
19
- border="${args.border}"
19
+ ?border=${args.border}
20
20
  border-color="${args.borderColor}"
21
21
  border-radius="${args.borderRadius}"
22
22
  direction="${args.direction}"
@@ -58,4 +58,4 @@ Default.args = {
58
58
  componentId: 'opt0',
59
59
  border: true,
60
60
  minHeight: '100px',
61
- };
61
+ };
@@ -20,6 +20,7 @@
20
20
  display: flex;
21
21
  width: 100%;
22
22
  }
23
+ :host([full-width=true]) a,
23
24
  :host([full-width=true]) button {
24
25
  justify-content: center;
25
26
  width: 100%;
@@ -18,12 +18,12 @@ export default {
18
18
  const BaseTemplate = (args) => html`
19
19
  <pds-button
20
20
  component-id=${args.componentId}
21
- disabled=${args.disabled}
22
- full-width=${args.fullWidth}
21
+ ?disabled=${args.disabled}
22
+ ?full-width=${args.fullWidth}
23
23
  href=${args.href}
24
- icon-only=${args.iconOnly}
24
+ ?icon-only=${args.iconOnly}
25
25
  icon=${args.icon}
26
- loading=${args.loading}
26
+ ?loading=${args.loading}
27
27
  name=${args.name}
28
28
  target=${args.target}
29
29
  type=${args.type}
@@ -15,6 +15,7 @@ export class PdsCheckbox {
15
15
  }
16
16
  const target = e.target;
17
17
  this.checked = target.checked;
18
+ this.updateFormValue();
18
19
  this.pdsCheckboxChange.emit({
19
20
  checked: target.checked,
20
21
  value: this.value
@@ -43,16 +44,53 @@ export class PdsCheckbox {
43
44
  }
44
45
  return classNames.join(' ');
45
46
  }
47
+ connectedCallback() {
48
+ if (this.el.attachInternals) {
49
+ this.internals = this.el.attachInternals();
50
+ }
51
+ }
52
+ componentDidLoad() {
53
+ this.updateFormValue();
54
+ }
55
+ checkedChanged() {
56
+ this.updateFormValue();
57
+ }
58
+ updateFormValue() {
59
+ var _a;
60
+ if (typeof jest !== 'undefined' || typeof process !== 'undefined' && ((_a = process.env) === null || _a === void 0 ? void 0 : _a.NODE_ENV) === 'test') {
61
+ return;
62
+ }
63
+ if (this.internals && this.internals.setFormValue) {
64
+ // For checkboxes, only send the value when checked, otherwise send null
65
+ const formValue = this.checked ? (this.value || 'on') : null;
66
+ this.internals.setFormValue(formValue);
67
+ }
68
+ if (this.internals && this.internals.setValidity) {
69
+ this.internals.setValidity({});
70
+ }
71
+ }
72
+ formStateRestoreCallback(state) {
73
+ if (state instanceof FormData) {
74
+ // For checkboxes, restore if the value exists in FormData
75
+ const value = this.value || 'on';
76
+ this.checked = state.get(this.name) === value;
77
+ }
78
+ else if (typeof state === 'string') {
79
+ // Restore from string state
80
+ this.checked = state === (this.value || 'on');
81
+ }
82
+ }
46
83
  componentWillLoad() {
47
84
  this.inheritedAttributes = Object.assign({}, inheritAriaAttributes(this.el));
48
85
  }
49
86
  render() {
50
- return (h(Host, { key: 'a60ffb7c96f1d15735f263cb55cd982fbfcbe729', class: this.classNames() }, h("label", { key: '6ed2c8670cded5165761374362d9f1e9f386a4d2', htmlFor: this.componentId }, h("input", Object.assign({ key: '0661b30a9af3bd8ee83b2f3ceb249810a78f19a5', type: "checkbox", "aria-describedby": assignDescription(this.componentId, this.invalid, this.errorMessage || this.helperMessage), "aria-invalid": this.invalid ? "true" : undefined, id: this.componentId, indeterminate: this.indeterminate, name: this.name, value: this.value, checked: this.checked, required: this.required, disabled: this.disabled, onChange: this.handleCheckboxChange, onInput: this.handleInput }, this.inheritedAttributes)), h("span", { key: 'b16d78ead4da7ebdffb0f37127bdacf8b1538f86', class: this.hideLabel ? 'visually-hidden' : '' }, this.label)), this.helperMessage &&
51
- h("div", { key: '78e88b11ba9e2759264e08ff0ce9e16c9cf67170', class: 'pds-checkbox__message', id: messageId(this.componentId, 'helper') }, this.helperMessage), this.errorMessage &&
52
- h("div", { key: '0ba7d2bd2b4f6c996eecdd103abe3fb6497e4376', class: `pds-checkbox__message pds-checkbox__message--error`, id: messageId(this.componentId, 'error'), "aria-live": "assertive" }, h("pds-icon", { key: '65a94316603638e5230de0644fc8ca60e9543b63', icon: danger, size: "small" }), this.errorMessage)));
87
+ return (h(Host, { key: 'f3a4cc998ec87374f2ee2dd91956d3bdd94d18ca', class: this.classNames() }, h("label", { key: '5c8ec6b36e50dedd76b0c23f912091ed40278d0f', htmlFor: this.componentId }, h("input", Object.assign({ key: '0969ba3846816446acc935636176b44aec9d90f5', type: "checkbox", "aria-describedby": assignDescription(this.componentId, this.invalid, this.errorMessage || this.helperMessage), "aria-invalid": this.invalid ? "true" : undefined, id: this.componentId, indeterminate: this.indeterminate, name: this.name, value: this.value, checked: this.checked, required: this.required, disabled: this.disabled, onChange: this.handleCheckboxChange, onInput: this.handleInput }, this.inheritedAttributes)), h("span", { key: 'ba47123715955ddad09296fbcfab6a423940f1f3', class: this.hideLabel ? 'visually-hidden' : '' }, this.label)), this.helperMessage &&
88
+ h("div", { key: '942c6ae8e8d77be86480395263dee5071e8132ea', class: 'pds-checkbox__message', id: messageId(this.componentId, 'helper') }, this.helperMessage), this.errorMessage &&
89
+ h("div", { key: '74ea1c3b398d072faf9d5359f00bacaa9a0a4169', class: `pds-checkbox__message pds-checkbox__message--error`, id: messageId(this.componentId, 'error'), "aria-live": "assertive" }, h("pds-icon", { key: '9b7aa5f226c169a1cd8e559dc731ea49be7ada6c', icon: danger, size: "small" }), this.errorMessage)));
53
90
  }
54
91
  static get is() { return "pds-checkbox"; }
55
92
  static get encapsulation() { return "shadow"; }
93
+ static get formAssociated() { return true; }
56
94
  static get originalStyleUrls() {
57
95
  return {
58
96
  "$": ["../../global/styles/utils/label.scss", "pds-checkbox.scss"]
@@ -346,6 +384,9 @@ export class PdsCheckbox {
346
384
  return [{
347
385
  "propName": "checked",
348
386
  "methodName": "updateIndeterminate"
387
+ }, {
388
+ "propName": "checked",
389
+ "methodName": "checkedChanged"
349
390
  }];
350
391
  }
351
392
  }
@@ -1 +1 @@
1
- {"version":3,"file":"pds-checkbox.js","sourceRoot":"","sources":["../../../src/components/pds-checkbox/pds-checkbox.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, h, Prop, Host, Event, EventEmitter, Watch } from '@stencil/core';\nimport { assignDescription, messageId } from '../../utils/form';\nimport { CheckboxChangeEventDetail } from './checkbox-interface';\nimport { danger } from '@pine-ds/icons/icons';\n\nimport { inheritAriaAttributes } from '@utils/attributes';\nimport type { Attributes } from '@utils/attributes';\n\n@Component({\n tag: 'pds-checkbox',\n styleUrls: ['../../global/styles/utils/label.scss', 'pds-checkbox.scss'],\n shadow: true,\n})\nexport class PdsCheckbox {\n private inheritedAttributes: Attributes = {};\n\n @Element() el: HTMLPdsCheckboxElement;\n\n /**\n * It determines whether or not the checkbox is checked.\n */\n @Prop({ mutable: true }) checked?: boolean = false;\n\n /**\n * A unique identifier used for the underlying component `id` attribute and the label `for` attribute.\n */\n @Prop() componentId!: string;\n\n /**\n * It determines whether or not the checkbox is disabled.\n */\n @Prop() disabled: boolean;\n\n /**\n * Displays message text describing an invalid state.\n */\n @Prop() errorMessage: string;\n\n /**\n * String used for helper message below checkbox.\n */\n @Prop() helperMessage: string;\n\n /**\n * If `true`, the checkbox will visually appear as indeterminate.\n * Only JavaScript can set the objects `indeterminate` property. See [MDN Web Docs](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#indeterminate_state_checkboxes).\n */\n @Prop({ mutable: true }) indeterminate: boolean;\n\n /**\n * It determines whether or not the checkbox is invalid.\n */\n @Prop() invalid: boolean;\n\n /**\n * String used for label text next to checkbox.\n */\n @Prop() label: string;\n\n /**\n * Visually hides the label text for instances where only the checkbox should be displayed. Label remains accessible to assistive technology such as screen readers.\n */\n @Prop() hideLabel: boolean;\n\n /**\n * String used for checkbox `name` attribute.\n */\n @Prop() name: string;\n\n /**\n * It determines whether or not the checkbox is required.\n */\n @Prop() required: boolean;\n\n /**\n * The value of the checkbox that is submitted with a form.\n */\n @Prop() value: string;\n\n /**\n * Event emitted that contains the `value` and `checked`.\n */\n @Event() pdsCheckboxChange: EventEmitter<CheckboxChangeEventDetail>;\n\n @Event() pdsCheckboxInput: EventEmitter<CheckboxChangeEventDetail>;\n\n @Watch('checked')\n updateIndeterminate() {\n this.indeterminate = undefined\n }\n\n private handleCheckboxChange = (e: Event) => {\n if (this.disabled) {\n return;\n }\n\n const target = e.target as HTMLInputElement;\n this.checked = target.checked;\n\n this.pdsCheckboxChange.emit({\n checked: target.checked,\n value: this.value\n });\n }\n\n private handleInput = () => {\n this.pdsCheckboxInput.emit({\n checked: this.checked,\n value: this.value\n });\n }\n\n private classNames() {\n const classNames = [];\n\n if (this.invalid) { classNames.push('is-invalid'); }\n if (this.indeterminate) { classNames.push('is-indeterminate'); }\n if (this.disabled) { classNames.push('is-disabled'); }\n\n return classNames.join(' ');\n }\n\n componentWillLoad() {\n this.inheritedAttributes = {\n ...inheritAriaAttributes(this.el)\n }\n }\n\n render() {\n return (\n <Host class={this.classNames()}>\n <label htmlFor={this.componentId}>\n <input\n type=\"checkbox\"\n aria-describedby={assignDescription(this.componentId, this.invalid, this.errorMessage || this.helperMessage)}\n aria-invalid={this.invalid ? \"true\" : undefined}\n id={this.componentId}\n indeterminate={this.indeterminate}\n name={this.name}\n value={this.value}\n checked={this.checked}\n required={this.required}\n disabled={this.disabled}\n onChange={this.handleCheckboxChange}\n onInput={this.handleInput}\n {...this.inheritedAttributes}\n />\n <span class={this.hideLabel ? 'visually-hidden' : ''}>\n {this.label}\n </span>\n </label>\n {this.helperMessage &&\n <div\n class={'pds-checkbox__message'}\n id={messageId(this.componentId, 'helper')}\n >\n {this.helperMessage}\n </div>\n }\n {this.errorMessage &&\n <div\n class={`pds-checkbox__message pds-checkbox__message--error`}\n id={messageId(this.componentId, 'error')}\n aria-live=\"assertive\"\n >\n <pds-icon icon={danger} size=\"small\" />\n {this.errorMessage}\n </div>\n }\n </Host>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"pds-checkbox.js","sourceRoot":"","sources":["../../../src/components/pds-checkbox/pds-checkbox.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, h, Prop, Host, Event, EventEmitter, Watch } from '@stencil/core';\nimport { assignDescription, messageId } from '../../utils/form';\nimport { CheckboxChangeEventDetail } from './checkbox-interface';\nimport { danger } from '@pine-ds/icons/icons';\n\nimport { inheritAriaAttributes } from '@utils/attributes';\nimport type { Attributes } from '@utils/attributes';\n\n@Component({\n tag: 'pds-checkbox',\n styleUrls: ['../../global/styles/utils/label.scss', 'pds-checkbox.scss'],\n shadow: true,\n formAssociated: true,\n})\nexport class PdsCheckbox {\n private inheritedAttributes: Attributes = {};\n private internals?: ElementInternals;\n\n @Element() el: HTMLPdsCheckboxElement;\n\n /**\n * It determines whether or not the checkbox is checked.\n */\n @Prop({ mutable: true }) checked?: boolean = false;\n\n /**\n * A unique identifier used for the underlying component `id` attribute and the label `for` attribute.\n */\n @Prop() componentId!: string;\n\n /**\n * It determines whether or not the checkbox is disabled.\n */\n @Prop() disabled: boolean;\n\n /**\n * Displays message text describing an invalid state.\n */\n @Prop() errorMessage: string;\n\n /**\n * String used for helper message below checkbox.\n */\n @Prop() helperMessage: string;\n\n /**\n * If `true`, the checkbox will visually appear as indeterminate.\n * Only JavaScript can set the objects `indeterminate` property. See [MDN Web Docs](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/checkbox#indeterminate_state_checkboxes).\n */\n @Prop({ mutable: true }) indeterminate: boolean;\n\n /**\n * It determines whether or not the checkbox is invalid.\n */\n @Prop() invalid: boolean;\n\n /**\n * String used for label text next to checkbox.\n */\n @Prop() label: string;\n\n /**\n * Visually hides the label text for instances where only the checkbox should be displayed. Label remains accessible to assistive technology such as screen readers.\n */\n @Prop() hideLabel: boolean;\n\n /**\n * String used for checkbox `name` attribute.\n */\n @Prop() name: string;\n\n /**\n * It determines whether or not the checkbox is required.\n */\n @Prop() required: boolean;\n\n /**\n * The value of the checkbox that is submitted with a form.\n */\n @Prop() value: string;\n\n /**\n * Event emitted that contains the `value` and `checked`.\n */\n @Event() pdsCheckboxChange: EventEmitter<CheckboxChangeEventDetail>;\n\n @Event() pdsCheckboxInput: EventEmitter<CheckboxChangeEventDetail>;\n\n @Watch('checked')\n updateIndeterminate() {\n this.indeterminate = undefined\n }\n\n private handleCheckboxChange = (e: Event) => {\n if (this.disabled) {\n return;\n }\n\n const target = e.target as HTMLInputElement;\n this.checked = target.checked;\n\n this.updateFormValue();\n\n this.pdsCheckboxChange.emit({\n checked: target.checked,\n value: this.value\n });\n }\n\n private handleInput = () => {\n this.pdsCheckboxInput.emit({\n checked: this.checked,\n value: this.value\n });\n }\n\n private classNames() {\n const classNames = [];\n\n if (this.invalid) { classNames.push('is-invalid'); }\n if (this.indeterminate) { classNames.push('is-indeterminate'); }\n if (this.disabled) { classNames.push('is-disabled'); }\n\n return classNames.join(' ');\n }\n\n connectedCallback() {\n if (this.el.attachInternals) {\n this.internals = this.el.attachInternals();\n }\n }\n\n componentDidLoad() {\n this.updateFormValue();\n }\n\n @Watch('checked')\n checkedChanged() {\n this.updateFormValue();\n }\n\n private updateFormValue() {\n if (typeof jest !== 'undefined' || typeof process !== 'undefined' && process.env?.NODE_ENV === 'test') {\n return;\n }\n\n if (this.internals && this.internals.setFormValue) {\n // For checkboxes, only send the value when checked, otherwise send null\n const formValue = this.checked ? (this.value || 'on') : null;\n this.internals.setFormValue(formValue);\n }\n\n if (this.internals && this.internals.setValidity) {\n this.internals.setValidity({});\n }\n }\n\n formStateRestoreCallback(state: string | FormData | null) {\n if (state instanceof FormData) {\n // For checkboxes, restore if the value exists in FormData\n const value = this.value || 'on';\n this.checked = state.get(this.name as string) === value;\n } else if (typeof state === 'string') {\n // Restore from string state\n this.checked = state === (this.value || 'on');\n }\n }\n\n componentWillLoad() {\n this.inheritedAttributes = {\n ...inheritAriaAttributes(this.el)\n }\n }\n\n render() {\n return (\n <Host class={this.classNames()}>\n <label htmlFor={this.componentId}>\n <input\n type=\"checkbox\"\n aria-describedby={assignDescription(this.componentId, this.invalid, this.errorMessage || this.helperMessage)}\n aria-invalid={this.invalid ? \"true\" : undefined}\n id={this.componentId}\n indeterminate={this.indeterminate}\n name={this.name}\n value={this.value}\n checked={this.checked}\n required={this.required}\n disabled={this.disabled}\n onChange={this.handleCheckboxChange}\n onInput={this.handleInput}\n {...this.inheritedAttributes}\n />\n <span class={this.hideLabel ? 'visually-hidden' : ''}>\n {this.label}\n </span>\n </label>\n {this.helperMessage &&\n <div\n class={'pds-checkbox__message'}\n id={messageId(this.componentId, 'helper')}\n >\n {this.helperMessage}\n </div>\n }\n {this.errorMessage &&\n <div\n class={`pds-checkbox__message pds-checkbox__message--error`}\n id={messageId(this.componentId, 'error')}\n aria-live=\"assertive\"\n >\n <pds-icon icon={danger} size=\"small\" />\n {this.errorMessage}\n </div>\n }\n </Host>\n );\n }\n}\n"]}
@@ -25,16 +25,16 @@ export default {
25
25
  const BaseTemplate = (args) =>
26
26
  html` <pds-checkbox
27
27
  component-id=${args.componentId}
28
- checked=${args.checked}
29
- disabled=${args.disabled}
28
+ ?checked=${args.checked}
29
+ ?disabled=${args.disabled}
30
30
  error-message=${args.errorMessage}
31
31
  helper-message=${args.helperMessage}
32
- hide-label=${args.hideLabel}
33
- indeterminate=${args.indeterminate}
34
- invalid=${args.invalid}
32
+ ?hide-label=${args.hideLabel}
33
+ ?indeterminate=${args.indeterminate}
34
+ ?invalid=${args.invalid}
35
35
  label=${args.label}
36
36
  name=${args.name}
37
- required=${args.required}
37
+ ?required=${args.required}
38
38
  value=${args.value}
39
39
  />`;
40
40
 
@@ -17,9 +17,9 @@ export default {
17
17
  const BaseTemplate = (args) => html`
18
18
  <pds-chip
19
19
  component-id="${args.componentId}"
20
- dot="${args.dot}"
20
+ ?dot=${args.dot}
21
21
  icon="${args.icon}"
22
- large="${args.large}"
22
+ ?large=${args.large}
23
23
  sentiment="${args.sentiment}"
24
24
  variant="${args.variant}"
25
25
  >
@@ -16,11 +16,11 @@ export default {
16
16
 
17
17
  const BaseTemplate = (args) => html`
18
18
  <pds-copytext
19
- border="${args.border}"
20
- full-width="${args.fullWidth}"
19
+ ?border=${args.border}
20
+ ?full-width=${args.fullWidth}
21
21
  component-id=${args.componentId}
22
22
  onClick=${args.onClick}
23
- truncate="${args.truncate}"
23
+ ?truncate=${args.truncate}
24
24
  value="${args.value}">
25
25
  </pds-copytext>`;
26
26
 
@@ -11,7 +11,7 @@ const BaseTemplate = (args) => html` <pds-image
11
11
  alt="${args.alt}"
12
12
  height="${args.height}"
13
13
  component-id="${args.componentId}"
14
- loading="${args.loading}"
14
+ ?loading=${args.loading}
15
15
  sizes="${args.sizes}"
16
16
  src="${args.src}"
17
17
  srcset="${args.srcset}"
@@ -42,16 +42,16 @@ const BaseTemplate = (args) => html`<pds-input
42
42
  autocomplete="${args.autocomplete}"
43
43
  component-id="${args.componentId}"
44
44
  debounce="${args.debounce}"
45
- disabled="${args.disabled}"
45
+ ?disabled=${args.disabled}
46
46
  error-message="${args.errorMessage}"
47
- full-width="${args.fullWidth}"
47
+ ?full-width=${args.fullWidth}
48
48
  helper-message="${args.helperMessage}"
49
- invalid="${args.invalid}"
49
+ ?invalid=${args.invalid}
50
50
  label="${args.label}"
51
51
  name="${args.name}"
52
52
  placeholder="${args.placeholder}"
53
- readonly="${args.readonly}"
54
- required="${args.required}"
53
+ ?readonly=${args.readonly}
54
+ ?required=${args.required}
55
55
  type="${args.type}"
56
56
  value="${args.value}">
57
57
  ${args.prefix || ''}
@@ -151,15 +151,15 @@ export const withPrefixIcon = (args) => html`<pds-input
151
151
  autocomplete="${args.autocomplete}"
152
152
  component-id="pds-input-prefix-icon"
153
153
  debounce="${args.debounce}"
154
- disabled="${args.disabled}"
154
+ ?disabled=${args.disabled}
155
155
  error-message="${args.errorMessage}"
156
156
  helper-message="${args.helperMessage}"
157
- invalid="${args.invalid}"
157
+ ?invalid=${args.invalid}
158
158
  label="Email"
159
159
  name="${args.name}"
160
160
  placeholder="${args.placeholder}"
161
- readonly="${args.readonly}"
162
- required="${args.required}"
161
+ ?readonly=${args.readonly}
162
+ ?required=${args.required}
163
163
  type="email"
164
164
  value="${args.value}">
165
165
  <pds-icon slot="prefix" name="mail" size="small"></pds-icon>
@@ -169,15 +169,15 @@ export const withSuffixButton = (args) => html`<pds-input
169
169
  autocomplete="${args.autocomplete}"
170
170
  component-id="pds-input-suffix-button"
171
171
  debounce="${args.debounce}"
172
- disabled="${args.disabled}"
172
+ ?disabled=${args.disabled}
173
173
  error-message="${args.errorMessage}"
174
174
  helper-message="${args.helperMessage}"
175
- invalid="${args.invalid}"
175
+ ?invalid=${args.invalid}
176
176
  label="Search"
177
177
  name="${args.name}"
178
178
  placeholder="${args.placeholder}"
179
- readonly="${args.readonly}"
180
- required="${args.required}"
179
+ ?readonly=${args.readonly}
180
+ ?required=${args.required}
181
181
  type="text"
182
182
  value="${args.value}">
183
183
  <pds-button slot="suffix" variant="unstyled" class="pds-input__suffix">
@@ -189,15 +189,15 @@ export const withPrependSelect = (args) => html`<pds-input
189
189
  autocomplete="${args.autocomplete}"
190
190
  component-id="pds-input-prepend-select"
191
191
  debounce="${args.debounce}"
192
- disabled="${args.disabled}"
192
+ ?disabled=${args.disabled}
193
193
  error-message="${args.errorMessage}"
194
194
  helper-message="${args.helperMessage}"
195
- invalid="${args.invalid}"
195
+ ?invalid=${args.invalid}
196
196
  label="Amount"
197
197
  name="${args.name}"
198
198
  placeholder="${args.placeholder}"
199
- readonly="${args.readonly}"
200
- required="${args.required}"
199
+ ?readonly=${args.readonly}
200
+ ?required=${args.required}
201
201
  type="text"
202
202
  value="${args.value}">
203
203
  <pds-select hide-label label="Currency" slot="prepend" class="pds-input__prepend" name="currency">
@@ -211,15 +211,15 @@ export const withAppendSelect = (args) => html`<pds-input
211
211
  autocomplete="${args.autocomplete}"
212
212
  component-id="pds-input-append-select"
213
213
  debounce="${args.debounce}"
214
- disabled="${args.disabled}"
214
+ ?disabled=${args.disabled}
215
215
  error-message="${args.errorMessage}"
216
216
  helper-message="${args.helperMessage}"
217
- invalid="${args.invalid}"
217
+ ?invalid=${args.invalid}
218
218
  label="Phone"
219
219
  name="${args.name}"
220
220
  placeholder="${args.placeholder}"
221
- readonly="${args.readonly}"
222
- required="${args.required}"
221
+ ?readonly=${args.readonly}
222
+ ?required=${args.required}
223
223
  type="tel"
224
224
  value="${args.value}">
225
225
  <pds-select hide-label slot="append" class="pds-input__append" name="phone-type">
@@ -233,15 +233,15 @@ export const withPrefixAndAppend = (args) => html`<pds-input
233
233
  autocomplete="${args.autocomplete}"
234
234
  component-id="pds-input-prefix-append"
235
235
  debounce="${args.debounce}"
236
- disabled="${args.disabled}"
236
+ ?disabled=${args.disabled}
237
237
  error-message="${args.errorMessage}"
238
238
  helper-message="${args.helperMessage}"
239
- invalid="${args.invalid}"
239
+ ?invalid=${args.invalid}
240
240
  label="Amount"
241
241
  name="${args.name}"
242
242
  placeholder="${args.placeholder}"
243
- readonly="${args.readonly}"
244
- required="${args.required}"
243
+ ?readonly=${args.readonly}
244
+ ?required=${args.required}
245
245
  type="text"
246
246
  value="${args.value}">
247
247
  <pds-icon slot="prefix" name="dollar" size="small"></pds-icon>
@@ -256,15 +256,15 @@ export const withPrependAndSuffix = (args) => html`<pds-input
256
256
  autocomplete="${args.autocomplete}"
257
257
  component-id="pds-input-prepend-suffix"
258
258
  debounce="${args.debounce}"
259
- disabled="${args.disabled}"
259
+ ?disabled=${args.disabled}
260
260
  error-message="${args.errorMessage}"
261
261
  helper-message="${args.helperMessage}"
262
- invalid="${args.invalid}"
262
+ ?invalid=${args.invalid}
263
263
  label="Amount"
264
264
  name="${args.name}"
265
265
  placeholder="${args.placeholder}"
266
- readonly="${args.readonly}"
267
- required="${args.required}"
266
+ ?readonly=${args.readonly}
267
+ ?required=${args.required}
268
268
  type="text"
269
269
  value="${args.value}">
270
270
  <pds-select hide-label slot="prepend" class="pds-input__prepend" name="currency">
@@ -281,15 +281,15 @@ export const withActionLink = (args) => html`<pds-input
281
281
  autocomplete="${args.autocomplete}"
282
282
  component-id="pds-input-action-link"
283
283
  debounce="${args.debounce}"
284
- disabled="${args.disabled}"
284
+ ?disabled=${args.disabled}
285
285
  error-message="${args.errorMessage}"
286
286
  helper-message="${args.helperMessage}"
287
- invalid="${args.invalid}"
287
+ ?invalid=${args.invalid}
288
288
  label="Password"
289
289
  name="${args.name}"
290
290
  placeholder="${args.placeholder}"
291
- readonly="${args.readonly}"
292
- required="true"
291
+ ?readonly=${args.readonly}
292
+ required
293
293
  type="password"
294
294
  value="${args.value}">
295
295
  <pds-link href="#" slot="action">
@@ -301,15 +301,15 @@ export const withActionButton = (args) => html`<pds-input
301
301
  autocomplete="${args.autocomplete}"
302
302
  component-id="pds-input-action-button"
303
303
  debounce="${args.debounce}"
304
- disabled="${args.disabled}"
304
+ ?disabled=${args.disabled}
305
305
  error-message="${args.errorMessage}"
306
306
  helper-message="Choose a unique username"
307
- invalid="${args.invalid}"
307
+ ?invalid=${args.invalid}
308
308
  label="Username"
309
309
  name="${args.name}"
310
310
  placeholder="${args.placeholder}"
311
- readonly="${args.readonly}"
312
- required="${args.required}"
311
+ ?readonly=${args.readonly}
312
+ ?required=${args.required}
313
313
  type="text"
314
314
  value="${args.value}">
315
315
  <pds-button slot="action" variant="unstyled">
@@ -14,8 +14,8 @@ export default {
14
14
  title: 'components/Link'
15
15
  }
16
16
 
17
- const BaseTemplate = (args) => html`<pds-link color=${args.color} external=${args.external} font-size=${args.fontSize} href=${args.href} component-id=${args.componentId} variant=${args.variant}></pds-link>`;
18
- const BaseTemplateWithSlot = (args) => html` <pds-link color=${args.color} external=${args.external} font-size=${args.fontSize} href=${args.href} component-id=${args.componentId} variant=${args.variant}>${args.slot}</pds-link>`;
17
+ const BaseTemplate = (args) => html`<pds-link color=${args.color} ?external=${args.external} font-size=${args.fontSize} href=${args.href} component-id=${args.componentId} variant=${args.variant}></pds-link>`;
18
+ const BaseTemplateWithSlot = (args) => html` <pds-link color=${args.color} ?external=${args.external} font-size=${args.fontSize} href=${args.href} component-id=${args.componentId} variant=${args.variant}>${args.slot}</pds-link>`;
19
19
 
20
20
  export const Colors = BaseTemplate.bind();
21
21
  Colors.args = {
@@ -13,8 +13,8 @@ export default {
13
13
 
14
14
  const BaseTemplate = (args) => html`
15
15
  <pds-loader
16
- is-loading="${args.isLoading}"
17
- show-label="${args.showLabel}"
16
+ ?is-loading=${args.isLoading}
17
+ ?show-label=${args.showLabel}
18
18
  size="${args.size}"
19
19
  variant="${args.variant}"
20
20
  >
@@ -33,4 +33,4 @@ Default.args = {
33
33
  export const Typing = BaseTemplate.bind();
34
34
  Typing.args = {
35
35
  variant: 'typing'
36
- };
36
+ };
@@ -30,8 +30,8 @@ const BaseTemplate = (args) => html`
30
30
  id="${args.componentId}"
31
31
  component-id="${args.componentId}"
32
32
  size="${args.size}"
33
- ?backdrop-dismiss="${args.backdropDismiss}"
34
- ?open="${args.open}"
33
+ ?backdrop-dismiss=${args.backdropDismiss}
34
+ ?open=${args.open}
35
35
  >
36
36
  <pds-modal-header>
37
37
  <pds-box direction="column" fit padding="md">
@@ -100,8 +100,8 @@ const DestructiveTemplate = (args) => html`
100
100
  id="${args.componentId}"
101
101
  component-id="${args.componentId}"
102
102
  size="${args.size}"
103
- ?backdrop-dismiss="${args.backdropDismiss}"
104
- ?open="${args.open}"
103
+ ?backdrop-dismiss=${args.backdropDismiss}
104
+ ?open=${args.open}
105
105
  >
106
106
  <pds-modal-header>
107
107
  <pds-box direction="column" fit padding="md">
@@ -166,8 +166,8 @@ const CustomContentTemplate = (args) => html`
166
166
  <pds-modal
167
167
  id="${args.componentId}"
168
168
  size="${args.size}"
169
- ?backdrop-dismiss="${args.backdropDismiss}"
170
- ?open="${args.open}"
169
+ ?backdrop-dismiss=${args.backdropDismiss}
170
+ ?open=${args.open}
171
171
  >
172
172
 
173
173
  <pds-modal-header>
@@ -254,8 +254,8 @@ const ScrollableTemplate = (args) => {
254
254
  <pds-modal
255
255
  id="${args.componentId}"
256
256
  size="${args.size}"
257
- ?backdrop-dismiss="${args.backdropDismiss}"
258
- ?open="${args.open}"
257
+ ?backdrop-dismiss=${args.backdropDismiss}
258
+ ?open=${args.open}
259
259
  >
260
260
  <pds-modal-header>
261
261
  <pds-box direction="column" fit padding="md">
@@ -338,7 +338,7 @@ const FullscreenTemplate = (args) => html`
338
338
  id="${args.componentId}"
339
339
  size=${args.size}
340
340
  ?backdrop-dismiss=${args.backdropDismiss}
341
- ?open="${args.open}"
341
+ ?open=${args.open}
342
342
  >
343
343
  <pds-modal-header>
344
344
  <pds-box
@@ -9,12 +9,12 @@ export default {
9
9
 
10
10
  const BaseTemplate = (args) =>
11
11
  html`<pds-progress
12
- animated=${args.animated}
12
+ ?animated=${args.animated}
13
13
  component-id=${args.componentId}
14
14
  fill-color=${args.fillColor}
15
15
  label=${args.label}
16
16
  percent=${args.percent}
17
- show-percent=${args.showPercent}
17
+ ?show-percent=${args.showPercent}
18
18
  ></pds-progress>`;
19
19
 
20
20
 
@@ -25,16 +25,16 @@ const BaseTemplate = (args) =>
25
25
  html` <pds-radio
26
26
  component-id=${args.componentId}
27
27
  label=${args.label}
28
- checked=${args.checked}
29
- disabled=${args.disabled}
28
+ ?checked=${args.checked}
29
+ ?disabled=${args.disabled}
30
30
  error-message=${args.errorMessage}
31
31
  helper-message=${args.helperMessage}
32
- hide-label=${args.hideLabel}
32
+ ?hide-label=${args.hideLabel}
33
33
  name=${args.name}
34
- indeterminate=${args.indeterminate}
35
- required=${args.required}
34
+ ?indeterminate=${args.indeterminate}
35
+ ?required=${args.required}
36
36
  value=${args.value}
37
- invalid=${args.invalid}
37
+ ?invalid=${args.invalid}
38
38
  />`;
39
39
 
40
40
  export const Default = BaseTemplate.bind();
@@ -9,34 +9,38 @@ export default {
9
9
 
10
10
  const BaseTemplate = (args) => html`
11
11
  <pds-row
12
- align-items="${args.alignItems}"
13
- border="${args.border}"
14
- component-id="${args.componentId}"
12
+ align-items="${args.alignItems}"
13
+ ?border=${args.border}
14
+ component-id="${args.componentId}"
15
15
  col-gap="${args.colGap}"
16
16
  justify-content="${args.justifyContent}"
17
17
  min-height="${args.minHeight}"
18
18
  no-wrap="${args.noWrap}"
19
19
  >
20
- <pds-box border>Item 1</pds-box>
21
- <pds-box border direction="column">
22
- <p>Content 1</p>
23
- <p>Content 2</p>
20
+ <pds-box>
21
+ <pds-box border>Item 1</pds-box>
22
+ </pds-box>
23
+ <pds-box>
24
+ <pds-box border direction="column">
25
+ <p>Content 1</p>
26
+ <p>Content 2</p>
27
+ </pds-box>
24
28
  </pds-box>
25
29
  </pds-row>
26
30
  `;
27
31
 
28
32
  export const Default = BaseTemplate.bind();
29
33
  Default.args = {
30
- border: "true",
34
+ border: true,
31
35
  componentId: 'opt0',
32
36
  colGap: '8px',
33
37
  };
34
38
 
35
39
  const GapTemplate = (args) => html`
36
40
  <pds-row
37
- align-items="${args.alignItems}"
38
- border="${args.border}"
39
- component-id="${args.componentId}"
41
+ align-items="${args.alignItems}"
42
+ ?border=${args.border}
43
+ component-id="${args.componentId}"
40
44
  col-gap="${args.colGap}"
41
45
  justify-content="${args.justifyContent}"
42
46
  min-height="${args.minHeight}"
@@ -67,7 +71,7 @@ const GapTemplate = (args) => html`
67
71
 
68
72
  export const Gap = GapTemplate.bind();
69
73
  Gap.args = {
70
- border: "false",
74
+ border: false,
71
75
  componentId: 'opt0',
72
76
  colGap: 'sm',
73
77
  };