diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index f4c5cf43a..b01dc4aac 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -38,8 +38,8 @@ lint: stage: lint script: - yarn - - npm run lint - - npm run stylelint + - yarn lint + - yarn stylelint test: stage: test @@ -62,7 +62,7 @@ build: - himem script: - yarn - - npm run build + - yarn build artifacts: paths: - dist/ diff --git a/build/check-versions.js b/build/check-versions.js index e2b6cf74c..a269a5bc3 100644 --- a/build/check-versions.js +++ b/build/check-versions.js @@ -11,11 +11,6 @@ var versionRequirements = [ name: 'node', currentVersion: semver.clean(process.version), versionRequirement: packageConfig.engines.node - }, - { - name: 'npm', - currentVersion: exec('npm --version'), - versionRequirement: packageConfig.engines.npm } ] diff --git a/changelog.d/customizable-actions.add b/changelog.d/customizable-actions.add new file mode 100644 index 000000000..5ce6a5180 --- /dev/null +++ b/changelog.d/customizable-actions.add @@ -0,0 +1 @@ +Post actions can be customized diff --git a/changelog.d/denpmify-gitlab-ci.skip b/changelog.d/denpmify-gitlab-ci.skip new file mode 100644 index 000000000..e69de29bb diff --git a/changelog.d/muted_user_en_translation.skip b/changelog.d/muted_user_en_translation.skip new file mode 100644 index 000000000..1d39e49d1 --- /dev/null +++ b/changelog.d/muted_user_en_translation.skip @@ -0,0 +1 @@ +Added missing EN translation key for status.muted_user diff --git a/changelog.d/no-check-npm.skip b/changelog.d/no-check-npm.skip new file mode 100644 index 000000000..e69de29bb diff --git a/changelog.d/vuex-devtools.skip b/changelog.d/vuex-devtools.skip new file mode 100644 index 000000000..e69de29bb diff --git a/package.json b/package.json index 182a541d9..2587202c5 100644 --- a/package.json +++ b/package.json @@ -10,13 +10,13 @@ "unit": "karma start test/unit/karma.conf.js --single-run", "unit:watch": "karma start test/unit/karma.conf.js --single-run=false", "e2e": "node test/e2e/runner.js", - "test": "npm run unit && npm run e2e", - "stylelint": "npx stylelint '**/*.scss' '**/*.vue'", + "test": "yarn run unit && yarn run e2e", + "stylelint": "yarn exec stylelint '**/*.scss' '**/*.vue'", "lint": "eslint --ext .js,.vue src test/unit/specs test/e2e/specs", "lint-fix": "eslint --fix --ext .js,.vue src test/unit/specs test/e2e/specs" }, "dependencies": { - "@babel/runtime": "7.21.5", + "@babel/runtime": "7.26.0", "@chenfengyuan/vue-qrcode": "2.0.0", "@fortawesome/fontawesome-svg-core": "6.4.0", "@fortawesome/free-regular-svg-icons": "6.4.0", @@ -24,7 +24,7 @@ "@fortawesome/vue-fontawesome": "3.0.3", "@kazvmoe-infra/pinch-zoom-element": "1.2.0", "@kazvmoe-infra/unicode-emoji-json": "0.4.0", - "@ruffle-rs/ruffle": "0.1.0-nightly.2024.8.21", + "@ruffle-rs/ruffle": "0.1.0-nightly.2025.1.13", "@vuelidate/core": "2.0.3", "@vuelidate/validators": "2.0.4", "body-scroll-lock": "3.1.5", @@ -37,11 +37,11 @@ "localforage": "1.10.0", "pako": "^2.1.0", "parse-link-header": "2.0.0", - "phoenix": "1.7.7", - "punycode.js": "2.3.0", - "qrcode": "1.5.3", + "phoenix": "1.7.18", + "punycode.js": "2.3.1", + "qrcode": "1.5.4", "querystring-es3": "0.2.1", - "url": "0.11.0", + "url": "0.11.4", "utf8": "3.0.0", "vue": "3.2.45", "vue-i18n": "10", @@ -51,18 +51,18 @@ "vuex": "4.1.0" }, "devDependencies": { - "@babel/core": "7.21.8", - "@babel/eslint-parser": "7.21.8", - "@babel/plugin-transform-runtime": "7.21.4", - "@babel/preset-env": "7.21.5", - "@babel/register": "7.21.0", + "@babel/core": "7.26.0", + "@babel/eslint-parser": "7.26.5", + "@babel/plugin-transform-runtime": "7.25.9", + "@babel/preset-env": "7.26.0", + "@babel/register": "7.25.9", "@intlify/vue-i18n-loader": "5.0.1", "@ungap/event-target": "0.2.4", "@vue/babel-helper-vue-jsx-merge-props": "1.4.0", - "@vue/babel-plugin-jsx": "1.2.2", + "@vue/babel-plugin-jsx": "1.2.5", "@vue/compiler-sfc": "3.2.45", "@vue/test-utils": "2.2.8", - "autoprefixer": "10.4.19", + "autoprefixer": "10.4.20", "babel-loader": "9.1.3", "babel-plugin-lodash": "3.3.4", "chai": "4.3.7", @@ -70,7 +70,7 @@ "chromedriver": "108.0.0", "connect-history-api-fallback": "2.0.0", "copy-webpack-plugin": "11.0.0", - "cross-spawn": "7.0.3", + "cross-spawn": "7.0.6", "css-loader": "6.10.0", "css-minimizer-webpack-plugin": "4.2.2", "custom-event-polyfill": "1.0.7", @@ -83,14 +83,14 @@ "eslint-plugin-vue": "9.9.0", "eslint-webpack-plugin": "3.2.0", "eventsource-polyfill": "0.9.6", - "express": "4.18.2", - "function-bind": "1.1.1", + "express": "4.21.2", + "function-bind": "1.1.2", "html-webpack-plugin": "5.5.1", - "http-proxy-middleware": "2.0.6", + "http-proxy-middleware": "2.0.7", "iso-639-1": "2.1.15", "json-loader": "0.5.7", "karma": "6.4.4", - "karma-coverage": "2.2.0", + "karma-coverage": "2.2.1", "karma-firefox-launcher": "2.1.3", "karma-mocha": "2.0.1", "karma-mocha-reporter": "2.2.5", @@ -110,7 +110,7 @@ "postcss-scss": "^4.0.6", "sass": "1.60.0", "sass-loader": "13.2.2", - "selenium-server": "2.53.1", + "selenium-server": "3.141.59", "semver": "7.3.8", "serviceworker-webpack5-plugin": "2.0.0", "shelljs": "0.8.5", @@ -131,8 +131,7 @@ "webpack-merge": "0.20.0" }, "engines": { - "node": ">= 16.0.0", - "npm": ">= 3.0.0" + "node": ">= 16.0.0" }, "packageManager": "yarn@1.22.22+sha512.a6b2f7906b721bba3d67d4aff083df04dad64c399707841b7acf00f6b133b7ac24255f2652fa22ae3534329dc6180534e98d17432037ff6fd140556e2bb3137e" } diff --git a/src/App.scss b/src/App.scss index 1b781304e..081ce2fdb 100644 --- a/src/App.scss +++ b/src/App.scss @@ -339,6 +339,8 @@ nav { grid-template-areas: "content"; padding: 0; + --_actionsColumnCount: 3; + .column { padding-top: 0; margin: var(--navbar-height) 0 0 0; diff --git a/src/components/account_actions/account_actions.vue b/src/components/account_actions/account_actions.vue index 62862a8fc..fd4837ee4 100644 --- a/src/components/account_actions/account_actions.vue +++ b/src/components/account_actions/account_actions.vue @@ -9,60 +9,80 @@