@things-factory/auth-ui 8.0.38 → 8.0.46
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/client/entries/auth/checkin.ts +53 -5
- package/dist-client/entries/auth/checkin.d.ts +4 -1
- package/dist-client/entries/auth/checkin.js +57 -4
- package/dist-client/entries/auth/checkin.js.map +1 -1
- package/dist-client/tsconfig.tsbuildinfo +1 -1
- package/dist-server/auth-ui/auth-ui-query.d.ts +3 -0
- package/dist-server/auth-ui/auth-ui-query.js +23 -0
- package/dist-server/auth-ui/auth-ui-query.js.map +1 -0
- package/dist-server/auth-ui/index.d.ts +2 -0
- package/dist-server/auth-ui/index.js +6 -0
- package/dist-server/auth-ui/index.js.map +1 -0
- package/dist-server/index.d.ts +1 -0
- package/dist-server/index.js +3 -0
- package/dist-server/index.js.map +1 -1
- package/dist-server/routes.d.ts +1 -0
- package/dist-server/routes.js +11 -0
- package/dist-server/routes.js.map +1 -0
- package/dist-server/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -3
- package/server/index.ts +1 -0
- package/server/routes.ts +10 -0
- package/translations/en.json +1 -0
- package/translations/ja.json +1 -0
- package/translations/ko.json +1 -0
- package/translations/ms.json +1 -0
- package/translations/zh.json +1 -0
|
@@ -4,7 +4,7 @@ import '@material/web/button/elevated-button.js'
|
|
|
4
4
|
import '@operato/lottie-player'
|
|
5
5
|
|
|
6
6
|
import { css, html, LitElement } from 'lit'
|
|
7
|
-
import { customElement, property } from 'lit/decorators.js'
|
|
7
|
+
import { customElement, property, state } from 'lit/decorators.js'
|
|
8
8
|
|
|
9
9
|
import { i18next, localize } from '@operato/i18n'
|
|
10
10
|
import { ScrollbarStyles } from '@operato/styles'
|
|
@@ -81,6 +81,24 @@ export class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
81
81
|
margin-left: var(--spacing-small);
|
|
82
82
|
}
|
|
83
83
|
|
|
84
|
+
input[search-input] {
|
|
85
|
+
width: 250px;
|
|
86
|
+
height: 35px;
|
|
87
|
+
margin-top: 10px;
|
|
88
|
+
border-radius: 5px;
|
|
89
|
+
padding: 3px 10px;
|
|
90
|
+
font-size: 17px;
|
|
91
|
+
color: var(--md-sys-color-primary);
|
|
92
|
+
background: var(--md-sys-color-surface);
|
|
93
|
+
border: var(--border-dim-color);
|
|
94
|
+
font-weight: 500;
|
|
95
|
+
display: none;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
input[search-input][visible] {
|
|
99
|
+
display: inline-block;
|
|
100
|
+
}
|
|
101
|
+
|
|
84
102
|
@media (max-width: 450px) {
|
|
85
103
|
.button-container md-elevated-button {
|
|
86
104
|
width: 100%;
|
|
@@ -96,6 +114,9 @@ export class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
96
114
|
@property({ type: Array }) domainTypes?: string[]
|
|
97
115
|
@property({ type: Object }) user: any
|
|
98
116
|
|
|
117
|
+
@state() searchValue: string = ''
|
|
118
|
+
@state() showDomainSearch: boolean = false
|
|
119
|
+
|
|
99
120
|
private _applicationMeta?: { icon?: string; title?: string; description?: string }
|
|
100
121
|
private redirectTo?: string
|
|
101
122
|
|
|
@@ -113,11 +134,31 @@ export class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
113
134
|
|
|
114
135
|
<h3>${i18next.t('label.select_domain')}</h3>
|
|
115
136
|
|
|
137
|
+
${html`
|
|
138
|
+
<input
|
|
139
|
+
search-input
|
|
140
|
+
?visible=${this.showDomainSearch}
|
|
141
|
+
type="text"
|
|
142
|
+
placeholder=${i18next.t('label.search_domain')}
|
|
143
|
+
.value=${this.searchValue}
|
|
144
|
+
@input=${e => (this.searchValue = e.target.value)}
|
|
145
|
+
/>
|
|
146
|
+
`}
|
|
116
147
|
${this.domains?.length
|
|
117
148
|
? html`
|
|
118
149
|
<ul class="domains">
|
|
119
|
-
${this.domains.map(
|
|
120
|
-
|
|
150
|
+
${this.domains.map(domain => {
|
|
151
|
+
// config에 showDomainSearch 옵션이 켜져있으면 검색 필터링 처리
|
|
152
|
+
if (
|
|
153
|
+
this.showDomainSearch &&
|
|
154
|
+
this.searchValue &&
|
|
155
|
+
!domain.name.toLowerCase().includes(this.searchValue.toLowerCase()) &&
|
|
156
|
+
!domain.description.toLowerCase().includes(this.searchValue.toLowerCase())
|
|
157
|
+
) {
|
|
158
|
+
return html``
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
return html`
|
|
121
162
|
<li
|
|
122
163
|
@click=${() =>
|
|
123
164
|
(location.href = `/auth/checkin/${domain.subdomain}?redirect_to=${encodeURIComponent(this.redirectTo || '/')}`)}
|
|
@@ -127,7 +168,7 @@ export class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
127
168
|
<span>${domain.description} </span>
|
|
128
169
|
</li>
|
|
129
170
|
`
|
|
130
|
-
)}
|
|
171
|
+
})}
|
|
131
172
|
</ul>
|
|
132
173
|
`
|
|
133
174
|
: html` <h3>${i18next.t('text.no domain available')}</h3> `}
|
|
@@ -150,13 +191,14 @@ export class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
150
191
|
`
|
|
151
192
|
}
|
|
152
193
|
|
|
153
|
-
updated(changed) {
|
|
194
|
+
async updated(changed) {
|
|
154
195
|
if (changed.has('data')) {
|
|
155
196
|
this.domains = this.data.domains
|
|
156
197
|
this.user = this.data.user
|
|
157
198
|
this.domainTypes = this.data.domainTypes
|
|
158
199
|
this.redirectTo = this.data.redirectTo
|
|
159
200
|
|
|
201
|
+
await this.fetchConfig()
|
|
160
202
|
this.requestUpdate()
|
|
161
203
|
}
|
|
162
204
|
}
|
|
@@ -165,6 +207,12 @@ export class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
165
207
|
location.pathname = url
|
|
166
208
|
}
|
|
167
209
|
|
|
210
|
+
async fetchConfig() {
|
|
211
|
+
const response = await fetch('/get-config')
|
|
212
|
+
const data = await response.json()
|
|
213
|
+
this.showDomainSearch = data.showDomainSearch || false
|
|
214
|
+
}
|
|
215
|
+
|
|
168
216
|
get applicationMeta() {
|
|
169
217
|
if (!this._applicationMeta) {
|
|
170
218
|
var iconLink: HTMLLinkElement | null = document.querySelector('link[rel="application-icon"]')
|
|
@@ -9,11 +9,14 @@ export declare class AuthCheckIn extends AuthCheckIn_base {
|
|
|
9
9
|
domains: any[];
|
|
10
10
|
domainTypes?: string[];
|
|
11
11
|
user: any;
|
|
12
|
+
searchValue: string;
|
|
13
|
+
showDomainSearch: boolean;
|
|
12
14
|
private _applicationMeta?;
|
|
13
15
|
private redirectTo?;
|
|
14
16
|
render(): import("lit-html").TemplateResult<1>;
|
|
15
|
-
updated(changed: any): void
|
|
17
|
+
updated(changed: any): Promise<void>;
|
|
16
18
|
navigateToUrl(url: any): void;
|
|
19
|
+
fetchConfig(): Promise<void>;
|
|
17
20
|
get applicationMeta(): {
|
|
18
21
|
icon?: string;
|
|
19
22
|
title?: string;
|
|
@@ -3,7 +3,7 @@ import '@material/web/icon/icon.js';
|
|
|
3
3
|
import '@material/web/button/elevated-button.js';
|
|
4
4
|
import '@operato/lottie-player';
|
|
5
5
|
import { css, html, LitElement } from 'lit';
|
|
6
|
-
import { customElement, property } from 'lit/decorators.js';
|
|
6
|
+
import { customElement, property, state } from 'lit/decorators.js';
|
|
7
7
|
import { i18next, localize } from '@operato/i18n';
|
|
8
8
|
import { ScrollbarStyles } from '@operato/styles';
|
|
9
9
|
import { isSafari } from '@operato/utils';
|
|
@@ -12,6 +12,8 @@ let AuthCheckIn = class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
12
12
|
constructor() {
|
|
13
13
|
super(...arguments);
|
|
14
14
|
this.domains = [];
|
|
15
|
+
this.searchValue = '';
|
|
16
|
+
this.showDomainSearch = false;
|
|
15
17
|
}
|
|
16
18
|
render() {
|
|
17
19
|
var _a;
|
|
@@ -27,10 +29,28 @@ let AuthCheckIn = class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
27
29
|
|
|
28
30
|
<h3>${i18next.t('label.select_domain')}</h3>
|
|
29
31
|
|
|
32
|
+
${html `
|
|
33
|
+
<input
|
|
34
|
+
search-input
|
|
35
|
+
?visible=${this.showDomainSearch}
|
|
36
|
+
type="text"
|
|
37
|
+
placeholder=${i18next.t('label.search_domain')}
|
|
38
|
+
.value=${this.searchValue}
|
|
39
|
+
@input=${e => (this.searchValue = e.target.value)}
|
|
40
|
+
/>
|
|
41
|
+
`}
|
|
30
42
|
${((_a = this.domains) === null || _a === void 0 ? void 0 : _a.length)
|
|
31
43
|
? html `
|
|
32
44
|
<ul class="domains">
|
|
33
|
-
${this.domains.map(domain =>
|
|
45
|
+
${this.domains.map(domain => {
|
|
46
|
+
// config에 showDomainSearch 옵션이 켜져있으면 검색 필터링 처리
|
|
47
|
+
if (this.showDomainSearch &&
|
|
48
|
+
this.searchValue &&
|
|
49
|
+
!domain.name.toLowerCase().includes(this.searchValue.toLowerCase()) &&
|
|
50
|
+
!domain.description.toLowerCase().includes(this.searchValue.toLowerCase())) {
|
|
51
|
+
return html ``;
|
|
52
|
+
}
|
|
53
|
+
return html `
|
|
34
54
|
<li
|
|
35
55
|
@click=${() => (location.href = `/auth/checkin/${domain.subdomain}?redirect_to=${encodeURIComponent(this.redirectTo || '/')}`)}
|
|
36
56
|
>
|
|
@@ -38,7 +58,8 @@ let AuthCheckIn = class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
38
58
|
<strong>${domain.name}</strong>
|
|
39
59
|
<span>${domain.description} </span>
|
|
40
60
|
</li>
|
|
41
|
-
|
|
61
|
+
`;
|
|
62
|
+
})}
|
|
42
63
|
</ul>
|
|
43
64
|
`
|
|
44
65
|
: html ` <h3>${i18next.t('text.no domain available')}</h3> `}
|
|
@@ -60,18 +81,24 @@ let AuthCheckIn = class AuthCheckIn extends localize(i18next)(LitElement) {
|
|
|
60
81
|
</div>
|
|
61
82
|
`;
|
|
62
83
|
}
|
|
63
|
-
updated(changed) {
|
|
84
|
+
async updated(changed) {
|
|
64
85
|
if (changed.has('data')) {
|
|
65
86
|
this.domains = this.data.domains;
|
|
66
87
|
this.user = this.data.user;
|
|
67
88
|
this.domainTypes = this.data.domainTypes;
|
|
68
89
|
this.redirectTo = this.data.redirectTo;
|
|
90
|
+
await this.fetchConfig();
|
|
69
91
|
this.requestUpdate();
|
|
70
92
|
}
|
|
71
93
|
}
|
|
72
94
|
navigateToUrl(url) {
|
|
73
95
|
location.pathname = url;
|
|
74
96
|
}
|
|
97
|
+
async fetchConfig() {
|
|
98
|
+
const response = await fetch('/get-config');
|
|
99
|
+
const data = await response.json();
|
|
100
|
+
this.showDomainSearch = data.showDomainSearch || false;
|
|
101
|
+
}
|
|
75
102
|
get applicationMeta() {
|
|
76
103
|
if (!this._applicationMeta) {
|
|
77
104
|
var iconLink = document.querySelector('link[rel="application-icon"]');
|
|
@@ -153,6 +180,24 @@ AuthCheckIn.styles = [
|
|
|
153
180
|
margin-left: var(--spacing-small);
|
|
154
181
|
}
|
|
155
182
|
|
|
183
|
+
input[search-input] {
|
|
184
|
+
width: 250px;
|
|
185
|
+
height: 35px;
|
|
186
|
+
margin-top: 10px;
|
|
187
|
+
border-radius: 5px;
|
|
188
|
+
padding: 3px 10px;
|
|
189
|
+
font-size: 17px;
|
|
190
|
+
color: var(--md-sys-color-primary);
|
|
191
|
+
background: var(--md-sys-color-surface);
|
|
192
|
+
border: var(--border-dim-color);
|
|
193
|
+
font-weight: 500;
|
|
194
|
+
display: none;
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
input[search-input][visible] {
|
|
198
|
+
display: inline-block;
|
|
199
|
+
}
|
|
200
|
+
|
|
156
201
|
@media (max-width: 450px) {
|
|
157
202
|
.button-container md-elevated-button {
|
|
158
203
|
width: 100%;
|
|
@@ -178,6 +223,14 @@ __decorate([
|
|
|
178
223
|
property({ type: Object }),
|
|
179
224
|
__metadata("design:type", Object)
|
|
180
225
|
], AuthCheckIn.prototype, "user", void 0);
|
|
226
|
+
__decorate([
|
|
227
|
+
state(),
|
|
228
|
+
__metadata("design:type", String)
|
|
229
|
+
], AuthCheckIn.prototype, "searchValue", void 0);
|
|
230
|
+
__decorate([
|
|
231
|
+
state(),
|
|
232
|
+
__metadata("design:type", Boolean)
|
|
233
|
+
], AuthCheckIn.prototype, "showDomainSearch", void 0);
|
|
181
234
|
AuthCheckIn = __decorate([
|
|
182
235
|
customElement('auth-checkin')
|
|
183
236
|
], AuthCheckIn);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"checkin.js","sourceRoot":"","sources":["../../../client/entries/auth/checkin.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@material/web/button/elevated-button.js'\n\nimport '@operato/lottie-player'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property } from 'lit/decorators.js'\n\nimport { i18next, localize } from '@operato/i18n'\nimport { ScrollbarStyles } from '@operato/styles'\nimport { isSafari } from '@operato/utils'\n\nimport { AUTH_STYLE_SIGN } from '../../auth-style-sign'\n\n@customElement('auth-checkin')\nexport class AuthCheckIn extends localize(i18next)(LitElement) {\n static styles = [\n ScrollbarStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n margin: auto;\n background-color: var(--md-sys-color-primary);\n color: var(--md-sys-color-on-primary);\n height: 100vh;\n height: 100dvh;\n }\n\n .header {\n background-color: var(--md-sys-color-primary);\n color: var(--md-sys-color-on-primary);\n height: var(--checkin-header-height);\n }\n\n .content {\n flex: 1;\n overflow: auto;\n }\n\n .domains {\n margin: var(--spacing-large) 0;\n padding: 0;\n background-color: var(--md-sys-color-surface);\n color: var(--md-sys-color-on-surface);\n border-radius: var(--border-radius);\n border: var(--border-dim-color);\n list-style: none;\n }\n\n li {\n border-bottom: var(--border-dim-color);\n padding: var(--spacing-medium) var(--spacing-large);\n font-size: 18px;\n text-align: left;\n\n cursor: pointer;\n }\n\n li:hover {\n background-color: var(--md-sys-color-primary-container);\n color: var(--md-sys-color-on-primary-container);\n }\n\n li span {\n display: block;\n font: normal var(--fontsize-default) var(--theme-font);\n }\n\n li md-icon {\n float: right;\n margin: 10px 0 0 0;\n opacity: 0.5;\n }\n\n .button-container {\n text-align: center;\n }\n\n .button-container md-elevated-button {\n margin-left: var(--spacing-small);\n }\n\n @media (max-width: 450px) {\n .button-container md-elevated-button {\n width: 100%;\n margin: var(--spacing-medium) 0 0 0;\n }\n }\n `,\n AUTH_STYLE_SIGN\n ]\n\n @property({ type: Object }) data: any\n @property({ type: Array }) domains: any[] = []\n @property({ type: Array }) domainTypes?: string[]\n @property({ type: Object }) user: any\n\n private _applicationMeta?: { icon?: string; title?: string; description?: string }\n private redirectTo?: string\n\n render() {\n var { icon, title, description } = this.applicationMeta\n\n return html`\n <div class=\"content md-typescale-display-medium\">\n <div class=\"wrap\">\n <div class=\"auth-brand\">\n <img src=${icon || ''} />\n <strong class=\"name\">${title}</strong>\n <span class=\"welcome-msg\">${description}</span>\n </div>\n\n <h3>${i18next.t('label.select_domain')}</h3>\n\n ${this.domains?.length\n ? html`\n <ul class=\"domains\">\n ${this.domains.map(\n domain => html`\n <li\n @click=${() =>\n (location.href = `/auth/checkin/${domain.subdomain}?redirect_to=${encodeURIComponent(this.redirectTo || '/')}`)}\n >\n <md-icon>keyboard_arrow_right</md-icon>\n <strong>${domain.name}</strong>\n <span>${domain.description} </span>\n </li>\n `\n )}\n </ul>\n `\n : html` <h3>${i18next.t('text.no domain available')}</h3> `}\n\n <div class=\"button-container\">\n <md-elevated-button @click=${() => (location.pathname = '/auth/signout')}\n >${String(i18next.t('button.logout'))}</md-elevated-button\n >\n </div>\n\n ${isSafari()\n ? html``\n : html`\n <div class=\"lottie-container\">\n <lottie-player autoplay loop src=\"../../assets/images/background-animation.json\"></lottie-player>\n </div>\n `}\n </div>\n </div>\n `\n }\n\n updated(changed) {\n if (changed.has('data')) {\n this.domains = this.data.domains\n this.user = this.data.user\n this.domainTypes = this.data.domainTypes\n this.redirectTo = this.data.redirectTo\n\n this.requestUpdate()\n }\n }\n\n navigateToUrl(url) {\n location.pathname = url\n }\n\n get applicationMeta() {\n if (!this._applicationMeta) {\n var iconLink: HTMLLinkElement | null = document.querySelector('link[rel=\"application-icon\"]')\n var titleMeta: HTMLMetaElement | null = document.querySelector('meta[name=\"application-name\"]')\n var descriptionMeta: HTMLMetaElement | null = document.querySelector('meta[name=\"application-description\"]')\n\n this._applicationMeta = {\n icon: iconLink?.href,\n title: titleMeta ? titleMeta.content : 'Things Factory',\n description: descriptionMeta ? descriptionMeta.content : 'Reimagining Software'\n }\n }\n\n return this._applicationMeta\n }\n}\n"]}
|
|
1
|
+
{"version":3,"file":"checkin.js","sourceRoot":"","sources":["../../../client/entries/auth/checkin.ts"],"names":[],"mappings":"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","sourcesContent":["import '@material/web/icon/icon.js'\nimport '@material/web/button/elevated-button.js'\n\nimport '@operato/lottie-player'\n\nimport { css, html, LitElement } from 'lit'\nimport { customElement, property, state } from 'lit/decorators.js'\n\nimport { i18next, localize } from '@operato/i18n'\nimport { ScrollbarStyles } from '@operato/styles'\nimport { isSafari } from '@operato/utils'\n\nimport { AUTH_STYLE_SIGN } from '../../auth-style-sign'\n\n@customElement('auth-checkin')\nexport class AuthCheckIn extends localize(i18next)(LitElement) {\n static styles = [\n ScrollbarStyles,\n css`\n :host {\n display: flex;\n flex-direction: column;\n margin: auto;\n background-color: var(--md-sys-color-primary);\n color: var(--md-sys-color-on-primary);\n height: 100vh;\n height: 100dvh;\n }\n\n .header {\n background-color: var(--md-sys-color-primary);\n color: var(--md-sys-color-on-primary);\n height: var(--checkin-header-height);\n }\n\n .content {\n flex: 1;\n overflow: auto;\n }\n\n .domains {\n margin: var(--spacing-large) 0;\n padding: 0;\n background-color: var(--md-sys-color-surface);\n color: var(--md-sys-color-on-surface);\n border-radius: var(--border-radius);\n border: var(--border-dim-color);\n list-style: none;\n }\n\n li {\n border-bottom: var(--border-dim-color);\n padding: var(--spacing-medium) var(--spacing-large);\n font-size: 18px;\n text-align: left;\n\n cursor: pointer;\n }\n\n li:hover {\n background-color: var(--md-sys-color-primary-container);\n color: var(--md-sys-color-on-primary-container);\n }\n\n li span {\n display: block;\n font: normal var(--fontsize-default) var(--theme-font);\n }\n\n li md-icon {\n float: right;\n margin: 10px 0 0 0;\n opacity: 0.5;\n }\n\n .button-container {\n text-align: center;\n }\n\n .button-container md-elevated-button {\n margin-left: var(--spacing-small);\n }\n\n input[search-input] {\n width: 250px;\n height: 35px;\n margin-top: 10px;\n border-radius: 5px;\n padding: 3px 10px;\n font-size: 17px;\n color: var(--md-sys-color-primary);\n background: var(--md-sys-color-surface);\n border: var(--border-dim-color);\n font-weight: 500;\n display: none;\n }\n\n input[search-input][visible] {\n display: inline-block;\n }\n\n @media (max-width: 450px) {\n .button-container md-elevated-button {\n width: 100%;\n margin: var(--spacing-medium) 0 0 0;\n }\n }\n `,\n AUTH_STYLE_SIGN\n ]\n\n @property({ type: Object }) data: any\n @property({ type: Array }) domains: any[] = []\n @property({ type: Array }) domainTypes?: string[]\n @property({ type: Object }) user: any\n\n @state() searchValue: string = ''\n @state() showDomainSearch: boolean = false\n\n private _applicationMeta?: { icon?: string; title?: string; description?: string }\n private redirectTo?: string\n\n render() {\n var { icon, title, description } = this.applicationMeta\n\n return html`\n <div class=\"content md-typescale-display-medium\">\n <div class=\"wrap\">\n <div class=\"auth-brand\">\n <img src=${icon || ''} />\n <strong class=\"name\">${title}</strong>\n <span class=\"welcome-msg\">${description}</span>\n </div>\n\n <h3>${i18next.t('label.select_domain')}</h3>\n\n ${html`\n <input\n search-input\n ?visible=${this.showDomainSearch}\n type=\"text\"\n placeholder=${i18next.t('label.search_domain')}\n .value=${this.searchValue}\n @input=${e => (this.searchValue = e.target.value)}\n />\n `}\n ${this.domains?.length\n ? html`\n <ul class=\"domains\">\n ${this.domains.map(domain => {\n // config에 showDomainSearch 옵션이 켜져있으면 검색 필터링 처리\n if (\n this.showDomainSearch &&\n this.searchValue &&\n !domain.name.toLowerCase().includes(this.searchValue.toLowerCase()) &&\n !domain.description.toLowerCase().includes(this.searchValue.toLowerCase())\n ) {\n return html``\n }\n\n return html`\n <li\n @click=${() =>\n (location.href = `/auth/checkin/${domain.subdomain}?redirect_to=${encodeURIComponent(this.redirectTo || '/')}`)}\n >\n <md-icon>keyboard_arrow_right</md-icon>\n <strong>${domain.name}</strong>\n <span>${domain.description} </span>\n </li>\n `\n })}\n </ul>\n `\n : html` <h3>${i18next.t('text.no domain available')}</h3> `}\n\n <div class=\"button-container\">\n <md-elevated-button @click=${() => (location.pathname = '/auth/signout')}\n >${String(i18next.t('button.logout'))}</md-elevated-button\n >\n </div>\n\n ${isSafari()\n ? html``\n : html`\n <div class=\"lottie-container\">\n <lottie-player autoplay loop src=\"../../assets/images/background-animation.json\"></lottie-player>\n </div>\n `}\n </div>\n </div>\n `\n }\n\n async updated(changed) {\n if (changed.has('data')) {\n this.domains = this.data.domains\n this.user = this.data.user\n this.domainTypes = this.data.domainTypes\n this.redirectTo = this.data.redirectTo\n\n await this.fetchConfig()\n this.requestUpdate()\n }\n }\n\n navigateToUrl(url) {\n location.pathname = url\n }\n\n async fetchConfig() {\n const response = await fetch('/get-config')\n const data = await response.json()\n this.showDomainSearch = data.showDomainSearch || false\n }\n\n get applicationMeta() {\n if (!this._applicationMeta) {\n var iconLink: HTMLLinkElement | null = document.querySelector('link[rel=\"application-icon\"]')\n var titleMeta: HTMLMetaElement | null = document.querySelector('meta[name=\"application-name\"]')\n var descriptionMeta: HTMLMetaElement | null = document.querySelector('meta[name=\"application-description\"]')\n\n this._applicationMeta = {\n icon: iconLink?.href,\n title: titleMeta ? titleMeta.content : 'Things Factory',\n description: descriptionMeta ? descriptionMeta.content : 'Reimagining Software'\n }\n }\n\n return this._applicationMeta\n }\n}\n"]}
|