@universal-material/web 3.0.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.
Files changed (57) hide show
  1. package/all.d.ts +9 -0
  2. package/all.d.ts.map +1 -0
  3. package/all.js +9 -0
  4. package/all.js.map +1 -0
  5. package/button/button-base.d.ts +37 -0
  6. package/button/button-base.d.ts.map +1 -0
  7. package/button/button-base.js +199 -0
  8. package/button/button-base.js.map +1 -0
  9. package/button/button-set.d.ts +11 -0
  10. package/button/button-set.d.ts.map +1 -0
  11. package/button/button-set.js +27 -0
  12. package/button/button-set.js.map +1 -0
  13. package/button/button.d.ts +18 -0
  14. package/button/button.d.ts.map +1 -0
  15. package/button/button.js +137 -0
  16. package/button/button.js.map +1 -0
  17. package/button/fab.d.ts +17 -0
  18. package/button/fab.d.ts.map +1 -0
  19. package/button/fab.js +144 -0
  20. package/button/fab.js.map +1 -0
  21. package/button/icon-button.d.ts +35 -0
  22. package/button/icon-button.d.ts.map +1 -0
  23. package/button/icon-button.js +153 -0
  24. package/button/icon-button.js.map +1 -0
  25. package/card/button-set.d.ts +11 -0
  26. package/card/button-set.d.ts.map +1 -0
  27. package/card/button-set.js +26 -0
  28. package/card/button-set.js.map +1 -0
  29. package/card/card-content.d.ts +11 -0
  30. package/card/card-content.d.ts.map +1 -0
  31. package/card/card-content.js +24 -0
  32. package/card/card-content.js.map +1 -0
  33. package/card/card-media.d.ts +12 -0
  34. package/card/card-media.d.ts.map +1 -0
  35. package/card/card-media.js +37 -0
  36. package/card/card-media.js.map +1 -0
  37. package/card/card.d.ts +15 -0
  38. package/card/card.d.ts.map +1 -0
  39. package/card/card.js +52 -0
  40. package/card/card.js.map +1 -0
  41. package/divider/divider.d.ts +11 -0
  42. package/divider/divider.d.ts.map +1 -0
  43. package/divider/divider.js +35 -0
  44. package/divider/divider.js.map +1 -0
  45. package/elevation/elevation.d.ts +10 -0
  46. package/elevation/elevation.d.ts.map +1 -0
  47. package/elevation/elevation.js +47 -0
  48. package/elevation/elevation.js.map +1 -0
  49. package/package.json +82 -0
  50. package/ripple/ripple.d.ts +19 -0
  51. package/ripple/ripple.d.ts.map +1 -0
  52. package/ripple/ripple.js +173 -0
  53. package/ripple/ripple.js.map +1 -0
  54. package/shared/area-hidden-element.d.ts +5 -0
  55. package/shared/area-hidden-element.d.ts.map +1 -0
  56. package/shared/area-hidden-element.js +10 -0
  57. package/shared/area-hidden-element.js.map +1 -0
