Skip to content

Commit

Permalink
WIP
Browse files Browse the repository at this point in the history
  • Loading branch information
nd0ut committed Nov 1, 2023
1 parent 01b8602 commit 2d5a6c4
Show file tree
Hide file tree
Showing 13 changed files with 168 additions and 186 deletions.
1 change: 0 additions & 1 deletion abstract/ActivityBlock.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
// @ts-check
import { Modal } from '../blocks/Modal/Modal.js';
import { debounce } from '../blocks/utils/debounce.js';
import { Block } from './Block.js';
import { activityBlockCtx } from './CTX.js';
Expand Down
32 changes: 28 additions & 4 deletions abstract/Block.js
Original file line number Diff line number Diff line change
@@ -1,14 +1,15 @@
// @ts-check
import { BaseComponent } from '@symbiotejs/symbiote';
import { EventEmitter } from '../blocks/UploadCtxProvider/EventEmitter.js';
import { createWindowHeightTracker, getIsWindowHeightTracked } from '../utils/createWindowHeightTracker.js';
import { getPluralForm } from '../utils/getPluralForm.js';
import { applyTemplateData, getPluralObjects } from '../utils/template-utils.js';
import { toKebabCase } from '../utils/toKebabCase.js';
import { waitForAttribute } from '../utils/waitForAttribute.js';
import { warnOnce } from '../utils/warnOnce.js';
import { blockCtx } from './CTX.js';
import { l10nProcessor } from './l10nProcessor.js';
import { sharedConfigKey } from './sharedConfigKey.js';
import { toKebabCase } from '../utils/toKebabCase.js';
import { warnOnce } from '../utils/warnOnce.js';
import { getPluralForm } from '../utils/getPluralForm.js';
import { waitForAttribute } from '../utils/waitForAttribute.js';

const TAG_PREFIX = 'lr-';

Expand Down Expand Up @@ -77,6 +78,20 @@ export class Block extends BaseComponent {
this.__l10nKeys = [];
}

/**
* @template {typeof import('../blocks/UploadCtxProvider/EventEmitter.js').EventType[keyof typeof import('../blocks/UploadCtxProvider/EventEmitter.js').EventType]} T
* @param {T} type
* @param {import('../blocks/UploadCtxProvider/EventEmitter.js').EventPayload[T]} [payload]
*/
emit(type, payload) {
/** @type {import('../blocks/UploadCtxProvider/EventEmitter.js').EventEmitter} */
const eventEmitter = this.has('*eventEmitter') && this.$['*eventEmitter'];
if (!eventEmitter) {
return;
}
eventEmitter.emit(type, payload);
}

/**
* @param {String} localPropKey
* @param {String} l10nKey
Expand Down Expand Up @@ -165,6 +180,10 @@ export class Block extends BaseComponent {
initCallback() {
let blocksRegistry = this.$['*blocksRegistry'];
blocksRegistry.add(this);

if (!this.$['*eventEmitter']) {
this.$['*eventEmitter'] = new EventEmitter(() => this.ctxName);
}
}

destroyCallback() {
Expand Down Expand Up @@ -271,7 +290,12 @@ export class Block extends BaseComponent {
}
}

/** @deprecated */
updateCtxCssData = () => {
warnOnce(
'Using CSS variables for configuration is deprecated. Please use `lr-config` instead. See migration guide: https://uploadcare.com/docs/file-uploader/migration-to-0.25.0/'
);

/** @type {Set<Block>} */
let blocks = this.$['*blocksRegistry'];
for (let block of blocks) {
Expand Down
2 changes: 2 additions & 0 deletions abstract/CTX.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ import { Queue } from '@uploadcare/upload-client';
export const blockCtx = () => ({
/** @type {Set<import('./Block').Block>} */
'*blocksRegistry': new Set(),
/** @type {import('../blocks/UploadCtxProvider/EventEmitter.js').EventEmitter | null} */
'*eventEmitter': null,
});

/** @param {import('./Block').Block} fnCtx */
Expand Down
66 changes: 0 additions & 66 deletions abstract/EventManager.js

This file was deleted.

79 changes: 9 additions & 70 deletions abstract/UploaderBlock.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import { ActivityBlock } from './ActivityBlock.js';
import { Data } from '@symbiotejs/symbiote';
import { calculateMaxCenteredCropFrame } from '../blocks/CloudImageEditor/src/crop-utils.js';
import { parseCropPreset } from '../blocks/CloudImageEditor/src/lib/parseCropPreset.js';
import { EventType } from '../blocks/UploadCtxProvider/EventEmitter.js';
import { UploadSource } from '../blocks/utils/UploadSource.js';
import { serializeCsv } from '../blocks/utils/comma-separated.js';
import { debounce } from '../blocks/utils/debounce.js';
Expand All @@ -14,7 +15,6 @@ import { prettyBytes } from '../utils/prettyBytes.js';
import { stringToArray } from '../utils/stringToArray.js';
import { warnOnce } from '../utils/warnOnce.js';
import { uploaderBlockCtx } from './CTX.js';
import { EVENT_TYPES, EventData, EventManager } from './EventManager.js';
import { TypedCollection } from './TypedCollection.js';
import { uploadEntrySchema } from './uploadEntrySchema.js';

Expand Down Expand Up @@ -268,14 +268,7 @@ export class UploaderBlock extends ActivityBlock {
this.setOrAddState('*modalActive', true);
}
}
EventManager.emit(
new EventData({
type: EVENT_TYPES.INIT_FLOW,
ctx: this.ctxName,
}),
undefined,
false
);
this.emit(EventType.INIT_FLOW);
}

