@universal-material/web 3.0.19 → 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.
Files changed (202) hide show
  1. package/app-bar/top-app-bar.d.ts +42 -0
  2. package/app-bar/top-app-bar.d.ts.map +1 -0
  3. package/app-bar/top-app-bar.js +139 -0
  4. package/app-bar/top-app-bar.js.map +1 -0
  5. package/{button/button-base.styles.d.ts → app-bar/top-app-bar.styles.d.ts} +1 -1
  6. package/app-bar/top-app-bar.styles.d.ts.map +1 -0
  7. package/app-bar/top-app-bar.styles.js +87 -0
  8. package/app-bar/top-app-bar.styles.js.map +1 -0
  9. package/button/button-base.d.ts +2 -30
  10. package/button/button-base.d.ts.map +1 -1
  11. package/button/button-base.js +4 -94
  12. package/button/button-base.js.map +1 -1
  13. package/button/button.d.ts +1 -1
  14. package/button/button.d.ts.map +1 -1
  15. package/button/button.js +9 -7
  16. package/button/button.js.map +1 -1
  17. package/button/button.styles.d.ts.map +1 -1
  18. package/button/button.styles.js +14 -10
  19. package/button/button.styles.js.map +1 -1
  20. package/button/fab.d.ts.map +1 -1
  21. package/button/fab.js +2 -2
  22. package/button/fab.js.map +1 -1
  23. package/button/icon-button.d.ts +2 -2
  24. package/button/icon-button.d.ts.map +1 -1
  25. package/button/icon-button.js +5 -4
  26. package/button/icon-button.js.map +1 -1
  27. package/button/icon-button.styles.js +8 -8
  28. package/button/icon-button.styles.js.map +1 -1
  29. package/card/card.d.ts +3 -3
  30. package/card/card.d.ts.map +1 -1
  31. package/card/card.js +4 -4
  32. package/card/card.js.map +1 -1
  33. package/checkbox/checkbox.d.ts.map +1 -1
  34. package/checkbox/checkbox.js +0 -1
  35. package/checkbox/checkbox.js.map +1 -1
  36. package/config.d.ts +6 -0
  37. package/config.d.ts.map +1 -0
  38. package/config.js +7 -0
  39. package/config.js.map +1 -0
  40. package/container/container.d.ts +1 -1
  41. package/container/container.d.ts.map +1 -1
  42. package/container/container.js +4 -4
  43. package/container/container.js.map +1 -1
  44. package/container/grid-base.styles.js +4 -4
  45. package/container/grid-base.styles.js.map +1 -1
  46. package/container/grid.d.ts +2 -2
  47. package/container/grid.d.ts.map +1 -1
  48. package/container/grid.js +4 -4
  49. package/container/grid.js.map +1 -1
  50. package/css/universal-material.css +1333 -0
  51. package/css/universal-material.min.css +2 -0
  52. package/custom-elements.json +2772 -814
  53. package/elevation/elevation.d.ts +1 -1
  54. package/elevation/elevation.d.ts.map +1 -1
  55. package/elevation/elevation.js +2 -2
  56. package/elevation/elevation.js.map +1 -1
  57. package/index.d.ts +41 -29
  58. package/index.d.ts.map +1 -1
  59. package/index.js +41 -29
  60. package/index.js.map +1 -1
  61. package/menu/menu-item.d.ts +26 -0
  62. package/menu/menu-item.d.ts.map +1 -0
  63. package/menu/menu-item.js +62 -0
  64. package/menu/menu-item.js.map +1 -0
  65. package/{table/table-row.styles.d.ts → menu/menu-item.styles.d.ts} +1 -1
  66. package/menu/menu-item.styles.d.ts.map +1 -0
  67. package/menu/menu-item.styles.js +37 -0
  68. package/menu/menu-item.styles.js.map +1 -0
  69. package/menu/menu.d.ts +55 -0
  70. package/menu/menu.d.ts.map +1 -0
  71. package/menu/menu.js +215 -0
  72. package/menu/menu.js.map +1 -0
  73. package/{table/table.styles.d.ts → menu/menu.styles.d.ts} +1 -1
  74. package/menu/menu.styles.d.ts.map +1 -0
  75. package/menu/menu.styles.js +95 -0
  76. package/menu/menu.styles.js.map +1 -0
  77. package/navigation/drawer-item.d.ts +39 -0
  78. package/navigation/drawer-item.d.ts.map +1 -0
  79. package/navigation/drawer-item.js +98 -0
  80. package/navigation/drawer-item.js.map +1 -0
  81. package/{table/table-body.styles.d.ts → navigation/drawer-item.styles.d.ts} +1 -1
  82. package/navigation/drawer-item.styles.d.ts.map +1 -0
  83. package/navigation/drawer-item.styles.js +43 -0
  84. package/navigation/drawer-item.styles.js.map +1 -0
  85. package/{table/table-row.d.ts → navigation/drawer.d.ts} +3 -3
  86. package/navigation/drawer.d.ts.map +1 -0
  87. package/{table/table-row.js → navigation/drawer.js} +11 -8
  88. package/navigation/drawer.js.map +1 -0
  89. package/{table/table-cell.styles.d.ts → navigation/drawer.styles.d.ts} +1 -1
  90. package/navigation/drawer.styles.d.ts.map +1 -0
  91. package/navigation/drawer.styles.js +17 -0
  92. package/navigation/drawer.styles.js.map +1 -0
  93. package/navigation/side-navigation-swiper.styles.d.ts +2 -0
  94. package/navigation/side-navigation-swiper.styles.d.ts.map +1 -0
  95. package/navigation/side-navigation-swiper.styles.js +131 -0
  96. package/navigation/side-navigation-swiper.styles.js.map +1 -0
  97. package/navigation/side-navigation.d.ts +32 -0
  98. package/navigation/side-navigation.d.ts.map +1 -0
  99. package/navigation/side-navigation.js +154 -0
  100. package/navigation/side-navigation.js.map +1 -0
  101. package/navigation/side-navigation.styles.d.ts +2 -0
  102. package/navigation/side-navigation.styles.d.ts.map +1 -0
  103. package/navigation/side-navigation.styles.js +124 -0
  104. package/navigation/side-navigation.styles.js.map +1 -0
  105. package/package.json +47 -21
  106. package/scss/_api.scss +2 -0
  107. package/scss/_common.scss +38 -0
  108. package/scss/_css-vars.scss +30 -0
  109. package/scss/_functions.scss +25 -0
  110. package/scss/_mixins.scss +3 -0
  111. package/scss/_variables.scss +110 -0
  112. package/scss/data-table/_data-table.scss +33 -0
  113. package/scss/data-table/_variables.scss +24 -0
  114. package/scss/functions/_font.scss +29 -0
  115. package/scss/mixins/_breakpoints.scss +21 -0
  116. package/scss/mixins/_colors.scss +6 -0
  117. package/scss/mixins/_text-bg.scss +33 -0
  118. package/scss/mixins/_typo.scss +26 -0
  119. package/scss/text-bg/_text-bg.scss +38 -0
  120. package/scss/text-bg/_text.scss +73 -0
  121. package/scss/typo/_font.scss +5 -0
  122. package/scss/typo/_typo.scss +19 -0
  123. package/scss/typo/_variables.scss +19 -0
  124. package/scss/universal-material.scss +7 -0
  125. package/shared/base.styles.js +1 -1
  126. package/shared/base.styles.js.map +1 -1
  127. package/shared/button-wrapper.d.ts +35 -0
  128. package/shared/button-wrapper.d.ts.map +1 -0
  129. package/shared/button-wrapper.js +110 -0
  130. package/shared/button-wrapper.js.map +1 -0
  131. package/shared/button-wrapper.styles.d.ts +2 -0
  132. package/shared/button-wrapper.styles.d.ts.map +1 -0
  133. package/{button/button-base.styles.js → shared/button-wrapper.styles.js} +27 -9
  134. package/shared/button-wrapper.styles.js.map +1 -0
  135. package/snackbar/snackbar.d.ts +38 -0
  136. package/snackbar/snackbar.d.ts.map +1 -0
  137. package/snackbar/snackbar.js +122 -0
  138. package/snackbar/snackbar.js.map +1 -0
  139. package/{table/table-head.styles.d.ts → snackbar/snackbar.styles.d.ts} +1 -1
  140. package/snackbar/snackbar.styles.d.ts.map +1 -0
  141. package/snackbar/snackbar.styles.js +81 -0
  142. package/snackbar/snackbar.styles.js.map +1 -0
  143. package/theme/css-var-builder.js +1 -1
  144. package/theme/css-var-builder.js.map +1 -1
  145. package/theme/index.d.ts +1 -1
  146. package/theme/index.d.ts.map +1 -1
  147. package/theme/index.js +1 -1
  148. package/theme/index.js.map +1 -1
  149. package/theme/neutral-colors.d.ts +1 -1
  150. package/theme/neutral-colors.d.ts.map +1 -1
  151. package/theme/neutral-colors.js +5 -0
  152. package/theme/neutral-colors.js.map +1 -1
  153. package/theme/theme-builder.d.ts +2 -3
  154. package/theme/theme-builder.d.ts.map +1 -1
  155. package/theme/theme-builder.js +41 -15
  156. package/theme/theme-builder.js.map +1 -1
  157. package/theme/theme-color.d.ts +1 -1
  158. package/theme/theme-color.d.ts.map +1 -1
  159. package/theme/theme-color.js.map +1 -1
  160. package/button/button-base.styles.d.ts.map +0 -1
  161. package/button/button-base.styles.js.map +0 -1
  162. package/table/table-body.d.ts +0 -11
  163. package/table/table-body.d.ts.map +0 -1
  164. package/table/table-body.js +0 -21
  165. package/table/table-body.js.map +0 -1
  166. package/table/table-body.styles.d.ts.map +0 -1
  167. package/table/table-body.styles.js +0 -11
  168. package/table/table-body.styles.js.map +0 -1
  169. package/table/table-cell.d.ts +0 -11
  170. package/table/table-cell.d.ts.map +0 -1
  171. package/table/table-cell.js +0 -21
  172. package/table/table-cell.js.map +0 -1
  173. package/table/table-cell.styles.d.ts.map +0 -1
  174. package/table/table-cell.styles.js +0 -11
  175. package/table/table-cell.styles.js.map +0 -1
  176. package/table/table-head.d.ts +0 -11
  177. package/table/table-head.d.ts.map +0 -1
  178. package/table/table-head.js +0 -21
  179. package/table/table-head.js.map +0 -1
  180. package/table/table-head.styles.d.ts.map +0 -1
  181. package/table/table-head.styles.js +0 -11
  182. package/table/table-head.styles.js.map +0 -1
  183. package/table/table-header-cell.d.ts +0 -11
  184. package/table/table-header-cell.d.ts.map +0 -1
  185. package/table/table-header-cell.js +0 -21
  186. package/table/table-header-cell.js.map +0 -1
  187. package/table/table-header-cell.styles.d.ts +0 -2
  188. package/table/table-header-cell.styles.d.ts.map +0 -1
  189. package/table/table-header-cell.styles.js +0 -12
  190. package/table/table-header-cell.styles.js.map +0 -1
  191. package/table/table-row.d.ts.map +0 -1
  192. package/table/table-row.js.map +0 -1
  193. package/table/table-row.styles.d.ts.map +0 -1
  194. package/table/table-row.styles.js +0 -7
  195. package/table/table-row.styles.js.map +0 -1
  196. package/table/table.d.ts +0 -16
  197. package/table/table.d.ts.map +0 -1
  198. package/table/table.js +0 -19
  199. package/table/table.js.map +0 -1
  200. package/table/table.styles.d.ts.map +0 -1
  201. package/table/table.styles.js +0 -16
  202. 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,2 @@