@@ -0,0 +1,35 @@
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
+ import { css, LitElement } from 'lit';
8
+ import { customElement, property } from 'lit/decorators.js';
9
+ let Divider = class Divider extends LitElement {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.noMargin = false;
13
+ }
14
+ };
15
+ Divider.styles = css `
16
+ :host {
17
+ --_divider-thickness: var(--u-divider-thickness, 1px);
18
+ display: block;
19
+ margin-block: 8px;
20
+ height: var(--_divider-thickness);
21
+ background-color: var(--u-divider-color, var(--u-outline-variant-color, #cac4d0));
22
+ }
23
+
24
+ :host([no-margin]) {
25
+ margin: 0;
26
+ }
27
+ `;
28
+ __decorate([
29
+ property({ type: Boolean, attribute: 'no-margin', reflect: true })
30
+ ], Divider.prototype, "noMargin", void 0);
31
+ Divider = __decorate([
32
+ customElement('u-divider')
33
+ ], Divider);
34
+ export { Divider };
35
+ //# sourceMappingURL=divider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"divider.js","sourceRoot":"","sources":["../../src/divider/divider.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAC,GAAG,EAAE,UAAU,EAAC,MAAM,KAAK,CAAC;AACpC,OAAO,EAAC,aAAa,EAAE,QAAQ,EAAC,MAAM,mBAAmB,CAAC;AAGnD,IAAM,OAAO,GAAb,MAAM,OAAQ,SAAQ,UAAU;IAAhC;;QAgB6D,aAAQ,GAAG,KAAK,CAAC;IACrF,CAAC;;AAfiB,cAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;GAY3B,AAZqB,CAYpB;AAEgE;IAAjE,QAAQ,CAAC,EAAC,IAAI,EAAE,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,OAAO,EAAE,IAAI,EAAC,CAAC;yCAAkB;AAhBxE,OAAO;IADnB,aAAa,CAAC,WAAW,CAAC;GACd,OAAO,CAiBnB","sourcesContent":["import {css, LitElement} from 'lit';\nimport {customElement, property} from 'lit/decorators.js';\n\n@customElement('u-divider')\nexport class Divider extends LitElement {\n\n static override styles = css`\n :host {\n --_divider-thickness: var(--u-divider-thickness, 1px);\n display: block;\n margin-block: 8px;\n height: var(--_divider-thickness);\n background-color: var(--u-divider-color, var(--u-outline-variant-color, #cac4d0));\n }\n \n :host([no-margin]) {\n margin: 0;\n }\n `;\n\n @property({type: Boolean, attribute: 'no-margin', reflect: true}) noMargin = false;\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-divider': Divider;\n }\n}\n"]}
@@ -0,0 +1,10 @@
1
+ import { AreaHiddenElement } from '../shared/area-hidden-element';
2
+ export declare class Elevation extends AreaHiddenElement {
3
+ static styles: import("lit").CSSResult;
4
+ }
5
+ declare global {
6
+ interface HTMLElementTagNameMap {
7
+ 'u-elevation': Elevation;
8
+ }
9
+ }
10
+ //# sourceMappingURL=elevation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"elevation.d.ts","sourceRoot":"","sources":["../../src/elevation/elevation.ts"],"names":[],"mappings":"AAGA,OAAO,EAAC,iBAAiB,EAAC,MAAM,+BAA+B,CAAC;AAEhE,qBACa,SAAU,SAAQ,iBAAiB;IAC9C,OAAgB,MAAM,0BA8BpB;CACH;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,aAAa,EAAE,SAAS,CAAC;KAC1B;CACF"}
@@ -0,0 +1,47 @@
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
+ import { css } from 'lit';
8
+ import { customElement } from 'lit/decorators.js';
9
+ import { AreaHiddenElement } from '../shared/area-hidden-element';
10
+ let Elevation = class Elevation extends AreaHiddenElement {
11
+ };
12
+ Elevation.styles = css `
13
+ :host {
14
+ --_level: var(--u-elevation-level, 0);
15
+ --_shadow-color: var(--u-shadow-color, #000);
16
+
17
+ -webkit-tap-highlight-color: transparent;
18
+ position: absolute;
19
+ inset: 0;
20
+ border-radius: inherit;
21
+ pointer-events: none;
22
+ }
23
+
24
+ :host::before,
25
+ :host::after {
26
+ content: '';
27
+ position: absolute;
28
+ inset: 0;
29
+ border-radius: inherit;
30
+ transition: box-shadow 150ms ease-in-out;
31
+ }
32
+
33
+ :host::before {
34
+ box-shadow: 0 calc(1px*(clamp(0,var(--_level),1) + clamp(0,var(--_level) - 3,1) + 2*clamp(0,var(--_level) - 4,1))) calc(1px*(2*clamp(0,var(--_level),1) + clamp(0,var(--_level) - 2,1) + clamp(0,var(--_level) - 4,1))) 0 var(--_shadow-color);
35
+ opacity: .3;
36
+ }
37
+
38
+ :host::after {
39
+ box-shadow: 0 calc(1px*(clamp(0,var(--_level),1) + clamp(0,var(--_level) - 1,1) + 2*clamp(0,var(--_level) - 2,3))) calc(1px*(3*clamp(0,var(--_level),2) + 2*clamp(0,var(--_level) - 2,3))) calc(1px*(clamp(0,var(--_level),4) + 2*clamp(0,var(--_level) - 4,1))) var(--_shadow-color);
40
+ opacity: .15;
41
+ }
42
+ `;
43
+ Elevation = __decorate([
44
+ customElement('u-elevation')
45
+ ], Elevation);
46
+ export { Elevation };
47
+ //# sourceMappingURL=elevation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"elevation.js","sourceRoot":"","sources":["../../src/elevation/elevation.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAC;AACxB,OAAO,EAAC,aAAa,EAAC,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAC,iBAAiB,EAAC,MAAM,+BAA+B,CAAC;AAGzD,IAAM,SAAS,GAAf,MAAM,SAAU,SAAQ,iBAAiB;;AAC9B,gBAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8B3B,AA9BqB,CA8BpB;AA/BS,SAAS;IADrB,aAAa,CAAC,aAAa,CAAC;GAChB,SAAS,CAgCrB","sourcesContent":["import {css} from 'lit';\nimport {customElement} from 'lit/decorators.js';\n\nimport {AreaHiddenElement} from '../shared/area-hidden-element';\n\n@customElement('u-elevation')\nexport class Elevation extends AreaHiddenElement {\n static override styles = css`\n :host {\n --_level: var(--u-elevation-level, 0);\n --_shadow-color: var(--u-shadow-color, #000);\n\n -webkit-tap-highlight-color: transparent;\n position: absolute;\n inset: 0;\n border-radius: inherit;\n pointer-events: none;\n }\n\n :host::before,\n :host::after {\n content: '';\n position: absolute;\n inset: 0;\n border-radius: inherit;\n transition: box-shadow 150ms ease-in-out;\n }\n \n :host::before {\n box-shadow: 0 calc(1px*(clamp(0,var(--_level),1) + clamp(0,var(--_level) - 3,1) + 2*clamp(0,var(--_level) - 4,1))) calc(1px*(2*clamp(0,var(--_level),1) + clamp(0,var(--_level) - 2,1) + clamp(0,var(--_level) - 4,1))) 0 var(--_shadow-color);\n opacity: .3;\n }\n \n :host::after {\n box-shadow: 0 calc(1px*(clamp(0,var(--_level),1) + clamp(0,var(--_level) - 1,1) + 2*clamp(0,var(--_level) - 2,3))) calc(1px*(3*clamp(0,var(--_level),2) + 2*clamp(0,var(--_level) - 2,3))) calc(1px*(clamp(0,var(--_level),4) + 2*clamp(0,var(--_level) - 4,1))) var(--_shadow-color);\n opacity: .15;\n }\n `;\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-elevation': Elevation;\n }\n}\n"]}
package/package.json ADDED
@@ -0,0 +1,82 @@
1
+ {
2
+ "name": "@universal-material/web",
3
+ "version": "3.0.0",
4
+ "description": "Material web components",
5
+ "type": "module",
6
+ "keywords": [
7
+ "material",
8
+ "material design",
9
+ "design system",
10
+ "components",
11
+ "web-components",
12
+ "lit-element",
13
+ "typescript",
14
+ "lit"
15
+ ],
16
+ "scripts": {
17
+ "build": "tsc",
18
+ "build:watch": "tsc --watch",
19
+ "clean": "rimraf my-element.{d.ts,d.ts.map,js,js.map} test/my-element.{d.ts,d.ts.map,js,js.map} test/my-element_test.{d.ts,d.ts.map,js,js.map}",
20
+ "lint": "npm run lint:lit-analyzer && npm run lint:eslint",
21
+ "lint:eslint": "eslint 'src/**/*.ts'",
22
+ "lint:lit-analyzer": "lit-analyzer",
23
+ "format": "prettier \"**/*.{cjs,html,js,json,md,ts}\" --ignore-path ./.eslintignore --write",
24
+ "docs": "npm run docs:clean && npm run build && npm run analyze && npm run docs:build && npm run docs:assets && npm run docs:gen",
25
+ "docs:clean": "rimraf docs",
26
+ "docs:gen": "eleventy --config=.eleventy.cjs",
27
+ "docs:gen:watch": "eleventy --config=.eleventy.cjs --watch",
28
+ "docs:build": "rollup -c --file docs/my-element.bundled.js",
29
+ "docs:assets": "cp node_modules/prismjs/themes/prism-okaidia.css docs/",
30
+ "docs:watch": "run-p docs:gulp docs:serve",
31
+ "docs:gulp": "gulp -f gulpfile.cjs docs",
32
+ "docs:serve": "wds --root-dir=docs/dist --node-resolve --watch",
33
+ "analyze": "cem analyze --litelement --globs \"src/**/*.ts\"",
34
+ "analyze:watch": "cem analyze --litelement --globs \"src/**/*.ts\" --watch",
35
+ "serve": "wds --watch",
36
+ "serve:prod": "MODE=prod npm run serve",
37
+ "test": "npm run test:dev && npm run test:prod",
38
+ "test:dev": "wtr",
39
+ "test:watch": "wtr --watch",
40
+ "test:prod": "MODE=prod wtr",
41
+ "test:prod:watch": "MODE=prod wtr --watch",
42
+ "checksize": "rollup -c ; cat my-element.bundled.js | gzip -9 | wc -c ; rm my-element.bundled.js"
43
+ },
44
+ "author": "https://github.com/universal-material/universal-material/graphs/contributors",
45
+ "repository": {
46
+ "type": "git",
47
+ "url": "git+https://github.com/universal-material/universal-material-web.git"
48
+ },
49
+ "license": "MIT",
50
+ "homepage": "https://universal-material.github.io",
51
+ "dependencies": {
52
+ "lit": "^3.0.0"
53
+ },
54
+ "devDependencies": {
55
+ "@11ty/eleventy": "^1.0.1",
56
+ "@11ty/eleventy-plugin-syntaxhighlight": "^4.0.0",
57
+ "@custom-elements-manifest/analyzer": "^0.6.3",
58
+ "@open-wc/testing": "^3.1.5",
59
+ "@rollup/plugin-node-resolve": "^13.3.0",
60
+ "@rollup/plugin-replace": "^5.0.2",
61
+ "@typescript-eslint/eslint-plugin": "^5.25.0",
62
+ "@typescript-eslint/parser": "^5.25.0",
63
+ "@web/dev-server": "^0.1.31",
64
+ "@web/dev-server-legacy": "^1.0.0",
65
+ "@web/test-runner": "^0.15.0",
66
+ "@web/test-runner-playwright": "^0.9.0",
67
+ "@webcomponents/webcomponentsjs": "^2.8.0",
68
+ "eslint": "^8.15.0",
69
+ "gulp": "^4.0.2",
70
+ "gulp-notify": "^4.0.0",
71
+ "gulp-pug": "^5.0.0",
72
+ "lit-analyzer": "^1.2.1",
73
+ "npm-run-all": "^4.1.5",
74
+ "prettier": "^2.6.2",
75
+ "rimraf": "^3.0.2",
76
+ "rollup": "^2.73.0",
77
+ "rollup-plugin-summary": "^1.4.3",
78
+ "rollup-plugin-terser": "^7.0.2",
79
+ "typescript": "~5.3.3"
80
+ },
81
+ "customElements": "custom-elements.json"
82
+ }
@@ -0,0 +1,19 @@
1
+ import { AreaHiddenElement } from '../shared/area-hidden-element';
2
+ export declare class Ripple extends AreaHiddenElement {
3
+ static styles: import("lit").CSSResult;
4
+ disabled: boolean;
5
+ private isTouching;
6
+ constructor();
7
+ private attachEvents;
8
+ private handleMouseDown;
9
+ private handleTouchStart;
10
+ private canCreateRipple;
11
+ createRipple(releaseEventName?: string | null, targetX?: number | null, targetY?: number | null): () => void;
12
+ private static _setElementSquareSizeAndCenter;
13
+ }
14
+ declare global {
15
+ interface HTMLElementTagNameMap {
16
+ 'u-ripple': Ripple;
17
+ }
18
+ }
19
+ //# sourceMappingURL=ripple.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ripple.d.ts","sourceRoot":"","sources":["../../src/ripple/ripple.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,iBAAiB,EAAC,MAAM,+BAA+B,CAAC;AAEhE,qBACa,MAAO,SAAQ,iBAAiB;IAE3C,OAAgB,MAAM,0BA0DpB;IAEwC,QAAQ,UAAS;IAC3D,OAAO,CAAC,UAAU,CAAS;;IAQ3B,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,eAAe;IASvB,OAAO,CAAC,gBAAgB;IAiCxB,OAAO,CAAC,eAAe;IAYvB,YAAY,CAAC,gBAAgB,GAAE,MAAM,GAAG,IAAW,EAAE,OAAO,GAAE,MAAM,GAAG,IAAW,EAAE,OAAO,GAAE,MAAM,GAAG,IAAW,GAAG,MAAM,IAAI;IAkD9H,OAAO,CAAC,MAAM,CAAC,8BAA8B;CAQ9C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,UAAU,EAAE,MAAM,CAAC;KACpB;CACF"}
@@ -0,0 +1,173 @@
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 Ripple_1;
8
+ import { css } from 'lit';
9
+ import { customElement, property } from 'lit/decorators.js';
10
+ import { AreaHiddenElement } from '../shared/area-hidden-element';
11
+ let Ripple = Ripple_1 = class Ripple extends AreaHiddenElement {
12
+ constructor() {
13
+ super();
14
+ this.disabled = false;
15
+ this.isTouching = false;
16
+ this.attachEvents();
17
+ }
18
+ attachEvents() {
19
+ this.addEventListener('mousedown', this.handleMouseDown);
20
+ this.addEventListener('touchstart', this.handleTouchStart);
21
+ }
22
+ handleMouseDown(e) {
23
+ if (this.isTouching || !this.canCreateRipple()) {
24
+ return;
25
+ }
26
+ this.createRipple('mouseup', e.clientX, e.clientY);
27
+ }
28
+ handleTouchStart(e) {
29
+ if (!this.canCreateRipple()) {
30
+ return;
31
+ }
32
+ this.isTouching = true;
33
+ let release;
34
+ let cancel = false;
35
+ const touchMove = () => {
36
+ cancel = true;
37
+ this.removeEventListener("touchmove", touchMove);
38
+ if (release) {
39
+ release();
40
+ }
41
+ };
42
+ this.addEventListener("touchmove", touchMove);
43
+ setTimeout(() => {
44
+ if (cancel) {
45
+ return;
46
+ }
47
+ release = this.createRipple('touchend', e.touches[0].clientX, e.touches[0].clientY);
48
+ }, 100);
49
+ }
50
+ canCreateRipple() {
51
+ if (this.disabled)
52
+ return false;
53
+ const parent = this.parentElement;
54
+ if (window.getComputedStyle(parent).position !== "relative" && window.getComputedStyle(parent).position !== "absolute" && window.getComputedStyle(parent).position !== "fixed") {
55
+ console.warn('Ripple: Parent element position must be "relative", "absolute" or "fixed"');
56
+ return false;
57
+ }
58
+ return true;
59
+ }
60
+ createRipple(releaseEventName = null, targetX = null, targetY = null) {
61
+ const preClientRect = this.getBoundingClientRect();
62
+ targetX ??= preClientRect.x + this.clientWidth / 2;
63
+ targetY ??= preClientRect.y + this.clientHeight / 2;
64
+ const ripple = document.createElement('DIV');
65
+ ripple.classList.add('ripple');
66
+ this.shadowRoot.appendChild(ripple);
67
+ const release = () => {
68
+ ripple.classList.add('dismiss');
69
+ this.isTouching = false;
70
+ };
71
+ ripple.addEventListener('transitionend', () => {
72
+ if (!ripple.classList.contains('dismiss') && !ripple.classList.contains('show-forced')) {
73
+ return;
74
+ }
75
+ ripple.remove();
76
+ this.removeEventListener('dragover', release);
77
+ this.removeEventListener('mouseleave', release);
78
+ if (releaseEventName) {
79
+ window.removeEventListener(releaseEventName, release);
80
+ }
81
+ });
82
+ requestAnimationFrame(() => {
83
+ const clientRect = this.getBoundingClientRect();
84
+ const largestDimensionSize = Math.max(this.clientWidth, this.clientHeight);
85
+ const rippleSize = largestDimensionSize * 2;
86
+ Ripple_1._setElementSquareSizeAndCenter(ripple, rippleSize);
87
+ ripple.style.transitionDuration = (1080 * Math.pow(rippleSize, 0.3)) + 'ms, 750ms';
88
+ const x = (targetX - clientRect.left) + ((rippleSize - this.clientWidth) / 2);
89
+ const y = (targetY - clientRect.top) + ((rippleSize - this.clientHeight) / 2);
90
+ ripple.style.transformOrigin = x + "px " + y + "px";
91
+ ripple.classList.add(releaseEventName ? 'show' : 'show-forced');
92
+ });
93
+ if (releaseEventName) {
94
+ window.addEventListener(releaseEventName, release);
95
+ }
96
+ return release;
97
+ }
98
+ static _setElementSquareSizeAndCenter(element, size) {
99
+ element.style.top = "50%";
100
+ element.style.left = "50%";
101
+ element.style.width = size + 'px';
102
+ element.style.height = size + 'px';
103
+ element.style.marginLeft = -size / 2 + 'px';
104
+ element.style.marginTop = -size / 2 + 'px';
105
+ }
106
+ };
107
+ Ripple.styles = css `
108
+
109
+ :host,
110
+ :host::before {
111
+ display: block;
112
+ inset: 0;
113
+ overflow: hidden;
114
+ isolation: isolate;
115
+ }
116
+
117
+ :host::before {
118
+ content: '';
119
+ background: var(--u-state-layer-color, currentColor);
120
+ opacity: 0;
121
+ transition: opacity 200ms;
122
+ }
123
+
124
+ @media (hover: hover) {
125
+ :host(:not([disabled]):hover)::before {
126
+ content: '';
127
+ background: var(--u-state-layer-color, currentColor);
128
+ opacity: .08;
129
+ }
130
+ }
131
+
132
+ :host,
133
+ :host::before,
134
+ .ripple {
135
+ position: absolute;
136
+ border-radius: inherit;
137
+ }
138
+
139
+ .ripple {
140
+ top: 50%;
141
+ left: 50%;
142
+ background: var(--u-state-layer-color, currentColor);
143
+ border-radius: 50%;
144
+ box-shadow: 0 0 4rem 4rem var(--u-state-layer-color, currentColor);
145
+ opacity: .2;
146
+ transform: scale3d(0, 0, 1);
147
+ will-change: transform;
148
+ }
149
+
150
+ .ripple.show {
151
+ transition: transform 1.5s cubic-bezier(.19, 1, .22, 1), opacity 750ms;
152
+ transform: scale3d(1, 1, 1);
153
+ }
154
+
155
+ .ripple.show-forced {
156
+ transition: transform 1s cubic-bezier(.19, 1, .22, 1), opacity 200ms 300ms;
157
+ transform: scale3d(2, 2, 1);
158
+ opacity: 0;
159
+ }
160
+
161
+ .ripple.dismiss {
162
+ opacity: 0;
163
+ transform: scale3d(2, 2, 1);
164
+ }
165
+ `;
166
+ __decorate([
167
+ property({ type: Boolean, reflect: true })
168
+ ], Ripple.prototype, "disabled", void 0);
169
+ Ripple = Ripple_1 = __decorate([
170
+ customElement('u-ripple')
171
+ ], Ripple);
172
+ export { Ripple };
173
+ //# sourceMappingURL=ripple.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ripple.js","sourceRoot":"","sources":["../../src/ripple/ripple.ts"],"names":[],"mappings":"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","sourcesContent":["import {css} from 'lit';\nimport {customElement, property} from 'lit/decorators.js';\nimport {AreaHiddenElement} from '../shared/area-hidden-element';\n\n@customElement('u-ripple')\nexport class Ripple extends AreaHiddenElement {\n\n static override styles = css`\n\n :host,\n :host::before {\n display: block;\n inset: 0;\n overflow: hidden;\n isolation: isolate;\n }\n \n :host::before {\n content: '';\n background: var(--u-state-layer-color, currentColor);\n opacity: 0;\n transition: opacity 200ms;\n }\n \n @media (hover: hover) {\n :host(:not([disabled]):hover)::before {\n content: '';\n background: var(--u-state-layer-color, currentColor);\n opacity: .08;\n }\n }\n\n :host,\n :host::before,\n .ripple {\n position: absolute;\n border-radius: inherit;\n }\n\n .ripple {\n top: 50%;\n left: 50%;\n background: var(--u-state-layer-color, currentColor);\n border-radius: 50%;\n box-shadow: 0 0 4rem 4rem var(--u-state-layer-color, currentColor);\n opacity: .2;\n transform: scale3d(0, 0, 1);\n will-change: transform;\n }\n\n .ripple.show {\n transition: transform 1.5s cubic-bezier(.19, 1, .22, 1), opacity 750ms;\n transform: scale3d(1, 1, 1);\n }\n\n .ripple.show-forced {\n transition: transform 1s cubic-bezier(.19, 1, .22, 1), opacity 200ms 300ms;\n transform: scale3d(2, 2, 1);\n opacity: 0;\n }\n\n .ripple.dismiss {\n opacity: 0;\n transform: scale3d(2, 2, 1);\n }\n `;\n\n @property({type: Boolean, reflect: true}) disabled = false;\n private isTouching = false;\n\n constructor() {\n super();\n \n this.attachEvents();\n }\n\n private attachEvents(): void {\n\n this.addEventListener('mousedown', this.handleMouseDown);\n this.addEventListener('touchstart', this.handleTouchStart);\n }\n\n private handleMouseDown(e: MouseEvent): void {\n\n if (this.isTouching || !this.canCreateRipple()) {\n return;\n }\n\n this.createRipple('mouseup', e.clientX, e.clientY);\n }\n\n private handleTouchStart(e: TouchEvent): void {\n\n if (!this.canCreateRipple()) {\n return;\n }\n\n this.isTouching = true;\n\n let release: (() => void) | null;\n let cancel = false;\n\n const touchMove = () => {\n\n cancel = true;\n\n this.removeEventListener(\"touchmove\", touchMove);\n\n if (release) {\n release();\n }\n };\n\n this.addEventListener(\"touchmove\", touchMove);\n\n setTimeout(() => {\n if (cancel) {\n return;\n }\n\n release = this.createRipple('touchend', e.touches[0].clientX, e.touches[0].clientY);\n }, 100);\n }\n\n private canCreateRipple(): boolean {\n if (this.disabled) return false;\n\n const parent = this.parentElement!;\n if (window.getComputedStyle(parent).position !== \"relative\" && window.getComputedStyle(parent).position !== \"absolute\" && window.getComputedStyle(parent).position !== \"fixed\") {\n console.warn('Ripple: Parent element position must be \"relative\", \"absolute\" or \"fixed\"');\n return false;\n }\n\n return true;\n }\n\n createRipple(releaseEventName: string | null = null, targetX: number | null = null, targetY: number | null = null): () => void {\n const preClientRect = this.getBoundingClientRect();\n targetX ??= preClientRect.x + this.clientWidth / 2;\n targetY ??= preClientRect.y + this.clientHeight / 2;\n\n const ripple = document.createElement('DIV');\n ripple.classList.add('ripple');\n this.shadowRoot!.appendChild(ripple);\n\n const release = () => {\n ripple.classList.add('dismiss');\n this.isTouching = false;\n };\n\n ripple.addEventListener('transitionend', () => {\n if (!ripple.classList.contains('dismiss') && !ripple.classList.contains('show-forced')) {\n return;\n }\n\n ripple.remove();\n this.removeEventListener('dragover', release);\n this.removeEventListener('mouseleave', release);\n\n if (releaseEventName) {\n window.removeEventListener(releaseEventName, release);\n }\n });\n\n requestAnimationFrame(() => {\n const clientRect = this.getBoundingClientRect();\n const largestDimensionSize = Math.max(this.clientWidth, this.clientHeight);\n const rippleSize = largestDimensionSize * 2;\n\n Ripple._setElementSquareSizeAndCenter(ripple, rippleSize);\n ripple.style.transitionDuration = (1080 * Math.pow(rippleSize, 0.3)) + 'ms, 750ms';\n\n const x = (targetX! - clientRect.left) + ((rippleSize - this.clientWidth) / 2);\n const y = (targetY! - clientRect.top) + ((rippleSize - this.clientHeight) / 2);\n\n ripple.style.transformOrigin = x + \"px \" + y + \"px\";\n ripple.classList.add(releaseEventName ? 'show' : 'show-forced');\n });\n\n if (releaseEventName) {\n window.addEventListener(releaseEventName, release);\n }\n\n return release;\n }\n\n private static _setElementSquareSizeAndCenter(element: HTMLElement, size: number) {\n element.style.top = \"50%\";\n element.style.left = \"50%\";\n element.style.width = size + 'px';\n element.style.height = size + 'px';\n element.style.marginLeft = -size / 2 + 'px';\n element.style.marginTop = -size / 2 + 'px';\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'u-ripple': Ripple;\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import { LitElement } from 'lit';
2
+ export declare abstract class AreaHiddenElement extends LitElement {
3
+ connectedCallback(): void;
4
+ }
5
+ //# sourceMappingURL=area-hidden-element.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"area-hidden-element.d.ts","sourceRoot":"","sources":["../../src/shared/area-hidden-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,KAAK,CAAC;AAE/B,8BAAsB,iBAAkB,SAAQ,UAAU;IAC/C,iBAAiB;CAM3B"}
@@ -0,0 +1,10 @@
1
+ import { LitElement } from 'lit';
2
+ export class AreaHiddenElement extends LitElement {
3
+ connectedCallback() {
4
+ super.connectedCallback();
5
+ // Needed for VoiceOver, which will create a "group" if the element is a
6
+ // sibling to other content.
7
+ this.setAttribute('aria-hidden', 'true');
8
+ }
9
+ }
10
+ //# sourceMappingURL=area-hidden-element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"area-hidden-element.js","sourceRoot":"","sources":["../../src/shared/area-hidden-element.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,KAAK,CAAC;AAE/B,MAAM,OAAgB,iBAAkB,SAAQ,UAAU;IAC/C,iBAAiB;QACxB,KAAK,CAAC,iBAAiB,EAAE,CAAC;QAC1B,wEAAwE;QACxE,4BAA4B;QAC5B,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;IAC3C,CAAC;CACF","sourcesContent":["import {LitElement} from 'lit';\n\nexport abstract class AreaHiddenElement extends LitElement {\n override connectedCallback() {\n super.connectedCallback();\n // Needed for VoiceOver, which will create a \"group\" if the element is a\n // sibling to other content.\n this.setAttribute('aria-hidden', 'true');\n }\n}\n"]}