UNPKG

iris-ds

Version:

Joveo iris libray

137 lines 22.3 kB
import { Component, Input, ViewChild } from '@angular/core'; // Old CODE // <div class="dropzone-container"> // <h5 class="w500">{{title}}</h5> // <p class="subtitle2 mt-1 mb-4">{{subtitle}}</p> // <div class="progress" #progressBar > // </div> // <div> // <div DragDrop class="dropzone" (filesChangeEmiter)="onFileChange($event)"> // <div class="text-wrapper"> // <div class="centered"> // <input type="file" name="file" id="file" (change)="onFileChange($event.target.files)" multiple> // <label for="file"><span class="textLink">Choose a file</span> or Drag it here!</label> // </div> // </div> // </div> // </div> // <hr> // <div> // <h3 mat-subheader>Files</h3> // <div *ngFor="let file of files"> // <div>{{file.name}}</div> // <button color="warn" (click)="deleteFile(file)">Delete</button> // </div> // </div> // </div> export class DropzoneComponent { constructor() { this.files = []; this.src = ''; this.title = ''; this.subtitle = ''; this.backgroundType = 'solid'; this.size = 'medium'; this.imgStyles = {}; this.nameStyles = {}; this.progressState = 'verify'; this.alt = ''; this.bgColors = [ 'red', 'pink', 'purple', 'deep-purple', 'indigo', 'blue', 'light-blue', 'cyan', 'teal', 'green', 'light-green', 'lime', 'amber', 'orange', 'deep-orange', ]; this.colorCssClass = ''; } ngAfterViewInit() { this.progressBar.nativeElement.hidden = true; //state = verify / success / error } ngOnChanges() { this.setProgress(this.ProgressPercentage); } onFileChange(pFileList) { console.log("change called"); this.files = Object.keys(pFileList).map(key => pFileList[key]); this.progressBar.nativeElement.hidden = false; // this.setProgressState('verify') } resetFileStack(event) { if (this.files.length == 0) { console.log("set dom data to null"); event.target.value = null; } } deleteFile(f) { this.files = this.files.filter(function (w) { return w.name != f.name; }); if (this.files.length == 0) { this.progressBar.nativeElement.hidden = true; } } setProgress(progresspercentage) { const totalLength = (this.progressBar.nativeElement.offsetWidth * 2) + (this.progressBar.nativeElement.offsetHeight * 2); const input = (progresspercentage > 100) ? 100 : progresspercentage; const borderLen = (input / 100) * totalLength; let backgroundPos; if (borderLen <= this.progressBar.nativeElement.offsetWidth) { backgroundPos = (-448 + borderLen) + 'px 0px, 448px -100px, 453px 95px, 0px 100px'; } else if (borderLen <= (this.progressBar.nativeElement.offsetWidth + this.progressBar.nativeElement.offsetHeight)) { backgroundPos = '0px 0px, 448px ' + (-100 + (borderLen - this.progressBar.nativeElement.offsetWidth)) + 'px, 453px 95px, 0px 100px'; } else if (borderLen <= (this.progressBar.nativeElement.offsetWidth * 2 + this.progressBar.nativeElement.offsetHeight)) { backgroundPos = '0px 0px, 448px 0px, ' + (448 - (borderLen - this.progressBar.nativeElement.offsetWidth - this.progressBar.nativeElement.offsetHeight)) + 'px 95px, 0px 100px'; } else { backgroundPos = '0px 0px, 448px 0px, 0px 95px, 0px ' + (100 - (borderLen - (this.progressBar.nativeElement.offsetWidth * 2) - this.progressBar.nativeElement.offsetHeight)) + 'px'; } this.progressBar.nativeElement.setAttribute("style", "background-position : " + backgroundPos); } } DropzoneComponent.decorators = [ { type: Component, args: [{ selector: 'iris-dropzone', template: ` <div class="dropzone-container"> <h5 class="iris-h5 w500">{{title}}</h5> <p class="iris-body2 mt-1 mb-4">{{subtitle}}</p> <div class="{{ 'progress ' + progressState }}" #progressBar> <div class="filenamecontainer"> <div *ngFor="let file of files"> <div class="filename">{{file.name}}</div> <button color="warn" (click)="deleteFile(file)"><svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg"> <path d="M10.0003 1.66602C5.39199 1.66602 1.66699 5.39102 1.66699 9.99935C1.66699 14.6077 5.39199 18.3327 10.0003 18.3327C14.6087 18.3327 18.3337 14.6077 18.3337 9.99935C18.3337 5.39102 14.6087 1.66602 10.0003 1.66602ZM14.167 12.991L12.992 14.166L10.0003 11.1744L7.00866 14.166L5.83366 12.991L8.82533 9.99935L5.83366 7.00768L7.00866 5.83268L10.0003 8.82435L12.992 5.83268L14.167 7.00768L11.1753 9.99935L14.167 12.991Z" fill="#718096"/> </svg> </button> </div> </div> </div> <div> <div DragDrop class="dropzone" (filesChangeEmiter)="onFileChange($event)"> <div class="text-wrapper"> <div class="centered"> <input type="file" name="file" id="file" (change)="onFileChange($event.target.files)" (click)="resetFileStack($event)"> <label for="file"><span class="textLink">Choose a file</span> or Drag it here!</label> </div> </div> </div> </div> </div> `, styles: ["@charset \"UTF-8\";.iris-h6{font-size:.6rem}.iris-h5,.iris-h6{color:#212121;margin:0}.iris-h5{font-size:1.2rem}.iris-h4{font-size:1.8rem}.iris-h3,.iris-h4{color:#212121;margin:0}.iris-h3{font-size:2.4rem}.iris-h2{font-size:3rem}.iris-h1,.iris-h2{color:#212121;margin:0}.iris-h1{font-size:3.6rem}.iris-subtitle1{font-size:1rem!important;color:#424242;font-weight:500;line-height:1.2rem}.iris-subtitle2{font-size:.9rem!important;color:#424242;font-weight:500}.iris-body1{line-height:1.2rem}.iris-body1,.iris-body2{font-size:.9rem!important;color:#616161;font-weight:400}.iris-caption{font-size:.75rem}.iris-caption,.iris-overline{color:#616161;font-weight:400}.iris-overline{font-size:.65rem}.w100{font-weight:100}.w200{font-weight:200}.w400{font-weight:400}.w500{font-weight:500}.w600{font-weight:600}.w700{font-weight:700}.dropzone{height:96px;display:table;background-color:#fff}.dropzone,.dropzone-container{width:448px}input[type=file]{display:none}.textLink{color:#2196f3;font-weight:600;cursor:pointer}.text-wrapper{display:table-cell;vertical-align:middle}.centered{font-size:1rem;text-align:center;color:#616161}.fileItem{width:calc(25% - 6px);overflow:hidden;height:-moz-fit-content;height:fit-content;margin:3px;padding:10px;display:block;position:relative;float:left;border:2px dashed #789;border-radius:5px;transition:.3s ease}.fileItem:hover{border:2px solid #c33838;background-color:rgba(195,56,56,.7490196078431373)}.fileItem:hover .fileItemIcon:before{content:\"\uF00D\";color:#f5f5f5}.fileItem:hover .fileItemText{color:#f5f5f5}.fileItemIconDiv{text-align:center}.fileItemIcon:before{font-style:normal;content:\"\uF15B\";color:#789;font-family:Font Awesome\\ 5 Free;font-weight:900}.fileItemText{text-align:center;margin-top:10px;height:40px}.filename{color:#4a5568;font-weight:500;float:left}.filenamecontainer{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center;background:#fff;width:calc(100% - 6px);margin-left:2px;margin-top:40px}.progress{height:100px;position:absolute;width:453px;margin-top:0;background-size:100% 5px,5px 100%,100% 5px,5px 100%!important;background-repeat:no-repeat!important;animation:progress 4s linear forwards}.progress.verify{background:linear-gradient(90deg,#42a5f5 99.99%,transparent),linear-gradient(180deg,#42a5f5 99.99%,transparent),linear-gradient(90deg,#42a5f5 99.99%,transparent),linear-gradient(180deg,#42a5f5 99.99%,transparent)}.progress.success{background:linear-gradient(90deg,#81c784 99.99%,transparent),linear-gradient(180deg,#81c784 99.99%,transparent),linear-gradient(90deg,#81c784 99.99%,transparent),linear-gradient(180deg,#81c784 99.99%,transparent)}.progress.error{background:linear-gradient(90deg,#e57373 99.99%,transparent),linear-gradient(180deg,#e57373 99.99%,transparent),linear-gradient(90deg,#e57373 99.99%,transparent),linear-gradient(180deg,#e57373 99.99%,transparent)}button{background:none;border:0;cursor:pointer}"] },] } ]; DropzoneComponent.ctorParameters = () => []; DropzoneComponent.propDecorators = { progressBar: [{ type: ViewChild, args: ['progressBar', { static: true },] }], src: [{ type: Input }], title: [{ type: Input }], subtitle: [{ type: Input }], backgroundType: [{ type: Input }], size: [{ type: Input }], imgStyles: [{ type: Input }], nameStyles: [{ type: Input }], ProgressPercentage: [{ type: Input }], progressState: [{ type: Input }] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropzone.component.js","sourceRoot":"","sources":["../../../../../projects/iris/src/lib/dropzone/dropzone.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ElementRef, ViewChild, AfterViewInit, OnChanges, SimpleChanges } from '@angular/core';\n\n@Component({\n  selector: 'iris-dropzone',\n  template: `\n    <div class=\"dropzone-container\">\n      <h5 class=\"iris-h5 w500\">{{title}}</h5>\n      <p class=\"iris-body2 mt-1 mb-4\">{{subtitle}}</p>\n      <div class=\"{{ 'progress ' + progressState }}\" #progressBar>\n        <div class=\"filenamecontainer\">\n            <div *ngFor=\"let file of files\">\n                <div class=\"filename\">{{file.name}}</div>\n                <button color=\"warn\" (click)=\"deleteFile(file)\"><svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                <path d=\"M10.0003 1.66602C5.39199 1.66602 1.66699 5.39102 1.66699 9.99935C1.66699 14.6077 5.39199 18.3327 10.0003 18.3327C14.6087 18.3327 18.3337 14.6077 18.3337 9.99935C18.3337 5.39102 14.6087 1.66602 10.0003 1.66602ZM14.167 12.991L12.992 14.166L10.0003 11.1744L7.00866 14.166L5.83366 12.991L8.82533 9.99935L5.83366 7.00768L7.00866 5.83268L10.0003 8.82435L12.992 5.83268L14.167 7.00768L11.1753 9.99935L14.167 12.991Z\" fill=\"#718096\"/>\n                </svg>\n                </button>\n            </div>\n        </div>\n      </div>\n      <div>\n        <div DragDrop class=\"dropzone\" (filesChangeEmiter)=\"onFileChange($event)\">\n          <div class=\"text-wrapper\">\n            <div class=\"centered\">\n              <input type=\"file\" name=\"file\" id=\"file\" (change)=\"onFileChange($event.target.files)\" (click)=\"resetFileStack($event)\">\n              <label for=\"file\"><span class=\"textLink\">Choose a file</span> or Drag it here!</label>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  `,\n  styleUrls: ['./dropzone.component.scss']\n})\n\n// Old CODE\n// <div class=\"dropzone-container\">\n// <h5 class=\"w500\">{{title}}</h5>\n// <p class=\"subtitle2 mt-1 mb-4\">{{subtitle}}</p>\n// <div class=\"progress\" #progressBar >\n\n// </div>\n// <div>\n//   <div DragDrop class=\"dropzone\" (filesChangeEmiter)=\"onFileChange($event)\">\n//     <div class=\"text-wrapper\">\n//       <div class=\"centered\">\n//         <input type=\"file\" name=\"file\" id=\"file\" (change)=\"onFileChange($event.target.files)\" multiple>\n//         <label for=\"file\"><span class=\"textLink\">Choose a file</span> or Drag it here!</label>\n//       </div>\n//     </div>\n//   </div>\n// </div>\n// <hr>\n// <div>\n//     <h3 mat-subheader>Files</h3>\n//     <div *ngFor=\"let file of files\">\n//         <div>{{file.name}}</div>\n//         <button color=\"warn\" (click)=\"deleteFile(file)\">Delete</button>\n//     </div>\n// </div>\n// </div>\n\n\n\nexport class DropzoneComponent implements AfterViewInit, OnChanges{\n  public files: any[] = [];\n\n  @ViewChild('progressBar', {static: true}) progressBar: ElementRef;\n  @Input() src = '';\n  @Input() title = '';\n  @Input() subtitle = '';\n  @Input() backgroundType: 'solid' | 'subtle' = 'solid';\n  @Input() size: 'small' | 'medium' | 'large' = 'medium'\n  @Input() imgStyles: { [type: string]: string } = {};\n  @Input() nameStyles: { [type: string]: string } = {};\n  @Input() ProgressPercentage: 0;\n  @Input() progressState: 'verify' | 'success' | 'error' = 'verify';\n\n  alt = '';\n  bgColors = [\n    'red', 'pink', 'purple', 'deep-purple', 'indigo', 'blue',\n    'light-blue', 'cyan', 'teal', 'green', 'light-green',\n    'lime', 'amber', 'orange', 'deep-orange',\n  ];\n  colorCssClass = '';\n\n  constructor() {\n  }\n  ngAfterViewInit(): void {\n    this.progressBar.nativeElement.hidden=true;\n    //state = verify / success / error\n  }\n  ngOnChanges(): void {\n    this.setProgress(this.ProgressPercentage)\n  }\n\n  onFileChange(pFileList: File[]){\n    console.log(\"change called\")\n    this.files = Object.keys(pFileList).map(key => pFileList[key]);\n    this.progressBar.nativeElement.hidden=false;\n    // this.setProgressState('verify')\n  }\n  resetFileStack(event)\n  {\n    if(this.files.length == 0)\n    {\n      console.log(\"set dom data to null\")\n      event.target.value = null\n    }\n  }\n  deleteFile(f){\n    this.files = this.files.filter(function(w){ return w.name != f.name });\n    if(this.files.length == 0)\n    {\n      this.progressBar.nativeElement.hidden=true;\n    }\n  }\n  setProgress(progresspercentage)\n  {\n      const totalLength = (this.progressBar.nativeElement.offsetWidth * 2) + (this.progressBar.nativeElement.offsetHeight * 2);\n      const input = (progresspercentage > 100) ? 100 : progresspercentage;\n      const borderLen = (input / 100) * totalLength;\n      let backgroundPos;\n      if (borderLen <= this.progressBar.nativeElement.offsetWidth) {\n        backgroundPos = (-448 + borderLen) + 'px 0px, 448px -100px, 453px 95px, 0px 100px';\n      } else if (borderLen <= (this.progressBar.nativeElement.offsetWidth + this.progressBar.nativeElement.offsetHeight)) {\n        backgroundPos = '0px 0px, 448px ' + (-100 + (borderLen - this.progressBar.nativeElement.offsetWidth)) + 'px, 453px 95px, 0px 100px';\n      } else if (borderLen <= (this.progressBar.nativeElement.offsetWidth * 2 + this.progressBar.nativeElement.offsetHeight)) {\n        backgroundPos = '0px 0px, 448px 0px, ' + (448 - (borderLen - this.progressBar.nativeElement.offsetWidth - this.progressBar.nativeElement.offsetHeight)) + 'px 95px, 0px 100px';\n      } else {\n        backgroundPos = '0px 0px, 448px 0px, 0px 95px, 0px ' + (100 - (borderLen - (this.progressBar.nativeElement.offsetWidth * 2) - this.progressBar.nativeElement.offsetHeight)) + 'px';\n      }\n      this.progressBar.nativeElement.setAttribute(\"style\",  \"background-position : \" + backgroundPos);\n  }\n  // setProgressState(state)\n  // {\n  //   var nativeclasslist = this.progressBar.nativeElement.classList;\n  //   if(nativeclasslist.contains('progresssuccess'))\n  //   {\n  //     nativeclasslist.remove('progresssuccess')\n  //   }\n  //   if(nativeclasslist.contains('progressverify'))\n  //   {\n  //     nativeclasslist.remove('progressverify')\n  //   }\n  //   if(nativeclasslist.contains('progresserror'))\n  //   {\n  //     nativeclasslist.remove('progresserror')\n  //   }\n  //   if(state == 'verify')\n  //   {\n  //     nativeclasslist.add('progressverify')\n  //   }\n  //   else if(state == 'success')\n  //   {\n  //     nativeclasslist.add('progresssuccess')\n  //   }\n  //   else if(state == 'error')\n  //   {\n  //     nativeclasslist.add('progresserror')\n  //   }\n  // }\n}\n"]}