-
Notifications
You must be signed in to change notification settings - Fork 170
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #473 from HaveAGitGat/2.10.01
Compare File Size Ratio
- Loading branch information
Showing
2 changed files
with
180 additions
and
0 deletions.
There are no files selected for viewing
84 changes: 84 additions & 0 deletions
84
FlowPlugins/CommunityFlowPlugins/file/compareFileSizeRatio/1.0.0/index.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.plugin = exports.details = void 0; | ||
/* eslint no-plusplus: ["error", { "allowForLoopAfterthoughts": true }] */ | ||
var details = function () { return ({ | ||
name: 'Compare File Size Ratio', | ||
description: 'Compare file size ratio of working file compared to original file using percentage.', | ||
style: { | ||
borderColor: 'orange', | ||
}, | ||
tags: '', | ||
isStartPlugin: false, | ||
pType: '', | ||
requiresVersion: '2.11.01', | ||
sidebarPosition: -1, | ||
icon: 'faQuestion', | ||
inputs: [ | ||
{ | ||
name: 'greaterThan', | ||
type: 'number', | ||
defaultValue: '40', | ||
inputUI: { | ||
type: 'text', | ||
}, | ||
tooltip: 'Specify lower bound. ' | ||
+ 'Default value is 40% so new file size must be at least 40% of original file size.', | ||
}, | ||
{ | ||
name: 'lessThan', | ||
type: 'number', | ||
defaultValue: '110', | ||
inputUI: { | ||
type: 'text', | ||
}, | ||
tooltip: 'Specify upper bound.' | ||
+ ' Default value is 110% so new file size must be at most 110% of original file size.', | ||
}, | ||
], | ||
outputs: [ | ||
{ | ||
number: 1, | ||
tooltip: 'Working file size % is within range', | ||
}, | ||
{ | ||
number: 2, | ||
tooltip: 'Working file size % is not within range', | ||
}, | ||
], | ||
}); }; | ||
exports.details = details; | ||
// eslint-disable-next-line @typescript-eslint/no-unused-vars | ||
var plugin = function (args) { | ||
var lib = require('../../../../../methods/lib')(); | ||
// eslint-disable-next-line @typescript-eslint/no-unused-vars,no-param-reassign | ||
args.inputs = lib.loadDefaultValues(args.inputs, details); | ||
var isWithinRange = false; | ||
var newFileSizeBytes = args.inputFileObj.file_size; | ||
var origFileSizeBytes = args.originalLibraryFile.file_size; | ||
var greaterThanPerc = Number(args.inputs.greaterThan); | ||
var lessThanPerc = Number(args.inputs.lessThan); | ||
var ratio = (newFileSizeBytes / origFileSizeBytes) * 100; | ||
var sizeText = "New file has size ".concat(newFileSizeBytes.toFixed(3), " MB which is ").concat(ratio, "% ") | ||
+ "of original file size: ".concat(origFileSizeBytes.toFixed(3), " MB"); | ||
var getBound = function (bound) { return (bound / 100) * origFileSizeBytes; }; | ||
var errText = 'New file size not within limits.'; | ||
if (newFileSizeBytes > getBound(lessThanPerc)) { | ||
// Item will be errored in UI | ||
args.jobLog("".concat(errText, " ").concat(sizeText, ". upperBound is ").concat(lessThanPerc, "%")); | ||
} | ||
else if (newFileSizeBytes < getBound(greaterThanPerc)) { | ||
// // Item will be errored in UI | ||
args.jobLog("".concat(errText, " ").concat(sizeText, ". lowerBound is ").concat(greaterThanPerc, "%")); | ||
} | ||
else { | ||
args.jobLog(sizeText); | ||
isWithinRange = true; | ||
} | ||
return { | ||
outputFileObj: args.inputFileObj, | ||
outputNumber: isWithinRange ? 1 : 2, | ||
variables: args.variables, | ||
}; | ||
}; | ||
exports.plugin = plugin; |
96 changes: 96 additions & 0 deletions
96
FlowPluginsTs/CommunityFlowPlugins/file/compareFileSizeRatio/1.0.0/index.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,96 @@ | ||
import { | ||
IpluginDetails, | ||
IpluginInputArgs, | ||
IpluginOutputArgs, | ||
} from '../../../../FlowHelpers/1.0.0/interfaces/interfaces'; | ||
|
||
/* eslint no-plusplus: ["error", { "allowForLoopAfterthoughts": true }] */ | ||
const details = (): IpluginDetails => ({ | ||
name: 'Compare File Size Ratio', | ||
description: 'Compare file size ratio of working file compared to original file using percentage.', | ||
style: { | ||
borderColor: 'orange', | ||
}, | ||
tags: '', | ||
|
||
isStartPlugin: false, | ||
pType: '', | ||
requiresVersion: '2.11.01', | ||
sidebarPosition: -1, | ||
icon: 'faQuestion', | ||
inputs: [ | ||
{ | ||
name: 'greaterThan', | ||
type: 'number', | ||
defaultValue: '40', | ||
inputUI: { | ||
type: 'text', | ||
}, | ||
tooltip: 'Specify lower bound. ' | ||
+ 'Default value is 40% so new file size must be at least 40% of original file size.', | ||
}, | ||
{ | ||
name: 'lessThan', | ||
type: 'number', | ||
defaultValue: '110', | ||
inputUI: { | ||
type: 'text', | ||
}, | ||
tooltip: 'Specify upper bound.' | ||
+ ' Default value is 110% so new file size must be at most 110% of original file size.', | ||
}, | ||
], | ||
outputs: [ | ||
{ | ||
number: 1, | ||
tooltip: 'Working file size % is within range', | ||
}, | ||
{ | ||
number: 2, | ||
tooltip: 'Working file size % is not within range', | ||
}, | ||
], | ||
}); | ||
|
||
// eslint-disable-next-line @typescript-eslint/no-unused-vars | ||
const plugin = (args: IpluginInputArgs): IpluginOutputArgs => { | ||
const lib = require('../../../../../methods/lib')(); | ||
// eslint-disable-next-line @typescript-eslint/no-unused-vars,no-param-reassign | ||
args.inputs = lib.loadDefaultValues(args.inputs, details); | ||
|
||
let isWithinRange = false; | ||
const newFileSizeBytes = args.inputFileObj.file_size; | ||
const origFileSizeBytes = args.originalLibraryFile.file_size; | ||
|
||
const greaterThanPerc = Number(args.inputs.greaterThan); | ||
const lessThanPerc = Number(args.inputs.lessThan); | ||
|
||
const ratio = (newFileSizeBytes / origFileSizeBytes) * 100; | ||
|
||
const sizeText = `New file has size ${newFileSizeBytes.toFixed(3)} MB which is ${ratio}% ` | ||
+ `of original file size: ${origFileSizeBytes.toFixed(3)} MB`; | ||
|
||
const getBound = (bound:number) => (bound / 100) * origFileSizeBytes; | ||
|
||
const errText = 'New file size not within limits.'; | ||
if (newFileSizeBytes > getBound(lessThanPerc)) { | ||
// Item will be errored in UI | ||
args.jobLog(`${errText} ${sizeText}. upperBound is ${lessThanPerc}%`); | ||
} else if (newFileSizeBytes < getBound(greaterThanPerc)) { | ||
// // Item will be errored in UI | ||
args.jobLog(`${errText} ${sizeText}. lowerBound is ${greaterThanPerc}%`); | ||
} else { | ||
args.jobLog(sizeText); | ||
isWithinRange = true; | ||
} | ||
|
||
return { | ||
outputFileObj: args.inputFileObj, | ||
outputNumber: isWithinRange ? 1 : 2, | ||
variables: args.variables, | ||
}; | ||
}; | ||
export { | ||
details, | ||
plugin, | ||
}; |