@planningcenter/tapestry 1.1.0-rc.3 → 1.1.0-rc.4
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/dist/components/btn/index.d.ts +2 -0
- package/dist/components/btn/index.d.ts.map +1 -0
- package/dist/components/sidenav/index.d.ts +2 -0
- package/dist/components/sidenav/index.d.ts.map +1 -0
- package/dist/components/sidenav/index.js +9 -0
- package/dist/components/sidenav/index.js.map +1 -0
- package/dist/index.css +224 -0
- package/dist/index.css.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/packages/tapestry-wc/dist/components/tds-page-header.js +1 -1
- package/dist/packages/tapestry-wc/dist/components/tds-page-header.js.map +1 -1
- package/dist/packages/tapestry-wc/dist/components/tds-sidenav-item.js +48 -0
- package/dist/packages/tapestry-wc/dist/components/tds-sidenav-item.js.map +1 -0
- package/dist/packages/tapestry-wc/dist/components/tds-sidenav-section.js +43 -0
- package/dist/packages/tapestry-wc/dist/components/tds-sidenav-section.js.map +1 -0
- package/dist/packages/tapestry-wc/dist/components/tds-sidenav.js +44 -0
- package/dist/packages/tapestry-wc/dist/components/tds-sidenav.js.map +1 -0
- package/dist/unstable.css +515 -0
- package/dist/unstable.css.map +1 -1
- package/dist/unstable.d.ts +1 -0
- package/dist/unstable.d.ts.map +1 -1
- package/dist/webComponents.css +515 -0
- package/dist/webComponents.css.map +1 -1
- package/package.json +4 -3
- package/react-types/index.d.ts +51 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tds-sidenav-section.js","sources":["../../../../../../tapestry-wc/dist/components/tds-sidenav-section.js"],"sourcesContent":["/*!\n * Planning Center Tapestry Web Components\n * Version: 1.1.0-rc.3\n */\nimport { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';\n\nlet sidenavSectionId = 0;\nconst SidenavSection = /*@__PURE__*/ proxyCustomElement(class SidenavSection extends HTMLElement {\n constructor() {\n super();\n this.__registerHost();\n this.componentId = `sidenav-section-header-${sidenavSectionId++}`;\n }\n // --------------------------------------------------------------------------\n //\n // Render Methods\n //\n // --------------------------------------------------------------------------\n render() {\n return (h(Host, { key: 'd6927841b03512afa5f72c382461cf0b84d037e3', class: \"tds-sidenav-section\" }, this.label && (h(\"h2\", { key: '4287b5ff6eb3e0ff7c31b5f8f393ce4b2a7b57b6', id: `${this.componentId}`, class: \"tds-sidenav-section-header\" }, this.label)), h(\"ul\", { key: 'aa6d707a4982c6c7b1bbece15a65dd90a11a7fa5', class: \"tds-sidenav-section-list\", \"aria-labelledby\": this.label ? `${this.componentId}` : undefined }, h(\"slot\", { key: 'b3754036903248516b095e89b55e1f1fb1c545d8' }))));\n }\n get el() { return this; }\n}, [4, \"tds-sidenav-section\", {\n \"label\": [1]\n }]);\nfunction defineCustomElement$1() {\n if (typeof customElements === \"undefined\") {\n return;\n }\n const components = [\"tds-sidenav-section\"];\n components.forEach(tagName => { switch (tagName) {\n case \"tds-sidenav-section\":\n if (!customElements.get(tagName)) {\n customElements.define(tagName, SidenavSection);\n }\n break;\n } });\n}\n\nconst TdsSidenavSection = SidenavSection;\nconst defineCustomElement = defineCustomElement$1;\n\nexport { TdsSidenavSection, defineCustomElement };\n//# sourceMappingURL=tds-sidenav-section.js.map\n\n//# sourceMappingURL=tds-sidenav-section.js.map"],"names":["HTMLElement"],"mappings":";;AAAA;AACA;AACA;AACA;AAEA;AACA,IAAI,gBAAgB,GAAG,CAAC,CAAC;AACzB,MAAM,cAAc,iBAAiB,kBAAkB,CAAC,MAAM,cAAc,SAASA,CAAW,CAAC;AACjG,IAAI,WAAW,GAAG;AAClB,QAAQ,KAAK,EAAE,CAAC;AAChB,QAAQ,IAAI,CAAC,cAAc,EAAE,CAAC;AAC9B,QAAQ,IAAI,CAAC,WAAW,GAAG,CAAC,uBAAuB,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC;AAC1E,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,IAAI,MAAM,GAAG;AACb,QAAQ,QAAQ,CAAC,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,KAAK,EAAE,qBAAqB,EAAE,EAAE,IAAI,CAAC,KAAK,KAAK,CAAC,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,EAAE,KAAK,EAAE,4BAA4B,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,KAAK,EAAE,0BAA0B,EAAE,iBAAiB,EAAE,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,GAAG,SAAS,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,CAAC,CAAC,CAAC,EAAE;AAC1e,KAAK;AACL,IAAI,IAAI,EAAE,GAAG,EAAE,OAAO,IAAI,CAAC,EAAE;AAC7B,CAAC,EAAE,CAAC,CAAC,EAAE,qBAAqB,EAAE;AAC9B,QAAQ,OAAO,EAAE,CAAC,CAAC,CAAC;AACpB,KAAK,CAAC,CAAC,CAAC;AACR,SAAS,qBAAqB,GAAG;AACjC,IAAI,IAAI,OAAO,cAAc,KAAK,WAAW,EAAE;AAC/C,QAAQ,OAAO;AACf,KAAK;AACL,IAAI,MAAM,UAAU,GAAG,CAAC,qBAAqB,CAAC,CAAC;AAC/C,IAAI,UAAU,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,QAAQ,OAAO;AACnD,QAAQ,KAAK,qBAAqB;AAClC,YAAY,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;AAC9C,gBAAgB,cAAc,CAAC,MAAM,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;AAC/D,aAAa;AACb,YAAY,MAAM;AAClB,KAAK,EAAE,CAAC,CAAC;AACT,CAAC;AAGI,MAAC,mBAAmB,GAAG;;;;"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { proxyCustomElement, H, h, Host } from './../../../../ext/@stencil/core/internal/client/index.js';
|
|
2
|
+
|
|
3
|
+
/*!
|
|
4
|
+
* Planning Center Tapestry Web Components
|
|
5
|
+
* Version: 1.1.0-rc.3
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
const Sidenav = /*@__PURE__*/ proxyCustomElement(class Sidenav extends H {
|
|
9
|
+
constructor() {
|
|
10
|
+
super();
|
|
11
|
+
this.__registerHost();
|
|
12
|
+
/**
|
|
13
|
+
* The label for the sidenav, used for accessibility.
|
|
14
|
+
*/
|
|
15
|
+
this.label = "Secondary Navigation";
|
|
16
|
+
}
|
|
17
|
+
// --------------------------------------------------------------------------
|
|
18
|
+
//
|
|
19
|
+
// Render Methods
|
|
20
|
+
//
|
|
21
|
+
// --------------------------------------------------------------------------
|
|
22
|
+
render() {
|
|
23
|
+
return (h(Host, { key: '53e44587f254a6462074e0a024317a8fbfc0d872' }, h("nav", { key: '82969d4f130b9e4cc1212265108e620d9f55e016', class: "tds-sidenav", "aria-label": this.label }, h("slot", { key: 'e5ec09b2b55ec233fc43db92d9ce922d900c52e1', name: "mobile" }), h("div", { key: '12257308ffbc2256a14831cff36ca79dc18196ae', class: "tds-sidenav-collapse" }, h("slot", { key: '67e55dacd4a8684fb18b2703ed498068dd2dc4a4' })))));
|
|
24
|
+
}
|
|
25
|
+
}, [4, "tds-sidenav", {
|
|
26
|
+
"label": [1]
|
|
27
|
+
}]);
|
|
28
|
+
function defineCustomElement$1() {
|
|
29
|
+
if (typeof customElements === "undefined") {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
const components = ["tds-sidenav"];
|
|
33
|
+
components.forEach(tagName => { switch (tagName) {
|
|
34
|
+
case "tds-sidenav":
|
|
35
|
+
if (!customElements.get(tagName)) {
|
|
36
|
+
customElements.define(tagName, Sidenav);
|
|
37
|
+
}
|
|
38
|
+
break;
|
|
39
|
+
} });
|
|
40
|
+
}
|
|
41
|
+
const defineCustomElement = defineCustomElement$1;
|
|
42
|
+
|
|
43
|
+
export { defineCustomElement };
|
|
44
|
+
//# sourceMappingURL=tds-sidenav.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tds-sidenav.js","sources":["../../../../../../tapestry-wc/dist/components/tds-sidenav.js"],"sourcesContent":["/*!\n * Planning Center Tapestry Web Components\n * Version: 1.1.0-rc.3\n */\nimport { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';\n\nconst Sidenav = /*@__PURE__*/ proxyCustomElement(class Sidenav extends HTMLElement {\n constructor() {\n super();\n this.__registerHost();\n /**\n * The label for the sidenav, used for accessibility.\n */\n this.label = \"Secondary Navigation\";\n }\n // --------------------------------------------------------------------------\n //\n // Render Methods\n //\n // --------------------------------------------------------------------------\n render() {\n return (h(Host, { key: '53e44587f254a6462074e0a024317a8fbfc0d872' }, h(\"nav\", { key: '82969d4f130b9e4cc1212265108e620d9f55e016', class: \"tds-sidenav\", \"aria-label\": this.label }, h(\"slot\", { key: 'e5ec09b2b55ec233fc43db92d9ce922d900c52e1', name: \"mobile\" }), h(\"div\", { key: '12257308ffbc2256a14831cff36ca79dc18196ae', class: \"tds-sidenav-collapse\" }, h(\"slot\", { key: '67e55dacd4a8684fb18b2703ed498068dd2dc4a4' })))));\n }\n}, [4, \"tds-sidenav\", {\n \"label\": [1]\n }]);\nfunction defineCustomElement$1() {\n if (typeof customElements === \"undefined\") {\n return;\n }\n const components = [\"tds-sidenav\"];\n components.forEach(tagName => { switch (tagName) {\n case \"tds-sidenav\":\n if (!customElements.get(tagName)) {\n customElements.define(tagName, Sidenav);\n }\n break;\n } });\n}\n\nconst TdsSidenav = Sidenav;\nconst defineCustomElement = defineCustomElement$1;\n\nexport { TdsSidenav, defineCustomElement };\n//# sourceMappingURL=tds-sidenav.js.map\n\n//# sourceMappingURL=tds-sidenav.js.map"],"names":["HTMLElement"],"mappings":";;AAAA;AACA;AACA;AACA;AAEA;AACA,MAAM,OAAO,iBAAiB,kBAAkB,CAAC,MAAM,OAAO,SAASA,CAAW,CAAC;AACnF,IAAI,WAAW,GAAG;AAClB,QAAQ,KAAK,EAAE,CAAC;AAChB,QAAQ,IAAI,CAAC,cAAc,EAAE,CAAC;AAC9B;AACA;AACA;AACA,QAAQ,IAAI,CAAC,KAAK,GAAG,sBAAsB,CAAC;AAC5C,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,IAAI,MAAM,GAAG;AACb,QAAQ,QAAQ,CAAC,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,KAAK,EAAE,sBAAsB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,EAAE,GAAG,EAAE,0CAA0C,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;AAC3a,KAAK;AACL,CAAC,EAAE,CAAC,CAAC,EAAE,aAAa,EAAE;AACtB,QAAQ,OAAO,EAAE,CAAC,CAAC,CAAC;AACpB,KAAK,CAAC,CAAC,CAAC;AACR,SAAS,qBAAqB,GAAG;AACjC,IAAI,IAAI,OAAO,cAAc,KAAK,WAAW,EAAE;AAC/C,QAAQ,OAAO;AACf,KAAK;AACL,IAAI,MAAM,UAAU,GAAG,CAAC,aAAa,CAAC,CAAC;AACvC,IAAI,UAAU,CAAC,OAAO,CAAC,OAAO,IAAI,EAAE,QAAQ,OAAO;AACnD,QAAQ,KAAK,aAAa;AAC1B,YAAY,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;AAC9C,gBAAgB,cAAc,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;AACxD,aAAa;AACb,YAAY,MAAM;AAClB,KAAK,EAAE,CAAC,CAAC;AACT,CAAC;AAGI,MAAC,mBAAmB,GAAG;;;;"}
|
package/dist/unstable.css
CHANGED
|
@@ -1,5 +1,229 @@
|
|
|
1
1
|
@layer t-critical, t-component;
|
|
2
2
|
|
|
3
|
+
|
|
4
|
+
@media (prefers-reduced-motion: no-preference) {
|
|
5
|
+
|
|
6
|
+
:root {
|
|
7
|
+
interpolate-size: allow-keywords;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
.tds-sidenav {
|
|
12
|
+
--tds-sidenav-indent: 12px;
|
|
13
|
+
--tds-sidenav-item-depth: 0;
|
|
14
|
+
|
|
15
|
+
--tds-sidenav-item-transition: background-color .2s cubic-bezier(.19, .91, .38, 1);
|
|
16
|
+
|
|
17
|
+
--tds-sidenav-item-background-hover: var(--t-fill-color-neutral-080);
|
|
18
|
+
--tds-sidenav-item-background-active: var(--t-fill-color-neutral-070);
|
|
19
|
+
--tds-sidenav-item-background-selected: var(--t-fill-color-neutral-050);
|
|
20
|
+
|
|
21
|
+
--tds-sidenav-item-nested-border-color: var(--t-fill-color-neutral-050);
|
|
22
|
+
--tds-sidenav-item-nested-border-color-hover: var(--t-fill-color-neutral-010);
|
|
23
|
+
--tds-sidenav-item-nested-border-color-selected: var(--t-fill-color-neutral-010);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
.tds-sidenav :where(nav,ul,.tds-sidenav-section,.tds-sidenav-collapse) {
|
|
27
|
+
display: flex;
|
|
28
|
+
flex-direction: column;
|
|
29
|
+
gap: 4px;
|
|
30
|
+
align-items: start;
|
|
31
|
+
width: 100%;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
.tds-sidenav-section-list {
|
|
35
|
+
width: 100%;
|
|
36
|
+
padding: 0;
|
|
37
|
+
margin: 0;
|
|
38
|
+
list-style: none;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
.tds-sidenav-section-header {
|
|
42
|
+
margin: var(--t-spacing-2) 0 0 0;
|
|
43
|
+
font-size: var(--t-font-size-sm);
|
|
44
|
+
font-weight: var(--t-font-weight-semibold);
|
|
45
|
+
color: var(--t-text-color-default-secondary);
|
|
46
|
+
text-transform: uppercase;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.tds-sidenav-section:first-of-type .tds-sidenav-section-header {
|
|
50
|
+
margin-top: 0;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
.tds-sidenav-section-list,
|
|
54
|
+
.tds-sidenav-item {
|
|
55
|
+
width: 100%;
|
|
56
|
+
padding: 0;
|
|
57
|
+
margin: 0;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
.tds-sidenav-item :is(a,button) {
|
|
61
|
+
position: relative;
|
|
62
|
+
display: flex;
|
|
63
|
+
gap: 12px;
|
|
64
|
+
align-items: center;
|
|
65
|
+
width: 100%;
|
|
66
|
+
padding: 12px;
|
|
67
|
+
font-size: var(--t-font-size-sm);
|
|
68
|
+
line-height: 18px;
|
|
69
|
+
color: var(--t-text-color-default-headline);
|
|
70
|
+
text-decoration: none;
|
|
71
|
+
appearance: none;
|
|
72
|
+
cursor: pointer;
|
|
73
|
+
outline: 0;
|
|
74
|
+
background-color: transparent;
|
|
75
|
+
border: 0;
|
|
76
|
+
border-radius: 4px;
|
|
77
|
+
transition: var(--tds-sidenav-item-transition);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
:is(.tds-sidenav-item :is(a,button)):not(:has([slot="prefix"],.prefix,[slot="suffix"],.suffix)) {
|
|
81
|
+
display: block;
|
|
82
|
+
flex: 1;
|
|
83
|
+
overflow: hidden;
|
|
84
|
+
text-overflow: ellipsis;
|
|
85
|
+
text-align: left;
|
|
86
|
+
white-space: nowrap;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
:is(.tds-sidenav-item :is(a,button)) :is(:not([slot="prefix"],.prefix,[slot="suffix"],.suffix)) {
|
|
90
|
+
flex: 1;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
.selected > :is(.tds-sidenav-item :is(a,button)) {
|
|
94
|
+
--tds-sidenav-item-nested-background: transparent;
|
|
95
|
+
--tds-sidenav-item-nested-border-color: var(--tds-sidenav-item-nested-border-color-selected);
|
|
96
|
+
font-weight: 600;
|
|
97
|
+
background-color: var(--tds-sidenav-item-background-selected);
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
:is(.selected > :is(.tds-sidenav-item :is(a,button))) .prefix,:is(.selected > :is(.tds-sidenav-item :is(a,button))) [slot="prefix"] {
|
|
101
|
+
color: var(--t-icon-color-default-primary);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
:is(.tds-sidenav-item :is(a,button)):hover {
|
|
105
|
+
background-color: var(--tds-sidenav-item-background-hover);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
:is(.tds-sidenav-item :is(a,button)):active {
|
|
109
|
+
background-color: var(--tds-sidenav-item-background-active);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
:is(.tds-sidenav-item :is(a,button)) :is(.prefix,[slot="prefix"]) {
|
|
113
|
+
display: block;
|
|
114
|
+
width: 16px;
|
|
115
|
+
height: 16px;
|
|
116
|
+
overflow: hidden;
|
|
117
|
+
color: var(--t-icon-color-default-secondary);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
:is(:is(.tds-sidenav-item :is(a,button)) :is(.prefix,[slot="prefix"])) svg {
|
|
121
|
+
display: block;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
:is(.tds-sidenav-item :is(a,button)):has(.prefix,[slot="prefix"]) + .tds-sidenav-section {
|
|
125
|
+
--tds-sidenav-indent: 19px;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
[aria-expanded="true"]:is(.tds-sidenav-item :is(a,button)) + .tds-sidenav-section-list {
|
|
129
|
+
visibility: visible;
|
|
130
|
+
block-size: auto;
|
|
131
|
+
opacity: 1;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
.tds-sidenav-item .tds-sidenav-section-list {
|
|
135
|
+
--tds-sidenav-item-depth: 1;
|
|
136
|
+
gap: 0;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
.tds-sidenav-action--toggle + :is(.tds-sidenav-item .tds-sidenav-section-list) {
|
|
140
|
+
visibility: hidden;
|
|
141
|
+
block-size: 0;
|
|
142
|
+
overflow-y: clip;
|
|
143
|
+
opacity: 0;
|
|
144
|
+
transition: content-visibility .2s allow-discrete, opacity .2s, block-size .2s;
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
:is(.tds-sidenav-item .tds-sidenav-section-list) .tds-sidenav-section-list {
|
|
148
|
+
--tds-sidenav-item-depth: 2;
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button) {
|
|
152
|
+
height: 32px;
|
|
153
|
+
padding-block: 9px;
|
|
154
|
+
padding-left: calc((var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth)) + var(--tds-sidenav-indent) + 2px);
|
|
155
|
+
line-height: 1;
|
|
156
|
+
background-color: transparent;
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button))::before {
|
|
160
|
+
position: absolute;
|
|
161
|
+
top: 0;
|
|
162
|
+
bottom: 0;
|
|
163
|
+
left: calc(var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth));
|
|
164
|
+
width: 2px;
|
|
165
|
+
content: "";
|
|
166
|
+
background-color: var(--tds-sidenav-item-nested-border-color);
|
|
167
|
+
transition: var(--tds-sidenav-item-transition);
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button))::after {
|
|
171
|
+
position: absolute;
|
|
172
|
+
inset: 0 0 0 calc(var(--tds-sidenav-indent) * var(--tds-sidenav-item-depth));
|
|
173
|
+
z-index: -1;
|
|
174
|
+
height: 100%;
|
|
175
|
+
content: "";
|
|
176
|
+
background-color: var(--tds-sidenav-item-nested-background);
|
|
177
|
+
border-radius: 0 4px 4px 0;
|
|
178
|
+
transition: var(--tds-sidenav-item-transition);
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
.selected:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)) {
|
|
182
|
+
background-color: transparent;
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
.selected:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button))::before {
|
|
186
|
+
background-color: var(--tds-sidenav-item-nested-border-color-selected);
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
.selected:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button))::after {
|
|
190
|
+
background-color: var(--tds-sidenav-item-background-selected);
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):hover {
|
|
194
|
+
background-color: transparent;
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):hover::before {
|
|
198
|
+
background-color: var(--tds-sidenav-item-nested-border-color-hover);
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
:is(:is(.tds-sidenav-section-list .tds-sidenav-section-list .tds-sidenav-item) :is(a,button)):hover::after {
|
|
202
|
+
background-color: var(--tds-sidenav-item-background-hover);
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
/* @media (max-width: 767px) {
|
|
206
|
+
.tds-sidenav-collapse {
|
|
207
|
+
position: absolute;
|
|
208
|
+
z-index: 7000;
|
|
209
|
+
max-width: 448px;
|
|
210
|
+
padding: 16px;
|
|
211
|
+
background: #fff;
|
|
212
|
+
border-radius: 6px;
|
|
213
|
+
box-shadow: 0 8px 20px 0 rgba(0, 0, 0, .25);
|
|
214
|
+
|
|
215
|
+
&:not(.show) {
|
|
216
|
+
display: none;
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
@media (min-width: 768px) {
|
|
222
|
+
.tds-sidenav-header {
|
|
223
|
+
display: none;
|
|
224
|
+
}
|
|
225
|
+
} */
|
|
226
|
+
|
|
3
227
|
@layer t-critical {
|
|
4
228
|
tds-page-header:not(.hydrated) {
|
|
5
229
|
display: none;
|
|
@@ -847,4 +1071,295 @@
|
|
|
847
1071
|
--t-banner-spacing: calc(var(--t-spacing-half) + var(--t-spacing-1));
|
|
848
1072
|
}
|
|
849
1073
|
|
|
1074
|
+
.tds-btn {
|
|
1075
|
+
--tds-btn-padding-x: 12px;
|
|
1076
|
+
--tds-btn-padding-truncated-x: 8px;
|
|
1077
|
+
--tds-btn-padding-y: 3px;
|
|
1078
|
+
--tds-btn-font-size: 16px;
|
|
1079
|
+
--tds-btn-font-weight: 400;
|
|
1080
|
+
--tds-btn-line-height: 1.5;
|
|
1081
|
+
--tds-btn-color: var(--t-text-color-default-headline);
|
|
1082
|
+
--tds-btn-bg: transparent;
|
|
1083
|
+
--tds-btn-border-width: var(--t-border-width-default);
|
|
1084
|
+
--tds-btn-border-color: transparent;
|
|
1085
|
+
--tds-btn-border-radius: var(--t-border-radius-md);
|
|
1086
|
+
--tds-btn-border-color-hover: transparent;
|
|
1087
|
+
--tds-btn-disabled-opacity: 1;
|
|
1088
|
+
--tds-btn-min-height: 32px;
|
|
1089
|
+
display: inline-flex;
|
|
1090
|
+
gap: 1ex;
|
|
1091
|
+
align-items: center;
|
|
1092
|
+
min-height: var(--tds-btn-min-height);
|
|
1093
|
+
padding: var(--tds-btn-padding-y) var(--tds-btn-padding-x);
|
|
1094
|
+
font-size: var(--tds-btn-font-size);
|
|
1095
|
+
font-weight: var(--tds-btn-font-weight);
|
|
1096
|
+
line-height: var(--tds-btn-line-height);
|
|
1097
|
+
vertical-align: middle;
|
|
1098
|
+
color: var(--tds-btn-color);
|
|
1099
|
+
text-align: center;
|
|
1100
|
+
text-decoration: none;
|
|
1101
|
+
cursor: pointer;
|
|
1102
|
+
user-select: none;
|
|
1103
|
+
background-color: var(--tds-btn-bg);
|
|
1104
|
+
border: var(--tds-btn-border-width) solid var(--tds-btn-border-color);
|
|
1105
|
+
border-radius: var(--tds-btn-border-radius);
|
|
1106
|
+
transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
|
|
1107
|
+
}
|
|
1108
|
+
|
|
1109
|
+
.tds-btn:where(.tds-btn--icononly,:has(.prefix,svg:not(.suffix))) {
|
|
1110
|
+
padding-left: var(--tds-btn-padding-truncated-x);
|
|
1111
|
+
}
|
|
1112
|
+
|
|
1113
|
+
.tds-btn:where(.tds-btn--icononly,:has(.suffix,svg:not(.prefix))) {
|
|
1114
|
+
padding-right: var(--tds-btn-padding-truncated-x);
|
|
1115
|
+
}
|
|
1116
|
+
|
|
1117
|
+
.tds-btn:hover {
|
|
1118
|
+
color: var(--tds-btn-color-hover);
|
|
1119
|
+
background-color: var(--tds-btn-bg-hover);
|
|
1120
|
+
border-color: var(--tds-btn-border-color-hover);
|
|
1121
|
+
}
|
|
1122
|
+
|
|
1123
|
+
.tds-btn:focus-visible {
|
|
1124
|
+
color: var(--tds-btn-color-hover);
|
|
1125
|
+
outline: solid 3px var(--t-border-color-status-info);
|
|
1126
|
+
outline-offset: 1px;
|
|
1127
|
+
background-color: var(--tds-btn-bg-hover);
|
|
1128
|
+
border-color: var(--tds-btn-border-color-hover);
|
|
1129
|
+
}
|
|
1130
|
+
|
|
1131
|
+
.tds-btn:active,.tds-btn.active {
|
|
1132
|
+
color: var(--tds-btn-color-active);
|
|
1133
|
+
background-color: var(--tds-btn-bg-active);
|
|
1134
|
+
border-color: var(--tds-btn-border-color-active);
|
|
1135
|
+
}
|
|
1136
|
+
|
|
1137
|
+
.tds-btn:disabled,.tds-btn.disabled {
|
|
1138
|
+
color: var(--tds-btn-color-disabled);
|
|
1139
|
+
pointer-events: none;
|
|
1140
|
+
background-color: var(--tds-btn-bg-disabled);
|
|
1141
|
+
border-color: var(--tds-btn-border-color-disabled);
|
|
1142
|
+
opacity: var(--tds-btn-disabled-opacity);
|
|
1143
|
+
}
|
|
1144
|
+
|
|
1145
|
+
.tds-btn svg {
|
|
1146
|
+
display: block;
|
|
1147
|
+
inline-size: auto;
|
|
1148
|
+
max-inline-size: 100%;
|
|
1149
|
+
block-size: auto;
|
|
1150
|
+
max-block-size: .66666667lh;
|
|
1151
|
+
color: var(--tds-btn-icon-color, currentColor);
|
|
1152
|
+
}
|
|
1153
|
+
|
|
1154
|
+
@media (prefers-reduced-motion: reduce) {
|
|
1155
|
+
|
|
1156
|
+
.tds-btn {
|
|
1157
|
+
transition: none;
|
|
1158
|
+
}
|
|
1159
|
+
}
|
|
1160
|
+
|
|
1161
|
+
/* Effective height 48px */
|
|
1162
|
+
|
|
1163
|
+
.tds-btn--xl {
|
|
1164
|
+
--tds-btn-padding-y: 11px;
|
|
1165
|
+
--tds-btn-padding-x: 18px;
|
|
1166
|
+
--tds-btn-padding-truncated-x: 12px;
|
|
1167
|
+
--tds-btn-min-height: 48px;
|
|
1168
|
+
}
|
|
1169
|
+
|
|
1170
|
+
/* Effective height 40px */
|
|
1171
|
+
|
|
1172
|
+
.tds-btn--lg {
|
|
1173
|
+
--tds-btn-padding-y: 7px;
|
|
1174
|
+
--tds-btn-padding-x: 14px;
|
|
1175
|
+
--tds-btn-min-height: 40px;
|
|
1176
|
+
}
|
|
1177
|
+
|
|
1178
|
+
/* Effective height 24px */
|
|
1179
|
+
|
|
1180
|
+
.tds-btn--sm {
|
|
1181
|
+
--tds-btn-padding-y: .5px;
|
|
1182
|
+
--tds-btn-padding-x: 7px;
|
|
1183
|
+
--tds-btn-padding-truncated-x: 4px;
|
|
1184
|
+
--tds-btn-min-height: 24px;
|
|
1185
|
+
--tds-btn-font-size: var(--t-font-size-sm);
|
|
1186
|
+
}
|
|
1187
|
+
|
|
1188
|
+
/* Effective height 20px */
|
|
1189
|
+
|
|
1190
|
+
.tds-btn--xs {
|
|
1191
|
+
--tds-btn-padding-y: 0;
|
|
1192
|
+
--tds-btn-padding-x: 5px;
|
|
1193
|
+
--tds-btn-padding-truncated-x: 5px;
|
|
1194
|
+
--tds-btn-min-height: 20px;
|
|
1195
|
+
--tds-btn-font-size: var(--t-font-size-xs);
|
|
1196
|
+
}
|
|
1197
|
+
|
|
1198
|
+
.tds-btn--neutral {
|
|
1199
|
+
--tds-btn-color: var(--t-text-color-default-inverted);
|
|
1200
|
+
--tds-btn-bg: var(--t-fill-color-button-neutral-solid-default);
|
|
1201
|
+
--tds-btn-border-color: var(--t-fill-color-button-neutral-solid-default);
|
|
1202
|
+
--tds-btn-color-hover: var(--t-text-color-default-inverted);
|
|
1203
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-neutral-solid-hover);
|
|
1204
|
+
--tds-btn-border-color-hover: var(--t-fill-color-button-neutral-solid-hover);
|
|
1205
|
+
--tds-btn-color-active: var(--t-text-color-default-inverted);
|
|
1206
|
+
--tds-btn-bg-active: var(--t-fill-color-button-neutral-solid-active);
|
|
1207
|
+
--tds-btn-border-color-active: var(--t-fill-color-button-neutral-solid-active);
|
|
1208
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1209
|
+
--tds-btn-bg-disabled: var(--t-fill-color-button-neutral-solid-disabled);
|
|
1210
|
+
--tds-btn-border-color-disabled: var(--t-fill-color-button-neutral-solid-disabled);
|
|
1211
|
+
}
|
|
1212
|
+
|
|
1213
|
+
.tds-btn--interaction {
|
|
1214
|
+
--tds-btn-color: var(--t-text-color-default-inverted);
|
|
1215
|
+
--tds-btn-bg: var(--t-fill-color-button-interaction-solid-default);
|
|
1216
|
+
--tds-btn-border-color: var(--t-fill-color-button-interaction-solid-default);
|
|
1217
|
+
--tds-btn-color-hover: var(--t-text-color-default-inverted);
|
|
1218
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-interaction-solid-hover);
|
|
1219
|
+
--tds-btn-border-color-hover: var(--t-fill-color-button-interaction-solid-hover);
|
|
1220
|
+
--tds-btn-color-active: var(--t-text-color-default-inverted);
|
|
1221
|
+
--tds-btn-bg-active: var(--t-fill-color-button-interaction-solid-active);
|
|
1222
|
+
--tds-btn-border-color-active: var(--t-fill-color-button-interaction-solid-active);
|
|
1223
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1224
|
+
--tds-btn-bg-disabled: var(--t-fill-color-button-interaction-solid-disabled);
|
|
1225
|
+
--tds-btn-border-color-disabled: var(--tds-btn-bg-disabled);
|
|
1226
|
+
}
|
|
1227
|
+
|
|
1228
|
+
.tds-btn--delete {
|
|
1229
|
+
--tds-btn-color: var(--t-text-color-default-inverted);
|
|
1230
|
+
--tds-btn-bg: var(--t-fill-color-button-delete-solid-default);
|
|
1231
|
+
--tds-btn-border-color: var(--t-fill-color-button-delete-solid-default);
|
|
1232
|
+
--tds-btn-color-hover: var(--t-text-color-default-inverted);
|
|
1233
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-delete-solid-hover);
|
|
1234
|
+
--tds-btn-border-color-hover: var(--t-fill-color-button-delete-solid-hover);
|
|
1235
|
+
--tds-btn-color-active: var(--t-text-color-default-inverted);
|
|
1236
|
+
--tds-btn-bg-active: var(--t-fill-color-button-delete-solid-active);
|
|
1237
|
+
--tds-btn-border-color-active: var(--t-fill-color-button-delete-solid-active);
|
|
1238
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1239
|
+
--tds-btn-bg-disabled: var(--t-fill-color-button-delete-solid-disabled);
|
|
1240
|
+
--tds-btn-border-color-disabled: var(--tds-btn-bg-disabled);
|
|
1241
|
+
}
|
|
1242
|
+
|
|
1243
|
+
.tds-btn--outline-neutral {
|
|
1244
|
+
--tds-btn-color: var(--t-text-color-status-neutral);
|
|
1245
|
+
--tds-btn-border-color: var(--t-border-color-button-neutral);
|
|
1246
|
+
--tds-btn-color-hover: var(--tds-btn-color);
|
|
1247
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-neutral-outline-dim-hover);
|
|
1248
|
+
--tds-btn-border-color-hover: var(--t-border-color-button-neutral);
|
|
1249
|
+
--tds-btn-color-active: var(--tds-btn-color);
|
|
1250
|
+
--tds-btn-bg-active: var(--t-fill-color-button-neutral-outline-dim-active);
|
|
1251
|
+
--tds-btn-border-color-active: var(--t-border-color-button-neutral);
|
|
1252
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1253
|
+
--tds-btn-bg-disabled: var(--t-fill-color-button-neutral-outline-dim-disabled);
|
|
1254
|
+
--tds-btn-border-color-disabled: var(--t-border-color-button-neutral);
|
|
1255
|
+
}
|
|
1256
|
+
|
|
1257
|
+
.tds-btn--outline-interaction {
|
|
1258
|
+
--tds-btn-color: var(--t-text-color-status-info);
|
|
1259
|
+
--tds-btn-border-color: var(--t-border-color-button-info);
|
|
1260
|
+
--tds-btn-color-hover: var(--tds-btn-color);
|
|
1261
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-interaction-outline-dim-hover);
|
|
1262
|
+
--tds-btn-border-color-hover: var(--tds-btn-border-color);
|
|
1263
|
+
--tds-btn-color-active: var(--tds-btn-color);
|
|
1264
|
+
--tds-btn-bg-active: var(--t-fill-color-button-interaction-outline-dim-active);
|
|
1265
|
+
--tds-btn-border-color-active: var(--tds-btn-border-color);
|
|
1266
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1267
|
+
--tds-btn-bg-disabled: var(--t-fill-color-button-interaction-outline-dim-disabled);
|
|
1268
|
+
--tds-btn-border-color-disabled: var(--t-border-color-button-neutral);
|
|
1269
|
+
}
|
|
1270
|
+
|
|
1271
|
+
.tds-btn--outline-delete {
|
|
1272
|
+
--tds-btn-color: var(--t-text-color-status-error);
|
|
1273
|
+
--tds-btn-border-color: var(--t-border-color-button-delete);
|
|
1274
|
+
--tds-btn-color-hover: var(--tds-btn-color);
|
|
1275
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-delete-outline-dim-hover);
|
|
1276
|
+
--tds-btn-border-color-hover: var(--tds-btn-border-color);
|
|
1277
|
+
--tds-btn-color-active: var(--tds-btn-color);
|
|
1278
|
+
--tds-btn-bg-active: var(--t-fill-color-button-delete-outline-dim-active);
|
|
1279
|
+
--tds-btn-border-color-active: var(--tds-btn-border-color);
|
|
1280
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1281
|
+
--tds-btn-bg-disabled: var(--t-fill-color-button-delete-outline-dim-disabled);
|
|
1282
|
+
--tds-btn-border-color-disabled: var(--t-border-color-button-neutral);
|
|
1283
|
+
}
|
|
1284
|
+
|
|
1285
|
+
.tds-btn--ghost-neutral {
|
|
1286
|
+
--tds-btn-color: var(--t-text-color-status-neutral);
|
|
1287
|
+
--tds-btn-border-color: transparent;
|
|
1288
|
+
--tds-btn-color-hover: var(--tds-btn-color);
|
|
1289
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-neutral-outline-dim-hover);
|
|
1290
|
+
--tds-btn-border-color-hover: var(--tds-btn-bg-hover);
|
|
1291
|
+
--tds-btn-color-active: var(--tds-btn-color);
|
|
1292
|
+
--tds-btn-bg-active: var(--t-fill-color-button-neutral-outline-dim-active);
|
|
1293
|
+
--tds-btn-border-color-active: var(--tds-btn-bg-active);
|
|
1294
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1295
|
+
--tds-btn-bg-disabled: transparent;
|
|
1296
|
+
--tds-btn-border-color-disabled: transparent;
|
|
1297
|
+
}
|
|
1298
|
+
|
|
1299
|
+
.tds-btn--ghost-interaction {
|
|
1300
|
+
--tds-btn-color: var(--t-text-color-status-info);
|
|
1301
|
+
--tds-btn-border-color: transparent;
|
|
1302
|
+
--tds-btn-color-hover: var(--tds-btn-color);
|
|
1303
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-interaction-outline-dim-hover);
|
|
1304
|
+
--tds-btn-border-color-hover: var(--tds-btn-bg-hover);
|
|
1305
|
+
--tds-btn-color-active: var(--tds-btn-color);
|
|
1306
|
+
--tds-btn-bg-active: var(--t-fill-color-button-interaction-outline-dim-active);
|
|
1307
|
+
--tds-btn-border-color-active: var(--tds-btn-bg-active);
|
|
1308
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1309
|
+
--tds-btn-bg-disabled: transparent;
|
|
1310
|
+
--tds-btn-border-color-disabled: transparent;
|
|
1311
|
+
}
|
|
1312
|
+
|
|
1313
|
+
.tds-btn--ghost-delete {
|
|
1314
|
+
--tds-btn-color: var(--t-text-color-status-error);
|
|
1315
|
+
--tds-btn-border-color: transparent;
|
|
1316
|
+
--tds-btn-color-hover: var(--tds-btn-color);
|
|
1317
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-delete-outline-dim-hover);
|
|
1318
|
+
--tds-btn-border-color-hover: var(--tds-btn-bg-hover);
|
|
1319
|
+
--tds-btn-color-active: var(--tds-btn-color);
|
|
1320
|
+
--tds-btn-bg-active: var(--t-fill-color-button-delete-outline-dim-active);
|
|
1321
|
+
--tds-btn-border-color-active: var(--tds-btn-bg-active);
|
|
1322
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1323
|
+
--tds-btn-bg-disabled: transparent;
|
|
1324
|
+
--tds-btn-border-color-disabled: transparent;
|
|
1325
|
+
}
|
|
1326
|
+
|
|
1327
|
+
.tds-btn--pill {
|
|
1328
|
+
--tds-btn-border-radius: 999px;
|
|
1329
|
+
--tds-btn-padding-y: 4px;
|
|
1330
|
+
--tds-btn-padding-x: 13px;
|
|
1331
|
+
|
|
1332
|
+
--tds-btn-color: var(--t-text-color-default-primary);
|
|
1333
|
+
--tds-btn-bg: var(--t-fill-color-button-pill-default);
|
|
1334
|
+
--tds-btn-border-color: var(--tds-btn-bg);
|
|
1335
|
+
--tds-btn-color-hover: var(--tds-btn-color);
|
|
1336
|
+
--tds-btn-bg-hover: var(--t-fill-color-button-pill-hover);
|
|
1337
|
+
--tds-btn-border-color-hover: var(--tds-btn-bg-hover);
|
|
1338
|
+
|
|
1339
|
+
--tds-btn-color-active: var(--tds-btn-color);
|
|
1340
|
+
--tds-btn-bg-active: var(--t-fill-color-button-pill-active);
|
|
1341
|
+
--tds-btn-border-color-active: var(--tds-btn-bg-active);
|
|
1342
|
+
--tds-btn-color-disabled: var(--t-text-color-default-disabled);
|
|
1343
|
+
--tds-btn-bg-disabled: var(--t-fill-color-button-neutral-solid-disabled);
|
|
1344
|
+
--tds-btn-border-color-disabled: var(--t-fill-color-button-neutral-solid-disabled);
|
|
1345
|
+
--tds-btn-icon-color: var(--t-icon-color-default-secondary);
|
|
1346
|
+
--tds-btn-min-height: 32px;
|
|
1347
|
+
}
|
|
1348
|
+
|
|
1349
|
+
.tds-btn--pill:is(.tds-btn--sm) {
|
|
1350
|
+
--tds-btn-padding-y: 1px;
|
|
1351
|
+
--tds-btn-padding-x: 7px;
|
|
1352
|
+
--tds-btn-min-height: auto;
|
|
1353
|
+
}
|
|
1354
|
+
|
|
1355
|
+
.tds-btn--pill:is(.tds-btn--xs) {
|
|
1356
|
+
--tds-btn-padding-y: 1px;
|
|
1357
|
+
--tds-btn-padding-x: 9px;
|
|
1358
|
+
--tds-btn-min-height: auto;
|
|
1359
|
+
}
|
|
1360
|
+
|
|
1361
|
+
.tds-btn--pill:disabled,.tds-btn--pill.disabled {
|
|
1362
|
+
--tds-btn-icon-color: inherit;
|
|
1363
|
+
}
|
|
1364
|
+
|
|
850
1365
|
/*# sourceMappingURL=unstable.css.map */
|