doneFlow() {
Expand All @@ -286,14 +279,7 @@ export class UploaderBlock extends ActivityBlock {
if (!this.$['*currentActivity']) {
this.setOrAddState('*modalActive', false);
}
EventManager.emit(
new EventData({
type: EVENT_TYPES.DONE_FLOW,
ctx: this.ctxName,
}),
undefined,
false
);
this.emit(EventType.DONE_FLOW);
}

/** @returns {TypedCollection} */
Expand Down Expand Up @@ -420,15 +406,7 @@ export class UploaderBlock extends ActivityBlock {
if (data.length !== this.uploadCollection.size) {
return;
}
EventManager.emit(
new EventData({
type: EVENT_TYPES.DATA_OUTPUT,
// @ts-ignore TODO: fix this
ctx: this.ctxName,
// @ts-ignore TODO: fix this
data,
})
);
this.emit(EventType.DATA_OUTPUT, data);
// @ts-ignore TODO: fix this
this.$['*outputData'] = data;
}, 100);
Expand Down Expand Up @@ -483,15 +461,7 @@ export class UploaderBlock extends ActivityBlock {
});
let progress = Math.round(commonProgress / items.length);
this.$['*commonProgress'] = progress;
EventManager.emit(
new EventData({
type: EVENT_TYPES.UPLOAD_PROGRESS,
ctx: this.ctxName,
data: progress,
}),
undefined,
progress === 100
);
this.emit(EventType.UPLOAD_PROGRESS, progress);
}
if (changeMap.fileInfo) {
if (this.cfg.cropPreset) {
Expand All @@ -507,62 +477,31 @@ export class UploaderBlock extends ActivityBlock {
let data = this.getOutputData((dataItem) => {
return !!dataItem.getValue('fileInfo') && !dataItem.getValue('silentUpload');
});
data.length > 0 &&
EventManager.emit(
new EventData({
type: EVENT_TYPES.UPLOAD_FINISH,
ctx: this.ctxName,
data,
})
);
data.length > 0 && this.emit(EventType.UPLOAD_FINISH, data);
}
}
if (changeMap.uploadError) {
let items = uploadCollection.findItems((entry) => {
return !!entry.getValue('uploadError');
});
items.forEach((id) => {
EventManager.emit(
new EventData({
type: EVENT_TYPES.UPLOAD_ERROR,
ctx: this.ctxName,
data: uploadCollection.readProp(id, 'uploadError'),
}),
undefined,
false
);
this.emit(EventType.UPLOAD_ERROR, uploadCollection.readProp(id, 'uploadError'));
});
}
if (changeMap.validationErrorMsg) {
let items = uploadCollection.findItems((entry) => {
return !!entry.getValue('validationErrorMsg');
});
items.forEach((id) => {
EventManager.emit(
new EventData({
type: EVENT_TYPES.VALIDATION_ERROR,
ctx: this.ctxName,
data: uploadCollection.readProp(id, 'validationErrorMsg'),
}),
undefined,
false
);
this.emit(EventType.VALIDATION_ERROR, uploadCollection.readProp(id, 'validationErrorMsg'));
});
}
if (changeMap.cdnUrlModifiers) {
let items = uploadCollection.findItems((entry) => {
return !!entry.getValue('cdnUrlModifiers');
});
items.forEach((id) => {
EventManager.emit(
new EventData({
type: EVENT_TYPES.CLOUD_MODIFICATION,
ctx: this.ctxName,
data: Data.getCtx(id).store,
}),
undefined,
false
);
this.emit(EventType.CLOUD_MODIFICATION, uploadCollection.readProp(id, 'cdnUrlModifiers'));
});
}
};
Expand Down
18 changes: 3 additions & 15 deletions blocks/FileItem/FileItem.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
// @ts-check
import { UploadClientError, uploadFile } from '@uploadcare/upload-client';
import { ActivityBlock } from '../../abstract/ActivityBlock.js';
import { EVENT_TYPES, EventData, EventManager } from '../../abstract/EventManager.js';
import { UploaderBlock } from '../../abstract/UploaderBlock.js';
import { createCdnUrl, createCdnUrlModifiers, createOriginalUrl } from '../../utils/cdn-utils.js';
import { EventType } from '../UploadCtxProvider/EventEmitter.js';
import { fileCssBg } from '../svg-backgrounds/svg-backgrounds.js';
import { debounce } from '../utils/debounce.js';
import { generateThumb } from '../utils/resizeImage.js';
Expand Down Expand Up @@ -74,13 +74,7 @@ export class FileItem extends UploaderBlock {
let data = this.getOutputData((dataItem) => {
return dataItem.getValue('uuid') === entryUuid;
});
EventManager.emit(
new EventData({
type: EVENT_TYPES.REMOVE,
ctx: this.ctxName,
data,
})
);
this.emit(EventType.REMOVE, data);
}
this.uploadCollection.remove(this.$.uid);
},
Expand Down Expand Up @@ -370,13 +364,7 @@ export class FileItem extends UploaderBlock {
return !dataItem.getValue('fileInfo');
});

EventManager.emit(
new EventData({
type: EVENT_TYPES.UPLOAD_START,
ctx: this.ctxName,
data,
})
);
this.emit(EventType.UPLOAD_START, data);

this._debouncedCalculateState();
entry.setValue('isUploading', true);
Expand Down
Loading

0 comments on commit 2d5a6c4

Please sign in to comment.