-
Notifications
You must be signed in to change notification settings - Fork 18
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
Vaadin 8 compatibility #27
Conversation
fix bounds check for maxFileCount to allow for uploading 1 file
Removed Viritin dependency - was only for one tiny piece, and pulled in a large amount of library code. Replaced with Commons-IO instead, which is a dependency for Vaadin-charts, among other things, and much smaller. Only used for byteCountToDisplaySize() method.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi Greg,
Thanks for contributing, it looks good. I recommended are a few small changes and questions, please take a look when you have time.
@mstahv if you could look at my comments as well, that would be good.
Thanks,
Adam
@@ -142,6 +142,7 @@ | |||
<goal>compile</goal> | |||
</goals> | |||
<configuration> | |||
<extraJvmArgs>-Xmx1G</extraJvmArgs> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do you need this parameter? I'm not having out of memory without it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, at least for me with Maven + Eclipse + V8 I needed it, and found it documented in the V8 migration guide:
https://vaadin.com/vaadin-fw8-documentation-portlet/framework/migration/migrating-to-vaadin8.html
Perhaps my Eclipse setup uses a different, lower default configuration than however you ran it?
pom.xml
Outdated
@@ -294,6 +295,30 @@ | |||
</dependency> | |||
<dependency> | |||
<groupId>com.vaadin</groupId> | |||
<artifactId>vaadin-compatibility-server</artifactId> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please remove vaadin-compatibility-client
and vaadin-compatibility-server
packages, they are not in use
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good catch. Found one unused import still referencing them, but otherwise I'd updated uses but left the dependencies. Will remove them in a new pull request.
@@ -4,7 +4,8 @@ | |||
<!-- WS Compiler: manually edited --> | |||
|
|||
<inherits name="org.swfupload.SWFUpload" /> | |||
<inherits name="com.vaadin.terminal.gwt.DefaultWidgetSet" /> | |||
<inherits name="com.vaadin.DefaultWidgetSet" /> | |||
<inherits name="com.vaadin.v7.Vaadin7WidgetSet" /> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please remove the Vaadin7WidgetSet
since there are no compatibility components in use
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yes
@@ -292,7 +296,7 @@ private void submit() { | |||
} else if (!AcceptUtil.accepted(file.getName(), file.getType(), | |||
accepted)) { | |||
noMatches.add(file); | |||
} else if (maxFileCount != null && filedetails.size() >= maxFileCount) { | |||
} else if (maxFileCount != null && filedetails.size() > maxFileCount) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this should stay >=
because when maxFileCount
is set to 1, on the second iteration filedetails.size()
will still be 1 at this point of code and the file should be added to tooMany
, so condition should be true
. That will happen when =
is also accepted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Without this change I can't click to open the browser file selection dialog and successfully choose only one file. I filed this as bug # 25 a while back. Without this you get a message like "0 files selected, but the maximum allowed is 1."
@@ -79,7 +79,7 @@ | |||
private Upload upload; | |||
protected Component display; | |||
|
|||
private ProgressIndicator progress = new ProgressIndicator(); | |||
private ProgressBar progress = new ProgressBar(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@mstahv we need to mention in the documentation that setting getUI().setPollInterval()
may be needed or need to support it internally somehow.
Currently the progress bar is not updated by default.
@@ -573,41 +534,29 @@ public void removeListener(Property.ValueChangeListener listener) { | |||
* validated before the event is created. | |||
*/ | |||
protected void fireValueChange(boolean repaintIsNotNeeded) { | |||
fireEvent(new AbstractField.ValueChangeEvent(this)); | |||
fireEvent(new HasValue.ValueChangeEvent(this, this, null, ! repaintIsNotNeeded)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It may not be important, but could perhaps pass the old value, at least when it's known as in setValue()
method. Not a blocker I guess.
* Tests the current value against all registered validators. | ||
* | ||
* @return <code>true</code> if all registered validators claim that the | ||
* current value is valid, <code>false</code> otherwise. | ||
*/ | ||
public boolean isValid() { | ||
public boolean isValid() { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Does this method make sense without the validation?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe not. Is is problematic to leave it?
I tried the changes in this pull request. I also had to change some dependencies to properly run the test UIs. There was still quite a lot of non-functional stuff there. You changes and my additions are now in https://github.com/parttio/easyuploads/tree/WoozyG-master Some issues are quite hard to resolve, like typing in fields. MultiFileUpload is probably easier to tackle as it is not a Field. It might be best to have a fresh start with V8 and its HasFields interface and leave old stuff to compatibility package. I think I'll do a "quick-and-dirty" V8 upgrade first and then we can look into V8 native UploadField etc. |
Thanks for checking it. I only use a small slice of the functionality
myself, and it works for that purposes, but since I couldn't get the UI to
run for manual testing I couldn't see the rest. I agree, it may be best to
not try to make some parts V8 native. Possibly time to drop the Flash
uploader entirely?
…On Thu, Mar 16, 2017 at 8:37 AM Matti Tahvonen ***@***.***> wrote:
I tried the changes in this pull request. I also had to change some
dependencies to properly run the test UIs. There was still quite a lot of
non-functional stuff there.
You changes and my additions are now in
https://github.com/parttio/easyuploads/tree/WoozyG-master
Some issues are quite hard to resolve, like typing in fields.
MultiFileUpload is probably easier to tackle as it is not a Field. It might
be best to have a fresh start with V8 and its HasFields interface and leave
old stuff to compatibility package. I think I'll do a "quick-and-dirty" V8
upgrade first and then we can look into V8 native UploadField etc.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub
<#27 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AB4IfbctCvQxoYOdREhDxyBM5qzV5npdks5rmVcvgaJpZM4MSlZb>
.
|
Yep, IIRC the flash uploader thingie is no more needed with IE11 (or any other modern browser). Hitting delete on that will bring a big smile on my face soon. |
@WoozyG Can you try a build from the latest master with your application and let me know if it works. I couldn't yet make all tests pass with the master either, but that appeared to be a Vaadin core issue, which should be fixed soon in 8.0.3. Could you also provide a test case for #25 ? I could then look into what is actually happening there, the proposed fix look somehow wrong. |
This was implemented in a separate changeset. |
You will want to review the POM changes - I think I only modified version #s (made it v8), and dependencies.
I removed the Viritin dependency, as it is a large library with multiple dependencies, and used only for string escaping, which is done differently/better now anyway in Vaadin. Added Commons-IO explicitly (was a transitive dependency from Viritin) - it is only used for
FileUtils.byteCountToDisplaySize(long)
.I think the UI test server framework you referenced in your comment needs updating for Vaadin 8 - I couldn't get the Jetty instance to launch, complaining about a method not found. I think the argument type changed packages in V8 or something.
This works for me in my project, drag/drop, clicking and selecting a file/files, displaying in-process uploads (using the newer progress component) etc.