web-dev-qa-db-fra.com

HTML 5 Glisser-déposer avec Angular 4

J'essaie de faire fonctionner le glisser-déposer HTML 5 natif dans mon angular). J'ai les événements drag, fire the drag & the dragOver, mais la baisse ne déclenche malheureusement rien. Ici, j'ai le code des événements HTML et drag ci-dessous.

<ul *ngFor="let channel of channelList" >
      <li class="list-group-item" *ngIf="channel.channel.substr(0, 1) === head" 
      style="float:left; margin:0.5px" draggable="true" (dragstart)="drag(channel)">
        <ng-container *ngIf="channel.compChannel.compChannelLogo.length !== 0; else noCompChannel">
          <img class="img-rounded" src="{{ channel.logo }}" alt="{{ channel.channel }}" width="100" height="100">
          <img class="img-rounded" src="{{ channel.compChannel.compChannelLogo }}" alt="{{ channel.channel.compChannelName }}" width="100" height="100">
        </ng-container>
        <ng-template #noCompChannel>
          <img class="img-rounded" src="{{ channel.logo }}" alt="{{ channel.channel }}" 
          width="100" height="100" >
        </ng-template>
      </li>
    </ul>
<ul class="list-group" *ngFor="let channels of currentPickSelection" dropzone="copy">
  <li class="list-group-item" style="float:Left; margin-left:0.5px" (dragover)="dragOver(channels[0])" (dragend)="drop(event)">
    <ng-container *ngIf="channels[0].compChannel.compChannelLogo.length !== 0; else noCompChannel">
      <img class="img-rounded" src="{{ channels[0].logo }}" alt="{{ channels[0].channel }}" width="70" height="70">
      <img class="img-rounded" src="{{ channels[0].compChannel.compChannelLogo }}" alt="{{ channels[0].compChannel.compChannelName }}"
        width="70" height="70">
    </ng-container>
    <ng-template #noCompChannel>
      <img class="img-rounded" src="{{ channels[0].logo }}" alt="{{ channels[0].channel }}" width="70" height="70">
    </ng-template>
    <br>
    <strong>
      <font size="2">{{ channels[0].pickCode }}</font>
    </strong>
  </li>
</ul>



drag(channel) {
    console.log(channel);
  }
  dragOver(channel) {
    this.draggedChannel = channel;
    // console.log(this.draggedChannel);
  }

  drop(e) {
    console.log(e);
  }
8
Sumchans

Je l'ai fait sans aucun autre module dans Angular 2/4/5/6, Vous pouvez aussi le faire en utilisant le code ci-dessous:

drag.component.html:

<h2>Drag and Drop demo</h2>
<div  id="div1" 
      (drop)="drop($event)" 
      (dragover)="allowDrop($event)">

      <img 
      src="https://images.pexels.com/photos/658687/pexels-photo-658687.jpeg?auto=compress&cs=tinysrgb&h=350" 
      draggable="true" 
      (dragstart)="drag($event)" 
      id="drag1"
      width="88" 
      height="31">
</div>

<div id="div2" 
  (drop)="drop($event)" 
  (dragover)="allowDrop($event)">
</div>

drag.component.ts:

import { Component } from '@angular/core';

@Component({
  selector: 'drag-root',
  templateUrl: './drag.component.html',
  styleUrls: ['./drag.component.css']
})
export class AppComponent {

  drop(ev) {
    ev.preventDefault();
    var data = ev.dataTransfer.getData("text");
    ev.target.appendChild(document.getElementById(data));
  }

  allowDrop(ev) {
    ev.preventDefault();
  }

  drag(ev) {
    ev.dataTransfer.setData("text", ev.target.id);
  }
}

drag.component.css:

#div1, #div2 {
    float: left;
    width: 100px;
    height: 35px;
    margin: 10px;
    padding: 10px;
    border: 1px solid black;
}

exemple Stackblitz

14
Shubham Verma
<div (dragover)="onDragOver($event)" (dragleave)="onDragLeave($event)" (drop)="onDrop($event)">

Dans votre composant

onDrop(event: any) {
    event.preventDefault();
    event.stopPropagation();
    // your code goes here after droping files or any
    }

    onDragOver(evt) {
     evt.preventDefault();
     evt.stopPropagation();
    }

   onDragLeave(evt) {
     evt.preventDefault();
     evt.stopPropagation();
    }
5
Phani Kumar

Paquet simple mais le plus puissant

prend en charge angular version> = 4.x

pour documentation

pour démo

Comment l'utiliser?

Installer

// if you use npm
npm install angular2-draggable

// or if you use yarn
yarn add angular2-draggable

Importation

import { AngularDraggableModule } from 'angular2-draggable';

@NgModule({
  imports: [
    ...,
    AngularDraggableModule
  ],
})
export class AppModule { }

et enfin utiliser

// Basic Usage
<div ngDraggable>Drag Me!</div>
1
WasiF

Pour utiliser le glisser-déposer dans angular 4 application, vous pouvez utiliser le module npm "ngx-uploader".

Vous trouverez l'étape d'intégration à partir du lien ci-dessous:

