-
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.
- Loading branch information
Showing
416 changed files
with
32,993 additions
and
1,672 deletions.
There are no files selected for viewing
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 |
---|---|---|
@@ -1,31 +1,87 @@ | ||
{ | ||
"env": { | ||
"commonjs": true, | ||
"es6": true, | ||
"node": true | ||
}, | ||
"extends": [ | ||
"airbnb-base" | ||
"settings": { | ||
"import/resolver": { | ||
"node": { | ||
"extensions": [ | ||
".js", | ||
".jsx", | ||
".ts", | ||
".tsx" | ||
] | ||
} | ||
} | ||
}, | ||
"env": { | ||
"commonjs": true, | ||
"es6": true, | ||
"node": true | ||
}, | ||
"extends": [ | ||
"airbnb-base", | ||
"plugin:@typescript-eslint/eslint-recommended", | ||
"plugin:@typescript-eslint/recommended" | ||
], | ||
"plugins": [ | ||
"prefer-arrow-functions" | ||
], | ||
"globals": { | ||
"Atomics": "readonly", | ||
"SharedArrayBuffer": "readonly" | ||
}, | ||
"parserOptions": { | ||
"ecmaVersion": 2018, | ||
"project": [ | ||
"./tsconfig.eslint.json" | ||
] | ||
}, | ||
"rules": { | ||
"func-style": [ | ||
"error", | ||
"expression" | ||
], | ||
"prefer-arrow-functions/prefer-arrow-functions": [ | ||
"warn", | ||
{ | ||
"classPropertiesAllowed": false, | ||
"disallowPrototype": false, | ||
"returnStyle": "unchanged", | ||
"singleReturnOnly": false | ||
} | ||
], | ||
"require-await":["error"], | ||
"global-require": 0, | ||
"no-void": 0, | ||
"@typescript-eslint/no-floating-promises": [ | ||
"error" | ||
], | ||
"globals": { | ||
"Atomics": "readonly", | ||
"SharedArrayBuffer": "readonly" | ||
}, | ||
"parserOptions": { | ||
"ecmaVersion": 2018 | ||
}, | ||
"rules": { | ||
"global-require":0, | ||
"class-methods-use-this": 0, | ||
"no-case-declarations": 0, | ||
"camelcase": 0, | ||
"jsx-a11y/click-events-have-key-events": 0, | ||
"no-underscore-dangle": ["error", { "allow": ["_id"] }], | ||
"max-len": [ | ||
"error", | ||
{ | ||
"code": 120 | ||
} | ||
"@typescript-eslint/no-var-requires": 0, | ||
"class-methods-use-this": 0, | ||
"no-case-declarations": 0, | ||
"camelcase": 0, | ||
"jsx-a11y/click-events-have-key-events": 0, | ||
"no-underscore-dangle": [ | ||
"error", | ||
{ | ||
"allow": [ | ||
"_id" | ||
] | ||
} | ||
], | ||
"max-len": [ | ||
"error", | ||
{ | ||
"code": 120 | ||
} | ||
], | ||
"import/extensions": [ | ||
"error", | ||
"ignorePackages", | ||
{ | ||
"js": "never", | ||
"jsx": "never", | ||
"ts": "never", | ||
"tsx": "never" | ||
} | ||
] | ||
} | ||
} |
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 @@ | ||
* text=auto eol=lf |
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
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 |
---|---|---|
|
@@ -8,3 +8,7 @@ | |
|
||
### VS Code ### | ||
.vscode/ | ||
|
||
/Local | ||
/FlowPluginsTs/LocalFlowPlugins | ||
/FlowPlugins/LocalFlowPlugins |
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
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
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
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
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
100 changes: 100 additions & 0 deletions
100
Community/Tdarr_Plugin_00td_action_remove_audio_by_channel_count.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,100 @@ | ||
const details = () => ({ | ||
id: 'Tdarr_Plugin_00td_action_remove_audio_by_channel_count', | ||
Stage: 'Pre-processing', | ||
Name: 'Remove audio streams by channel count', | ||
Type: 'Video', | ||
Operation: 'Transcode', | ||
Description: ` | ||
This plugin removes audio streams based on channel count. The output container is the same as the original. | ||
If the file only has one audio stream, the plugin will be skipped. If the number of audio streams to remove | ||
equals the total number of audio streams, the plugin will be skipped. This ensures there is always at least | ||
one audio stream in the file. | ||
`, | ||
Version: '1.00', | ||
Tags: 'action', | ||
Inputs: [ | ||
{ | ||
name: 'channelCounts', | ||
type: 'string', | ||
defaultValue: '', | ||
inputUI: { | ||
type: 'text', | ||
}, | ||
tooltip: | ||
`Enter the the channel counts to remove. | ||
\\nExample:\\n | ||
8,6 | ||
`, | ||
}, | ||
], | ||
}); | ||
|
||
// eslint-disable-next-line @typescript-eslint/no-unused-vars | ||
const plugin = (file, librarySettings, inputs, otherArguments) => { | ||
const lib = require('../methods/lib')(); | ||
// eslint-disable-next-line @typescript-eslint/no-unused-vars,no-param-reassign | ||
inputs = lib.loadDefaultValues(inputs, details); | ||
const response = { | ||
processFile: false, | ||
preset: '', | ||
container: `.${file.container}`, | ||
handBrakeMode: false, | ||
FFmpegMode: true, | ||
reQueueAfter: false, | ||
infoLog: '', | ||
}; | ||
|
||
if (inputs.channelCounts.trim() === '') { | ||
response.infoLog += 'No input entered in plugin, skipping'; | ||
return response; | ||
} | ||
|
||
const audioStreams = file.ffProbeData.streams.filter((row) => row.codec_type === 'audio'); | ||
|
||
if (audioStreams.length === 0) { | ||
response.infoLog += 'File has no audio streams, skipping plugin'; | ||
return response; | ||
} | ||
|
||
if (audioStreams.length === 1) { | ||
response.infoLog += 'File only has 1 audio stream, skipping plugin'; | ||
return response; | ||
} | ||
|
||
response.preset += ', -map 0 -c copy -max_muxing_queue_size 9999'; | ||
|
||
const audioToRemove = []; | ||
const channelCounts = inputs.channelCounts.trim().split(','); | ||
|
||
for (let i = 0; i < channelCounts.length; i += 1) { | ||
const channelCount = parseInt(channelCounts[i], 10); | ||
for (let j = 0; j < audioStreams.length; j += 1) { | ||
if (channelCount === audioStreams[j].channels) { | ||
audioToRemove.push(audioStreams[j]); | ||
} | ||
} | ||
} | ||
|
||
if (audioToRemove.length === 0) { | ||
response.infoLog += 'No audio streams to remove!'; | ||
return response; | ||
} | ||
|
||
if (audioToRemove.length === audioStreams.length) { | ||
response.infoLog += 'The number of audio streams to remove equals ' | ||
+ 'the total number of audio streams, skipping plugin'; | ||
return response; | ||
} | ||
|
||
audioToRemove.forEach((row) => { | ||
response.preset += ` -map -0:${row.index} `; | ||
response.infoLog += ` Removing stream ${row.index} which has ${row.channels} channels.`; | ||
}); | ||
|
||
response.processFile = true; | ||
return response; | ||
}; | ||
|
||
module.exports.details = details; | ||
module.exports.plugin = plugin; |
Oops, something went wrong.