1
+ export declare const styles: import("lit").CSSResult;
2
+ //# sourceMappingURL=side-navigation.styles.d.ts.map
@@ -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.19",
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 sass:sass-to-ts script:build analyze copy",
20
- "build:watch": "npm-run-all clean sass:sass-to-ts --parallel sass:sass-to-ts:watch script: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:build:watch": "tsc --watch",
23
- "script:build:prod": "npm run clean && npm run script:build && npm run copy",
24
- "sass:sass-to-ts": "gulp -f gulpfile.js sass:sass-to-ts",
25
- "sass:sass-to-ts:watch": "gulp -f gulpfile.js sass:sass-to-ts:watch",
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
- "docs": "npm run docs:clean && npm run build && npm run analyze && npm run docs:build",
33
- "docs:clean": "rimraf ./docs/dist/",
34
- "docs:build": "gulp -f gulpfile.js docs",
35
- "docs:watch": "run-p docs:gulp:watch docs:serve",
36
- "docs:bundle": "gulp -f gulpfile.js docs:bundle",
37
- "docs:gulp:watch": "gulp -f gulpfile.js docs:watch",
38
- "docs:serve": "wds --root-dir=docs/dist --node-resolve --watch",
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
- "@material/material-color-utilities": "^0.2.7"
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/dev-server": "^0.1.31",
65
- "@web/dev-server-legacy": "^1.0.0",
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,2 @@
1
+ @import "mixins";
2
+ @import "functions";
@@ -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,3 @@
1
+ @import "mixins/breakpoints";
2
+ @import "mixins/colors";
3
+ @import "mixins/typo";
@@ -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
+ );