https://www.npmjs.com/package/ngx-uploader

Tous les paramètres et classes d'import que vous pouvez utiliser à partir du lien ci-dessus.

Voici mon code pour angular:

if (output.type === 'allAddedToQueue') { // when all files added in queue
  // uncomment this if you want to auto upload files when added
  const event: UploadInput = {
    type: 'uploadAll',
    url: API_BASE +'/api/uploads',

    method: 'POST',
    data:{total_files: this.files.length.toString()}
  };
  this.uploadInput.emit(event);
} else if (output.type === 'addedToQueue'  && typeof output.file !== 'undefined') { // add file to array when added
  this.files.Push(output.file);
} else if (output.type === 'uploading' && typeof output.file !== 'undefined') {
  // update current data in files array for uploading file
  const index = this.files.findIndex(file => typeof output.file !== 'undefined' && file.id === output.file.id);
  this.files[index] = output.file;

} else if (output.type === 'removed') {
  // remove file from array when removed
  this.files = this.files.filter((file: UploadFile) => file !== output.file);
} else if (output.type === 'dragOver') {
  this.dragOver = true;
} else if (output.type === 'dragOut') {
  this.dragOver = false;
} else if (output.type === 'drop') {
  this.dragOver = false;
}else if (output.type === 'done') { 

  if (output.file.response.status == 200) { 
    var uploaded_files = output.file.response.data;
    this.propertyImage.Push(uploaded_files);
  } 
  else { 
    this.msgs = [];
    this.msgs.Push({ severity: 'error', summary: 'Error Message', detail: 'unable to upload images' });
  }

Dans le code ci-dessus pour la sortie === terminé, vous obtiendrez une réponse du côté serveur (Dans mon cas, nodejs)

Ci-dessous vous pouvez trouver le code pour backend:

var formidable = require('formidable'),
    http = require('http'),
    util = require('util');

var form = new formidable.IncomingForm();

var src = './public/images/properties';
var dst_small = './public/images/properties/small'
var dst_medium = './public/images/properties/medium'
var validImage = false;
form.keepExtensions = true; //keep file extension
form.uploadDir = src;
form.onPart = function (part) {
    if (!part.filename || part.filename.match(/\.(jpg|jpeg|png)$/i)) {
        validImage = true;
        this.handlePart(part);
    }

    else {
        validImage = false;
        return res.json({ status: 404, msg: part.filename + ' is not allowed.' });

    }
}
form.parse(req, function (err, fields, files) {
    if (validImage) {

        var image = files.file.path.split("/")[3];
        var name = files.file.path.split("/")[3];


        easyimg.rescrop({
            src: files.file.path, dst: dst_small + '/' + files.file.path.split('/')[3],
            width: 100, height: 100,
            cropwidth: 100, cropheight: 100,
            x: 0, y: 0
        }).then(
            function (image) {
                //  console.log('Resized and cropped: ' + image.width + ' x ' + image.height);
            },
            function (err) {
                //  console.log(err);
            }
            );


        // for largeImage
        easyimg.rescrop({
            src: files.file.path, dst: dst_medium + '/' + files.file.path.split('/')[3],
            width: 300, height: 300,
            cropwidth: 300, cropheight: 300,
            x: 0, y: 0
        }).then(
            function (image) {
                //  console.log('Resized and cropped: ' + image.width + ' x ' + image.height);
                return res.json({ status: 200, msg: 'Uploaded images', data: image });

            },
            function (err) {
                console.log(err);
            }
            );
    } else {
        return res.json({ status: 500, msg: constant.message.error_profile_pic_type });
    }
});

Veuillez modifier le chemin de votre image en fonction de votre chemin de fichier. J'ai utilisé ce code et cela a fonctionné pour moi.

J'espère que le code ci-dessus vous aidera.

Merci !!

1
Rsona

Voici une solution sur Angular 7 :

Material ( https://material.angular.io/ ) l'explique parfaitement (vous devez prendre la version> = 7.1 ). Voici un lien vers API .

Tout d’abord, importez le module "DragAndDrop" dans vos modules:

import {DragDropModule} from '@angular/cdk/drag-drop';

Il ne reste plus qu’à ajouter la directive "cdkDrag" à votre élément HTML:

<div class="example-box" cdkDrag>
  Drag me around
</div>

Stackblitz (à partir de matériel): ici

C'est vraiment facile à utiliser et il existe des options intéressantes si vous devez faire un glisser-déposer plus spécifique (par exemple avec un verrouillage de position)!

1
Curse

Utilisez drop événement. Cela ne se déclenche que lorsque vous déposez un fichier.

0
sachin

C'est comme ça que je l'ai fait fonctionner. Les fonctions preventDefault () génèrent une erreur et l'ont modifiée pour un retour false qui a bien fonctionné. Merci les gars pour les réponses rapides.

 drag(channel) {
    console.log(channel);
  }
  onDragOver(channel: any) {
    console.log("Drag Over");
    return false;
  }
  onDrop(e:any) {
    console.log("Drop");
  }
0
Sumchans