@universal-material/web 3.0.20 → 3.0.21
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/app-bar/top-app-bar.d.ts +42 -0
- package/app-bar/top-app-bar.d.ts.map +1 -0
- package/app-bar/top-app-bar.js +139 -0
- package/app-bar/top-app-bar.js.map +1 -0
- package/{button/button-base.styles.d.ts → app-bar/top-app-bar.styles.d.ts} +1 -1
- package/app-bar/top-app-bar.styles.d.ts.map +1 -0
- package/app-bar/top-app-bar.styles.js +87 -0
- package/app-bar/top-app-bar.styles.js.map +1 -0
- package/button/button-base.d.ts +2 -30
- package/button/button-base.d.ts.map +1 -1
- package/button/button-base.js +4 -94
- package/button/button-base.js.map +1 -1
- package/button/button.d.ts +1 -1
- package/button/button.d.ts.map +1 -1
- package/button/button.js +9 -7
- package/button/button.js.map +1 -1
- package/button/button.styles.d.ts.map +1 -1
- package/button/button.styles.js +14 -10
- package/button/button.styles.js.map +1 -1
- package/button/fab.d.ts.map +1 -1
- package/button/fab.js +2 -2
- package/button/fab.js.map +1 -1
- package/button/icon-button.d.ts +2 -2
- package/button/icon-button.d.ts.map +1 -1
- package/button/icon-button.js +5 -4
- package/button/icon-button.js.map +1 -1
- package/button/icon-button.styles.js +8 -8
- package/button/icon-button.styles.js.map +1 -1
- package/card/card.d.ts +3 -3
- package/card/card.d.ts.map +1 -1
- package/card/card.js +3 -3
- package/card/card.js.map +1 -1
- package/checkbox/checkbox.d.ts.map +1 -1
- package/checkbox/checkbox.js +0 -1
- package/checkbox/checkbox.js.map +1 -1
- package/config.d.ts +6 -0
- package/config.d.ts.map +1 -0
- package/config.js +7 -0
- package/config.js.map +1 -0
- package/container/container.d.ts +1 -1
- package/container/container.d.ts.map +1 -1
- package/container/container.js +4 -4
- package/container/container.js.map +1 -1
- package/container/grid-base.styles.js +4 -4
- package/container/grid-base.styles.js.map +1 -1
- package/container/grid.d.ts +2 -2
- package/container/grid.d.ts.map +1 -1
- package/container/grid.js +4 -4
- package/container/grid.js.map +1 -1
- package/css/universal-material.css +1333 -0
- package/css/universal-material.min.css +2 -0
- package/custom-elements.json +2873 -915
- package/elevation/elevation.d.ts +1 -1
- package/elevation/elevation.d.ts.map +1 -1
- package/elevation/elevation.js +2 -2
- package/elevation/elevation.js.map +1 -1
- package/index.d.ts +41 -29
- package/index.d.ts.map +1 -1
- package/index.js +41 -29
- package/index.js.map +1 -1
- package/menu/menu-item.d.ts +26 -0
- package/menu/menu-item.d.ts.map +1 -0
- package/menu/menu-item.js +62 -0
- package/menu/menu-item.js.map +1 -0
- package/{table/table-row.styles.d.ts → menu/menu-item.styles.d.ts} +1 -1
- package/menu/menu-item.styles.d.ts.map +1 -0
- package/menu/menu-item.styles.js +37 -0
- package/menu/menu-item.styles.js.map +1 -0
- package/menu/menu.d.ts +55 -0
- package/menu/menu.d.ts.map +1 -0
- package/menu/menu.js +215 -0
- package/menu/menu.js.map +1 -0
- package/{table/table.styles.d.ts → menu/menu.styles.d.ts} +1 -1
- package/menu/menu.styles.d.ts.map +1 -0
- package/menu/menu.styles.js +95 -0
- package/menu/menu.styles.js.map +1 -0
- package/navigation/drawer-item.d.ts +39 -0
- package/navigation/drawer-item.d.ts.map +1 -0
- package/navigation/drawer-item.js +98 -0
- package/navigation/drawer-item.js.map +1 -0
- package/{table/table-body.styles.d.ts → navigation/drawer-item.styles.d.ts} +1 -1
- package/navigation/drawer-item.styles.d.ts.map +1 -0
- package/navigation/drawer-item.styles.js +43 -0
- package/navigation/drawer-item.styles.js.map +1 -0
- package/{table/table-row.d.ts → navigation/drawer.d.ts} +3 -3
- package/navigation/drawer.d.ts.map +1 -0
- package/{table/table-row.js → navigation/drawer.js} +11 -8
- package/navigation/drawer.js.map +1 -0
- package/{table/table-cell.styles.d.ts → navigation/drawer.styles.d.ts} +1 -1
- package/navigation/drawer.styles.d.ts.map +1 -0
- package/navigation/drawer.styles.js +17 -0
- package/navigation/drawer.styles.js.map +1 -0
- package/navigation/side-navigation-swiper.styles.d.ts +2 -0
- package/navigation/side-navigation-swiper.styles.d.ts.map +1 -0
- package/navigation/side-navigation-swiper.styles.js +131 -0
- package/navigation/side-navigation-swiper.styles.js.map +1 -0
- package/navigation/side-navigation.d.ts +32 -0
- package/navigation/side-navigation.d.ts.map +1 -0
- package/navigation/side-navigation.js +154 -0
- package/navigation/side-navigation.js.map +1 -0
- package/navigation/side-navigation.styles.d.ts +2 -0
- package/navigation/side-navigation.styles.d.ts.map +1 -0
- package/navigation/side-navigation.styles.js +124 -0
- package/navigation/side-navigation.styles.js.map +1 -0
- package/package.json +47 -21
- package/scss/_api.scss +2 -0
- package/scss/_common.scss +38 -0
- package/scss/_css-vars.scss +30 -0
- package/scss/_functions.scss +25 -0
- package/scss/_mixins.scss +3 -0
- package/scss/_variables.scss +110 -0
- package/scss/data-table/_data-table.scss +33 -0
- package/scss/data-table/_variables.scss +24 -0
- package/scss/functions/_font.scss +29 -0
- package/scss/mixins/_breakpoints.scss +21 -0
- package/scss/mixins/_colors.scss +6 -0
- package/scss/mixins/_text-bg.scss +33 -0
- package/scss/mixins/_typo.scss +26 -0
- package/scss/text-bg/_text-bg.scss +38 -0
- package/scss/text-bg/_text.scss +73 -0
- package/scss/typo/_font.scss +5 -0
- package/scss/typo/_typo.scss +19 -0
- package/scss/typo/_variables.scss +19 -0
- package/scss/universal-material.scss +7 -0
- package/shared/base.styles.js +1 -1
- package/shared/base.styles.js.map +1 -1
- package/shared/button-wrapper.d.ts +35 -0
- package/shared/button-wrapper.d.ts.map +1 -0
- package/shared/button-wrapper.js +110 -0
- package/shared/button-wrapper.js.map +1 -0
- package/shared/button-wrapper.styles.d.ts +2 -0
- package/shared/button-wrapper.styles.d.ts.map +1 -0
- package/{button/button-base.styles.js → shared/button-wrapper.styles.js} +27 -9
- package/shared/button-wrapper.styles.js.map +1 -0
- package/snackbar/snackbar.d.ts +38 -0
- package/snackbar/snackbar.d.ts.map +1 -0
- package/snackbar/snackbar.js +122 -0
- package/snackbar/snackbar.js.map +1 -0
- package/{table/table-head.styles.d.ts → snackbar/snackbar.styles.d.ts} +1 -1
- package/snackbar/snackbar.styles.d.ts.map +1 -0
- package/snackbar/snackbar.styles.js +81 -0
- package/snackbar/snackbar.styles.js.map +1 -0
- package/theme/css-var-builder.js +1 -1
- package/theme/css-var-builder.js.map +1 -1
- package/theme/index.d.ts +1 -1
- package/theme/index.d.ts.map +1 -1
- package/theme/index.js +1 -1
- package/theme/index.js.map +1 -1
- package/theme/neutral-colors.d.ts +1 -1
- package/theme/neutral-colors.d.ts.map +1 -1
- package/theme/neutral-colors.js +5 -0
- package/theme/neutral-colors.js.map +1 -1
- package/theme/theme-builder.d.ts +2 -3
- package/theme/theme-builder.d.ts.map +1 -1
- package/theme/theme-builder.js +41 -15
- package/theme/theme-builder.js.map +1 -1
- package/theme/theme-color.d.ts +1 -1
- package/theme/theme-color.d.ts.map +1 -1
- package/theme/theme-color.js.map +1 -1
- package/button/button-base.styles.d.ts.map +0 -1
- package/button/button-base.styles.js.map +0 -1
- package/table/table-body.d.ts +0 -11
- package/table/table-body.d.ts.map +0 -1
- package/table/table-body.js +0 -21
- package/table/table-body.js.map +0 -1
- package/table/table-body.styles.d.ts.map +0 -1
- package/table/table-body.styles.js +0 -11
- package/table/table-body.styles.js.map +0 -1
- package/table/table-cell.d.ts +0 -11
- package/table/table-cell.d.ts.map +0 -1
- package/table/table-cell.js +0 -21
- package/table/table-cell.js.map +0 -1
- package/table/table-cell.styles.d.ts.map +0 -1
- package/table/table-cell.styles.js +0 -11
- package/table/table-cell.styles.js.map +0 -1
- package/table/table-head.d.ts +0 -11
- package/table/table-head.d.ts.map +0 -1
- package/table/table-head.js +0 -21
- package/table/table-head.js.map +0 -1
- package/table/table-head.styles.d.ts.map +0 -1
- package/table/table-head.styles.js +0 -11
- package/table/table-head.styles.js.map +0 -1
- package/table/table-header-cell.d.ts +0 -11
- package/table/table-header-cell.d.ts.map +0 -1
- package/table/table-header-cell.js +0 -21
- package/table/table-header-cell.js.map +0 -1
- package/table/table-header-cell.styles.d.ts +0 -2
- package/table/table-header-cell.styles.d.ts.map +0 -1
- package/table/table-header-cell.styles.js +0 -12
- package/table/table-header-cell.styles.js.map +0 -1
- package/table/table-row.d.ts.map +0 -1
- package/table/table-row.js.map +0 -1
- package/table/table-row.styles.d.ts.map +0 -1
- package/table/table-row.styles.js +0 -7
- package/table/table-row.styles.js.map +0 -1
- package/table/table.d.ts +0 -16
- package/table/table.d.ts.map +0 -1
- package/table/table.js +0 -19
- package/table/table.js.map +0 -1
- package/table/table.styles.d.ts.map +0 -1
- package/table/table.styles.js +0 -16
- package/table/table.styles.js.map +0 -1
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
2
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
3
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
4
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
5
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
6
|
+
};
|
|
7
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
+
};
|
|
12
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
13
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
14
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
15
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
16
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
17
|
+
};
|
|
18
|
+
var _UmSideNavigation_toggleDrawer;
|
|
19
|
+
import { html, LitElement } from 'lit';
|
|
20
|
+
import { customElement, property, query } from 'lit/decorators.js';
|
|
21
|
+
import { config } from '../config';
|
|
22
|
+
import { styles as baseStyles } from '../shared/base.styles';
|
|
23
|
+
import { styles as swiperStyles } from './side-navigation-swiper.styles';
|
|
24
|
+
import { styles } from './side-navigation.styles';
|
|
25
|
+
let UmSideNavigation = class UmSideNavigation extends LitElement {
|
|
26
|
+
constructor() {
|
|
27
|
+
super(...arguments);
|
|
28
|
+
_UmSideNavigation_toggleDrawer.set(this, false);
|
|
29
|
+
this.disableSlideAnimation = false;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Toggle the navigation drawer visibility
|
|
33
|
+
*
|
|
34
|
+
* _Modal drawer_: Open if `true`, closed if `false`
|
|
35
|
+
* _Standard drawer_: Collapsed if `true`, visible if `false`
|
|
36
|
+
*/
|
|
37
|
+
get toggleDrawer() { return __classPrivateFieldGet(this, _UmSideNavigation_toggleDrawer, "f"); }
|
|
38
|
+
set toggleDrawer(toggleDrawer) {
|
|
39
|
+
__classPrivateFieldSet(this, _UmSideNavigation_toggleDrawer, toggleDrawer, "f");
|
|
40
|
+
if (!this.disableSlideAnimation) {
|
|
41
|
+
this.swiperContainer?.swiper?.slideTo(toggleDrawer ? 0 : 1);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
render() {
|
|
45
|
+
return config.navigationDrawer.useSwiperJs
|
|
46
|
+
? this.renderWithSwipe()
|
|
47
|
+
: this.renderDefault();
|
|
48
|
+
}
|
|
49
|
+
renderDefault() {
|
|
50
|
+
return html `
|
|
51
|
+
<div class="grid container">
|
|
52
|
+
<div>
|
|
53
|
+
<div class="navigation">
|
|
54
|
+
<div class="scrim ${this.toggleDrawer ? 'toggle' : ''}" @click="${this.scrimClick}"></div>
|
|
55
|
+
<div class="drawer ${this.toggleDrawer ? 'toggle' : ''}">
|
|
56
|
+
<u-elevation></u-elevation>
|
|
57
|
+
<div class="drawer-container">
|
|
58
|
+
<slot name="drawer"></slot>
|
|
59
|
+
</div>
|
|
60
|
+
</div>
|
|
61
|
+
<slot name="rail"></slot>
|
|
62
|
+
</div>
|
|
63
|
+
</div>
|
|
64
|
+
<div class="content">
|
|
65
|
+
<slot></slot>
|
|
66
|
+
</div>
|
|
67
|
+
</div>
|
|
68
|
+
`;
|
|
69
|
+
}
|
|
70
|
+
renderWithSwipe() {
|
|
71
|
+
return html `
|
|
72
|
+
<swiper-container
|
|
73
|
+
class="container"
|
|
74
|
+
initial-slide="1"
|
|
75
|
+
resistance-ratio="0"
|
|
76
|
+
slides-per-view="auto"
|
|
77
|
+
simulate-touch="false"
|
|
78
|
+
@swiperactiveindexchange="${this.swiperActiveIndexChange}"
|
|
79
|
+
@swiperslidermove="${this.swiperSliderMove}"
|
|
80
|
+
@swipertransitionend="${this.swiperTransitionEnd}"
|
|
81
|
+
@swipertransitionstart="${this.swiperTransitionStart}"
|
|
82
|
+
@swiperslidesgridlengthchange="${this.slidesGridLengthChange}">
|
|
83
|
+
<swiper-slide class="drawer ${this.toggleDrawer ? 'toggle' : ''}">
|
|
84
|
+
<u-elevation></u-elevation>
|
|
85
|
+
<div class="drawer-container">
|
|
86
|
+
<slot name="drawer"></slot>
|
|
87
|
+
</div>
|
|
88
|
+
</swiper-slide>
|
|
89
|
+
<swiper-slide class="dummy-slide"></swiper-slide>
|
|
90
|
+
|
|
91
|
+
<div id="scroll-container" class="content" slot="container-end">
|
|
92
|
+
<slot></slot>
|
|
93
|
+
</div>
|
|
94
|
+
<div class="scrim ${this.toggleDrawer ? 'toggle' : ''}" @click="${this.scrimClick}" slot="container-end"></div>
|
|
95
|
+
</swiper-container>`;
|
|
96
|
+
}
|
|
97
|
+
swiperActiveIndexChange() {
|
|
98
|
+
if (!this.swiperContainer?.swiper) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
this.toggleDrawer = !this.swiperContainer.swiper.activeIndex;
|
|
102
|
+
}
|
|
103
|
+
swiperTransitionStart() {
|
|
104
|
+
this.scrim.classList.add('moving');
|
|
105
|
+
}
|
|
106
|
+
slidesGridLengthChange() {
|
|
107
|
+
if (!this.swiperContainer?.swiper) {
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
this.classList.add('disable-transition');
|
|
111
|
+
const gridLength = this.swiperContainer.swiper.snapGrid.length;
|
|
112
|
+
this.swiperContainer.swiper.slideTo(gridLength === 1 ? 0 : 1, 0);
|
|
113
|
+
this.disableSlideAnimation = true;
|
|
114
|
+
this.toggleDrawer = true;
|
|
115
|
+
this.toggleDrawer = false;
|
|
116
|
+
this.disableSlideAnimation = false;
|
|
117
|
+
setTimeout(() => this.classList.remove('disable-transition'));
|
|
118
|
+
}
|
|
119
|
+
swiperTransitionEnd() {
|
|
120
|
+
this.scrim.style.removeProperty('--_modal-drawer-open-progress');
|
|
121
|
+
this.scrim.classList.remove('moving');
|
|
122
|
+
}
|
|
123
|
+
swiperSliderMove(e) {
|
|
124
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
125
|
+
const swiper = e.detail[0];
|
|
126
|
+
this.scrim.style.setProperty('--_modal-drawer-open-progress', `${1 - swiper.progress}`);
|
|
127
|
+
}
|
|
128
|
+
scrimClick() {
|
|
129
|
+
this.toggleDrawer = false;
|
|
130
|
+
this.swiperContainer.swiper.slideTo(1);
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
_UmSideNavigation_toggleDrawer = new WeakMap();
|
|
134
|
+
UmSideNavigation.styles = [
|
|
135
|
+
baseStyles,
|
|
136
|
+
config.navigationDrawer.useSwiperJs ? swiperStyles : styles
|
|
137
|
+
];
|
|
138
|
+
__decorate([
|
|
139
|
+
property({ type: Boolean, attribute: 'toggle-drawer' })
|
|
140
|
+
], UmSideNavigation.prototype, "toggleDrawer", null);
|
|
141
|
+
__decorate([
|
|
142
|
+
query('swiper-container')
|
|
143
|
+
], UmSideNavigation.prototype, "swiperContainer", void 0);
|
|
144
|
+
__decorate([
|
|
145
|
+
query('.scrim')
|
|
146
|
+
], UmSideNavigation.prototype, "scrim", void 0);
|
|
147
|
+
__decorate([
|
|
148
|
+
query('#scroll-container')
|
|
149
|
+
], UmSideNavigation.prototype, "scrollContainer", void 0);
|
|
150
|
+
UmSideNavigation = __decorate([
|
|
151
|
+
customElement('u-side-navigation')
|
|
152
|
+
], UmSideNavigation);
|
|
153
|
+
export { UmSideNavigation };
|
|
154
|
+
//# sourceMappingURL=side-navigation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"side-navigation.js","sourceRoot":"","sources":["../../src/navigation/side-navigation.ts"],"names":[],"mappings":"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","sourcesContent":["import { html, HTMLTemplateResult, LitElement } from 'lit';\nimport { customElement, property, query } from 'lit/decorators.js';\n\nimport { config } from '../config';\nimport { styles as baseStyles } from '../shared/base.styles';\nimport { styles as swiperStyles } from './side-navigation-swiper.styles';\nimport { styles } from './side-navigation.styles';\n\n@customElement('u-side-navigation')\nexport class UmSideNavigation extends LitElement {\n\n static override styles = [\n baseStyles,\n config.navigationDrawer.useSwiperJs ? swiperStyles : styles\n ];\n\n #toggleDrawer = false;\n private disableSlideAnimation = false;\n\n /**\n * Toggle the navigation drawer visibility\n *\n * _Modal drawer_: Open if `true`, closed if `false`\n * _Standard drawer_: Collapsed if `true`, visible if `false`\n */\n @property({type: Boolean, attribute: 'toggle-drawer'})\n get toggleDrawer() { return this.#toggleDrawer; }\n set toggleDrawer(toggleDrawer: boolean) {\n this.#toggleDrawer = toggleDrawer;\n\n if (!this.disableSlideAnimation) {\n this.swiperContainer?.swiper?.slideTo(toggleDrawer ? 0 : 1);\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n @query('swiper-container') swiperContainer!: any;\n @query('.scrim') scrim!: HTMLElement;\n @query('#scroll-container') scrollContainer: HTMLElement | undefined;\n\n override render(): HTMLTemplateResult {\n return config.navigationDrawer.useSwiperJs\n ? this.renderWithSwipe()\n : this.renderDefault();\n }\n\n private renderDefault() {\n return html`\n <div class=\"grid container\">\n <div>\n <div class=\"navigation\">\n <div class=\"scrim ${this.toggleDrawer ? 'toggle' : ''}\" @click=\"${this.scrimClick}\"></div>\n <div class=\"drawer ${this.toggleDrawer ? 'toggle' : ''}\">\n <u-elevation></u-elevation>\n <div class=\"drawer-container\">\n <slot name=\"drawer\"></slot>\n </div>\n </div>\n <slot name=\"rail\"></slot>\n </div>\n </div>\n <div class=\"content\">\n <slot></slot>\n </div>\n </div>\n `;\n }\n\n private renderWithSwipe() {\n return html`\n <swiper-container\n class=\"container\"\n initial-slide=\"1\"\n resistance-ratio=\"0\"\n slides-per-view=\"auto\"\n simulate-touch=\"false\"\n @swiperactiveindexchange=\"${this.swiperActiveIndexChange}\"\n @swiperslidermove=\"${this.swiperSliderMove}\"\n @swipertransitionend=\"${this.swiperTransitionEnd}\"\n @swipertransitionstart=\"${this.swiperTransitionStart}\"\n @swiperslidesgridlengthchange=\"${this.slidesGridLengthChange}\">\n <swiper-slide class=\"drawer ${this.toggleDrawer ? 'toggle' : ''}\">\n <u-elevation></u-elevation>\n <div class=\"drawer-container\">\n <slot name=\"drawer\"></slot>\n </div>\n </swiper-slide>\n <swiper-slide class=\"dummy-slide\"></swiper-slide>\n\n <div id=\"scroll-container\" class=\"content\" slot=\"container-end\">\n <slot></slot>\n </div>\n <div class=\"scrim ${this.toggleDrawer ? 'toggle' : ''}\" @click=\"${this.scrimClick}\" slot=\"container-end\"></div>\n </swiper-container>`;\n }\n\n private swiperActiveIndexChange() {\n\n if (!this.swiperContainer?.swiper) {\n return;\n }\n\n this.toggleDrawer = !this.swiperContainer.swiper.activeIndex;\n }\n\n private swiperTransitionStart() {\n this.scrim.classList.add('moving');\n }\n\n private slidesGridLengthChange() {\n if (!this.swiperContainer?.swiper) {\n return;\n }\n\n this.classList.add('disable-transition');\n\n const gridLength = this.swiperContainer.swiper.snapGrid.length;\n this.swiperContainer.swiper.slideTo(gridLength === 1 ? 0 : 1, 0);\n this.disableSlideAnimation = true;\n this.toggleDrawer = true;\n this.toggleDrawer = false;\n this.disableSlideAnimation = false;\n setTimeout(() =>\n this.classList.remove('disable-transition'));\n }\n\n private swiperTransitionEnd() {\n this.scrim.style.removeProperty('--_modal-drawer-open-progress');\n this.scrim.classList.remove('moving');\n }\n\n private swiperSliderMove(e: Event) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const swiper = (<any>e).detail[0];\n this.scrim.style.setProperty('--_modal-drawer-open-progress', `${1 - swiper.progress}`);\n }\n\n private scrimClick() {\n this.toggleDrawer = false;\n this.swiperContainer.swiper.slideTo(1);\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-side-navigation': UmSideNavigation;\n }\n}\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"side-navigation.styles.d.ts","sourceRoot":"","sources":["../../src/navigation/side-navigation.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBAyHlB,CAAC"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { css } from 'lit';
|
|
2
|
+
export const styles = css `
|
|
3
|
+
:host {
|
|
4
|
+
--_navigation-width: 0;
|
|
5
|
+
--_navigation-drawer-width: min(var(--u-navigation-drawer-width, 360px), 85vw);
|
|
6
|
+
--_navigation-drawer-width-negative: calc(var(--_navigation-drawer-width) * -1);
|
|
7
|
+
--_navigation-drawer-corner-shape: var(--u-navigation-drawer-corner-shape, var(--u-shape-corner-large, 16px));
|
|
8
|
+
--_scrim-opacity: var(--u-drawer-scrim-opacity, .4);
|
|
9
|
+
display: block;
|
|
10
|
+
width: 100%;
|
|
11
|
+
height: 100%;
|
|
12
|
+
--u-app-bar-offset: var(--_navigation-width);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
:host(.disable-transition) * {
|
|
16
|
+
transition: none !important;
|
|
17
|
+
}
|
|
18
|
+
:host(.disable-transition) * ::slotted(u-top-app-bar) {
|
|
19
|
+
transition: none !important;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
.drawer {
|
|
23
|
+
transition: inset 375ms cubic-bezier(0.19, 1, 0.22, 1);
|
|
24
|
+
}
|
|
25
|
+
.drawer,
|
|
26
|
+
.drawer u-elevation,
|
|
27
|
+
.drawer .drawer-container {
|
|
28
|
+
border-start-end-radius: var(--_navigation-drawer-corner-shape);
|
|
29
|
+
border-end-end-radius: var(--_navigation-drawer-corner-shape);
|
|
30
|
+
}
|
|
31
|
+
.drawer.toggle u-elevation {
|
|
32
|
+
--u-elevation-level: 1;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
.drawer-container {
|
|
36
|
+
height: 100%;
|
|
37
|
+
overflow: hidden;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.scrim {
|
|
41
|
+
--_modal-drawer-open-progress: 0;
|
|
42
|
+
position: absolute;
|
|
43
|
+
inset-inline-start: 0;
|
|
44
|
+
inset-block-start: 0;
|
|
45
|
+
width: 100vw;
|
|
46
|
+
height: 100vh;
|
|
47
|
+
background: var(--u-drawer-scrim-color, var(--u-color-scrim, rgb(0, 0, 0)));
|
|
48
|
+
pointer-events: none;
|
|
49
|
+
opacity: calc(var(--_scrim-opacity) * var(--_modal-drawer-open-progress));
|
|
50
|
+
transition: opacity 375ms linear;
|
|
51
|
+
}
|
|
52
|
+
.scrim.moving {
|
|
53
|
+
transition: none;
|
|
54
|
+
}
|
|
55
|
+
.scrim.toggle {
|
|
56
|
+
--_modal-drawer-open-progress: 1;
|
|
57
|
+
pointer-events: auto;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
@media (min-width: 840px) {
|
|
61
|
+
.content slot {
|
|
62
|
+
display: flex;
|
|
63
|
+
flex-direction: column;
|
|
64
|
+
height: 100vh;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
@media (min-width: 1200px) {
|
|
68
|
+
.container {
|
|
69
|
+
--_navigation-width: var(--_navigation-drawer-width);
|
|
70
|
+
}
|
|
71
|
+
.container:has(.drawer.toggle) {
|
|
72
|
+
--_navigation-width: 0;
|
|
73
|
+
}
|
|
74
|
+
.drawer {
|
|
75
|
+
border-radius: 0;
|
|
76
|
+
inset-inline-start: 0;
|
|
77
|
+
}
|
|
78
|
+
.drawer.toggle {
|
|
79
|
+
inset-inline-start: var(--_navigation-drawer-width-negative);
|
|
80
|
+
}
|
|
81
|
+
u-elevation,
|
|
82
|
+
.scrim {
|
|
83
|
+
display: none;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
.navigation {
|
|
87
|
+
position: fixed;
|
|
88
|
+
inset-inline-start: 0;
|
|
89
|
+
inset-block-start: 0;
|
|
90
|
+
height: 100%;
|
|
91
|
+
z-index: var(--u-side-navigation-z-index, 1030);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
.drawer {
|
|
95
|
+
position: absolute;
|
|
96
|
+
inset-inline-start: var(--_navigation-drawer-width-negative);
|
|
97
|
+
inset-block-start: 0;
|
|
98
|
+
width: var(--_navigation-drawer-width);
|
|
99
|
+
height: 100%;
|
|
100
|
+
border-start-end-radius: var(--_navigation-drawer-corner-shape);
|
|
101
|
+
border-end-end-radius: var(--_navigation-drawer-corner-shape);
|
|
102
|
+
overflow: hidden;
|
|
103
|
+
}
|
|
104
|
+
.drawer.toggle {
|
|
105
|
+
inset-inline-start: 0;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
.grid {
|
|
109
|
+
display: grid;
|
|
110
|
+
grid-template-columns: var(--_navigation-width) minmax(0, 1fr);
|
|
111
|
+
transition: 375ms cubic-bezier(0.19, 1, 0.22, 1);
|
|
112
|
+
--u-app-bar-offset: var(--_navigation-width);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
@media (min-width: 1200px) {
|
|
116
|
+
.drawer {
|
|
117
|
+
inset-inline-start: 0;
|
|
118
|
+
}
|
|
119
|
+
.drawer.toggle {
|
|
120
|
+
inset-inline-start: var(--_navigation-drawer-width-negative);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
`;
|
|
124
|
+
//# sourceMappingURL=side-navigation.styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"side-navigation.styles.js","sourceRoot":"","sources":["../../src/navigation/side-navigation.styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAE1B,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyHzB,CAAC","sourcesContent":["import { css } from 'lit';\n\nexport const styles = css `\n :host {\n --_navigation-width: 0;\n --_navigation-drawer-width: min(var(--u-navigation-drawer-width, 360px), 85vw);\n --_navigation-drawer-width-negative: calc(var(--_navigation-drawer-width) * -1);\n --_navigation-drawer-corner-shape: var(--u-navigation-drawer-corner-shape, var(--u-shape-corner-large, 16px));\n --_scrim-opacity: var(--u-drawer-scrim-opacity, .4);\n display: block;\n width: 100%;\n height: 100%;\n --u-app-bar-offset: var(--_navigation-width);\n }\n\n :host(.disable-transition) * {\n transition: none !important;\n }\n :host(.disable-transition) * ::slotted(u-top-app-bar) {\n transition: none !important;\n }\n\n .drawer {\n transition: inset 375ms cubic-bezier(0.19, 1, 0.22, 1);\n }\n .drawer,\n .drawer u-elevation,\n .drawer .drawer-container {\n border-start-end-radius: var(--_navigation-drawer-corner-shape);\n border-end-end-radius: var(--_navigation-drawer-corner-shape);\n }\n .drawer.toggle u-elevation {\n --u-elevation-level: 1;\n }\n\n .drawer-container {\n height: 100%;\n overflow: hidden;\n }\n\n .scrim {\n --_modal-drawer-open-progress: 0;\n position: absolute;\n inset-inline-start: 0;\n inset-block-start: 0;\n width: 100vw;\n height: 100vh;\n background: var(--u-drawer-scrim-color, var(--u-color-scrim, rgb(0, 0, 0)));\n pointer-events: none;\n opacity: calc(var(--_scrim-opacity) * var(--_modal-drawer-open-progress));\n transition: opacity 375ms linear;\n }\n .scrim.moving {\n transition: none;\n }\n .scrim.toggle {\n --_modal-drawer-open-progress: 1;\n pointer-events: auto;\n }\n\n @media (min-width: 840px) {\n .content slot {\n display: flex;\n flex-direction: column;\n height: 100vh;\n }\n }\n @media (min-width: 1200px) {\n .container {\n --_navigation-width: var(--_navigation-drawer-width);\n }\n .container:has(.drawer.toggle) {\n --_navigation-width: 0;\n }\n .drawer {\n border-radius: 0;\n inset-inline-start: 0;\n }\n .drawer.toggle {\n inset-inline-start: var(--_navigation-drawer-width-negative);\n }\n u-elevation,\n .scrim {\n display: none;\n }\n }\n .navigation {\n position: fixed;\n inset-inline-start: 0;\n inset-block-start: 0;\n height: 100%;\n z-index: var(--u-side-navigation-z-index, 1030);\n }\n\n .drawer {\n position: absolute;\n inset-inline-start: var(--_navigation-drawer-width-negative);\n inset-block-start: 0;\n width: var(--_navigation-drawer-width);\n height: 100%;\n border-start-end-radius: var(--_navigation-drawer-corner-shape);\n border-end-end-radius: var(--_navigation-drawer-corner-shape);\n overflow: hidden;\n }\n .drawer.toggle {\n inset-inline-start: 0;\n }\n\n .grid {\n display: grid;\n grid-template-columns: var(--_navigation-width) minmax(0, 1fr);\n transition: 375ms cubic-bezier(0.19, 1, 0.22, 1);\n --u-app-bar-offset: var(--_navigation-width);\n }\n\n @media (min-width: 1200px) {\n .drawer {\n inset-inline-start: 0;\n }\n .drawer.toggle {\n inset-inline-start: var(--_navigation-drawer-width-negative);\n }\n }\n`;\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@universal-material/web",
|
|
3
|
-
"version": "3.0.
|
|
3
|
+
"version": "3.0.21",
|
|
4
4
|
"description": "Material web components",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"keywords": [
|
|
@@ -16,30 +16,31 @@
|
|
|
16
16
|
"module": "./index.js",
|
|
17
17
|
"typings": "./index.d.ts",
|
|
18
18
|
"scripts": {
|
|
19
|
-
"build": "run-s clean
|
|
20
|
-
"build:watch": "
|
|
19
|
+
"build": "run-s clean script:sass-to-ts script:build sass analyze copy",
|
|
20
|
+
"build:watch": "gulp -f gulpfile.js scripts:watch",
|
|
21
21
|
"script:build": "tsc",
|
|
22
|
-
"script:
|
|
23
|
-
"script:
|
|
24
|
-
"sass
|
|
25
|
-
"sass:
|
|
22
|
+
"script:sass-to-ts": "gulp -f gulpfile.js scripts:sass-to-ts",
|
|
23
|
+
"script:sass-to-ts:watch": "gulp -f gulpfile.js scripts:sass-to-ts:watch",
|
|
24
|
+
"sass": "gulp -f gulpfile.js sass",
|
|
25
|
+
"sass:watch": "gulp -f gulpfile.js sass:watch",
|
|
26
26
|
"clean": "rimraf ./dist/ rimraf ./src/**/*.d.ts rimraf ./src/**/*.styles.ts",
|
|
27
|
-
"copy": "copyfiles package.json README.md custom-elements.json dist/",
|
|
27
|
+
"copy": "copyfiles package.json README.md custom-elements.json dist/ && copyfiles -u 1 src/scss/**/*.scss dist/",
|
|
28
28
|
"lint": "npm run lint:lit-analyzer && npm run lint:eslint",
|
|
29
29
|
"lint:eslint": "eslint 'src/**/*.ts'",
|
|
30
30
|
"lint:lit-analyzer": "lit-analyzer",
|
|
31
31
|
"format": "prettier \"**/*.{cjs,html,js,json,md,ts}\" --ignore-path ./.eslintignore --write",
|
|
32
|
-
"
|
|
33
|
-
"docs
|
|
34
|
-
"docs:
|
|
35
|
-
"docs:watch": "
|
|
36
|
-
"docs:
|
|
37
|
-
"docs:
|
|
38
|
-
"docs:
|
|
32
|
+
"predocs": "run-p analyze docs:apis script:sass-to-ts",
|
|
33
|
+
"docs": "run-p script:sass-to-ts:watch docs:serve",
|
|
34
|
+
"docs:apis": "gulp -f gulpfile.js docs:apis",
|
|
35
|
+
"docs:apis:watch": "gulp -f gulpfile.js docs:apis:watch",
|
|
36
|
+
"docs:serve": "cd docs && ng serve --disable-host-check",
|
|
37
|
+
"docs:build": "npm run predocs && cd docs && ng build",
|
|
38
|
+
"docs:watch": "npm run predocs && cd docs && ng build --watch --configuration development",
|
|
39
39
|
"analyze": "cem analyze --litelement --globs \"src/**/*.ts\"",
|
|
40
40
|
"analyze:watch": "cem analyze --litelement --globs \"src/**/*.ts\" --watch",
|
|
41
41
|
"checksize": "rollup -c ; cat my-element.bundled.js | gzip -9 | wc -c ; rm my-element.bundled.js",
|
|
42
|
-
"publish": "cd dist && npm publish"
|
|
42
|
+
"publish": "cd dist && npm publish",
|
|
43
|
+
"postinstall": "node ./change-schematics-to-generate-pug.js && node ./change-compiler-to-add-custom-elements.js"
|
|
43
44
|
},
|
|
44
45
|
"author": "https://github.com/universal-material/universal-material/graphs/contributors",
|
|
45
46
|
"repository": {
|
|
@@ -49,22 +50,39 @@
|
|
|
49
50
|
"license": "MIT",
|
|
50
51
|
"homepage": "https://universal-material.github.io",
|
|
51
52
|
"dependencies": {
|
|
53
|
+
"@angular/animations": "^17.3.4",
|
|
54
|
+
"@angular/common": "^17.3.4",
|
|
55
|
+
"@angular/compiler": "^17.3.4",
|
|
56
|
+
"@angular/core": "^17.3.4",
|
|
57
|
+
"@angular/forms": "^17.3.4",
|
|
58
|
+
"@angular/platform-browser": "^17.3.4",
|
|
59
|
+
"@angular/platform-browser-dynamic": "^17.3.4",
|
|
60
|
+
"@angular/router": "^17.3.4",
|
|
61
|
+
"@material/material-color-utilities": "^0.2.7",
|
|
62
|
+
"highlight.js": "^11.9.0",
|
|
52
63
|
"lit": "^3.0.0",
|
|
53
|
-
"
|
|
64
|
+
"ngx-highlightjs": "^11.0.0-beta.1",
|
|
65
|
+
"ngx-markdown": "^17.2.0",
|
|
66
|
+
"rxjs": "~7.8.0",
|
|
67
|
+
"swiper": "^11.1.1",
|
|
68
|
+
"tslib": "^2.3.0",
|
|
69
|
+
"zone.js": "~0.14.3"
|
|
54
70
|
},
|
|
55
71
|
"devDependencies": {
|
|
56
72
|
"@11ty/eleventy": "^1.0.1",
|
|
57
73
|
"@11ty/eleventy-plugin-syntaxhighlight": "^4.0.0",
|
|
74
|
+
"@angular-devkit/build-angular": "^17.3.4",
|
|
75
|
+
"@angular/cli": "^17.3.4",
|
|
76
|
+
"@angular/compiler-cli": "^17.3.0",
|
|
58
77
|
"@custom-elements-manifest/analyzer": "^0.6.3",
|
|
59
78
|
"@open-wc/testing": "^3.1.5",
|
|
60
79
|
"@rollup/plugin-node-resolve": "^15.2.3",
|
|
61
80
|
"@rollup/plugin-replace": "^5.0.5",
|
|
81
|
+
"@types/mocha": "^10.0.6",
|
|
62
82
|
"@typescript-eslint/eslint-plugin": "^7.5.0",
|
|
63
83
|
"@typescript-eslint/parser": "^7.5.0",
|
|
64
|
-
"@web/
|
|
65
|
-
"@web/
|
|
66
|
-
"@web/test-runner": "^0.15.0",
|
|
67
|
-
"@web/test-runner-playwright": "^0.9.0",
|
|
84
|
+
"@web/test-runner": "^0.18.0",
|
|
85
|
+
"@web/test-runner-playwright": "^0.11.0",
|
|
68
86
|
"@webcomponents/webcomponentsjs": "^2.8.0",
|
|
69
87
|
"copyfiles": "^2.4.1",
|
|
70
88
|
"eslint": "^8.57.0",
|
|
@@ -72,13 +90,21 @@
|
|
|
72
90
|
"eslint-plugin-import-helpers": "^1.3.1",
|
|
73
91
|
"eslint-plugin-unused-imports": "^3.1.0",
|
|
74
92
|
"gulp": "^4.0.2",
|
|
93
|
+
"gulp-changed": "^5.0.2",
|
|
94
|
+
"gulp-newer": "^1.4.0",
|
|
75
95
|
"gulp-notify": "^4.0.0",
|
|
76
96
|
"gulp-pug": "^5.0.0",
|
|
97
|
+
"gulp-rename": "^2.0.0",
|
|
77
98
|
"gulp-sass": "^5.1.0",
|
|
99
|
+
"gulp-sourcemaps": "^3.0.0",
|
|
100
|
+
"gulp-typescript": "^6.0.0-alpha.1",
|
|
78
101
|
"html-entities": "^2.5.2",
|
|
79
102
|
"lit-analyzer": "^1.2.1",
|
|
103
|
+
"ngx-pug-builders": "^17.0.1",
|
|
80
104
|
"npm-run-all": "^4.1.5",
|
|
81
105
|
"prettier": "^2.6.2",
|
|
106
|
+
"pug": "^3.0.2",
|
|
107
|
+
"raw-loader": "^4.0.2",
|
|
82
108
|
"rimraf": "^3.0.2",
|
|
83
109
|
"rollup": "^2.73.0",
|
|
84
110
|
"rollup-plugin-summary": "^2.0.0",
|
package/scss/_api.scss
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
@use "functions";
|
|
2
|
+
|
|
3
|
+
* {
|
|
4
|
+
outline: 0;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
*:focus-visible {
|
|
8
|
+
animation: u-focus-pulse 400ms ease;
|
|
9
|
+
animation-fill-mode: forwards;
|
|
10
|
+
outline-offset: 2px;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
body {
|
|
14
|
+
color: rgba(var(--u-current-text-color-rgb), var(--u-text-opacity));
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
@keyframes u-focus-pulse {
|
|
18
|
+
0% {
|
|
19
|
+
outline: 2px solid var(--u-color-primary);
|
|
20
|
+
}
|
|
21
|
+
50% {
|
|
22
|
+
outline: 4px solid var(--u-color-primary);
|
|
23
|
+
}
|
|
24
|
+
100% {
|
|
25
|
+
outline: 2px solid var(--u-color-primary);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
a {
|
|
30
|
+
border-radius: #{functions.get-spacing-var(extra-small)};
|
|
31
|
+
text-decoration: none;
|
|
32
|
+
|
|
33
|
+
@media (hover: hover) {
|
|
34
|
+
&:hover {
|
|
35
|
+
text-decoration: underline;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
@use "sass:map";
|
|
2
|
+
|
|
3
|
+
@use "variables";
|
|
4
|
+
@use "functions";
|
|
5
|
+
@use "mixins";
|
|
6
|
+
|
|
7
|
+
:root {
|
|
8
|
+
--u-state-layer-color: currentColor;
|
|
9
|
+
--u-hover-state-layer-opacity: .08;
|
|
10
|
+
--u-focus-state-layer-opacity: .12;
|
|
11
|
+
--u-pressed-state-layer-opacity: .12;
|
|
12
|
+
--u-dragged-state-layer-opacity: .16;
|
|
13
|
+
--u-disabled-state-background-opacity: .12;
|
|
14
|
+
--u-disabled-state-label-opacity: .57;
|
|
15
|
+
--u-disabled-state-opacity: .38;
|
|
16
|
+
--u-high-emphasis-opacity: 1;
|
|
17
|
+
--u-low-emphasis-opacity: .75;
|
|
18
|
+
--u-lower-emphasis-opacity: .5;
|
|
19
|
+
--u-color-background: #{functions.get-color-var(surface)};
|
|
20
|
+
--u-color-on-background: #{functions.get-color-var(on-surface)};
|
|
21
|
+
--u-color-background-rgb: #{functions.get-color-rgb-var(surface)};
|
|
22
|
+
--u-color-on-background-rgb: #{functions.get-color-rgb-var(on-surface)};
|
|
23
|
+
|
|
24
|
+
--u-current-text-color-rgb: var(--u-color-on-background-rgb);
|
|
25
|
+
--u-text-opacity: var(--u-high-emphasis-opacity);
|
|
26
|
+
|
|
27
|
+
@each $name, $value in variables.$font-weights {
|
|
28
|
+
--u-font-weight-#{$name}: #{$value};
|
|
29
|
+
}
|
|
30
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
@use "sass:map";
|
|
2
|
+
|
|
3
|
+
@use "variables";
|
|
4
|
+
|
|
5
|
+
@import "functions/font";
|
|
6
|
+
|
|
7
|
+
@function get-color-var($name) {
|
|
8
|
+
@return var(--u-color-#{$name}, map.get(variables.$colors, $name));
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
@function get-color-rgb-var($name) {
|
|
12
|
+
@return var(--u-color-#{$name}-rgb, map.get(variables.$rgb-colors, $name));
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
@function get-shape-corner-var($name) {
|
|
16
|
+
@return var(--u-shape-corner-#{$name}, map.get(variables.$shape-corner, $name));
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
@function get-spacing-var($name) {
|
|
20
|
+
@return var(--u-spacing-#{$name}, map.get(variables.$spacings, $name));
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
@function hexToRgbString($hexColor) {
|
|
24
|
+
@return "#{red($hexColor)},#{green($hexColor)},#{blue($hexColor)}";
|
|
25
|
+
}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
@use "sass:map";
|
|
2
|
+
|
|
3
|
+
$awesome-cubic-bezier: cubic-bezier(.19, 1, .22, 1) !default;
|
|
4
|
+
|
|
5
|
+
$breakpoints: (
|
|
6
|
+
xs: 0,
|
|
7
|
+
sm: 600px,
|
|
8
|
+
md: 840px,
|
|
9
|
+
lg: 1200px,
|
|
10
|
+
xl: 1600px
|
|
11
|
+
);
|
|
12
|
+
|
|
13
|
+
$theme-colors: (
|
|
14
|
+
primary,
|
|
15
|
+
secondary,
|
|
16
|
+
tertiary
|
|
17
|
+
);
|
|
18
|
+
|
|
19
|
+
$color-roles: (
|
|
20
|
+
primary,
|
|
21
|
+
primary-container,
|
|
22
|
+
secondary,
|
|
23
|
+
secondary-container,
|
|
24
|
+
tertiary,
|
|
25
|
+
tertiary-container,
|
|
26
|
+
error,
|
|
27
|
+
error-container,
|
|
28
|
+
surface,
|
|
29
|
+
surface-variant,
|
|
30
|
+
surface-container,
|
|
31
|
+
surface-container-highest,
|
|
32
|
+
surface-container-high,
|
|
33
|
+
surface-container-low,
|
|
34
|
+
surface-container-lowest
|
|
35
|
+
);
|
|
36
|
+
|
|
37
|
+
$rgb-colors: (
|
|
38
|
+
primary: unquote("103, 80, 164"),
|
|
39
|
+
on-primary: unquote("255, 255, 255"),
|
|
40
|
+
primary-container: unquote("234, 221, 255"),
|
|
41
|
+
on-primary-container: unquote("33, 0, 93"),
|
|
42
|
+
secondary: unquote("98, 91, 113"),
|
|
43
|
+
secondary-container: unquote("232, 222, 248"),
|
|
44
|
+
on-secondary-container: unquote("29, 25, 43"),
|
|
45
|
+
on-secondary: unquote("255, 255, 255"),
|
|
46
|
+
tertiary: unquote("125, 82, 96"),
|
|
47
|
+
on-tertiary: unquote("255, 255, 255"),
|
|
48
|
+
tertiary-container: unquote("255, 216, 228"),
|
|
49
|
+
on-tertiary-container: unquote("49, 17, 29"),
|
|
50
|
+
error: unquote("179, 38, 30"),
|
|
51
|
+
on-error: unquote("255, 255, 255"),
|
|
52
|
+
error-container: unquote("249, 222, 220"),
|
|
53
|
+
on-error-container: unquote("65, 14, 11"),
|
|
54
|
+
surface: unquote("254, 247, 255"),
|
|
55
|
+
on-surface: unquote("29, 27, 32"),
|
|
56
|
+
surface-variant: unquote("231, 224, 236"),
|
|
57
|
+
on-surface-variant: unquote("73, 69, 79"),
|
|
58
|
+
surface-container-highest: unquote("230, 224, 233"),
|
|
59
|
+
surface-container-high: unquote("236, 230, 240"),
|
|
60
|
+
surface-container: unquote("243, 237, 247"),
|
|
61
|
+
surface-container-low: unquote("247, 242, 250"),
|
|
62
|
+
surface-container-lowest: unquote("255, 255, 255"),
|
|
63
|
+
inverse-surface: unquote("50, 47, 53"),
|
|
64
|
+
on-inverse-surface: unquote("245, 239, 247"),
|
|
65
|
+
outline: unquote("121, 116, 126"),
|
|
66
|
+
outline-variant: unquote("202, 196, 208"),
|
|
67
|
+
scrim: unquote("0, 0, 0"),
|
|
68
|
+
shadow: unquote("0, 0, 0")
|
|
69
|
+
);
|
|
70
|
+
|
|
71
|
+
$colors: ();
|
|
72
|
+
|
|
73
|
+
@each $name, $value in $rgb-colors {
|
|
74
|
+
$colors: map.set($colors, $name, unquote("rgb(#{$value})"));
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
$fixed-colors: (
|
|
78
|
+
success,
|
|
79
|
+
info,
|
|
80
|
+
warning
|
|
81
|
+
);
|
|
82
|
+
|
|
83
|
+
$spacings: (
|
|
84
|
+
extra-small: 4px,
|
|
85
|
+
small: 8px,
|
|
86
|
+
medium: 16px,
|
|
87
|
+
large: 24px,
|
|
88
|
+
extra-large: 40px,
|
|
89
|
+
);
|
|
90
|
+
|
|
91
|
+
$font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" !default;
|
|
92
|
+
|
|
93
|
+
$font-weights: (
|
|
94
|
+
thin: 100,
|
|
95
|
+
light: 300,
|
|
96
|
+
regular: 400,
|
|
97
|
+
medium: 500,
|
|
98
|
+
bold: 700,
|
|
99
|
+
bolder: 900,
|
|
100
|
+
);
|
|
101
|
+
|
|
102
|
+
$shape-corner: (
|
|
103
|
+
none: 0,
|
|
104
|
+
extra-small: 4px,
|
|
105
|
+
small: 8px,
|
|
106
|
+
medium: 12px,
|
|
107
|
+
large: 16px,
|
|
108
|
+
extra-large: 28px,
|
|
109
|
+
full: 9999px
|
|
110
|
+
);
|