1 <div class="import-container-all">
2 <div class="import-container">
3 <div class="import-container-input">
4 <input class="ng-pristine ng-valid ng-touched" placeholder="Enter file URL then ENTER" type="input">
5 <a class="enter-link" href="#"><i class="icon-enter-link"></i></a>
7 <span tourAnchor="st-scriptsImport" class="import-container-span">Or you can also <a data-target="#scriptsModal"
9 (click)="resetTheUploadedFiles()"
10 href="#"><b>Import File</b></a></span>
12 <div class="card creat-card"></div>
13 <div class="single-line-model">
14 <label class="label-name">File Name
15 <span _ngcontent-uew-c3="">*</span>
17 <div class="label-input">
18 <input type="input" [(ngModel)]="currentFileName"
19 placeholder="script name" name="scriptName" autofocus [autofocus]="true">
21 <div class="single-line">
22 <label class="label-name">Script Type</label>
23 <div class="label-input" (change)="changeExtension()">
24 <label name="trst" id="kt">
25 <input class="form-check-input" [(ngModel)]="scriptExtension" type="radio"
26 name="exampleRadios1" id="kt" value=kotlin>
31 <label name="trst" id="py">
32 <input class="form-check-input" [(ngModel)]="scriptExtension" type="radio"
33 name="exampleRadios2" id="py" value=python>
39 <input class="form-check-input" [(ngModel)]="scriptExtension" type="radio"
40 name="exampleRadios3" id="ansible" value=ansible>
48 <div id="id-script" class="collapse show">
49 <div class="card-body">
50 <ace-editor [(text)]="currentFileContent"
51 [mode]="currentExtension"
52 [autoUpdateContent]="true" [durationBeforeCallback]="3000" [theme]="'eclipse'"
54 style="height:300px;">
59 <button tourAnchor="tm-templateFinish" (click)="textCurrentChanges()" [disabled]="currentFileName?.length == 0 ||
60 this.currentFileContent?.length == 0
62 title="Submit template and close" class="btn btn-primary">Save
67 <div class="accordion">
68 <!-- <div class="card creat-card">
69 <div class="single-line">
70 <label class="label-name">File</label>
73 <div *ngFor="let file of scriptsFiles | keyvalue; let mapIndex = index" id="accordion-script">
76 <div [id]="'head-script-'+mapIndex" class="card-header">
77 <h5 class="mb-0 d-flex justify-content-between">
78 <button (click)="changeDivShow(mapIndex)" aria-expanded="false" class="btn btn-link collapsed"
79 data-toggle="collapse">
80 <i class="icon-file-code"></i> {{file.key}}
82 <a data-toggle="modal" (click)="initDelete(file)" data-target="#exampleModal"
83 class="accordion-delete"><i class="icon-delete-sm"></i></a>
84 <!-- <a (click)="removeFile(file.key,mapIndex)" data-toggle="modal" data-target="#exampleModal" class="accordion-delete"><i
85 class="icon-delete-sm"></i></a> -->
87 <div class="modal fade" id="exampleModal" tabindex="-1" role="dialog"
88 aria-labelledby="exampleModalLabel" aria-hidden="true">
89 <div class="modal-dialog" role="document">
90 <div class="modal-content">
91 <div class="modal-header">
92 <h5 class="modal-title" id="exampleModalLabel">Delete Script</h5>
93 <button type="button" class="close" data-dismiss="modal" aria-label="Close">
94 <img src="assets/img/icon-close.svg"/>
97 <div class="modal-body">
98 <p>Are you sure you want to delete script file
99 <span>{{fileToDelete?.key?.split('/')[2]}}</span>?</p>
101 <div class="modal-footer">
102 <button type="button" class="btn btn-secondary"
103 data-dismiss="modal">Cancel
105 <button type="button" (click)="removeFile(fileToDelete?.key,0)"
106 data-dismiss="modal" class="btn btn-danger">Delete
116 <div [attr.aria-labelledby]="'head-script-'+mapIndex" [id]="'id-script-'+mapIndex" class="collapse"
117 data-parent="#accordion-script">
118 <div class="card-body">
119 <ace-editor [(text)]="file.value" (textChange)="textChanges($event,file.key)" [mode]="'kotlin'"
120 [autoUpdateContent]="true" [durationBeforeCallback]="5000" [theme]="'eclipse'"
122 style="height:300px;">
133 <div aria-hidden="true" aria-labelledby="scriptsModalLabel" class="modal fade" id="scriptsModal" role="dialog"
135 <div class="modal-dialog" role="document">
136 <div class="modal-content">
137 <div class="modal-header">
138 <h5 class="modal-title" id="scriptsModalLabel">Import File</h5>
139 <button aria-label="Close" class="close" data-dismiss="modal" type="button">
140 <img src="assets/img/icon-close.svg"/>
143 <div class="modal-body">
144 <ngx-file-drop accept=".kt,.py" (onFileDrop)="dropped($event)" (onFileLeave)="fileLeave($event)"
145 (onFileOver)="fileOver($event)" dropZoneLabel="Drop files here">
146 <ng-template let-openFileSelector="openFileSelector" ngx-file-drop-content-tmp>
147 <div class="folder-upload">
148 <img src="assets/img/folder-upload.svg"/>
150 <div class="folder-upload-text">
153 <div class="folder-upload-text">or
154 <button (click)="openFileSelector()" class="btn btn-sm btn-primary" type="button">Browse
158 <div class="folder-upload-type">Allowed file type: Kotlin(kt), Python(py)</div>
161 <div class="upload-table">
162 <table class="table">
164 <tr *ngFor="let item of uploadedFiles; let i=index">
165 <th width="40"><img src="assets/img/icon-file-code.svg"/></th>
166 <th>{{ item.name }}</th>
167 <th (click)="removeInitFile(i)" width="40" class="text-right"><img
168 src="assets/img/icon-remove-file.svg"/></th>
174 <div class="modal-footer">
175 <button (click)="resetTheUploadedFiles()" class="btn btn-sm btn-secondary" data-dismiss="modal"
178 <button (click)="setFilesToStore()" class="btn btn-sm btn-primary" [disabled]="uploadedFiles?.length<=0"
179 data-dismiss="modal" type="button">