-
-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathct-loading.ts
More file actions
executable file
·118 lines (111 loc) · 2.77 KB
/
ct-loading.ts
File metadata and controls
executable file
·118 lines (111 loc) · 2.77 KB
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import "./ct-card.js";
import "./ct-spinner.js";
import "./lit-if.js";
import { CtDialog, showCtDialog } from "./ct-dialog.js";
import { CtLit, customElement, html } from "./ct-lit.js";
/**
* ## `ct-loading`
* A dialog component that displays a loading spinner with customizable text.
*
* ### Usage
* ```javascript
* import { showCtLoading } from "./ct-dialog.js";
*
* // Show a loading dialog
* const loadingDialog = showCtLoading();
*
* // Show a loading dialog with custom text
* const customLoadingDialog = showCtLoading(undefined, 'Processing');
*
* // Close the dialog when operation completes
* loadingDialog.close();
* ```
*
* @group ct-elements
* @element ct-loading
*/
@customElement("ct-loading")
export class CtLoading extends CtLit {
/**
* Text to display next to the spinner
*/
ttl: string = "Loading";
/**
* Reference to the internal dialog instance
*/
dialog!: CtDialog;
render() {
return html`
<style>
:host {
display: block;
}
.body {
display: flex;
flex-direction: row;
align-items: center;
margin: 0 auto;
}
ct-spinner {
margin-right: 24px;
}
</style>
<ct-card shadow decorator>
<div class="card-content">
<span class="body"> <ct-spinner></ct-spinner>${this.ttl}... </span>
</div>
</ct-card>
`;
}
static get properties() {
return {
ttl: { type: String }
};
}
}
declare global {
interface HTMLElementTagNameMap {
"ct-loading": CtLoading;
}
}
/**
* Displays a loading dialog with a spinner and optional custom text
*
* @param {string} [id] - Optional identifier for the dialog
* @param {string} [str] - Optional custom text to display (default: "Loading")
* @returns {CtDialog} The created dialog instance
*
* @example
* ```javascript
* // Display a loading dialog
* const dialog = showCtLoading();
*
* // Do some async operation
* await someAsyncOperation();
*
* // Close the loading dialog when complete
* dialog.close();
* ```
*/
export function showCtLoading(id?: string, str?: string): CtDialog {
let ctConfirm = document.createElement("ct-loading") as CtLoading;
if (str) ctConfirm.ttl = str;
ctConfirm.dialog = showCtDialog(ctConfirm, id);
return ctConfirm.dialog;
}
/**
* Displays a loading dialog and returns the CtLoading instance
*
* @param {string} [id] - Optional identifier for the dialog
* @param {string} [str] - Optional custom text to display (default: "Loading")
* @returns {CtLoading} The created CtLoading instance
*/
export function showCtLoading2(id?: string, str?: string): CtLoading {
let ctConfirm = document.createElement("ct-loading") as CtLoading;
if (str) ctConfirm.ttl = str;
ctConfirm.dialog = showCtDialog(ctConfirm, id);
return ctConfirm;
}
export { CtDialog };
// @ts-ignore
window.showCtLoading = showCtLoading;