@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.
- package/all.d.ts +9 -0
- package/all.d.ts.map +1 -0
- package/all.js +9 -0
- package/all.js.map +1 -0
- package/button/button-base.d.ts +37 -0
- package/button/button-base.d.ts.map +1 -0
- package/button/button-base.js +199 -0
- package/button/button-base.js.map +1 -0
- package/button/button-set.d.ts +11 -0
- package/button/button-set.d.ts.map +1 -0
- package/button/button-set.js +27 -0
- package/button/button-set.js.map +1 -0
- package/button/button.d.ts +18 -0
- package/button/button.d.ts.map +1 -0
- package/button/button.js +137 -0
- package/button/button.js.map +1 -0
- package/button/fab.d.ts +17 -0
- package/button/fab.d.ts.map +1 -0
- package/button/fab.js +144 -0
- package/button/fab.js.map +1 -0
- package/button/icon-button.d.ts +35 -0
- package/button/icon-button.d.ts.map +1 -0
- package/button/icon-button.js +153 -0
- package/button/icon-button.js.map +1 -0
- package/card/button-set.d.ts +11 -0
- package/card/button-set.d.ts.map +1 -0
- package/card/button-set.js +26 -0
- package/card/button-set.js.map +1 -0
- package/card/card-content.d.ts +11 -0
- package/card/card-content.d.ts.map +1 -0
- package/card/card-content.js +24 -0
- package/card/card-content.js.map +1 -0
- package/card/card-media.d.ts +12 -0
- package/card/card-media.d.ts.map +1 -0
- package/card/card-media.js +37 -0
- package/card/card-media.js.map +1 -0
- package/card/card.d.ts +15 -0
- package/card/card.d.ts.map +1 -0
- package/card/card.js +52 -0
- package/card/card.js.map +1 -0
- package/divider/divider.d.ts +11 -0
- package/divider/divider.d.ts.map +1 -0
- package/divider/divider.js +35 -0
- package/divider/divider.js.map +1 -0
- package/elevation/elevation.d.ts +10 -0
- package/elevation/elevation.d.ts.map +1 -0
- package/elevation/elevation.js +47 -0
- package/elevation/elevation.js.map +1 -0
- package/package.json +82 -0
- package/ripple/ripple.d.ts +19 -0
- package/ripple/ripple.d.ts.map +1 -0
- package/ripple/ripple.js +173 -0
- package/ripple/ripple.js.map +1 -0
- package/shared/area-hidden-element.d.ts +5 -0
- package/shared/area-hidden-element.d.ts.map +1 -0
- package/shared/area-hidden-element.js +10 -0
- 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"}
|
package/ripple/ripple.js
ADDED
|
@@ -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 @@
|
|
|
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"]}
|