AngularFire2 - Получить URL-адрес магазина загрузки Firebase в String - PullRequest
0 голосов
/ 07 октября 2018

Что я использую

AngularFire2 FireStore Angular v 6

Что я пытаюсь сделать

Получите строку URL для загрузки для каждого загружаемого изображения

Проблема

Я получаю Observable, но мне нужно значение в строке для отправки в API

Наблюдения

Мне не нужен наблюдаемый и используемый асинхронный канал для просмотра URL, мне нужен URL-адрес в строке для отправки его в API.

Компонент TS

import { Component, OnInit } from '@angular/core';
import { FaceApiService } from '../../services/face-api.service';
import { AngularFireStorage, AngularFireUploadTask } from 'angularfire2/storage';
import { Observable } from 'rxjs';
import { AngularFirestore } from 'angularfire2/firestore';
import { tap, finalize } from 'rxjs/operators';

@Component({
  selector: 'app-file-upload',
  templateUrl: './file-upload.component.html',
  styleUrls: ['./file-upload.component.scss']
})
export class FileUploadComponent implements OnInit {

  public imgUrl: String;

  public dataApi: any;

  // Main Task
  task: AngularFireUploadTask;

  // Progress monitoring
  percentage: Observable<number>;

  snapshot: Observable<any>;

  // Dowload URL
  public downloadURL: Observable<string>;

  // State for dropzone CSS toggling
  isHovering: boolean;

  // unsupported file
  unsupportedFile = '';

  constructor( private data: FaceApiService, private storage: AngularFireStorage,
    private db: AngularFirestore ) {}

  // Get URL for API
  sendUrl(imgUrl) {

      this.data.getApiData(imgUrl).subscribe( data => {
        this.dataApi = {
          'imgUrl': imgUrl,
          'dataApi': data
        };
      });
    }

  toggleHover(event: boolean) {
    this.isHovering = event;
  }

  startUpload(event: FileList) {
    // The File object
    const file = event.item(0);

    // Client-side validation example
    if (file.type.split('/')[0] !== 'image') {
      this.unsupportedFile = 'Archivo no soportado';
      console.error('unsupported file type :( ');
      return;
    }

    // The storage path
    const path = `photos/${new Date().getTime()}_${file.name}`;

    // Totally optional metadata
    const customMetadata = { Caronte: 'De Colombia con amor' };

    // The main task
    this.task = this.storage.upload(path, file, { customMetadata });

    // Progress monitoring
    this.percentage = this.task.percentageChanges();
    this.snapshot = this.task.snapshotChanges();

    // Download URL file
    this.snapshot.pipe(finalize(() => {
      this.downloadURL = this.storage.ref(path).getDownloadURL();
      console.log(this.downloadURL); // Get a Observable
    }) ).subscribe();

    this.downloadURL.subscribe( url => {
      if (url) {
        console.log(url);
      }

    } );

    // AFS
    this.snapshot = this.task.snapshotChanges().pipe(
      tap(snap => {
        if (snap.bytesTransferred === snap.totalBytes) {

          // Update firestore on completion
          this.db.collection('photos').add( {path, size: snap.totalBytes });
        }
      })
    );
  }

  // Determines if the upload task is active
  isActive(snapshot) {
    return snapshot.state === 'running' && snapshot.bytesTransferred < snapshot.totalBytes;
  }

  ngOnInit() {}

}

Это важное

// Download URL file
    this.snapshot.pipe(finalize(() => {
      this.downloadURL = this.storage.ref(path).getDownloadURL();
      console.log(this.downloadURL); // Get a Observable
    }) ).subscribe();

Журнал загрузки varURL

ОБНОВЛЕНИЕ

ОШИБКА TypeError:Не удается прочитать свойство «подписаться»

...