aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbob <bcz@cs.brown.edu>2019-05-20 13:15:16 -0400
committerbob <bcz@cs.brown.edu>2019-05-20 13:15:16 -0400
commit850ac067fb4e62f91a6eee8df40fe95eca3a3326 (patch)
treeeef75d00c7d82c3f2e991d1161b59f25d7cb35a6
parente5d71fc1362c77f076c10187625c74fe294669aa (diff)
changed so that cat image works.
-rw-r--r--src/client/views/nodes/ImageBox.tsx20
1 files changed, 11 insertions, 9 deletions
diff --git a/src/client/views/nodes/ImageBox.tsx b/src/client/views/nodes/ImageBox.tsx
index 29a99e53c..1bd1b80a7 100644
--- a/src/client/views/nodes/ImageBox.tsx
+++ b/src/client/views/nodes/ImageBox.tsx
@@ -177,6 +177,11 @@ export class ImageBox extends DocComponent<FieldViewProps, ImageDocument>(ImageD
if (this._curSuffix === "_m") this._mediumRetryCount++;
if (this._curSuffix === "_l") this._largeRetryCount++;
}
+ @action onError = () => {
+ let timeout = this._curSuffix === "_s" ? this._smallRetryCount : this._curSuffix === "_m" ? this._mediumRetryCount : this._largeRetryCount;
+ if (timeout < 10)
+ setTimeout(this.retryPath, Math.min(10000, timeout * 5));
+ }
_curSuffix = "";
render() {
let transform = this.props.ScreenToLocalTransform().inverse();
@@ -191,9 +196,9 @@ export class ImageBox extends DocComponent<FieldViewProps, ImageDocument>(ImageD
this._curSuffix = "";
if (w > 20) {
let field = this.Document[this.props.fieldKey];
- if (w < 100) this._curSuffix = "_s";
- else if (w < 600) this._curSuffix = "_m";
- else this._curSuffix = "_l";
+ if (w < 100 && this._smallRetryCount < 10) this._curSuffix = "_s";
+ else if (w < 600 && this._mediumRetryCount < 10) this._curSuffix = "_m";
+ else if (this._largeRetryCount < 10) this._curSuffix = "_l";
if (field instanceof ImageField) paths = [this.choosePath(field.url)];
else if (field instanceof List) paths = field.filter(val => val instanceof ImageField).map(p => this.choosePath((p as ImageField).url));
}
@@ -205,16 +210,13 @@ export class ImageBox extends DocComponent<FieldViewProps, ImageDocument>(ImageD
<img id={id}
key={this._smallRetryCount + (this._mediumRetryCount << 4) + (this._largeRetryCount << 8)} // force cache to update on retrys
src={paths[Math.min(paths.length, this._photoIndex)]}
- style={{ objectFit: (this._photoIndex === 0 ? undefined : "contain") }}
+ // style={{ objectFit: (this._photoIndex === 0 ? undefined : "contain") }}
width={nativeWidth}
ref={this._imgRef}
- onError={action(() => {
- let timeout = this._curSuffix === "_s" ? this._smallRetryCount : this._curSuffix === "_m" ? this._mediumRetryCount : this._largeRetryCount;
- setTimeout(this.retryPath, Math.min(10000, timeout * 5));
- })}
+ onError={this.onError}
onLoad={this.onLoad} />
{paths.length > 1 ? this.dots(paths) : (null)}
- {this.lightbox(paths)}
+ {/* {this.lightbox(paths)} */}
</div>);
}
} \ No newline at end of file