Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Prevent trigerring a click action for inner components #80

Open
xamoom-pali opened this issue Jun 16, 2016 · 0 comments
Open

Prevent trigerring a click action for inner components #80

xamoom-pali opened this issue Jun 16, 2016 · 0 comments

Comments

@xamoom-pali
Copy link

xamoom-pali commented Jun 16, 2016

I am using file-picker wrapping my own component which previews the files about to be uploaded.

    {{#file-picker filesLoaded="filesAddedToTheDroppableArea" multiple=true}}
        {{#each queue as |enrichedMediaItem|}}
            {{media-item-previewer
            mediaItem=enrichedMediaItem
            actionOnUpdate=(action 'updateMediaItem' enrichedMediaItem)
          }}
      {{/each}}
    {{/file-picker}}

As you can see, there is an action 'updateMediaItem' which gets fired when user clicks on an associated button.
My problem is that file-picker listens on click() actions and opens a window for selecting a file to be uploaded (added). It is fine as long as there is nothing to preview (the drag&drop area is empty), but as there is at least 1 file drag&dropped and I can click on my component's button, I don't want to get this click action propagated.
After closing the window my action takes over. As you assume, I want to prevent file-picker opening the window if the event target is my component.
I believe this is the line that causes the problem:

  click: function(event) {
    if (this.get('selectOnClick') === true) {
      if (!$(event.target).hasClass('file-picker__input')) {
        this.$('.file-picker__input').trigger('click');
      }
    }
  },

I managed to achieve the target as follows:

  • pass selectOnClick=false to the file-picker: {{#file-picker selectOnClick=false ... }}
  • overrode click() action in my component that wraps file-picker:
    click(e){
      if ($(e.target).hasClass('file-picker__dropzone')){
         this.$('.file-picker__input').trigger('click'); // do the same as click() in file-picker.js
      }
    }

Now, everytime I click anywhere inside the file-picker dropzone area, the file selection window pops up UNLESS the direct target is the dropzone area. Clicking any other element that belongs to my component is treated by the component.

Is there a better way? Would it be an idea for extending the functionality or am I doing something wrong?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant