Skip to content

Commit a7e29e1

Browse files
Merge branch 'FreeTubeApp:development' into development
This is an automated nightly publish.
2 parents 5a1dda8 + 57a72e0 commit a7e29e1

File tree

126 files changed

+8830
-7200
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

126 files changed

+8830
-7200
lines changed

.babelrc

+1-1
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@
55
{
66
"targets": {
77
"chrome": "104",
8-
"node": 16
8+
"node": "16.15.0"
99
}
1010
}
1111
]
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,28 @@
1+
# Compress images on demand (workflow_dispatch), and at 12am every Sunday (schedule).
2+
# Open a Pull Request if any images can be compressed.
3+
name: Compress Images
4+
on:
5+
workflow_dispatch:
6+
schedule:
7+
- cron: '0 0 * * 0'
8+
jobs:
9+
build:
10+
name: calibreapp/image-actions
11+
runs-on: ubuntu-latest
12+
steps:
13+
- name: Checkout Repo
14+
uses: actions/checkout@v2
15+
- name: Compress Images
16+
id: calibre
17+
uses: calibreapp/image-actions@main
18+
with:
19+
githubToken: ${{ secrets.GITHUB_TOKEN }}
20+
compressOnly: true
21+
- name: Create New Pull Request If Needed
22+
if: steps.calibre.outputs.markdown != ''
23+
uses: peter-evans/create-pull-request@v3
24+
with:
25+
title: Compressed Images Nightly
26+
branch-suffix: timestamp
27+
commit-message: Compressed Images
28+
body: ${{ steps.calibre.outputs.markdown }}

.github/workflows/conflicts.yml

+25
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
name: "Conflicts"
2+
on:
3+
# So that PRs touching the same files as the push are updated
4+
push:
5+
# So that the `dirtyLabel` is removed if conflicts are resolve
6+
# We recommend `pull_request_target` so that github secrets are available.
7+
# In `pull_request` we wouldn't be able to change labels of fork PRs
8+
pull_request_target:
9+
types: [synchronize]
10+
workflow_run:
11+
workflows: ['Dummy workflow for conflicts']
12+
types: [requested]
13+
14+
jobs:
15+
main:
16+
runs-on: ubuntu-latest
17+
steps:
18+
- name: check if prs are dirty
19+
uses: eps1lon/actions-label-merge-conflict@releases/2.x
20+
with:
21+
dirtyLabel: "PR: merge conflicts / rebase needed"
22+
removeOnDirtyLabel: "PR: waiting for review"
23+
repoToken: "${{ secrets.GITHUB_TOKEN }}"
24+
commentOnDirty: "This pull request has conflicts, please resolve those before we can evaluate the pull request."
25+
commentOnClean: "Conflicts have been resolved. A maintainer will review the pull request shortly."

.github/workflows/dummy-conflicts.yml

+9
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
name: Dummy workflow for conflicts
2+
on:
3+
pull_request_review:
4+
types: [submitted]
5+
jobs:
6+
dummy:
7+
runs-on: ubuntu-latest
8+
steps:
9+
- run: echo "this is a dummy workflow that triggers a workflow_run; it's necessary because otherwise the repo secrets will not be in scope for externally forked pull requests"

README.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -57,7 +57,7 @@ Download Privacy Redirect for [Firefox](https://addons.mozilla.org/en-US/firefox
5757

5858
Download LibRedirect for [Firefox](https://addons.mozilla.org/firefox/addon/libredirect/) or [Google Chrome](https://github.com/libredirect/libredirect/blob/master/chromium.md).
5959

60-
Disclaimer: Learn more about why a browser extension is bad for your [privacy](https://www.privacyguides.org/browsers/#extensions).
60+
Disclaimer: Learn more about why a browser extension is bad for your [privacy](https://www.privacyguides.org/desktop-browsers/#additional-resources).
6161

6262
If you have issues with the extension working with FreeTube, please create an issue in this repository instead of the extension repository.
6363

_icons/.icon-set/iconColor_256.png

-394 Bytes
Loading

_icons/.icon-set/icon_128x128.png

-517 Bytes
Loading

_icons/.icon-set/icon_16x16.png

-37 Bytes
Loading

_icons/.icon-set/icon_32x32.png

-117 Bytes
Loading

_icons/.icon-set/icon_48x48.png

-251 Bytes
Loading

_icons/.icon-set/icon_64x64.png

-249 Bytes
Loading

_icons/256x256.png

-322 Bytes
Loading

_icons/iconBlackSmall.png

-146 Bytes
Loading
-3.05 KB
Loading
-4.16 KB
Loading

_icons/iconColor.png

-322 Bytes
Loading

_icons/iconColorSmall.png

-146 Bytes
Loading

_icons/iconDraculaDarkSmall.png

-5.01 KB
Loading

_icons/iconDraculaLightSmall.png

-4.37 KB
Loading

_icons/logoColor.png

-747 Bytes
Loading
-3.81 KB
Loading
-7.32 KB
Loading

_icons/textColor.png

-466 Bytes
Loading

_icons/textColorSmall.png

-391 Bytes
Loading

_icons/textDraculaDarkSmall.png

-5.66 KB
Loading

_icons/textDraculaLightSmall.png

-5.73 KB
Loading

_icons/textWhite.png

-5.73 KB
Loading

_scripts/build.js

+7-15
Original file line numberDiff line numberDiff line change
@@ -58,22 +58,14 @@ const config = {
5858
'icon.svg',
5959
'./dist/**/*',
6060
'!dist/web/*',
61-
'!**/node_modules/**/.*',
62-
'!**/node_modules/**/index.html',
63-
'!**/{.github,Jenkinsfile}',
64-
'!**/{CHANGES.md,CODE_OF_CONDUCT.md,CONTRIBUTING.md,CONTRIBUTION.md,DEVELOPMENT.md,docs,docs.md,docs.mli,examples,History.md,HISTORY.md,README.md,TODO.md,UPGRADE_GUIDE.md,UPGRADING.md}',
65-
'!**/{commitlint.config.js,.editorconfig,.eslintignore,.eslintrc.{js,yml},.gitmodules,.huskyrc,.lintstagedrc,.nvmrc,.nycrc{,.json},.prettierrc{,.yaml},tslint.json}',
66-
'!**/{.babelrc,bower.json,Gruntfile.js,Makefile,.npmrc.proregistry,rollup.config.js,.tm_properties,.tool-versions,tsconfig.json,webpack.config.js}',
67-
'!**/*.{{,c,m}js,min,ts}.map',
68-
'!**/*.d.ts',
61+
'!node_modules/**/*',
62+
63+
// renderer
64+
'node_modules/{miniget,ytpl,ytsr}/**/*',
6965

70-
// only exclude the src directory for specific packages
71-
// as some of them have their dist code in there and we don't want to exclude those
72-
'!**/node_modules/{@fortawesome/vue-fontawesome,agent-base,jquery,localforage,m3u8-parser,marked,mpd-parser,performance-now,video.js,vue,vue-i18n,vue-router}/src/*',
73-
'!**/node_modules/**/{bin,man,scripts}/*',
74-
'!**/node_modules/jquery/dist/jquery.slim*.js',
75-
'!**/node_modules/video.js/dist/{alt/*,video.js}',
76-
'!**/node_modules/@videojs/*/src'
66+
'!**/README.md',
67+
'!**/*.js.map',
68+
'!**/*.d.ts',
7769
],
7870
dmg: {
7971
contents: [

_scripts/webpack.main.config.js

+7-18
Original file line numberDiff line numberDiff line change
@@ -2,15 +2,9 @@ const path = require('path')
22
const webpack = require('webpack')
33
const CopyWebpackPlugin = require('copy-webpack-plugin')
44

5-
const {
6-
dependencies,
7-
devDependencies,
8-
productName,
9-
} = require('../package.json')
5+
const { productName } = require('../package.json')
106

11-
const externals = Object.keys(dependencies).concat(Object.keys(devDependencies))
127
const isDevMode = process.env.NODE_ENV === 'development'
13-
const whiteListedModules = []
148

159
const config = {
1610
name: 'main',
@@ -19,7 +13,10 @@ const config = {
1913
entry: {
2014
main: path.join(__dirname, '../src/main/index.js'),
2115
},
22-
externals: externals.filter(d => !whiteListedModules.includes(d)),
16+
// webpack spits out errors while inlining electron-debug as
17+
// it tries to dynamically load dependencies
18+
// the error: "Critical dependency: the request of a dependency is an expression"
19+
externals: ['electron-debug'],
2320
module: {
2421
rules: [
2522
{
@@ -68,13 +65,9 @@ if (isDevMode) {
6865
config.plugins.push(
6966
new CopyWebpackPlugin({
7067
patterns: [
71-
{
72-
from: path.join(__dirname, '../static/pwabuilder-sw.js'),
73-
to: path.join(__dirname, '../dist/web/pwabuilder-sw.js'),
74-
},
7568
{
7669
from: path.join(__dirname, '../static'),
77-
to: path.join(__dirname, '../dist/web/static'),
70+
to: path.join(__dirname, '../dist/static'),
7871
globOptions: {
7972
dot: true,
8073
ignore: ['**/.*', '**/pwabuilder-sw.js', '**/dashFiles/**', '**/storyboards/**'],
@@ -96,11 +89,7 @@ if (isDevMode) {
9689
ignore: ['**/.*'],
9790
},
9891
},
99-
]
100-
}
101-
),
102-
new webpack.LoaderOptionsPlugin({
103-
minimize: true,
92+
]
10493
})
10594
)
10695
}

_scripts/webpack.renderer.config.js

+7-62
Original file line numberDiff line numberDiff line change
@@ -2,18 +2,11 @@ const path = require('path')
22
const webpack = require('webpack')
33
const HtmlWebpackPlugin = require('html-webpack-plugin')
44
const VueLoaderPlugin = require('vue-loader/lib/plugin')
5-
const CopyWebpackPlugin = require('copy-webpack-plugin')
65
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
76

8-
const {
9-
dependencies,
10-
devDependencies,
11-
productName,
12-
} = require('../package.json')
7+
const { productName } = require('../package.json')
138

14-
const externals = Object.keys(dependencies).concat(Object.keys(devDependencies))
159
const isDevMode = process.env.NODE_ENV === 'development'
16-
const whiteListedModules = ['vue']
1710

1811
const config = {
1912
name: 'renderer',
@@ -33,7 +26,10 @@ const config = {
3326
path: path.join(__dirname, '../dist'),
3427
filename: '[name].js',
3528
},
36-
externals: externals.filter(d => !whiteListedModules.includes(d)),
29+
// webpack spits out errors while inlining ytpl and ytsr as
30+
// they dynamically import their package.json file to extract the bug report URL
31+
// the error: "Critical dependency: the request of a dependency is an expression"
32+
externals: ['ytpl', 'ytsr'],
3733
module: {
3834
rules: [
3935
{
@@ -54,11 +50,8 @@ const config = {
5450
use: [
5551
{
5652
loader: MiniCssExtractPlugin.loader,
57-
options: {},
58-
},
59-
{
60-
loader: 'css-loader',
6153
},
54+
'css-loader',
6255
{
6356
loader: 'sass-loader',
6457
options: {
@@ -75,8 +68,7 @@ const config = {
7568
test: /\.css$/,
7669
use: [
7770
{
78-
loader: MiniCssExtractPlugin.loader,
79-
options: {},
71+
loader: MiniCssExtractPlugin.loader
8072
},
8173
'css-loader',
8274
],
@@ -153,53 +145,6 @@ if (isDevMode) {
153145
__static: `"${path.join(__dirname, '../static').replace(/\\/g, '\\\\')}"`,
154146
})
155147
)
156-
} else {
157-
config.plugins.push(
158-
new CopyWebpackPlugin({
159-
patterns: [
160-
{
161-
from: path.join(__dirname, '../static/pwabuilder-sw.js'),
162-
to: path.join(__dirname, '../dist/web/pwabuilder-sw.js'),
163-
},
164-
{
165-
from: path.join(__dirname, '../static'),
166-
to: path.join(__dirname, '../dist/web/static'),
167-
globOptions: {
168-
dot: true,
169-
ignore: ['**/.*', '**/pwabuilder-sw.js', '**/dashFiles/**', '**/storyboards/**'],
170-
},
171-
},
172-
{
173-
from: path.join(__dirname, '../static'),
174-
to: path.join(__dirname, '../dist/static'),
175-
globOptions: {
176-
dot: true,
177-
ignore: ['**/.*', '**/pwabuilder-sw.js', '**/dashFiles/**', '**/storyboards/**'],
178-
},
179-
},
180-
{
181-
from: path.join(__dirname, '../_icons'),
182-
to: path.join(__dirname, '../dist/web/_icons'),
183-
globOptions: {
184-
dot: true,
185-
ignore: ['**/.*'],
186-
},
187-
},
188-
{
189-
from: path.join(__dirname, '../src/renderer/assets/img'),
190-
to: path.join(__dirname, '../dist/web/images'),
191-
globOptions: {
192-
dot: true,
193-
ignore: ['**/.*'],
194-
},
195-
},
196-
]
197-
}
198-
),
199-
new webpack.LoaderOptionsPlugin({
200-
minimize: true,
201-
})
202-
)
203148
}
204149

205150
module.exports = config

_scripts/webpack.web.config.js

+3-11
Original file line numberDiff line numberDiff line change
@@ -46,11 +46,8 @@ const config = {
4646
use: [
4747
{
4848
loader: MiniCssExtractPlugin.loader,
49-
options: {},
50-
},
51-
{
52-
loader: 'css-loader',
5349
},
50+
'css-loader',
5451
{
5552
loader: 'sass-loader',
5653
options: {
@@ -67,8 +64,7 @@ const config = {
6764
test: /\.css$/,
6865
use: [
6966
{
70-
loader: MiniCssExtractPlugin.loader,
71-
options: {},
67+
loader: MiniCssExtractPlugin.loader
7268
},
7369
'css-loader',
7470
],
@@ -183,11 +179,7 @@ if (isDevMode) {
183179
ignore: ['**/.*'],
184180
},
185181
},
186-
]
187-
}
188-
),
189-
new webpack.LoaderOptionsPlugin({
190-
minimize: true,
182+
]
191183
})
192184
)
193185
}

_scripts/webpack.workers.config.js

+1-5
Original file line numberDiff line numberDiff line change
@@ -63,11 +63,7 @@ const config = {
6363
if (isDevMode) {
6464
// any dev only config
6565
} else {
66-
config.plugins.push(
67-
new webpack.LoaderOptionsPlugin({
68-
minimize: true,
69-
})
70-
)
66+
// any producation only config
7167
}
7268

7369
module.exports = config

package.json

+13-14
Original file line numberDiff line numberDiff line change
@@ -44,15 +44,16 @@
4444
"rebuild:electron": "electron-builder install-app-deps",
4545
"rebuild:node": "npm rebuild",
4646
"release": "run-s test build",
47-
"ci": "yarn install"
47+
"ci": "yarn install --frozen-lockfile"
4848
},
4949
"dependencies": {
5050
"@fortawesome/fontawesome-svg-core": "^1.2.36",
5151
"@fortawesome/free-brands-svg-icons": "^5.15.4",
5252
"@fortawesome/free-solid-svg-icons": "^5.15.4",
5353
"@fortawesome/vue-fontawesome": "^2.0.2",
5454
"@freetube/youtube-chat": "^1.1.2",
55-
"@freetube/yt-comment-scraper": "^6.1.0",
55+
"@freetube/yt-comment-scraper": "^6.2.0",
56+
"@freetube/yt-trending-scraper": "^3.1.0",
5657
"@silvermine/videojs-quality-selector": "^1.2.5",
5758
"archiver": "^5.3.1",
5859
"autolinker": "^3.15.0",
@@ -79,24 +80,23 @@
7980
"vue-router": "^3.5.2",
8081
"vuex": "^3.6.2",
8182
"youtube-suggest": "^1.1.2",
82-
"yt-channel-info": "^3.0.4",
83+
"yt-channel-info": "^3.1.0",
8384
"yt-dash-manifest-generator": "1.1.0",
84-
"yt-trending-scraper": "^2.0.1",
85-
"ytdl-core": "git+https://github.com/absidue/node-ytdl-core#temp-fix-11-08-2022",
85+
"ytdl-core": "^4.11.2",
8686
"ytpl": "^2.3.0",
8787
"ytsr": "^3.8.0"
8888
},
8989
"devDependencies": {
90+
"@babel/core": "^7.18.13",
91+
"@babel/plugin-proposal-class-properties": "^7.18.6",
92+
"@babel/preset-env": "^7.18.10",
9093
"@evilmartians/lefthook": "^1.0.5",
91-
"@babel/core": "^7.17.10",
92-
"@babel/plugin-proposal-class-properties": "^7.16.7",
93-
"@babel/preset-env": "^7.17.10",
9494
"babel-eslint": "^10.1.0",
9595
"babel-loader": "^8.2.5",
96-
"copy-webpack-plugin": "^9.0.1",
96+
"copy-webpack-plugin": "^11.0.0",
9797
"cordova": "^11.0.0",
9898
"css-loader": "5.2.6",
99-
"electron": "^20.1.0",
99+
"electron": "^20.1.1",
100100
"electron-builder": "^23.0.3",
101101
"electron-builder-squirrel-windows": "^22.13.1",
102102
"electron-debug": "^3.2.0",
@@ -126,9 +126,8 @@
126126
"vue-loader": "^15.9.8",
127127
"vue-style-loader": "^4.1.3",
128128
"vue-template-compiler": "^2.6.14",
129-
"webpack": "^5.51.1",
130-
"webpack-cli": "^4.8.0",
131-
"webpack-dev-server": "^4.1.0",
132-
"xml2js": "^0.4.23"
129+
"webpack": "^5.74.0",
130+
"webpack-cli": "^4.10.0",
131+
"webpack-dev-server": "^4.10.1"
133132
}
134133
}

0 commit comments

Comments
 (0)