@patternfly/elements 4.0.2 → 4.2.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.
- package/custom-elements.json +13680 -12603
- package/package.json +17 -14
- package/pf-accordion/pf-accordion-header.css +37 -0
- package/pf-accordion/pf-accordion-header.d.ts +0 -61
- package/pf-accordion/pf-accordion-header.js +180 -2
- package/pf-accordion/pf-accordion-header.js.map +1 -1
- package/pf-accordion/pf-accordion-panel.css +12 -0
- package/pf-accordion/pf-accordion-panel.d.ts +0 -34
- package/pf-accordion/pf-accordion-panel.js +87 -2
- package/pf-accordion/pf-accordion-panel.js.map +1 -1
- package/pf-accordion/pf-accordion.css +62 -0
- package/pf-accordion/pf-accordion.d.ts +1 -64
- package/pf-accordion/pf-accordion.js +156 -2
- package/pf-accordion/pf-accordion.js.map +1 -1
- package/pf-avatar/pf-avatar.css +14 -0
- package/pf-avatar/pf-avatar.d.ts +1 -14
- package/pf-avatar/pf-avatar.js +82 -2
- package/pf-avatar/pf-avatar.js.map +1 -1
- package/pf-back-to-top/pf-back-to-top.css +12 -0
- package/pf-back-to-top/pf-back-to-top.d.ts +1 -17
- package/pf-back-to-top/pf-back-to-top.js +91 -4
- package/pf-back-to-top/pf-back-to-top.js.map +1 -1
- package/pf-background-image/pf-background-image.css +7 -0
- package/pf-background-image/pf-background-image.d.ts +1 -8
- package/pf-background-image/pf-background-image.js +76 -2
- package/pf-background-image/pf-background-image.js.map +1 -1
- package/pf-badge/pf-badge.css +13 -0
- package/pf-badge/pf-badge.d.ts +1 -13
- package/pf-badge/pf-badge.js +53 -2
- package/pf-badge/pf-badge.js.map +1 -1
- package/pf-banner/pf-banner.css +21 -0
- package/pf-banner/pf-banner.d.ts +1 -19
- package/pf-banner/pf-banner.js +122 -2
- package/pf-banner/pf-banner.js.map +1 -1
- package/pf-button/pf-button-tokens.css +38 -0
- package/pf-button/pf-button.d.ts +1 -106
- package/pf-button/pf-button.js +837 -4
- package/pf-button/pf-button.js.map +1 -1
- package/pf-card/pf-card.css +24 -0
- package/pf-card/pf-card.d.ts +1 -38
- package/pf-card/pf-card.js +248 -2
- package/pf-card/pf-card.js.map +1 -1
- package/pf-card/test/pf-card.e2e.js +20 -1
- package/pf-card/test/pf-card.e2e.js.map +1 -1
- package/pf-chip/pf-chip-group.css +15 -0
- package/pf-chip/pf-chip-group.d.ts +0 -15
- package/pf-chip/pf-chip-group.js +111 -2
- package/pf-chip/pf-chip-group.js.map +1 -1
- package/pf-chip/pf-chip.css +30 -1
- package/pf-chip/pf-chip.d.ts +1 -20
- package/pf-chip/pf-chip.js +135 -2
- package/pf-chip/pf-chip.js.map +1 -1
- package/pf-clipboard-copy/pf-clipboard-copy.css +25 -0
- package/pf-clipboard-copy/pf-clipboard-copy.d.ts +1 -27
- package/pf-clipboard-copy/pf-clipboard-copy.js +323 -6
- package/pf-clipboard-copy/pf-clipboard-copy.js.map +1 -1
- package/pf-code-block/pf-code-block.css +11 -1
- package/pf-code-block/pf-code-block.js +70 -18
- package/pf-code-block/pf-code-block.js.map +1 -1
- package/pf-dropdown/pf-dropdown-group.js +40 -2
- package/pf-dropdown/pf-dropdown-group.js.map +1 -1
- package/pf-dropdown/pf-dropdown-item.css +10 -0
- package/pf-dropdown/pf-dropdown-item.d.ts +0 -27
- package/pf-dropdown/pf-dropdown-item.js +155 -2
- package/pf-dropdown/pf-dropdown-item.js.map +1 -1
- package/pf-dropdown/pf-dropdown-menu.js +39 -2
- package/pf-dropdown/pf-dropdown-menu.js.map +1 -1
- package/pf-dropdown/pf-dropdown.css +5 -0
- package/pf-dropdown/pf-dropdown.d.ts +1 -9
- package/pf-dropdown/pf-dropdown.js +350 -2
- package/pf-dropdown/pf-dropdown.js.map +1 -1
- package/pf-icon/pf-icon.css +1 -0
- package/pf-icon/pf-icon.d.ts +1 -3
- package/pf-icon/pf-icon.js +44 -4
- package/pf-icon/pf-icon.js.map +1 -1
- package/pf-jump-links/pf-jump-links-item.css +7 -1
- package/pf-jump-links/pf-jump-links-item.d.ts +0 -8
- package/pf-jump-links/pf-jump-links-item.js +77 -2
- package/pf-jump-links/pf-jump-links-item.js.map +1 -1
- package/pf-jump-links/pf-jump-links-list.css +3 -0
- package/pf-jump-links/pf-jump-links-list.d.ts +0 -5
- package/pf-jump-links/pf-jump-links-list.js +20 -2
- package/pf-jump-links/pf-jump-links-list.js.map +1 -1
- package/pf-jump-links/pf-jump-links.css +36 -0
- package/pf-jump-links/pf-jump-links.d.ts +1 -38
- package/pf-jump-links/pf-jump-links.js +179 -2
- package/pf-jump-links/pf-jump-links.js.map +1 -1
- package/pf-label/pf-label.css +51 -1
- package/pf-label/pf-label.d.ts +1 -58
- package/pf-label/pf-label.js +257 -2
- package/pf-label/pf-label.js.map +1 -1
- package/pf-modal/pf-modal.css +11 -0
- package/pf-modal/pf-modal.d.ts +1 -24
- package/pf-modal/pf-modal.js +215 -2
- package/pf-modal/pf-modal.js.map +1 -1
- package/pf-panel/pf-panel.css +29 -0
- package/pf-panel/pf-panel.d.ts +1 -32
- package/pf-panel/pf-panel.js +204 -2
- package/pf-panel/pf-panel.js.map +1 -1
- package/pf-popover/pf-popover.css +33 -0
- package/pf-popover/pf-popover.d.ts +1 -108
- package/pf-popover/pf-popover.js +251 -3
- package/pf-popover/pf-popover.js.map +1 -1
- package/pf-progress/pf-progress.css +19 -0
- package/pf-progress/pf-progress.d.ts +1 -57
- package/pf-progress/pf-progress.js +231 -2
- package/pf-progress/pf-progress.js.map +1 -1
- package/pf-progress-stepper/pf-progress-step.js +126 -2
- package/pf-progress-stepper/pf-progress-step.js.map +1 -1
- package/pf-progress-stepper/pf-progress-stepper.css +96 -0
- package/pf-progress-stepper/pf-progress-stepper.d.ts +1 -115
- package/pf-progress-stepper/pf-progress-stepper.js +326 -2
- package/pf-progress-stepper/pf-progress-stepper.js.map +1 -1
- package/pf-search-input/pf-search-input.css +308 -0
- package/pf-search-input/pf-search-input.d.ts +75 -0
- package/pf-search-input/pf-search-input.js +630 -0
- package/pf-search-input/pf-search-input.js.map +1 -0
- package/pf-search-input/test/pf-search-input.e2e.d.ts +1 -0
- package/pf-search-input/test/pf-search-input.e2e.js +23 -0
- package/pf-search-input/test/pf-search-input.e2e.js.map +1 -0
- package/pf-search-input/test/pf-search-input.spec.d.ts +1 -0
- package/pf-search-input/test/pf-search-input.spec.js +1021 -0
- package/pf-search-input/test/pf-search-input.spec.js.map +1 -0
- package/pf-select/pf-option-group.js +27 -2
- package/pf-select/pf-option-group.js.map +1 -1
- package/pf-select/pf-option.css +9 -1
- package/pf-select/pf-option.js +83 -2
- package/pf-select/pf-option.js.map +1 -1
- package/pf-select/pf-select.css +157 -0
- package/pf-select/pf-select.d.ts +1 -158
- package/pf-select/pf-select.js +542 -5
- package/pf-select/pf-select.js.map +1 -1
- package/pf-spinner/pf-spinner.css +13 -0
- package/pf-spinner/pf-spinner.d.ts +1 -14
- package/pf-spinner/pf-spinner.js +101 -2
- package/pf-spinner/pf-spinner.js.map +1 -1
- package/pf-switch/pf-switch.css +22 -0
- package/pf-switch/pf-switch.d.ts +1 -30
- package/pf-switch/pf-switch.js +156 -2
- package/pf-switch/pf-switch.js.map +1 -1
- package/pf-table/context.d.ts +3 -0
- package/pf-table/context.js +3 -0
- package/pf-table/context.js.map +1 -0
- package/pf-table/pf-caption.js +10 -2
- package/pf-table/pf-caption.js.map +1 -1
- package/pf-table/pf-table.css +211 -0
- package/pf-table/pf-table.d.ts +2 -635
- package/pf-table/pf-table.js +445 -4
- package/pf-table/pf-table.js.map +1 -1
- package/pf-table/pf-tbody.js +18 -2
- package/pf-table/pf-tbody.js.map +1 -1
- package/pf-table/pf-td.js +107 -2
- package/pf-table/pf-td.js.map +1 -1
- package/pf-table/pf-th.d.ts +1 -0
- package/pf-table/pf-th.js +102 -7
- package/pf-table/pf-th.js.map +1 -1
- package/pf-table/pf-thead.d.ts +1 -0
- package/pf-table/pf-thead.js +26 -2
- package/pf-table/pf-thead.js.map +1 -1
- package/pf-table/pf-tr.js +89 -2
- package/pf-table/pf-tr.js.map +1 -1
- package/pf-tabs/pf-tab-panel.css +1 -0
- package/pf-tabs/pf-tab-panel.d.ts +0 -2
- package/pf-tabs/pf-tab-panel.js +19 -3
- package/pf-tabs/pf-tab-panel.js.map +1 -1
- package/pf-tabs/pf-tab.css +33 -0
- package/pf-tabs/pf-tab.d.ts +1 -41
- package/pf-tabs/pf-tab.js +234 -4
- package/pf-tabs/pf-tab.js.map +1 -1
- package/pf-tabs/pf-tabs.css +26 -0
- package/pf-tabs/pf-tabs.d.ts +1 -34
- package/pf-tabs/pf-tabs.js +307 -2
- package/pf-tabs/pf-tabs.js.map +1 -1
- package/pf-tabs/test/pf-tabs.spec.js +9 -0
- package/pf-tabs/test/pf-tabs.spec.js.map +1 -1
- package/pf-text-area/pf-text-area.css +125 -0
- package/pf-text-area/pf-text-area.d.ts +1 -125
- package/pf-text-area/pf-text-area.js +320 -2
- package/pf-text-area/pf-text-area.js.map +1 -1
- package/pf-text-input/pf-text-input.css +126 -0
- package/pf-text-input/pf-text-input.d.ts +1 -126
- package/pf-text-input/pf-text-input.js +395 -2
- package/pf-text-input/pf-text-input.js.map +1 -1
- package/pf-tile/pf-tile.css +28 -8
- package/pf-tile/pf-tile.d.ts +1 -24
- package/pf-tile/pf-tile.js +156 -2
- package/pf-tile/pf-tile.js.map +1 -1
- package/pf-timestamp/pf-timestamp.d.ts +1 -0
- package/pf-timestamp/pf-timestamp.js +10 -2
- package/pf-timestamp/pf-timestamp.js.map +1 -1
- package/pf-tooltip/pf-tooltip.css +10 -0
- package/pf-tooltip/pf-tooltip.d.ts +1 -79
- package/pf-tooltip/pf-tooltip.js +115 -5
- package/pf-tooltip/pf-tooltip.js.map +1 -1
- package/pfe.min.js +0 -7439
- package/pfe.min.js.LEGAL.txt +0 -57
- package/pfe.min.js.map +0 -7
- package/react/pf-accordion/pf-accordion-header.d.ts +0 -5
- package/react/pf-accordion/pf-accordion-header.js +0 -12
- package/react/pf-accordion/pf-accordion-panel.d.ts +0 -5
- package/react/pf-accordion/pf-accordion-panel.js +0 -10
- package/react/pf-accordion/pf-accordion.d.ts +0 -5
- package/react/pf-accordion/pf-accordion.js +0 -13
- package/react/pf-avatar/pf-avatar.d.ts +0 -5
- package/react/pf-avatar/pf-avatar.js +0 -12
- package/react/pf-back-to-top/pf-back-to-top.d.ts +0 -5
- package/react/pf-back-to-top/pf-back-to-top.js +0 -10
- package/react/pf-background-image/pf-background-image.d.ts +0 -5
- package/react/pf-background-image/pf-background-image.js +0 -10
- package/react/pf-badge/pf-badge.d.ts +0 -5
- package/react/pf-badge/pf-badge.js +0 -10
- package/react/pf-banner/pf-banner.d.ts +0 -5
- package/react/pf-banner/pf-banner.js +0 -10
- package/react/pf-button/pf-button.d.ts +0 -5
- package/react/pf-button/pf-button.js +0 -12
- package/react/pf-card/pf-card.d.ts +0 -5
- package/react/pf-card/pf-card.js +0 -10
- package/react/pf-chip/pf-chip-group.d.ts +0 -5
- package/react/pf-chip/pf-chip-group.js +0 -13
- package/react/pf-chip/pf-chip.d.ts +0 -5
- package/react/pf-chip/pf-chip.js +0 -13
- package/react/pf-clipboard-copy/pf-clipboard-copy.d.ts +0 -5
- package/react/pf-clipboard-copy/pf-clipboard-copy.js +0 -12
- package/react/pf-code-block/pf-code-block.d.ts +0 -5
- package/react/pf-code-block/pf-code-block.js +0 -10
- package/react/pf-dropdown/pf-dropdown-group.d.ts +0 -5
- package/react/pf-dropdown/pf-dropdown-group.js +0 -10
- package/react/pf-dropdown/pf-dropdown-item.d.ts +0 -5
- package/react/pf-dropdown/pf-dropdown-item.js +0 -10
- package/react/pf-dropdown/pf-dropdown-menu.d.ts +0 -5
- package/react/pf-dropdown/pf-dropdown-menu.js +0 -10
- package/react/pf-dropdown/pf-dropdown.d.ts +0 -5
- package/react/pf-dropdown/pf-dropdown.js +0 -14
- package/react/pf-icon/pf-icon.d.ts +0 -5
- package/react/pf-icon/pf-icon.js +0 -13
- package/react/pf-jump-links/pf-jump-links-item.d.ts +0 -5
- package/react/pf-jump-links/pf-jump-links-item.js +0 -13
- package/react/pf-jump-links/pf-jump-links-list.d.ts +0 -5
- package/react/pf-jump-links/pf-jump-links-list.js +0 -10
- package/react/pf-jump-links/pf-jump-links.d.ts +0 -5
- package/react/pf-jump-links/pf-jump-links.js +0 -12
- package/react/pf-label/pf-label.d.ts +0 -5
- package/react/pf-label/pf-label.js +0 -12
- package/react/pf-modal/pf-modal.d.ts +0 -5
- package/react/pf-modal/pf-modal.js +0 -13
- package/react/pf-panel/pf-panel.d.ts +0 -5
- package/react/pf-panel/pf-panel.js +0 -10
- package/react/pf-popover/pf-popover.d.ts +0 -5
- package/react/pf-popover/pf-popover.js +0 -10
- package/react/pf-progress/pf-progress.d.ts +0 -5
- package/react/pf-progress/pf-progress.js +0 -10
- package/react/pf-progress-stepper/pf-progress-step.d.ts +0 -5
- package/react/pf-progress-stepper/pf-progress-step.js +0 -10
- package/react/pf-progress-stepper/pf-progress-stepper.d.ts +0 -5
- package/react/pf-progress-stepper/pf-progress-stepper.js +0 -10
- package/react/pf-select/pf-option-group.d.ts +0 -5
- package/react/pf-select/pf-option-group.js +0 -10
- package/react/pf-select/pf-option.d.ts +0 -5
- package/react/pf-select/pf-option.js +0 -10
- package/react/pf-select/pf-select.d.ts +0 -5
- package/react/pf-select/pf-select.js +0 -13
- package/react/pf-spinner/pf-spinner.d.ts +0 -5
- package/react/pf-spinner/pf-spinner.js +0 -10
- package/react/pf-switch/pf-switch.d.ts +0 -5
- package/react/pf-switch/pf-switch.js +0 -12
- package/react/pf-table/pf-caption.d.ts +0 -5
- package/react/pf-table/pf-caption.js +0 -10
- package/react/pf-table/pf-table.d.ts +0 -5
- package/react/pf-table/pf-table.js +0 -10
- package/react/pf-table/pf-tbody.d.ts +0 -5
- package/react/pf-table/pf-tbody.js +0 -10
- package/react/pf-table/pf-td.d.ts +0 -5
- package/react/pf-table/pf-td.js +0 -10
- package/react/pf-table/pf-th.d.ts +0 -5
- package/react/pf-table/pf-th.js +0 -10
- package/react/pf-table/pf-thead.d.ts +0 -5
- package/react/pf-table/pf-thead.js +0 -10
- package/react/pf-table/pf-tr.d.ts +0 -5
- package/react/pf-table/pf-tr.js +0 -10
- package/react/pf-tabs/pf-tab-panel.d.ts +0 -5
- package/react/pf-tabs/pf-tab-panel.js +0 -10
- package/react/pf-tabs/pf-tab.d.ts +0 -5
- package/react/pf-tabs/pf-tab.js +0 -12
- package/react/pf-tabs/pf-tabs.d.ts +0 -5
- package/react/pf-tabs/pf-tabs.js +0 -10
- package/react/pf-text-area/pf-text-area.d.ts +0 -5
- package/react/pf-text-area/pf-text-area.js +0 -10
- package/react/pf-text-input/pf-text-input.d.ts +0 -5
- package/react/pf-text-input/pf-text-input.js +0 -10
- package/react/pf-tile/pf-tile.d.ts +0 -5
- package/react/pf-tile/pf-tile.js +0 -10
- package/react/pf-timestamp/pf-timestamp.d.ts +0 -5
- package/react/pf-timestamp/pf-timestamp.js +0 -10
- package/react/pf-tooltip/pf-tooltip.d.ts +0 -5
- package/react/pf-tooltip/pf-tooltip.js +0 -10
|
@@ -7,7 +7,236 @@ import { property } from 'lit/decorators/property.js';
|
|
|
7
7
|
import { ifDefined } from 'lit/directives/if-defined.js';
|
|
8
8
|
import { styleMap } from 'lit/directives/style-map.js';
|
|
9
9
|
import { css } from "lit";
|
|
10
|
-
const styles = css `* {
|
|
10
|
+
const styles = css `* {
|
|
11
|
+
box-sizing: border-box;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
#container {
|
|
15
|
+
--_pf-c-progress__bar--before--BackgroundColorWithOpacity: #0066cc33; /* WARNING: not a recognized token value */
|
|
16
|
+
--_pf-c-progress--m-success__bar--BackgroundColorWithOpacity: #3e863533; /* WARNING: not a recognized token value */
|
|
17
|
+
--_pf-c-progress--m-warning__bar--BackgroundColorWithOpacity: #f0ab0033; /* WARNING: not a recognized token value */
|
|
18
|
+
--_pf-c-progress--m-danger__bar--BackgroundColorWithOpacity: #c9190b33; /* WARNING: not a recognized token value */
|
|
19
|
+
|
|
20
|
+
/** Gap between sections of progress bar */
|
|
21
|
+
--pf-c-progress--GridGap: var(--pf-global--spacer--md, 1rem);
|
|
22
|
+
/** Color of progress bar */
|
|
23
|
+
--pf-c-progress__bar--before--BackgroundColor: var(--pf-global--primary-color--100, #0066cc);
|
|
24
|
+
/** Height of progress bar */
|
|
25
|
+
--pf-c-progress__bar--Height: var(--pf-global--spacer--md, 1rem);
|
|
26
|
+
/** Background color of progress bar */
|
|
27
|
+
--pf-c-progress__bar--BackgroundColor: var(--pf-global--BackgroundColor--light-100, #ffffff);
|
|
28
|
+
/** Color of status icon */
|
|
29
|
+
--pf-c-progress__status-icon--Color: var(--pf-global--Color--100, #151515);
|
|
30
|
+
/** Margin left of status icon */
|
|
31
|
+
--pf-c-progress__status-icon--MarginLeft: var(--pf-global--spacer--sm, 0.5rem);
|
|
32
|
+
/** Height of progress bar indicator */
|
|
33
|
+
--pf-c-progress__indicator--Height: var(--pf-c-progress__bar--Height);
|
|
34
|
+
/** Background color of progress bar indicator */
|
|
35
|
+
--pf-c-progress__indicator--BackgroundColor: var(--pf-c-progress__bar--before--BackgroundColor);
|
|
36
|
+
/** Background color of progress bar when variant is success */
|
|
37
|
+
--pf-c-progress--m-success__bar--BackgroundColor: var(--pf-global--success-color--100, #3e8635);
|
|
38
|
+
/** Background color of progress bar when variant is warning */
|
|
39
|
+
--pf-c-progress--m-warning__bar--BackgroundColor: var(--pf-global--warning-color--100, #f0ab00);
|
|
40
|
+
/** Background color of progress bar when variant is danger */
|
|
41
|
+
--pf-c-progress--m-danger__bar--BackgroundColor: var(--pf-global--danger-color--100, #c9190b);
|
|
42
|
+
/** Color of status icon when variant is success */
|
|
43
|
+
--pf-c-progress--m-success__status-icon--Color: var(--pf-global--success-color--100, #3e8635);
|
|
44
|
+
/** Color of status icon when variant is warning */
|
|
45
|
+
--pf-c-progress--m-warning__status-icon--Color: var(--pf-global--warning-color--100, #f0ab00);
|
|
46
|
+
/** Color of status icon when variant is danger */
|
|
47
|
+
--pf-c-progress--m-danger__status-icon--Color: var(--pf-global--danger-color--100, #c9190b);
|
|
48
|
+
/** Color of progress bar measure when variant is success and measure location is inside */
|
|
49
|
+
--pf-c-progress--m-success--m-inside__measure--Color: var(--pf-global--Color--light-100, #ffffff);
|
|
50
|
+
/** Font size of progress bar measure when measure location is outside */
|
|
51
|
+
--pf-c-progress--m-outside__measure--FontSize: var(--pf-global--FontSize--sm, 0.875rem);
|
|
52
|
+
/** Height of progress bar when size is small */
|
|
53
|
+
--pf-c-progress--m-sm__bar--Height: var(--pf-global--spacer--sm, 0.5rem);
|
|
54
|
+
/** Font size of progress bar description when size is small */
|
|
55
|
+
--pf-c-progress--m-sm__description--FontSize: var(--pf-global--FontSize--sm, 0.875rem);
|
|
56
|
+
/** Height of progress bar when size is large */
|
|
57
|
+
--pf-c-progress--m-lg__bar--Height: var(--pf-global--spacer--lg, 1.5rem);
|
|
58
|
+
display: grid;
|
|
59
|
+
align-items: end;
|
|
60
|
+
grid-gap: var(--pf-c-progress--GridGap);
|
|
61
|
+
grid-template-columns: 1fr auto;
|
|
62
|
+
grid-template-rows: 1fr auto;
|
|
63
|
+
width: 100%;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.sm {
|
|
67
|
+
--pf-c-progress__bar--Height: var(--pf-c-progress--m-sm__bar--Height);
|
|
68
|
+
--pf-c-progress__indicator--Height: var(--pf-c-progress--m-sm__bar--Height);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
.sm #description {
|
|
72
|
+
font-size: var(--pf-c-progress--m-sm__description--FontSize);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
.lg {
|
|
76
|
+
--pf-c-progress__bar--Height: var(--pf-c-progress--m-lg__bar--Height);
|
|
77
|
+
--pf-c-progress__indicator--Height: var(--pf-c-progress--m-lg__bar--Height);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
.outside #description {
|
|
81
|
+
grid-column: 1/3;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
.outside #status {
|
|
85
|
+
grid-column: 2/3;
|
|
86
|
+
grid-row: 2/3;
|
|
87
|
+
align-self: center;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
.outside progress,
|
|
91
|
+
.outside span {
|
|
92
|
+
display: inline-block;
|
|
93
|
+
font-size: var(--pf-c-progress--m-outside__measure--FontSize);
|
|
94
|
+
grid-column: 1/2;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
.singleline {
|
|
98
|
+
grid-template-rows: 1fr;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
.singleline #description {
|
|
102
|
+
display: none;
|
|
103
|
+
visibility: hidden;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
.singleline progress,
|
|
107
|
+
.singleline span {
|
|
108
|
+
grid-row: 1/2;
|
|
109
|
+
grid-column: 1/2;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
.singleline #status {
|
|
113
|
+
grid-row: 1/2;
|
|
114
|
+
grid-column: 2/3;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
.outside, .singleline {
|
|
118
|
+
grid-template-columns: 1fr fit-content(50%);
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
#container.success {
|
|
122
|
+
--pf-c-progress__bar--before--BackgroundColor: var(--pf-c-progress--m-success__bar--BackgroundColor);
|
|
123
|
+
--_pf-c-progress__bar--before--BackgroundColorWithOpacity: var(--_pf-c-progress--m-success__bar--BackgroundColorWithOpacity);
|
|
124
|
+
--pf-c-progress__status-icon--Color: var(--pf-c-progress--m-success__status-icon--Color);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
#container.warning {
|
|
128
|
+
--pf-c-progress__bar--before--BackgroundColor: var(--pf-c-progress--m-warning__bar--BackgroundColor);
|
|
129
|
+
--_pf-c-progress__bar--before--BackgroundColorWithOpacity: var(--_pf-c-progress--m-warning__bar--BackgroundColorWithOpacity);
|
|
130
|
+
--pf-c-progress__status-icon--Color: var(--pf-c-progress--m-warning__status-icon--Color);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
#container.danger {
|
|
134
|
+
--pf-c-progress__bar--before--BackgroundColor: var(--pf-c-progress--m-danger__bar--BackgroundColor);
|
|
135
|
+
--_pf-c-progress__bar--before--BackgroundColorWithOpacity: var(--_pf-c-progress--m-danger__bar--BackgroundColorWithOpacity);
|
|
136
|
+
--pf-c-progress__status-icon--Color: var(--pf-c-progress--m-danger__status-icon--Color);
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
#description {
|
|
140
|
+
word-break: break-word;
|
|
141
|
+
grid-column: 1/2;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
.descriptionTruncated #description {
|
|
145
|
+
overflow-x: hidden;
|
|
146
|
+
text-overflow: ellipsis;
|
|
147
|
+
white-space: nowrap;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
#status {
|
|
151
|
+
grid-column: 2/3;
|
|
152
|
+
grid-row: 1/2;
|
|
153
|
+
text-align: right;
|
|
154
|
+
word-break: break-word;
|
|
155
|
+
display: flex;
|
|
156
|
+
align-items: center;
|
|
157
|
+
justify-content: end;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
pf-icon {
|
|
161
|
+
margin-left: var(--pf-c-progress__status-icon--MarginLeft);
|
|
162
|
+
color: var(--pf-c-progress__status-icon--Color);
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
progress {
|
|
166
|
+
position: relative;
|
|
167
|
+
grid-column: 1/3;
|
|
168
|
+
grid-row: 2/3;
|
|
169
|
+
align-self: center;
|
|
170
|
+
height: var(--pf-c-progress__bar--Height);
|
|
171
|
+
background-color: var(--pf-c-progress__bar--BackgroundColor);
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
.indicator {
|
|
175
|
+
position: absolute;
|
|
176
|
+
top: 0;
|
|
177
|
+
left: 0;
|
|
178
|
+
height: var(--pf-c-progress__indicator--Height);
|
|
179
|
+
background-color: var(--pf-c-progress__indicator--BackgroundColor);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
.indicator {
|
|
183
|
+
width: 100%;
|
|
184
|
+
height: var(--pf-c-progress__bar--Height);
|
|
185
|
+
|
|
186
|
+
display: block;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
span {
|
|
190
|
+
grid-column: 1/3;
|
|
191
|
+
grid-row: 2/3;
|
|
192
|
+
text-align: center;
|
|
193
|
+
color: var(--pf-c-progress--m-success--m-inside__measure--Color);
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
span::after {
|
|
197
|
+
content: attr(data-value);
|
|
198
|
+
position: relative;
|
|
199
|
+
height: 100%;
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
progress[value] {
|
|
203
|
+
-webkit-appearance: none;
|
|
204
|
+
-moz-appearance: none;
|
|
205
|
+
appearance: none;
|
|
206
|
+
|
|
207
|
+
background: var(--_pf-c-progress__bar--before--BackgroundColorWithOpacity);
|
|
208
|
+
|
|
209
|
+
width: 100%;
|
|
210
|
+
height: var(--pf-c-progress__bar--Height);
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
progress:not([value]) {
|
|
214
|
+
-webkit-appearance: none;
|
|
215
|
+
-moz-appearance: none;
|
|
216
|
+
appearance: none;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
progress[value]::-webkit-progress-bar {
|
|
220
|
+
background: var(--_pf-c-progress__bar--before--BackgroundColorWithOpacity);
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
progress[value]::-moz-progress-bar {
|
|
224
|
+
background: var(--pf-c-progress__bar--before--BackgroundColor);
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
progress[value]::-webkit-progress-value {
|
|
228
|
+
background-size: 100% 100%;
|
|
229
|
+
background-image: linear-gradient(
|
|
230
|
+
90deg,
|
|
231
|
+
var(--pf-c-progress__bar--before--BackgroundColor) 100%,
|
|
232
|
+
var(--pf-c-progress__bar--before--BackgroundColor) 100%
|
|
233
|
+
);
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
pf-tooltip {
|
|
237
|
+
height: 0.01px;
|
|
238
|
+
}
|
|
239
|
+
`;
|
|
11
240
|
const ICONS = new Map(Object.entries({
|
|
12
241
|
success: { icon: 'circle-check' },
|
|
13
242
|
danger: { icon: 'circle-xmark' },
|
|
@@ -101,7 +330,7 @@ _PfProgress_icon_get = function _PfProgress_icon_get() {
|
|
|
101
330
|
return ICONS.get(this.variant ?? '')?.icon;
|
|
102
331
|
};
|
|
103
332
|
PfProgress.styles = [styles];
|
|
104
|
-
PfProgress.version = "4.0
|
|
333
|
+
PfProgress.version = "4.2.0";
|
|
105
334
|
__decorate([
|
|
106
335
|
property({ reflect: true, type: Number })
|
|
107
336
|
], PfProgress.prototype, "value", void 0);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pf-progress.js","sourceRoot":"","sources":["pf-progress.ts"],"names":[],"mappings":"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","sourcesContent":["import type { PropertyValues, TemplateResult } from 'lit';\nimport { LitElement, html } from 'lit';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { customElement } from 'lit/decorators/custom-element.js';\nimport { property } from 'lit/decorators/property.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport styles from './pf-progress.css';\n\nconst ICONS = new Map(Object.entries({\n success: { icon: 'circle-check' },\n danger: { icon: 'circle-xmark' },\n warning: { icon: 'triangle-exclamation' },\n}));\n\n/**\n * A progress bar gives the user a visual representation of their completion status of an ongoing process or task.\n * @summary Display completion status of ongoing process or task.\n * @cssprop {<length>} [--pf-c-progress--GridGap=1rem]\n * Gap between the sections of the progress bar.\n *\n * @cssprop {<color>} [--pf-c-progress__bar--before--BackgroundColor=#06c]\n * Color of the progress bar.\n *\n * @cssprop {<length>} [--pf-c-progress__bar--Height=1rem]\n * Height of the progress bar.\n *\n * @cssprop {<color>} [--pf-c-progress__bar--BackgroundColor=#ffffff]\n * Background color of the progress bar.\n *\n * @cssprop {<color>} [--pf-c-progress__status-icon--Color=#151515]\n * Color of the status icon.\n *\n * @cssprop {<length>} [--pf-c-progress__status-icon--MarginLeft=0.5rem]\n * Margin left of the status icon.\n *\n * @cssprop {<length>} [--pf-c-progress__indicator--Height=1rem]\n * Height of the progress bar indicator.\n *\n * @cssprop {<color>} [--pf-c-progress__indicator--BackgroundColor=#ffffff]\n * Background color of the progress bar indicator.\n *\n * @cssprop {<color>} [--pf-c-progress--m-success__bar--BackgroundColor=#3e8635]\n * Background color of the progress bar when variant is success.\n *\n * @cssprop {<color>} [--pf-c-progress--m-warning__bar--BackgroundColor=#f0ab00]\n * Background color of the progress bar when variant is warning.\n *\n * @cssprop {<color>} [--pf-c-progress--m-danger__bar--BackgroundColor=#c9190b]\n * Background color of the progress bar when variant is danger.\n *\n * @cssprop {<color>} [--pf-c-progress--m-success__status-icon--Color=#3e8635]\n * Color of the status icon when variant is success.\n *\n * @cssprop {<color>} [--pf-c-progress--m-warning__status-icon--Color=#f0ab00]\n * Color of the status icon when variant is warning.\n *\n * @cssprop {<color>} [--pf-c-progress--m-danger__status-icon--Color=#c9190b]\n * Color of the status icon when variant is danger.\n *\n * @cssprop {<color>} [--pf-c-progress--m-success--m-inside__measure--Color=#ffffff]\n * Color of the progress bar measure when variant is success and measure location is inside.\n *\n * @cssprop {<length>} [--pf-c-progress--m-outside__measure--FontSize=0.875rem]\n * Font size of the progress bar measure when measure location is outside.\n *\n * @cssprop {<length>} [--pf-c-progress--m-sm__bar--Height=0.5rem]\n * Height of the progress bar when the size is small.\n *\n * @cssprop {<length>} [--pf-c-progress--m-sm__description--FontSize=0.875rem]\n * Font size of the progress bar description when the size is small.\n *\n * @cssprop {<length>} [--pf-c-progress--m-lg__bar--Height=1.5rem]\n * Height of the progress bar when the size is large.\n *\n */\n@customElement('pf-progress')\nexport class PfProgress extends LitElement {\n static readonly styles: CSSStyleSheet[] = [styles];\n\n #internals = this.attachInternals();\n\n /** Represents the value of the progress bar */\n @property({ reflect: true, type: Number }) value = 0;\n\n /** Description (title) above the progress bar */\n @property() description?: string;\n\n /** Indicate whether to truncate the string description (title) */\n @property({\n type: Boolean,\n reflect: true,\n attribute: 'description-truncated',\n }) descriptionTruncated = false;\n\n /** Maximum value for the progress bar */\n @property({ type: Number, reflect: true }) max = 100;\n\n /** Minimum value for the progress bar */\n @property({ type: Number, reflect: true }) min = 0;\n\n /** Size of the progress bar (height) */\n @property() size?: 'sm' | 'lg';\n\n /** Where the percentage will be displayed with the progress element */\n @property({ attribute: 'measure-location' }) measureLocation?: 'outside' | 'inside' | 'none';\n\n /** Variant of the progress bar */\n @property() variant?: 'success' | 'danger' | 'warning';\n\n get #calculatedPercentage(): number {\n const { value, min, max } = this;\n const percentage = Math.round((value - min) / (max - min) * 100);\n if (Number.isNaN(percentage) || percentage < 0) {\n return 0;\n }\n return Math.min(percentage, 100);\n }\n\n get #icon() {\n return ICONS.get(this.variant ?? '')?.icon;\n }\n\n override willUpdate(changed: PropertyValues<this>): void {\n if (changed.has('value') || changed.has('min') || changed.has('max')) {\n this.#internals.ariaValueNow = this.#calculatedPercentage.toString();\n }\n if (this.#icon) {\n import('@patternfly/elements/pf-icon/pf-icon.js');\n }\n if (this.descriptionTruncated) {\n import('@patternfly/elements/pf-tooltip/pf-tooltip.js');\n }\n }\n\n render(): TemplateResult<1> {\n const { size, measureLocation, variant, description, descriptionTruncated } = this;\n const icon = this.#icon;\n const singleLine = description?.length === 0;\n const pct = this.#calculatedPercentage;\n const width = `${pct}%`;\n\n return html`\n <div id=\"container\" class=\"${classMap({\n [size ?? '']: !!size,\n [measureLocation ?? '']: !!measureLocation,\n [variant ?? '']: !!variant,\n singleLine,\n descriptionTruncated,\n })}\">\n\n <div id=\"description\" aria-hidden=\"true\">${description ?? ''}</div>\n\n ${!descriptionTruncated ? '' : html`\n <pf-tooltip content=\"${this.description ?? ''}\"\n trigger=\"description\"></pf-tooltip>\n `}\n\n ${measureLocation === 'none' ? '' : html`\n <div id=\"status\" aria-hidden=\"true\">\n ${measureLocation !== 'inside' ? '' : width}\n <pf-icon set=\"fas\"\n icon=\"${ifDefined(icon)}\"\n size=\"md\"\n ?hidden=\"${!icon}\"\n ></pf-icon>\n </div>\n `}\n\n <progress id=\"progress\"\n max=\"100\"\n value=\"${pct}\"\n aria-valuemin=\"0\"\n aria-valuenow=\"${pct}\"\n aria-valuemax=\"100\"\n ></progress>\n\n ${measureLocation !== 'inside' ? '' : html`\n <span id=\"progress-span\"\n style=\"${styleMap({ width })}\"\n data-value=\"${width}\"></span>\n `}\n </div>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'pf-progress': PfProgress;\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"pf-progress.js","sourceRoot":"","sources":["pf-progress.ts"],"names":[],"mappings":"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","sourcesContent":["import type { PropertyValues, TemplateResult } from 'lit';\nimport { LitElement, html } from 'lit';\nimport { classMap } from 'lit/directives/class-map.js';\nimport { customElement } from 'lit/decorators/custom-element.js';\nimport { property } from 'lit/decorators/property.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { styleMap } from 'lit/directives/style-map.js';\n\nimport styles from './pf-progress.css';\n\nconst ICONS = new Map(Object.entries({\n success: { icon: 'circle-check' },\n danger: { icon: 'circle-xmark' },\n warning: { icon: 'triangle-exclamation' },\n}));\n\n/**\n * A progress bar gives the user a visual representation of their completion status of an ongoing process or task.\n * @summary Display completion status of ongoing process or task.\n * @alias Progress\n */\n@customElement('pf-progress')\nexport class PfProgress extends LitElement {\n static readonly styles: CSSStyleSheet[] = [styles];\n\n #internals = this.attachInternals();\n\n /** Represents the value of the progress bar */\n @property({ reflect: true, type: Number }) value = 0;\n\n /** Description (title) above the progress bar */\n @property() description?: string;\n\n /** Indicate whether to truncate the string description (title) */\n @property({\n type: Boolean,\n reflect: true,\n attribute: 'description-truncated',\n }) descriptionTruncated = false;\n\n /** Maximum value for the progress bar */\n @property({ type: Number, reflect: true }) max = 100;\n\n /** Minimum value for the progress bar */\n @property({ type: Number, reflect: true }) min = 0;\n\n /** Size of the progress bar (height) */\n @property() size?: 'sm' | 'lg';\n\n /** Where the percentage will be displayed with the progress element */\n @property({ attribute: 'measure-location' }) measureLocation?: 'outside' | 'inside' | 'none';\n\n /** Variant of the progress bar */\n @property() variant?: 'success' | 'danger' | 'warning';\n\n get #calculatedPercentage(): number {\n const { value, min, max } = this;\n const percentage = Math.round((value - min) / (max - min) * 100);\n if (Number.isNaN(percentage) || percentage < 0) {\n return 0;\n }\n return Math.min(percentage, 100);\n }\n\n get #icon() {\n return ICONS.get(this.variant ?? '')?.icon;\n }\n\n override willUpdate(changed: PropertyValues<this>): void {\n if (changed.has('value') || changed.has('min') || changed.has('max')) {\n this.#internals.ariaValueNow = this.#calculatedPercentage.toString();\n }\n if (this.#icon) {\n import('@patternfly/elements/pf-icon/pf-icon.js');\n }\n if (this.descriptionTruncated) {\n import('@patternfly/elements/pf-tooltip/pf-tooltip.js');\n }\n }\n\n render(): TemplateResult<1> {\n const { size, measureLocation, variant, description, descriptionTruncated } = this;\n const icon = this.#icon;\n const singleLine = description?.length === 0;\n const pct = this.#calculatedPercentage;\n const width = `${pct}%`;\n\n return html`\n <div id=\"container\" class=\"${classMap({\n [size ?? '']: !!size,\n [measureLocation ?? '']: !!measureLocation,\n [variant ?? '']: !!variant,\n singleLine,\n descriptionTruncated,\n })}\">\n\n <div id=\"description\" aria-hidden=\"true\">${description ?? ''}</div>\n\n ${!descriptionTruncated ? '' : html`\n <pf-tooltip content=\"${this.description ?? ''}\"\n trigger=\"description\"></pf-tooltip>\n `}\n\n ${measureLocation === 'none' ? '' : html`\n <div id=\"status\" aria-hidden=\"true\">\n ${measureLocation !== 'inside' ? '' : width}\n <pf-icon set=\"fas\"\n icon=\"${ifDefined(icon)}\"\n size=\"md\"\n ?hidden=\"${!icon}\"\n ></pf-icon>\n </div>\n `}\n\n <progress id=\"progress\"\n max=\"100\"\n value=\"${pct}\"\n aria-valuemin=\"0\"\n aria-valuenow=\"${pct}\"\n aria-valuemax=\"100\"\n ></progress>\n\n ${measureLocation !== 'inside' ? '' : html`\n <span id=\"progress-span\"\n style=\"${styleMap({ width })}\"\n data-value=\"${width}\"></span>\n `}\n </div>`;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'pf-progress': PfProgress;\n }\n}\n"]}
|
|
@@ -8,7 +8,131 @@ import { classMap } from 'lit/directives/class-map.js';
|
|
|
8
8
|
import { SlotController } from '@patternfly/pfe-core/controllers/slot-controller.js';
|
|
9
9
|
import { InternalsController } from '@patternfly/pfe-core/controllers/internals-controller.js';
|
|
10
10
|
import { css } from "lit";
|
|
11
|
-
const style = css `[hidden] {
|
|
11
|
+
const style = css `[hidden] {
|
|
12
|
+
display: none !important;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
#icon {
|
|
16
|
+
z-index: var(--pf-c-progress-stepper__step-icon--ZIndex);
|
|
17
|
+
display: flex;
|
|
18
|
+
align-items: center;
|
|
19
|
+
justify-content: center;
|
|
20
|
+
width: var(--pf-c-progress-stepper__step-icon--Width);
|
|
21
|
+
height: var(--pf-c-progress-stepper__step-icon--Height);
|
|
22
|
+
color: var(--pf-c-progress-stepper__step-icon--Color);
|
|
23
|
+
background-color: var(--pf-c-progress-stepper__step-icon--BackgroundColor);
|
|
24
|
+
border: var(--pf-c-progress-stepper__step-icon--BorderWidth) solid var(--pf-c-progress-stepper__step-icon--BorderColor);
|
|
25
|
+
border-radius: 50%;
|
|
26
|
+
font-size: var(--pf-c-progress-stepper__step-icon--FontSize);
|
|
27
|
+
--pf-icon--size: 1.125em;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
#main {
|
|
31
|
+
position: var(--pf-c-progress-stepper__step-main--Position, initial);
|
|
32
|
+
min-width: 0;
|
|
33
|
+
margin: var(--pf-c-progress-stepper__step-main--MarginTop) var(--pf-c-progress-stepper__step-main--MarginRight) var(--pf-c-progress-stepper__step-main--MarginBottom) var(--pf-c-progress-stepper__step-main--MarginLeft);
|
|
34
|
+
text-align: var(--pf-c-progress-stepper--step-main--TextAlign, auto);
|
|
35
|
+
overflow-wrap: anywhere;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
:host(:not([current])) #main.compact {
|
|
39
|
+
position: fixed;
|
|
40
|
+
top: 0;
|
|
41
|
+
left: 0;
|
|
42
|
+
overflow: hidden;
|
|
43
|
+
clip: rect(0, 0, 0, 0);
|
|
44
|
+
white-space: nowrap;
|
|
45
|
+
border: 0;
|
|
46
|
+
margin-bottom: var(--pf-c-progress-stepper--m-compact__step-main--MarginBottom);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
:host([current]) #main.compact {
|
|
50
|
+
grid-column: 1/-1;
|
|
51
|
+
grid-row: 1/2;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
#title {
|
|
55
|
+
font-size: var(--pf-c-progress-stepper__step-title--FontSize);
|
|
56
|
+
font-weight: var(--pf-c-progress-stepper__step-title--FontWeight);
|
|
57
|
+
color: var(--pf-c-progress-stepper__step-title--Color);
|
|
58
|
+
text-align: var(--pf-c-progress-stepper__step-title--TextAlign);
|
|
59
|
+
border: 0;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
#description {
|
|
63
|
+
margin-top: var(--pf-c-progress-stepper__step-description--MarginTop);
|
|
64
|
+
font-size: var(--pf-c-progress-stepper__step-description--FontSize);
|
|
65
|
+
color: var(--pf-c-progress-stepper__step-description--Color);
|
|
66
|
+
text-align: var(--pf-c-progress-stepper__step-description--TextAlign);
|
|
67
|
+
display: block;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
:host {
|
|
71
|
+
display: contents;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
#connector {
|
|
75
|
+
position: relative;
|
|
76
|
+
display: flex;
|
|
77
|
+
justify-content: var(--pf-c-progress-stepper__step-connector--JustifyContent);
|
|
78
|
+
width: 100%;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
#connector.compact {
|
|
82
|
+
min-width: var(--pf-c-progress-stepper--m-compact__step-connector--MinWidth);
|
|
83
|
+
grid-row: var(--pf-c-progress-stepper--m-compact__step-connector--GridRow);
|
|
84
|
+
padding-bottom: var(--pf-c-progress-stepper--m-compact__step-connector--PaddingBottom);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
:host(:not(:last-of-type)) #main::before {
|
|
88
|
+
content: var(--pf-c-progress-stepper__step-main--before--Content);
|
|
89
|
+
position: absolute;
|
|
90
|
+
top: calc(100% + var(--pf-c-progress-stepper__step-main--MarginTop));
|
|
91
|
+
left: calc(50% - var(--pf-c-progress-stepper__step-connector--before--BorderRightWidth) / 2);
|
|
92
|
+
width: auto;
|
|
93
|
+
height: calc(var(--pf-c-progress-stepper__step-main--MarginTop) + var(--pf-c-progress-stepper__step-main--MarginBottom));
|
|
94
|
+
border-right: var(--pf-c-progress-stepper__step-connector--before--BorderRightWidth) solid var(--pf-c-progress-stepper__step-connector--before--BorderRightColor);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
:host(:not(:last-of-type)) #connector::before {
|
|
98
|
+
position: absolute;
|
|
99
|
+
top: var(--pf-c-progress-stepper__step-connector--before--Top);
|
|
100
|
+
left: var(--pf-c-progress-stepper__step-connector--before--Left);
|
|
101
|
+
width: var(--pf-c-progress-stepper__step-connector--before--Width);
|
|
102
|
+
height: var(--pf-c-progress-stepper__step-connector--before--Height);
|
|
103
|
+
content: var(--pf-c-progress-stepper__step-connector--before--Content);
|
|
104
|
+
border-right: var(--pf-c-progress-stepper__step-connector--before--BorderRightWidth) solid var(--pf-c-progress-stepper__step-connector--before--BorderRightColor);
|
|
105
|
+
border-bottom: var(--pf-c-progress-stepper__step-connector--before--BorderBottomWidth) solid var(--pf-c-progress-stepper__step-connector--before--BorderBottomColor);
|
|
106
|
+
transform: var(--pf-c-progress-stepper__step-connector--before--Transform);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
:host([current]) {
|
|
110
|
+
--pf-c-progress-stepper__step-title--FontWeight: var(--pf-c-progress-stepper__step--m-current__step-title--FontWeight);
|
|
111
|
+
--pf-c-progress-stepper__step-title--Color: var(--pf-c-progress-stepper__step--m-current__step-title--Color);
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
:host([variant="success"]) {
|
|
115
|
+
--pf-c-progress-stepper__step-icon--Color: var(--pf-global--success-color--100, #3e8635);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
:host([variant="info"]) {
|
|
119
|
+
--pf-c-progress-stepper__step-icon--Color: var(--pf-global--info-color--100, #2b9af3);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
:host([variant="warning"]) {
|
|
123
|
+
--pf-c-progress-stepper__step-icon--Color: var(--pf-global--warning-color--100, #f0ab00);
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
:host([variant="danger"]) {
|
|
127
|
+
--pf-c-progress-stepper__step-icon--Color: var(--pf-global--danger-color--100, #c9190b);
|
|
128
|
+
--pf-c-progress-stepper__step-title--Color: var(--pf-c-progress-stepper__step--m-danger__step-title--Color);
|
|
129
|
+
--pf-c-progress-stepper__step-title--m-help-text--hover--Color: var(--pf-c-progress-stepper__step--m-danger__step-title--m-help-text--hover--Color);
|
|
130
|
+
--pf-c-progress-stepper__step-title--m-help-text--focus--Color: var(--pf-c-progress-stepper__step--m-danger__step-title--m-help-text--focus--Color);
|
|
131
|
+
--pf-c-progress-stepper__step-title--m-help-text--TextDecorationColor: var(--pf-c-progress-stepper__step--m-danger__step-title--m-help-text--TextDecorationColor);
|
|
132
|
+
--pf-c-progress-stepper__step-title--m-help-text--hover--TextDecorationColor: var(--pf-c-progress-stepper__step--m-danger__step-title--m-help-text--hover--TextDecorationColor);
|
|
133
|
+
--pf-c-progress-stepper__step-title--m-help-text--focus--TextDecorationColor: var(--pf-c-progress-stepper__step--m-danger__step-title--m-help-text--focus--TextDecorationColor);
|
|
134
|
+
}
|
|
135
|
+
`;
|
|
12
136
|
const ICONS = new Map(Object.entries({
|
|
13
137
|
success: { icon: 'check-circle' },
|
|
14
138
|
danger: { icon: 'exclamation-circle' },
|
|
@@ -53,7 +177,7 @@ _PfProgressStep_slots = new WeakMap();
|
|
|
53
177
|
_PfProgressStep_internals = new WeakMap();
|
|
54
178
|
PfProgressStep.parentTagName = 'pf-progress-stepper';
|
|
55
179
|
PfProgressStep.styles = [style];
|
|
56
|
-
PfProgressStep.version = "4.0
|
|
180
|
+
PfProgressStep.version = "4.2.0";
|
|
57
181
|
__decorate([
|
|
58
182
|
property()
|
|
59
183
|
], PfProgressStep.prototype, "description", void 0);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pf-progress-step.js","sourceRoot":"","sources":["pf-progress-step.ts"],"names":[],"mappings":";;AAGA,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAEvD,OAAO,EAAE,cAAc,EAAE,MAAM,qDAAqD,CAAC;AACrF,OAAO,EAAE,mBAAmB,EAAE,MAAM,0DAA0D,CAAC
|
|
1
|
+
{"version":3,"file":"pf-progress-step.js","sourceRoot":"","sources":["pf-progress-step.ts"],"names":[],"mappings":"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","sourcesContent":["import type { PropertyValues, TemplateResult } from 'lit';\nimport type { PfProgressStepper } from './pf-progress-stepper.js';\n\nimport { LitElement, html } from 'lit';\nimport { customElement } from 'lit/decorators/custom-element.js';\nimport { property } from 'lit/decorators/property.js';\nimport { ifDefined } from 'lit/directives/if-defined.js';\nimport { classMap } from 'lit/directives/class-map.js';\n\nimport { SlotController } from '@patternfly/pfe-core/controllers/slot-controller.js';\nimport { InternalsController } from '@patternfly/pfe-core/controllers/internals-controller.js';\n\nimport style from './pf-progress-step.css';\n\nconst ICONS = new Map(Object.entries({\n success: { icon: 'check-circle' },\n danger: { icon: 'exclamation-circle' },\n warning: { icon: 'exclamation-triangle' },\n info: { icon: 'resources-full', set: 'patternfly' },\n}));\n\n/**\n * @slot -\n * Short description of the current step.\n * @slot description\n * Longer description of the current step.\n * @slot icon\n * Overrides the icon property\n */\n@customElement('pf-progress-step')\nexport class PfProgressStep extends LitElement {\n protected static parentTagName = 'pf-progress-stepper';\n\n static readonly styles: CSSStyleSheet[] = [style];\n\n /** Optional extended description of the step */\n @property() description?: string;\n\n /** Step Icon */\n @property() icon?: string;\n\n /** Step icon set */\n @property({ attribute: 'icon-set' }) iconSet?: string;\n\n /** Describes the state of the current item */\n @property({ reflect: true }) variant?: 'pending' | 'info' | 'success' | 'warning' | 'danger';\n\n /** Indicates if this item is the current active item. */\n @property({ type: Boolean, reflect: true }) current = false;\n\n #slots = new SlotController(this, 'title', 'description');\n\n #internals = InternalsController.of(this, { role: 'listitem' });\n\n render(): TemplateResult<1> {\n const hasDescription = !!(this.description ?? this.#slots.hasSlotted('description'));\n const icon = this.icon ?? ICONS.get(this.variant ?? 'default')?.icon;\n const set = this.iconSet ?? ICONS.get(this.variant ?? 'default')?.set;\n const { parentTagName } = (this.constructor as typeof PfProgressStep);\n const { compact = false } = this.closest?.<PfProgressStepper>(parentTagName) ?? {};\n return html`\n <div id=\"connector\" class=\"${classMap({ compact })}\">\n <slot id=\"icon\" name=\"icon\">\n <pf-icon ?hidden=\"${!icon}\"\n icon=\"${ifDefined(icon)}\"\n set=\"${ifDefined(set)}\"></pf-icon>\n </slot>\n </div>\n <div id=\"main\" class=\"${classMap({ compact })}\">\n <slot id=\"title\"></slot>\n <slot id=\"description\" name=\"description\" ?hidden=\"${!hasDescription}\">${this.description}</slot>\n </div>\n `;\n }\n\n updated(changed: PropertyValues<this>): void {\n if (changed.has('current')) {\n this.#internals.ariaCurrent = String(!!this.current);\n }\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'pf-progress-step': PfProgressStep;\n }\n}\n"]}
|