tas-uell-sdk 0.0.2 → 0.0.4
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/INSTALL_AND_TEST.md +427 -0
- package/esm2020/lib/components/tas-btn/tas-btn.component.mjs +13 -3
- package/esm2020/lib/components/tas-waiting-room/tas-waiting-room.component.mjs +47 -5
- package/fesm2015/tas-uell-sdk.mjs +59 -6
- package/fesm2015/tas-uell-sdk.mjs.map +1 -1
- package/fesm2020/tas-uell-sdk.mjs +58 -6
- package/fesm2020/tas-uell-sdk.mjs.map +1 -1
- package/lib/components/tas-btn/tas-btn.component.d.ts +5 -1
- package/lib/components/tas-waiting-room/tas-waiting-room.component.d.ts +10 -2
- package/package.json +4 -2
- package/src/lib/styles/tas-global.scss +37 -0
|
@@ -0,0 +1,427 @@
|
|
|
1
|
+
# TAS-UELL-SDK Library Installation & Testing Guide
|
|
2
|
+
|
|
3
|
+
This guide provides step-by-step instructions for installing and testing the `tas-uell-sdk` Angular library.
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## Prerequisites
|
|
8
|
+
|
|
9
|
+
- Angular 13+ project
|
|
10
|
+
- Node.js and npm installed
|
|
11
|
+
- A TokBox/Vonage API Key (for video call functionality)
|
|
12
|
+
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
## Installation Steps
|
|
16
|
+
|
|
17
|
+
### Step 1: Install the Library
|
|
18
|
+
|
|
19
|
+
Install from npm:
|
|
20
|
+
|
|
21
|
+
```bash
|
|
22
|
+
npm install tas-uell-sdk --legacy-peer-deps
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
### Step 2: Install Peer Dependencies
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
npm install @ng-bootstrap/ng-bootstrap @opentok/client interactjs --legacy-peer-deps
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
### Step 3: Install Style Dependencies (IMPORTANT!)
|
|
32
|
+
|
|
33
|
+
The library uses **Font Awesome icons** and **Bootstrap** for styling:
|
|
34
|
+
|
|
35
|
+
```bash
|
|
36
|
+
npm install font-awesome bootstrap --legacy-peer-deps
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
### Step 4: Add Styles to angular.json
|
|
40
|
+
|
|
41
|
+
Update your `angular.json` file to include the required CSS files in the `styles` array:
|
|
42
|
+
|
|
43
|
+
```json
|
|
44
|
+
{
|
|
45
|
+
"projects": {
|
|
46
|
+
"your-project-name": {
|
|
47
|
+
"architect": {
|
|
48
|
+
"build": {
|
|
49
|
+
"options": {
|
|
50
|
+
"styles": [
|
|
51
|
+
"node_modules/bootstrap/dist/css/bootstrap.min.css",
|
|
52
|
+
"node_modules/font-awesome/css/font-awesome.min.css",
|
|
53
|
+
"src/styles.scss"
|
|
54
|
+
]
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
**Important:** Make sure Bootstrap and Font Awesome are added BEFORE your custom styles.
|
|
64
|
+
|
|
65
|
+
---
|
|
66
|
+
|
|
67
|
+
## Configuration Steps
|
|
68
|
+
|
|
69
|
+
### Step 5: Create HTTP Adapter Service
|
|
70
|
+
|
|
71
|
+
Create a new file at `src/app/adapters/tas-http-adapter.service.ts`:
|
|
72
|
+
|
|
73
|
+
```typescript
|
|
74
|
+
import { Injectable } from '@angular/core';
|
|
75
|
+
import { HttpClient } from '@angular/common/http';
|
|
76
|
+
import { Observable } from 'rxjs';
|
|
77
|
+
import { TasHttpClient } from 'tas-uell-sdk';
|
|
78
|
+
|
|
79
|
+
@Injectable({ providedIn: 'root' })
|
|
80
|
+
export class TasHttpAdapterService implements TasHttpClient {
|
|
81
|
+
// IMPORTANT: Change this to your actual API URL
|
|
82
|
+
private apiUrl = 'https://your-api-url.com';
|
|
83
|
+
|
|
84
|
+
constructor(private http: HttpClient) {}
|
|
85
|
+
|
|
86
|
+
post<T>(url: string, options: { body: any; headers?: Record<string, string> }): Observable<T> {
|
|
87
|
+
return this.http.post<T>(`${this.apiUrl}/${url}`, options.body, {
|
|
88
|
+
headers: options.headers
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
### Step 6: Update AppModule
|
|
95
|
+
|
|
96
|
+
Update `src/app/app.module.ts` to import and configure the TAS SDK:
|
|
97
|
+
|
|
98
|
+
```typescript
|
|
99
|
+
import { NgModule } from '@angular/core';
|
|
100
|
+
import { BrowserModule } from '@angular/platform-browser';
|
|
101
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
102
|
+
import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
|
|
103
|
+
|
|
104
|
+
// Import TAS SDK
|
|
105
|
+
import { TasUellSdkModule } from 'tas-uell-sdk';
|
|
106
|
+
import { TasHttpAdapterService } from './adapters/tas-http-adapter.service';
|
|
107
|
+
|
|
108
|
+
// IMPORTANT: Replace with your actual TokBox API Key
|
|
109
|
+
const TOKBOX_API_KEY = 'YOUR_TOKBOX_API_KEY';
|
|
110
|
+
|
|
111
|
+
@NgModule({
|
|
112
|
+
declarations: [
|
|
113
|
+
AppComponent,
|
|
114
|
+
// ... your other components
|
|
115
|
+
],
|
|
116
|
+
imports: [
|
|
117
|
+
BrowserModule,
|
|
118
|
+
HttpClientModule,
|
|
119
|
+
NgbModule,
|
|
120
|
+
|
|
121
|
+
// TAS SDK configuration
|
|
122
|
+
TasUellSdkModule.forRoot({
|
|
123
|
+
config: { tokBoxApiKey: TOKBOX_API_KEY },
|
|
124
|
+
httpClient: TasHttpAdapterService
|
|
125
|
+
})
|
|
126
|
+
],
|
|
127
|
+
providers: [],
|
|
128
|
+
bootstrap: [AppComponent]
|
|
129
|
+
})
|
|
130
|
+
export class AppModule { }
|
|
131
|
+
```
|
|
132
|
+
|
|
133
|
+
### Step 7: Add Global Modal Styles
|
|
134
|
+
|
|
135
|
+
Add these styles to your `src/styles.scss` (or `src/styles.css`):
|
|
136
|
+
|
|
137
|
+
```scss
|
|
138
|
+
/* TAS Video Modal - Full screen video call */
|
|
139
|
+
.tas-video-modal {
|
|
140
|
+
.modal-dialog {
|
|
141
|
+
max-width: 100vw;
|
|
142
|
+
margin: 0;
|
|
143
|
+
height: 100vh;
|
|
144
|
+
}
|
|
145
|
+
.modal-content {
|
|
146
|
+
height: 100vh;
|
|
147
|
+
border: none;
|
|
148
|
+
border-radius: 0;
|
|
149
|
+
background: #000;
|
|
150
|
+
}
|
|
151
|
+
.modal-body {
|
|
152
|
+
padding: 0;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
/* TAS Waiting Room Modal */
|
|
157
|
+
.tas-waiting-room-modal {
|
|
158
|
+
.modal-dialog {
|
|
159
|
+
max-width: 480px;
|
|
160
|
+
}
|
|
161
|
+
.modal-content {
|
|
162
|
+
border: none;
|
|
163
|
+
border-radius: 5px;
|
|
164
|
+
background: #ffffff;
|
|
165
|
+
overflow: hidden;
|
|
166
|
+
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15);
|
|
167
|
+
}
|
|
168
|
+
.modal-body {
|
|
169
|
+
padding: 0;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
### Step 8: Add Floating Call Component
|
|
175
|
+
|
|
176
|
+
Update `src/app/app.component.html` to include the floating call component at the end:
|
|
177
|
+
|
|
178
|
+
```html
|
|
179
|
+
<!-- Your existing content -->
|
|
180
|
+
<router-outlet></router-outlet>
|
|
181
|
+
|
|
182
|
+
<!-- Add this line at the end for Picture-in-Picture support -->
|
|
183
|
+
<tas-floating-call></tas-floating-call>
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
---
|
|
187
|
+
|
|
188
|
+
## Usage - Create a Test Component
|
|
189
|
+
|
|
190
|
+
### Step 9: Create a Test Component
|
|
191
|
+
|
|
192
|
+
Create `src/app/tas-test/tas-test.component.ts`:
|
|
193
|
+
|
|
194
|
+
```typescript
|
|
195
|
+
import { Component } from '@angular/core';
|
|
196
|
+
import { TasCurrentUser, TasUserRole } from 'tas-uell-sdk';
|
|
197
|
+
|
|
198
|
+
@Component({
|
|
199
|
+
selector: 'app-tas-test',
|
|
200
|
+
template: `
|
|
201
|
+
<div style="padding: 40px; text-align: center;">
|
|
202
|
+
<h1>TAS SDK Test</h1>
|
|
203
|
+
<p>Click the button below to test the video call functionality:</p>
|
|
204
|
+
|
|
205
|
+
<tas-btn
|
|
206
|
+
[appointmentId]="appointmentId"
|
|
207
|
+
[product]="product"
|
|
208
|
+
[tenantId]="tenantId"
|
|
209
|
+
[currentUser]="currentUser"
|
|
210
|
+
[ownerUserIds]="[userId]"
|
|
211
|
+
[regularUserIds]="[]"
|
|
212
|
+
[moderatorUserIds]="[]"
|
|
213
|
+
></tas-btn>
|
|
214
|
+
|
|
215
|
+
<hr style="margin: 40px 0;">
|
|
216
|
+
|
|
217
|
+
<h3>Test Configuration:</h3>
|
|
218
|
+
<pre style="text-align: left; background: #f5f5f5; padding: 20px; border-radius: 8px;">
|
|
219
|
+
User ID: {{ userId }}
|
|
220
|
+
Appointment ID: {{ appointmentId }}
|
|
221
|
+
Product: {{ product }}
|
|
222
|
+
Tenant ID: {{ tenantId }}
|
|
223
|
+
Current User: {{ currentUser | json }}
|
|
224
|
+
</pre>
|
|
225
|
+
</div>
|
|
226
|
+
`
|
|
227
|
+
})
|
|
228
|
+
export class TasTestComponent {
|
|
229
|
+
// Test configuration - modify these values as needed
|
|
230
|
+
userId = 12345;
|
|
231
|
+
appointmentId = 1;
|
|
232
|
+
product = 'test-product';
|
|
233
|
+
tenantId = 'test-tenant';
|
|
234
|
+
|
|
235
|
+
currentUser: TasCurrentUser = {
|
|
236
|
+
name: 'Test',
|
|
237
|
+
lastname: 'User',
|
|
238
|
+
role: TasUserRole.OWNER
|
|
239
|
+
};
|
|
240
|
+
}
|
|
241
|
+
```
|
|
242
|
+
|
|
243
|
+
### Step 10: Register the Test Component
|
|
244
|
+
|
|
245
|
+
Add the test component to your module declarations in `app.module.ts`:
|
|
246
|
+
|
|
247
|
+
```typescript
|
|
248
|
+
import { TasTestComponent } from './tas-test/tas-test.component';
|
|
249
|
+
|
|
250
|
+
@NgModule({
|
|
251
|
+
declarations: [
|
|
252
|
+
AppComponent,
|
|
253
|
+
TasTestComponent, // Add this
|
|
254
|
+
// ... other components
|
|
255
|
+
],
|
|
256
|
+
// ...
|
|
257
|
+
})
|
|
258
|
+
```
|
|
259
|
+
|
|
260
|
+
### Step 11: Add Route or Use Directly
|
|
261
|
+
|
|
262
|
+
**Option A - Add a route** in `app-routing.module.ts`:
|
|
263
|
+
|
|
264
|
+
```typescript
|
|
265
|
+
const routes: Routes = [
|
|
266
|
+
{ path: 'tas-test', component: TasTestComponent },
|
|
267
|
+
// ... other routes
|
|
268
|
+
];
|
|
269
|
+
```
|
|
270
|
+
|
|
271
|
+
**Option B - Use directly** in `app.component.html`:
|
|
272
|
+
|
|
273
|
+
```html
|
|
274
|
+
<app-tas-test></app-tas-test>
|
|
275
|
+
<tas-floating-call></tas-floating-call>
|
|
276
|
+
```
|
|
277
|
+
|
|
278
|
+
---
|
|
279
|
+
|
|
280
|
+
## Run and Test
|
|
281
|
+
|
|
282
|
+
### Step 12: Start the Application
|
|
283
|
+
|
|
284
|
+
```bash
|
|
285
|
+
ng serve
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
### Step 13: Navigate to Test Page
|
|
289
|
+
|
|
290
|
+
Open your browser and go to:
|
|
291
|
+
- `http://localhost:4200/tas-test` (if using route)
|
|
292
|
+
- Or `http://localhost:4200` (if using directly in app.component)
|
|
293
|
+
|
|
294
|
+
### Step 14: Test the Video Call
|
|
295
|
+
|
|
296
|
+
1. Click the **"Iniciar TAS"** button
|
|
297
|
+
2. The waiting room modal should appear
|
|
298
|
+
3. Click **"Create Room"** to create a video room
|
|
299
|
+
4. Click **"Join Session"** to enter the video call
|
|
300
|
+
5. Test the controls: mute, swap views, minimize to PiP
|
|
301
|
+
6. Test the floating window (PiP mode)
|
|
302
|
+
7. Click hang up to end the call
|
|
303
|
+
|
|
304
|
+
---
|
|
305
|
+
|
|
306
|
+
## Style Dependencies Summary
|
|
307
|
+
|
|
308
|
+
| Dependency | Purpose | Required |
|
|
309
|
+
|------------|---------|----------|
|
|
310
|
+
| `bootstrap` | Button styles, modal layout | ✅ Yes |
|
|
311
|
+
| `font-awesome` | Icons (video, phone, mute, etc.) | ✅ Yes |
|
|
312
|
+
| Global modal styles | Modal positioning | ✅ Yes (add to styles.scss) |
|
|
313
|
+
|
|
314
|
+
---
|
|
315
|
+
|
|
316
|
+
## API Endpoints Required
|
|
317
|
+
|
|
318
|
+
Your backend API must provide these endpoints:
|
|
319
|
+
|
|
320
|
+
| Method | Endpoint | Description |
|
|
321
|
+
|--------|----------|-------------|
|
|
322
|
+
| POST | `v2/room` | Creates a new video room |
|
|
323
|
+
| POST | `v2/room/token` | Generates a session token |
|
|
324
|
+
|
|
325
|
+
### Request/Response Examples
|
|
326
|
+
|
|
327
|
+
**POST v2/room**
|
|
328
|
+
```json
|
|
329
|
+
// Request
|
|
330
|
+
{
|
|
331
|
+
"roomType": "TAS",
|
|
332
|
+
"type": "SPONTANEOUS",
|
|
333
|
+
"tenant": "tenant-id",
|
|
334
|
+
"appointmentId": 123,
|
|
335
|
+
"users": [{ "userExternalId": 12345, "rol": "OWNER" }],
|
|
336
|
+
"product": "product-name"
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
// Response
|
|
340
|
+
{
|
|
341
|
+
"content": {
|
|
342
|
+
"sessionId": "session-id-from-tokbox",
|
|
343
|
+
"roomId": 456
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
```
|
|
347
|
+
|
|
348
|
+
**POST v2/room/token**
|
|
349
|
+
```json
|
|
350
|
+
// Request
|
|
351
|
+
{
|
|
352
|
+
"sessionId": "session-id-from-tokbox",
|
|
353
|
+
"name": "John",
|
|
354
|
+
"lastname": "Doe",
|
|
355
|
+
"roleVC": "OWNER"
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
// Response
|
|
359
|
+
{
|
|
360
|
+
"content": {
|
|
361
|
+
"token": "tokbox-token-string"
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
```
|
|
365
|
+
|
|
366
|
+
---
|
|
367
|
+
|
|
368
|
+
## Troubleshooting
|
|
369
|
+
|
|
370
|
+
### Styles not applying
|
|
371
|
+
- ✅ Check that `bootstrap` and `font-awesome` are installed
|
|
372
|
+
- ✅ Check that styles are added to `angular.json` in the correct order
|
|
373
|
+
- ✅ Check that global modal styles are in `styles.scss`
|
|
374
|
+
- ✅ Restart `ng serve` after modifying `angular.json`
|
|
375
|
+
|
|
376
|
+
### Icons not showing
|
|
377
|
+
- ✅ Verify `font-awesome` is installed: `npm list font-awesome`
|
|
378
|
+
- ✅ Verify the CSS is in `angular.json`: `"node_modules/font-awesome/css/font-awesome.min.css"`
|
|
379
|
+
|
|
380
|
+
### "Cannot find module 'tas-uell-sdk'"
|
|
381
|
+
- ✅ Verify installation: `npm list tas-uell-sdk`
|
|
382
|
+
|
|
383
|
+
### "No provider for TAS_CONFIG"
|
|
384
|
+
- ✅ Ensure `TasUellSdkModule.forRoot()` is called in AppModule
|
|
385
|
+
|
|
386
|
+
### "No provider for TAS_HTTP_CLIENT"
|
|
387
|
+
- ✅ Ensure `httpClient` is passed to `forRoot()`
|
|
388
|
+
|
|
389
|
+
### NgbModal errors
|
|
390
|
+
- ✅ Ensure `NgbModule` is imported in AppModule
|
|
391
|
+
|
|
392
|
+
### Video not working
|
|
393
|
+
- ✅ Check browser console for TokBox errors
|
|
394
|
+
- ✅ Verify TokBox API key is correct
|
|
395
|
+
- ✅ Check camera/microphone permissions
|
|
396
|
+
|
|
397
|
+
---
|
|
398
|
+
|
|
399
|
+
## Checklist
|
|
400
|
+
|
|
401
|
+
- [ ] Library installed (`npm install tas-uell-sdk`)
|
|
402
|
+
- [ ] Peer dependencies installed (`@ng-bootstrap/ng-bootstrap`, `@opentok/client`, `interactjs`)
|
|
403
|
+
- [ ] Style dependencies installed (`bootstrap`, `font-awesome`)
|
|
404
|
+
- [ ] Styles added to `angular.json`
|
|
405
|
+
- [ ] HTTP Adapter service created
|
|
406
|
+
- [ ] AppModule updated with `TasUellSdkModule.forRoot()`
|
|
407
|
+
- [ ] Global modal styles added to `styles.scss`
|
|
408
|
+
- [ ] `<tas-floating-call>` added to app.component.html
|
|
409
|
+
- [ ] Test component created
|
|
410
|
+
- [ ] TokBox API key configured
|
|
411
|
+
- [ ] Backend API endpoints available
|
|
412
|
+
|
|
413
|
+
---
|
|
414
|
+
|
|
415
|
+
## Success Criteria
|
|
416
|
+
|
|
417
|
+
The library is working correctly if:
|
|
418
|
+
1. ✅ The TAS button renders with proper styling (pink/magenta button with video icon)
|
|
419
|
+
2. ✅ Clicking the button opens the waiting room modal
|
|
420
|
+
3. ✅ "Create Room" successfully calls the API
|
|
421
|
+
4. ✅ "Join Session" opens the full-screen video call
|
|
422
|
+
5. ✅ Video from camera is displayed
|
|
423
|
+
6. ✅ Mute/unmute works (icon changes)
|
|
424
|
+
7. ✅ Minimize to PiP works
|
|
425
|
+
8. ✅ Expand from PiP works
|
|
426
|
+
9. ✅ Hang up ends the call properly
|
|
427
|
+
|
|
@@ -16,6 +16,10 @@ export class TasButtonComponent {
|
|
|
16
16
|
this.tenantId = "";
|
|
17
17
|
this.regularUserIds = [];
|
|
18
18
|
this.moderatorUserIds = [];
|
|
19
|
+
/** Optional: If provided, skips room creation and goes directly to getting a token */
|
|
20
|
+
this.existingSessionId = "";
|
|
21
|
+
/** Optional: Custom button text */
|
|
22
|
+
this.buttonText = "Iniciar TAS";
|
|
19
23
|
this.isLoading = false;
|
|
20
24
|
this.subscriptions = new Subscription();
|
|
21
25
|
this.currentModalRef = null;
|
|
@@ -69,6 +73,8 @@ export class TasButtonComponent {
|
|
|
69
73
|
this.currentModalRef.componentInstance.ownerUserIds = this.ownerUserIds;
|
|
70
74
|
this.currentModalRef.componentInstance.regularUserIds = this.regularUserIds;
|
|
71
75
|
this.currentModalRef.componentInstance.moderatorUserIds = this.moderatorUserIds;
|
|
76
|
+
// Pass existing session ID if provided
|
|
77
|
+
this.currentModalRef.componentInstance.existingSessionId = this.existingSessionId;
|
|
72
78
|
this.currentModalRef.result.then(() => { this.currentModalRef = null; }, () => { this.currentModalRef = null; });
|
|
73
79
|
}
|
|
74
80
|
openVideoCallModal(isReturningFromPip = false) {
|
|
@@ -85,10 +91,10 @@ export class TasButtonComponent {
|
|
|
85
91
|
}
|
|
86
92
|
}
|
|
87
93
|
TasButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TasButtonComponent, deps: [{ token: i1.NgbModal }, { token: i2.TasService }], target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
-
TasButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: TasButtonComponent, selector: "tas-btn", inputs: { appointmentId: "appointmentId", product: "product", tenantId: "tenantId", currentUser: "currentUser", ownerUserIds: "ownerUserIds", regularUserIds: "regularUserIds", moderatorUserIds: "moderatorUserIds" }, ngImport: i0, template: "<button\n\ttype=\"button\"\n\tclass=\"btn btn-primary tas-btn\"\n\t(click)=\"onClick()\"\n\t[disabled]=\"isLoading\"\n>\n\t<i class=\"fa fa-video-camera\" aria-hidden=\"true\" *ngIf=\"!isLoading\"></i>\n\t<span *ngIf=\"!isLoading\">
|
|
94
|
+
TasButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: TasButtonComponent, selector: "tas-btn", inputs: { appointmentId: "appointmentId", product: "product", tenantId: "tenantId", currentUser: "currentUser", ownerUserIds: "ownerUserIds", regularUserIds: "regularUserIds", moderatorUserIds: "moderatorUserIds", existingSessionId: "existingSessionId", buttonText: "buttonText" }, ngImport: i0, template: "<button\n\ttype=\"button\"\n\tclass=\"btn btn-primary tas-btn\"\n\t(click)=\"onClick()\"\n\t[disabled]=\"isLoading\"\n>\n\t<i class=\"fa fa-video-camera\" aria-hidden=\"true\" *ngIf=\"!isLoading\"></i>\n\t<span *ngIf=\"!isLoading\"> {{ buttonText }}</span>\n\t<span *ngIf=\"isLoading\"> Processing...</span>\n</button>\n", styles: [":host{display:inline-block}.tas-btn{background-color:#ee316b!important;color:#fff!important;border-color:#ee316b!important;margin-right:24px}.tas-btn:disabled{background-color:#ccc!important;border-color:#ccc!important;cursor:not-allowed}.tas-btn:hover:not(:disabled){background-color:#d62a5f!important;border-color:#d62a5f!important}.tas-btn i{margin-right:5px}\n"], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
89
95
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TasButtonComponent, decorators: [{
|
|
90
96
|
type: Component,
|
|
91
|
-
args: [{ selector: "tas-btn", template: "<button\n\ttype=\"button\"\n\tclass=\"btn btn-primary tas-btn\"\n\t(click)=\"onClick()\"\n\t[disabled]=\"isLoading\"\n>\n\t<i class=\"fa fa-video-camera\" aria-hidden=\"true\" *ngIf=\"!isLoading\"></i>\n\t<span *ngIf=\"!isLoading\">
|
|
97
|
+
args: [{ selector: "tas-btn", template: "<button\n\ttype=\"button\"\n\tclass=\"btn btn-primary tas-btn\"\n\t(click)=\"onClick()\"\n\t[disabled]=\"isLoading\"\n>\n\t<i class=\"fa fa-video-camera\" aria-hidden=\"true\" *ngIf=\"!isLoading\"></i>\n\t<span *ngIf=\"!isLoading\"> {{ buttonText }}</span>\n\t<span *ngIf=\"isLoading\"> Processing...</span>\n</button>\n", styles: [":host{display:inline-block}.tas-btn{background-color:#ee316b!important;color:#fff!important;border-color:#ee316b!important;margin-right:24px}.tas-btn:disabled{background-color:#ccc!important;border-color:#ccc!important;cursor:not-allowed}.tas-btn:hover:not(:disabled){background-color:#d62a5f!important;border-color:#d62a5f!important}.tas-btn i{margin-right:5px}\n"] }]
|
|
92
98
|
}], ctorParameters: function () { return [{ type: i1.NgbModal }, { type: i2.TasService }]; }, propDecorators: { appointmentId: [{
|
|
93
99
|
type: Input
|
|
94
100
|
}], product: [{
|
|
@@ -103,5 +109,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
103
109
|
type: Input
|
|
104
110
|
}], moderatorUserIds: [{
|
|
105
111
|
type: Input
|
|
112
|
+
}], existingSessionId: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], buttonText: [{
|
|
115
|
+
type: Input
|
|
106
116
|
}] } });
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tas-btn.component.js","sourceRoot":"","sources":["../../../../../../projects/tas-uell-sdk/src/lib/components/tas-btn/tas-btn.component.ts","../../../../../../projects/tas-uell-sdk/src/lib/components/tas-btn/tas-btn.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, Input } from \"@angular/core\";\nimport { NgbModal, NgbModalRef } from \"@ng-bootstrap/ng-bootstrap\";\nimport { Subscription } from \"rxjs\";\nimport { TasCurrentUser, ViewMode } from \"../../interfaces/tas.interfaces\";\nimport { TasWaitingRoomComponent } from \"../tas-waiting-room/tas-waiting-room.component\";\nimport { TasVideocallComponent } from \"../tas-videocall/tas-videocall.component\";\nimport { TasService } from \"../../services/tas.service\";\n\n@Component({\n\tselector: \"tas-btn\",\n\ttemplateUrl: \"./tas-btn.component.html\",\n\tstyleUrls: [\"./tas-btn.component.scss\"],\n})\nexport class TasButtonComponent implements OnInit, OnDestroy {\n\t@Input() appointmentId: number = 1;\n\t@Input() product: string = \"uell\";\n\t@Input() tenantId: string = \"\";\n\t@Input() currentUser!: TasCurrentUser;\n\t@Input() ownerUserIds!: number[];\n\t@Input() regularUserIds: number[] = [];\n\t@Input() moderatorUserIds: number[] = [];\n\t\n\tpublic isLoading = false;\n\t\n\tprivate subscriptions = new Subscription();\n\tprivate currentModalRef: NgbModalRef | null = null;\n\tprivate videoCallModalRef: NgbModalRef | null = null;\n\n\tconstructor(\n\t\tprivate modalService: NgbModal,\n\t\tprivate tasService: TasService\n\t) {}\n\n\tngOnInit(): void {\n\t\tif (!this.ownerUserIds || this.ownerUserIds.length !== 1) {\n\t\t\tthrow new Error('tas-btn: ownerUserIds input is required and must contain exactly one user');\n\t\t}\n\t\t\n\t\t// Subscribe to viewMode to handle PiP return\n\t\tthis.subscriptions.add(\n\t\t\tthis.tasService.viewMode$.subscribe(mode => {\n\t\t\t\t// Reopen video call modal when returning from PiP\n\t\t\t\tif (mode === ViewMode.FULLSCREEN && \n\t\t\t\t\tthis.tasService.isCallActive() && \n\t\t\t\t\t!this.videoCallModalRef) {\n\t\t\t\t\tconst sessionId = this.tasService.sessionId;\n\t\t\t\t\tconst token = this.tasService.token;\n\t\t\t\t\tif (sessionId && token) {\n\t\t\t\t\t\tthis.openVideoCallModal(true);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t// When entering PiP, clear the videoCallModalRef since modal will close\n\t\t\t\tif (mode === ViewMode.PIP) {\n\t\t\t\t\tthis.videoCallModalRef = null;\n\t\t\t\t}\n\t\t\t})\n\t\t);\n\t}\n\n\tngOnDestroy(): void {\n\t\tthis.subscriptions.unsubscribe();\n\t}\n\n\tonClick(): void {\n\t\tif (!this.tenantId || !this.currentUser?.name) {\n\t\t\tconsole.error(\"Tenant ID or current user not available\");\n\t\t\treturn;\n\t\t}\n\n\t\tthis.openWaitingRoomModal();\n\t}\n\n\tprivate openWaitingRoomModal(): void {\n\t\tthis.currentModalRef = this.modalService.open(TasWaitingRoomComponent, {\n\t\t\tsize: \"lg\",\n\t\t\twindowClass: \"tas-waiting-room-modal\",\n\t\t\tbackdrop: \"static\",\n\t\t\tkeyboard: false,\n\t\t\tcentered: true\n\t\t});\n\n\t\t// Pass all necessary inputs to the waiting room component\n\t\tthis.currentModalRef.componentInstance.appointmentId = this.appointmentId;\n\t\tthis.currentModalRef.componentInstance.product = this.product;\n\t\tthis.currentModalRef.componentInstance.tenantId = this.tenantId;\n\t\tthis.currentModalRef.componentInstance.currentUser = this.currentUser;\n\t\tthis.currentModalRef.componentInstance.ownerUserIds = this.ownerUserIds;\n\t\tthis.currentModalRef.componentInstance.regularUserIds = this.regularUserIds;\n\t\tthis.currentModalRef.componentInstance.moderatorUserIds = this.moderatorUserIds;\n\n\t\tthis.currentModalRef.result.then(\n\t\t\t() => { this.currentModalRef = null; },\n\t\t\t() => { this.currentModalRef = null; }\n\t\t);\n\t}\n\n\tprivate openVideoCallModal(isReturningFromPip: boolean = false): void {\n\t\tthis.videoCallModalRef = this.modalService.open(TasVideocallComponent, {\n\t\t\tsize: 'xl',\n\t\t\twindowClass: 'tas-video-modal',\n\t\t\tbackdrop: 'static',\n\t\t\tkeyboard: false\n\t\t});\n\n\t\tthis.videoCallModalRef.componentInstance.sessionId = this.tasService.sessionId;\n\t\tthis.videoCallModalRef.componentInstance.token = this.tasService.token;\n\t\tthis.videoCallModalRef.componentInstance.isReturningFromPip = isReturningFromPip;\n\n\t\tthis.videoCallModalRef.result.then(\n\t\t\t() => { this.videoCallModalRef = null; },\n\t\t\t() => { this.videoCallModalRef = null; }\n\t\t);\n\t}\n}\n\n","<button\n\ttype=\"button\"\n\tclass=\"btn btn-primary tas-btn\"\n\t(click)=\"onClick()\"\n\t[disabled]=\"isLoading\"\n>\n\t<i class=\"fa fa-video-camera\" aria-hidden=\"true\" *ngIf=\"!isLoading\"></i>\n\t<span *ngIf=\"!isLoading\"> Iniciar TAS</span>\n\t<span *ngIf=\"isLoading\"> Processing...</span>\n</button>\n\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tas-btn.component.js","sourceRoot":"","sources":["../../../../../../projects/tas-uell-sdk/src/lib/components/tas-btn/tas-btn.component.ts","../../../../../../projects/tas-uell-sdk/src/lib/components/tas-btn/tas-btn.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, Input } from \"@angular/core\";\nimport { NgbModal, NgbModalRef } from \"@ng-bootstrap/ng-bootstrap\";\nimport { Subscription } from \"rxjs\";\nimport { TasCurrentUser, ViewMode } from \"../../interfaces/tas.interfaces\";\nimport { TasWaitingRoomComponent } from \"../tas-waiting-room/tas-waiting-room.component\";\nimport { TasVideocallComponent } from \"../tas-videocall/tas-videocall.component\";\nimport { TasService } from \"../../services/tas.service\";\n\n@Component({\n\tselector: \"tas-btn\",\n\ttemplateUrl: \"./tas-btn.component.html\",\n\tstyleUrls: [\"./tas-btn.component.scss\"],\n})\nexport class TasButtonComponent implements OnInit, OnDestroy {\n\t@Input() appointmentId: number = 1;\n\t@Input() product: string = \"uell\";\n\t@Input() tenantId: string = \"\";\n\t@Input() currentUser!: TasCurrentUser;\n\t@Input() ownerUserIds!: number[];\n\t@Input() regularUserIds: number[] = [];\n\t@Input() moderatorUserIds: number[] = [];\n\t\n\t/** Optional: If provided, skips room creation and goes directly to getting a token */\n\t@Input() existingSessionId: string = \"\";\n\t\n\t/** Optional: Custom button text */\n\t@Input() buttonText: string = \"Iniciar TAS\";\n\t\n\tpublic isLoading = false;\n\t\n\tprivate subscriptions = new Subscription();\n\tprivate currentModalRef: NgbModalRef | null = null;\n\tprivate videoCallModalRef: NgbModalRef | null = null;\n\n\tconstructor(\n\t\tprivate modalService: NgbModal,\n\t\tprivate tasService: TasService\n\t) {}\n\n\tngOnInit(): void {\n\t\tif (!this.ownerUserIds || this.ownerUserIds.length !== 1) {\n\t\t\tthrow new Error('tas-btn: ownerUserIds input is required and must contain exactly one user');\n\t\t}\n\t\t\n\t\t// Subscribe to viewMode to handle PiP return\n\t\tthis.subscriptions.add(\n\t\t\tthis.tasService.viewMode$.subscribe(mode => {\n\t\t\t\t// Reopen video call modal when returning from PiP\n\t\t\t\tif (mode === ViewMode.FULLSCREEN && \n\t\t\t\t\tthis.tasService.isCallActive() && \n\t\t\t\t\t!this.videoCallModalRef) {\n\t\t\t\t\tconst sessionId = this.tasService.sessionId;\n\t\t\t\t\tconst token = this.tasService.token;\n\t\t\t\t\tif (sessionId && token) {\n\t\t\t\t\t\tthis.openVideoCallModal(true);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t// When entering PiP, clear the videoCallModalRef since modal will close\n\t\t\t\tif (mode === ViewMode.PIP) {\n\t\t\t\t\tthis.videoCallModalRef = null;\n\t\t\t\t}\n\t\t\t})\n\t\t);\n\t}\n\n\tngOnDestroy(): void {\n\t\tthis.subscriptions.unsubscribe();\n\t}\n\n\tonClick(): void {\n\t\tif (!this.tenantId || !this.currentUser?.name) {\n\t\t\tconsole.error(\"Tenant ID or current user not available\");\n\t\t\treturn;\n\t\t}\n\n\t\tthis.openWaitingRoomModal();\n\t}\n\n\tprivate openWaitingRoomModal(): void {\n\t\tthis.currentModalRef = this.modalService.open(TasWaitingRoomComponent, {\n\t\t\tsize: \"lg\",\n\t\t\twindowClass: \"tas-waiting-room-modal\",\n\t\t\tbackdrop: \"static\",\n\t\t\tkeyboard: false,\n\t\t\tcentered: true\n\t\t});\n\n\t\t// Pass all necessary inputs to the waiting room component\n\t\tthis.currentModalRef.componentInstance.appointmentId = this.appointmentId;\n\t\tthis.currentModalRef.componentInstance.product = this.product;\n\t\tthis.currentModalRef.componentInstance.tenantId = this.tenantId;\n\t\tthis.currentModalRef.componentInstance.currentUser = this.currentUser;\n\t\tthis.currentModalRef.componentInstance.ownerUserIds = this.ownerUserIds;\n\t\tthis.currentModalRef.componentInstance.regularUserIds = this.regularUserIds;\n\t\tthis.currentModalRef.componentInstance.moderatorUserIds = this.moderatorUserIds;\n\t\t\n\t\t// Pass existing session ID if provided\n\t\tthis.currentModalRef.componentInstance.existingSessionId = this.existingSessionId;\n\n\t\tthis.currentModalRef.result.then(\n\t\t\t() => { this.currentModalRef = null; },\n\t\t\t() => { this.currentModalRef = null; }\n\t\t);\n\t}\n\n\tprivate openVideoCallModal(isReturningFromPip: boolean = false): void {\n\t\tthis.videoCallModalRef = this.modalService.open(TasVideocallComponent, {\n\t\t\tsize: 'xl',\n\t\t\twindowClass: 'tas-video-modal',\n\t\t\tbackdrop: 'static',\n\t\t\tkeyboard: false\n\t\t});\n\n\t\tthis.videoCallModalRef.componentInstance.sessionId = this.tasService.sessionId;\n\t\tthis.videoCallModalRef.componentInstance.token = this.tasService.token;\n\t\tthis.videoCallModalRef.componentInstance.isReturningFromPip = isReturningFromPip;\n\n\t\tthis.videoCallModalRef.result.then(\n\t\t\t() => { this.videoCallModalRef = null; },\n\t\t\t() => { this.videoCallModalRef = null; }\n\t\t);\n\t}\n}\n","<button\n\ttype=\"button\"\n\tclass=\"btn btn-primary tas-btn\"\n\t(click)=\"onClick()\"\n\t[disabled]=\"isLoading\"\n>\n\t<i class=\"fa fa-video-camera\" aria-hidden=\"true\" *ngIf=\"!isLoading\"></i>\n\t<span *ngIf=\"!isLoading\"> {{ buttonText }}</span>\n\t<span *ngIf=\"isLoading\"> Processing...</span>\n</button>\n"]}
|