This repository has been archived by the owner on Jul 22, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
sc-gh-link.js
102 lines (87 loc) · 2.7 KB
/
sc-gh-link.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
import { html, css, svg, nothing } from 'lit';
import ScElement from './ScElement.js';
import { theme } from './styles.js';
class ScGhLink extends ScElement {
static get properties() {
return {
width: {
type: Number,
},
height: {
type: Number,
},
href: {
type: String,
},
};
}
static get styles() {
return css`
:host {
vertical-align: top;
display: inline-block;
box-sizing: border-box;
background-color: ${theme['--color-primary-1']};
font-size: 0 !important;
border-radius: 2px;
}
a {
box-sizing: border-box;
display: block;
border: 1px solid ${theme['--color-primary-2']};
}
svg {
box-sizing: border-box;
}
`;
}
set width(value) {
this._size = value;
this.requestUpdate();
}
get width() {
return this._size;
}
set height(value) {
this._size = value;
this.requestUpdate();
}
get height() {
return this._size;
}
constructor() {
super();
this.width = 30;
this.height = 30;
this.href = 'https://github.com/ircam-ismm/simple-components';
}
render() {
const size = this._size - 2;
// width="98" height="96"
return html`
<a
href="${this.href}"
target="_blank"
style="
width: ${this._size}px;
height: ${this._size}px;
padding: 4px;
">
<svg
style="
width: ${this._size - 10}px;
height: ${this._size - 10}px;
"
viewbox="0 0 98 98"
xmlns="http://www.w3.org/2000/svg"
>
<path fill-rule="evenodd" clip-rule="evenodd" d="M48.854 0C21.839 0 0 22 0 49.217c0 21.756 13.993 40.172 33.405 46.69 2.427.49 3.316-1.059 3.316-2.362 0-1.141-.08-5.052-.08-9.127-13.59 2.934-16.42-5.867-16.42-5.867-2.184-5.704-5.42-7.17-5.42-7.17-4.448-3.015.324-3.015.324-3.015 4.934.326 7.523 5.052 7.523 5.052 4.367 7.496 11.404 5.378 14.235 4.074.404-3.178 1.699-5.378 3.074-6.6-10.839-1.141-22.243-5.378-22.243-24.283 0-5.378 1.94-9.778 5.014-13.2-.485-1.222-2.184-6.275.486-13.038 0 0 4.125-1.304 13.426 5.052a46.97 46.97 0 0 1 12.214-1.63c4.125 0 8.33.571 12.213 1.63 9.302-6.356 13.427-5.052 13.427-5.052 2.67 6.763.97 11.816.485 13.038 3.155 3.422 5.015 7.822 5.015 13.2 0 18.905-11.404 23.06-22.324 24.283 1.78 1.548 3.316 4.481 3.316 9.126 0 6.6-.08 11.897-.08 13.526 0 1.304.89 2.853 3.316 2.364 19.412-6.52 33.405-24.935 33.405-46.691C97.707 22 75.788 0 48.854 0z" fill="#fff"/>
</svg>
</a>
`
}
}
if (customElements.get('sc-gh-link') === undefined) {
customElements.define('sc-gh-link', ScGhLink);
}
export default ScGhLink;