Compare commits
No commits in common. "master" and "v3.11.1" have entirely different histories.
|
@ -1,30 +0,0 @@
|
||||||
name: New question
|
|
||||||
about: Use this template when you don't know how to do something
|
|
||||||
title: "[Question] "
|
|
||||||
labels:
|
|
||||||
- question
|
|
||||||
body:
|
|
||||||
- type: markdown
|
|
||||||
attributes:
|
|
||||||
value: |
|
|
||||||
Thanks for taking the time to fill information.
|
|
||||||
|
|
||||||
- type: textarea
|
|
||||||
id: environment
|
|
||||||
attributes:
|
|
||||||
label: Environment
|
|
||||||
value: |
|
|
||||||
* Custom menu version:
|
|
||||||
* Nextcloud version:
|
|
||||||
* PHP version:
|
|
||||||
* Web server (Nginx, Apache2):
|
|
||||||
* Web browser and version (Firefox 80, Google Chrome 74, etc):
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
|
|
||||||
- type: textarea
|
|
||||||
id: question
|
|
||||||
attributes:
|
|
||||||
label: Question
|
|
||||||
validations:
|
|
||||||
required: true
|
|
|
@ -1,8 +0,0 @@
|
||||||
blank_issues_enabled: false
|
|
||||||
contact_links:
|
|
||||||
- name: Documentation
|
|
||||||
url: https://deblan.gitnet.page/side_menu_doc/
|
|
||||||
about: Official documentation web site
|
|
||||||
- name: Ask a question in our Matrix room
|
|
||||||
about: If you prefer a chat-like conversation or in need for quick help, this might be an alternative to opening an issue.
|
|
||||||
url: https://matrix.to/#/#custommenu:neutralnetwork.org
|
|
95
.woodpecker.yml
Normal file
95
.woodpecker.yml
Normal file
|
@ -0,0 +1,95 @@
|
||||||
|
steps:
|
||||||
|
dependencies:
|
||||||
|
image: node:16
|
||||||
|
pull: true
|
||||||
|
commands:
|
||||||
|
- npm i
|
||||||
|
when:
|
||||||
|
event: [tag, push, pull_request, manual]
|
||||||
|
branch: [master, develop, feature/*, fix/*, bugfix/*, translations]
|
||||||
|
|
||||||
|
osv-detector:
|
||||||
|
image: gitnet.fr/deblan/osv-detector:v0.10
|
||||||
|
commands:
|
||||||
|
- osv-detector package-lock.json
|
||||||
|
failure: ignore
|
||||||
|
|
||||||
|
build-js:
|
||||||
|
image: node:16
|
||||||
|
commands:
|
||||||
|
- npm run build
|
||||||
|
when:
|
||||||
|
event: [tag, push, pull_request, manual]
|
||||||
|
branch: [master, develop, feature/*, fix/*, bugfix/*, translations]
|
||||||
|
|
||||||
|
build-translations:
|
||||||
|
image: deblan/php:8.0
|
||||||
|
commands:
|
||||||
|
- php bin/generate_l10n.php
|
||||||
|
when:
|
||||||
|
event: [tag, push, pull_request, manual]
|
||||||
|
branch: [master, develop, feature/*, fix/*, bugfix/*, translations]
|
||||||
|
|
||||||
|
create-signature:
|
||||||
|
image: nextcloud:25
|
||||||
|
secrets: [app_certificate, app_public_certificate]
|
||||||
|
environment:
|
||||||
|
SQLITE_DATABASE: /var/www/data/data.db
|
||||||
|
NEXTCLOUD_ADMIN_USER: admin
|
||||||
|
NEXTCLOUD_ADMIN_PASSWORD: admin
|
||||||
|
commands:
|
||||||
|
- echo "$APP_CERTIFICATE" > "/tmp/side_menu.key"
|
||||||
|
- echo "$APP_PUBLIC_CERTIFICATE" > "/tmp/side_menu.crt"
|
||||||
|
- mkdir /tmp/app
|
||||||
|
- cp -r README.md CHANGELOG.md appinfo css lib img l10n js src templates screenshots vendor /tmp/app
|
||||||
|
- /usr/src/nextcloud/occ integrity:sign-app
|
||||||
|
--privateKey=/tmp/side_menu.key
|
||||||
|
--certificate=/tmp/side_menu.crt
|
||||||
|
--path=/tmp/app
|
||||||
|
- mv /tmp/app/appinfo/signature.json appinfo/
|
||||||
|
when:
|
||||||
|
event: [tag]
|
||||||
|
|
||||||
|
# check-code-quality:
|
||||||
|
# image: sonarsource/sonar-scanner-cli
|
||||||
|
# secrets: [sonar_token, sonar_host, sonar_project]
|
||||||
|
# commands:
|
||||||
|
# - sonar-scanner
|
||||||
|
# -Dsonar.projectKey=$SONAR_PROJECT
|
||||||
|
# -Dsonar.sources=.
|
||||||
|
# -Dsonar.host.url=$SONAR_HOST
|
||||||
|
# -Dsonar.pullrequest.key=$CI_COMMIT_PULL_REQUEST
|
||||||
|
# -Dsonar.pullrequest.branch=$CI_COMMIT_SOURCE_BRANCH
|
||||||
|
# -Dsonar.pullrequest.base=$CI_COMMIT_TARGET_BRANCH
|
||||||
|
# failure: ignore
|
||||||
|
# when:
|
||||||
|
# event: [pull_request]
|
||||||
|
|
||||||
|
create-package:
|
||||||
|
image: deblan/php:8.0
|
||||||
|
volumes:
|
||||||
|
- /var/www/html/artifacts:/var/www/html/artifacts
|
||||||
|
secrets: [app_certificate]
|
||||||
|
commands:
|
||||||
|
- apt-get update
|
||||||
|
- apt-get install -y zip make
|
||||||
|
- mkdir -p "$HOME/.nextcloud/certificates"
|
||||||
|
- echo "$APP_CERTIFICATE" > "$HOME/.nextcloud/certificates/side_menu.key"
|
||||||
|
- export VERSION=$(grep "<version>" appinfo/info.xml | grep -o "[0-9]*\.[0-9]*\.[0-9]*" --color=never)
|
||||||
|
- export RELEASE_DIRECTORY="/var/www/html/artifacts/deblan/side_menu"
|
||||||
|
- make release
|
||||||
|
when:
|
||||||
|
event: [tag]
|
||||||
|
|
||||||
|
push-release:
|
||||||
|
image: plugins/gitea-release
|
||||||
|
volumes:
|
||||||
|
- /var/www/html/artifacts:/var/www/html/artifacts
|
||||||
|
settings:
|
||||||
|
api_key:
|
||||||
|
from_secret: gitnet_api_key
|
||||||
|
base_url: https://gitnet.fr
|
||||||
|
note: ${CI_COMMIT_MESSAGE}
|
||||||
|
files: /var/www/html/artifacts/deblan/side_menu/${CI_COMMIT_TAG/v//}/*
|
||||||
|
when:
|
||||||
|
event: [tag]
|
|
@ -1,28 +0,0 @@
|
||||||
variables:
|
|
||||||
volumes: &volumes
|
|
||||||
- /data/${CI_REPO}:/builds
|
|
||||||
|
|
||||||
when:
|
|
||||||
event: [tag, push, pull_request, manual]
|
|
||||||
branch: [master, develop, feature/*, fix/*, bugfix/*, translations]
|
|
||||||
|
|
||||||
steps:
|
|
||||||
"Install dependencies":
|
|
||||||
image: node:16
|
|
||||||
pull: true
|
|
||||||
commands:
|
|
||||||
- npm i
|
|
||||||
|
|
||||||
"Build JS":
|
|
||||||
image: node:16
|
|
||||||
commands:
|
|
||||||
- npm run build
|
|
||||||
|
|
||||||
"Build translations":
|
|
||||||
image: deblan/php:8.3
|
|
||||||
commands:
|
|
||||||
- php bin/generate_l10n.php
|
|
||||||
|
|
||||||
"Build cache":
|
|
||||||
image: gitnet.fr/deblan/woodpecker-cache
|
|
||||||
volumes: *volumes
|
|
|
@ -1,61 +0,0 @@
|
||||||
variables:
|
|
||||||
volumes: &volumes
|
|
||||||
- /data/${CI_REPO}:/builds
|
|
||||||
- /var/www/html/artifacts:/var/www/html/artifacts
|
|
||||||
|
|
||||||
depends_on:
|
|
||||||
- build
|
|
||||||
|
|
||||||
when:
|
|
||||||
event: [tag]
|
|
||||||
|
|
||||||
steps:
|
|
||||||
"Verify tag and app version":
|
|
||||||
image: alpine
|
|
||||||
commands:
|
|
||||||
- TAG=${CI_COMMIT_TAG/v//}
|
|
||||||
- grep "<version>$TAG</version>" appinfo/info.xml
|
|
||||||
|
|
||||||
"Create signature":
|
|
||||||
image: nextcloud:25
|
|
||||||
secrets: [app_certificate, app_public_certificate]
|
|
||||||
volumes: *volumes
|
|
||||||
environment:
|
|
||||||
SQLITE_DATABASE: /var/www/data/data.db
|
|
||||||
NEXTCLOUD_ADMIN_USER: admin
|
|
||||||
NEXTCLOUD_ADMIN_PASSWORD: admin
|
|
||||||
commands:
|
|
||||||
- cd "/builds/$CI_COMMIT_SHA"
|
|
||||||
- echo "$APP_CERTIFICATE" > "/tmp/side_menu.key"
|
|
||||||
- echo "$APP_PUBLIC_CERTIFICATE" > "/tmp/side_menu.crt"
|
|
||||||
- mkdir /tmp/app
|
|
||||||
- cp -r README.md CHANGELOG.md appinfo css lib img l10n js src templates screenshots vendor /tmp/app
|
|
||||||
- /usr/src/nextcloud/occ integrity:sign-app
|
|
||||||
--privateKey=/tmp/side_menu.key
|
|
||||||
--certificate=/tmp/side_menu.crt
|
|
||||||
--path=/tmp/app
|
|
||||||
- mv /tmp/app/appinfo/signature.json appinfo/
|
|
||||||
|
|
||||||
"Create package":
|
|
||||||
image: deblan/php:8.3
|
|
||||||
volumes: *volumes
|
|
||||||
secrets: [app_certificate]
|
|
||||||
commands:
|
|
||||||
- cd "/builds/$CI_COMMIT_SHA"
|
|
||||||
- apt-get update
|
|
||||||
- apt-get install -y zip make
|
|
||||||
- mkdir -p "$HOME/.nextcloud/certificates"
|
|
||||||
- echo "$APP_CERTIFICATE" > "$HOME/.nextcloud/certificates/side_menu.key"
|
|
||||||
- export VERSION=$(grep "<version>" appinfo/info.xml | grep -o "[0-9]*\.[0-9]*\.[0-9]*" --color=never)
|
|
||||||
- export RELEASE_DIRECTORY="/var/www/html/artifacts/deblan/side_menu"
|
|
||||||
- make release
|
|
||||||
|
|
||||||
"Push release":
|
|
||||||
image: plugins/gitea-release
|
|
||||||
volumes: *volumes
|
|
||||||
settings:
|
|
||||||
api_key:
|
|
||||||
from_secret: gitnet_api_key
|
|
||||||
base_url: https://gitnet.fr
|
|
||||||
note: ${CI_COMMIT_MESSAGE}
|
|
||||||
files: /var/www/html/artifacts/deblan/side_menu/${CI_COMMIT_TAG/v//}/*
|
|
|
@ -1,17 +0,0 @@
|
||||||
variables:
|
|
||||||
volumes: &volumes
|
|
||||||
- /data/${CI_REPO}:/builds
|
|
||||||
|
|
||||||
depends_on:
|
|
||||||
- build
|
|
||||||
|
|
||||||
skip_clone: true
|
|
||||||
|
|
||||||
steps:
|
|
||||||
"Check dependencies":
|
|
||||||
image: gitnet.fr/deblan/osv-detector:v0.10
|
|
||||||
volumes: *volumes
|
|
||||||
commands:
|
|
||||||
- cd "/builds/$CI_COMMIT_SHA"
|
|
||||||
- osv-detector package-lock.json
|
|
||||||
failure: ignore
|
|
40
CHANGELOG.md
40
CHANGELOG.md
|
@ -1,45 +1,5 @@
|
||||||
## [Unreleased]
|
## [Unreleased]
|
||||||
|
|
||||||
## 3.12.0
|
|
||||||
### Added
|
|
||||||
* add compatibility with NC29
|
|
||||||
|
|
||||||
## 3.11.8
|
|
||||||
### Fixed
|
|
||||||
* move the logo inside #nextcloud element (fix #278 #239) [NC26]
|
|
||||||
|
|
||||||
## 3.11.7
|
|
||||||
### Added
|
|
||||||
* update translations
|
|
||||||
* update ci steps names
|
|
||||||
### Fixed
|
|
||||||
* add accessibility to open and close buttons (#311)
|
|
||||||
* fully apply Nextcloud AppMenu.vue updated (#326)
|
|
||||||
* add missing label on the 'save' button in personal settings (fix #318)
|
|
||||||
### Changed
|
|
||||||
* upgrade axios
|
|
||||||
* upgrade css-loader
|
|
||||||
|
|
||||||
## 3.11.6
|
|
||||||
### Fixed
|
|
||||||
* add --background-invert-if-bright in top menu (fix #326)
|
|
||||||
|
|
||||||
## 3.11.5
|
|
||||||
### Fixed
|
|
||||||
* add missing label on buttons for accessiblity (fix #311)
|
|
||||||
|
|
||||||
## 3.11.4
|
|
||||||
### Fixed
|
|
||||||
* add label on buttons for accessiblity (fix #311)
|
|
||||||
|
|
||||||
## 3.11.3
|
|
||||||
### Fixed
|
|
||||||
* fix menu icon in decks, collectives and other apps (#302)
|
|
||||||
|
|
||||||
## 3.11.2
|
|
||||||
### Fixed
|
|
||||||
* add default translations for Slovak - fix #298
|
|
||||||
|
|
||||||
## 3.11.1
|
## 3.11.1
|
||||||
### Added
|
### Added
|
||||||
* add Portuguese (Brazil) translations - Thanks to igorfreire
|
* add Portuguese (Brazil) translations - Thanks to igorfreire
|
||||||
|
|
|
@ -32,7 +32,7 @@ Notice
|
||||||
Because I believe in a free and decentralized Internet, [Gitnet](https://gitnet.fr) is **self-hosted at home**.
|
Because I believe in a free and decentralized Internet, [Gitnet](https://gitnet.fr) is **self-hosted at home**.
|
||||||
In case of downtime, you can download **Custom Menu** from [here](https://kim.deblan.fr/~side_menu/).
|
In case of downtime, you can download **Custom Menu** from [here](https://kim.deblan.fr/~side_menu/).
|
||||||
]]></description>
|
]]></description>
|
||||||
<version>3.11.8</version>
|
<version>3.11.1</version>
|
||||||
<licence>agpl</licence>
|
<licence>agpl</licence>
|
||||||
<author mail="contact@deblan.fr" homepage="https://www.deblan.io/">Simon Vieille</author>
|
<author mail="contact@deblan.fr" homepage="https://www.deblan.io/">Simon Vieille</author>
|
||||||
<namespace>SideMenu</namespace>
|
<namespace>SideMenu</namespace>
|
||||||
|
@ -54,7 +54,7 @@ In case of downtime, you can download **Custom Menu** from [here](https://kim.de
|
||||||
<screenshot>https://gitnet.fr/deblan/side_menu/raw/branch/master/screenshots/nc25_big_menu.png</screenshot>
|
<screenshot>https://gitnet.fr/deblan/side_menu/raw/branch/master/screenshots/nc25_big_menu.png</screenshot>
|
||||||
<screenshot>https://gitnet.fr/deblan/side_menu/raw/branch/master/screenshots/nc25_default_menu.png</screenshot>
|
<screenshot>https://gitnet.fr/deblan/side_menu/raw/branch/master/screenshots/nc25_default_menu.png</screenshot>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<nextcloud min-version="25" max-version="29"/>
|
<nextcloud min-version="25" max-version="28"/>
|
||||||
<php min-version="7.4"/>
|
<php min-version="7.4"/>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<settings>
|
<settings>
|
||||||
|
|
|
@ -83,12 +83,6 @@
|
||||||
padding-left: 12px !important;
|
padding-left: 12px !important;
|
||||||
margin-left: 5px !important;
|
margin-left: 5px !important;
|
||||||
margin-left: 3px !important;
|
margin-left: 3px !important;
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
|
|
||||||
.side-menu-opener span {
|
|
||||||
position: relative;
|
|
||||||
left: 50px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.side-menu-opener:active, .side-menu-opener:focus {
|
.side-menu-opener:active, .side-menu-opener:focus {
|
||||||
|
@ -294,7 +288,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.side-menu-always-displayed .app-navigation--close {
|
.side-menu-always-displayed .app-navigation--close {
|
||||||
transform: translateX(calc(-100% + 50px));
|
transform: translateX(calc(-100% + 50px)) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
#side-menu.side-menu-with-categories {
|
#side-menu.side-menu-with-categories {
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
"stylelint:fix": "./node_modules/.bin/stylelint src --fix"
|
"stylelint:fix": "./node_modules/.bin/stylelint src --fix"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"axios": "^1.6.7",
|
"axios": "^0.24.0",
|
||||||
"trim": "^1.0.1",
|
"trim": "^1.0.1",
|
||||||
"vue": "^2.6.11"
|
"vue": "^2.6.11"
|
||||||
},
|
},
|
||||||
|
@ -33,7 +33,7 @@
|
||||||
"@nextcloud/vue": "^7.12.1",
|
"@nextcloud/vue": "^7.12.1",
|
||||||
"babel-eslint": "^10.1.0",
|
"babel-eslint": "^10.1.0",
|
||||||
"babel-loader": "^8.1.0",
|
"babel-loader": "^8.1.0",
|
||||||
"css-loader": "^6.10.0",
|
"css-loader": "^3.4.2",
|
||||||
"eslint": "^8.0.0",
|
"eslint": "^8.0.0",
|
||||||
"eslint-config-standard": "^17.0.0",
|
"eslint-config-standard": "^17.0.0",
|
||||||
"eslint-import-resolver-webpack": "^0.12.1",
|
"eslint-import-resolver-webpack": "^0.12.1",
|
||||||
|
|
|
@ -1,3 +0,0 @@
|
||||||
{
|
|
||||||
"$schema": "https://docs.renovatebot.com/renovate-schema.json"
|
|
||||||
}
|
|
|
@ -21,10 +21,7 @@
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<nav
|
<nav class="app-menu show">
|
||||||
class="app-menu show"
|
|
||||||
:aria-label="t('core', 'Applications menu')"
|
|
||||||
>
|
|
||||||
<ul
|
<ul
|
||||||
class="app-menu-main"
|
class="app-menu-main"
|
||||||
:class="{ 'app-menu-main__hidden-label': hiddenLabels === 1, 'app-menu-main__show-hovered': hiddenLabels === 2 }"
|
:class="{ 'app-menu-main__hidden-label': hiddenLabels === 1, 'app-menu-main__show-hovered': hiddenLabels === 2 }"
|
||||||
|
@ -168,7 +165,6 @@ $header-icon-size: 20px;
|
||||||
flex-shrink: 1;
|
flex-shrink: 1;
|
||||||
flex-wrap: wrap;
|
flex-wrap: wrap;
|
||||||
}
|
}
|
||||||
|
|
||||||
.app-menu-main {
|
.app-menu-main {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-wrap: nowrap;
|
flex-wrap: nowrap;
|
||||||
|
@ -178,6 +174,7 @@ $header-icon-size: 20px;
|
||||||
height: 50px;
|
height: 50px;
|
||||||
position: relative;
|
position: relative;
|
||||||
display: flex;
|
display: flex;
|
||||||
|
opacity: .7;
|
||||||
|
|
||||||
&.app-menu-entry__active {
|
&.app-menu-entry__active {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
|
@ -217,8 +214,7 @@ $header-icon-size: 20px;
|
||||||
width: $header-icon-size;
|
width: $header-icon-size;
|
||||||
height: $header-icon-size;
|
height: $header-icon-size;
|
||||||
padding: calc((100% - $header-icon-size) / 2);
|
padding: calc((100% - $header-icon-size) / 2);
|
||||||
box-sizing: content-box;
|
filter: var(--primary-invert-if-bright);
|
||||||
filter: var(--background-image-invert-if-bright, var(--primary-invert-if-bright));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.app-menu-entry--label {
|
.app-menu-entry--label {
|
||||||
|
@ -227,8 +223,8 @@ $header-icon-size: 20px;
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
color: var(--color-primary-text);
|
color: var(--color-primary-text);
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
bottom: -5px;
|
||||||
left: 50%;
|
left: 50%;
|
||||||
top: 45%;
|
|
||||||
display: block;
|
display: block;
|
||||||
min-width: 100%;
|
min-width: 100%;
|
||||||
transform: translateX(-50%);
|
transform: translateX(-50%);
|
||||||
|
@ -236,7 +232,6 @@ $header-icon-size: 20px;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
letter-spacing: -0.5px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&:not(.app-menu-entry__hidden-label):not(.app-menu-entry__show-hovered):hover,
|
&:not(.app-menu-entry__hidden-label):not(.app-menu-entry__show-hovered):hover,
|
||||||
|
@ -244,11 +239,11 @@ $header-icon-size: 20px;
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
.app-menu-entry--label {
|
.app-menu-entry--label {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
font-weight: bolder;
|
font-weight: bold;
|
||||||
|
font-size: 14px;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
width: 100%;
|
width: auto;
|
||||||
text-overflow: ellipsis;
|
overflow: visible;
|
||||||
overflow: hidden;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -265,10 +260,8 @@ $header-icon-size: 20px;
|
||||||
&:not(.app-menu-main__hidden-label):not(.app-menu-main__show-hovered):focus-within,
|
&:not(.app-menu-main__hidden-label):not(.app-menu-main__show-hovered):focus-within,
|
||||||
.app-menu-entry:not(.app-menu-entry__hidden-label):hover,
|
.app-menu-entry:not(.app-menu-entry__hidden-label):hover,
|
||||||
.app-menu-entry:not(.app-menu-entry__hidden-label):focus {
|
.app-menu-entry:not(.app-menu-entry__hidden-label):focus {
|
||||||
opacity: 1;
|
|
||||||
|
|
||||||
img {
|
img {
|
||||||
margin-top: -8px;
|
margin-top: -6px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.app-menu-entry--label {
|
.app-menu-entry--label {
|
||||||
|
@ -284,7 +277,7 @@ $header-icon-size: 20px;
|
||||||
&.app-menu-main__show-hovered .app-menu-entry:hover,
|
&.app-menu-main__show-hovered .app-menu-entry:hover,
|
||||||
&.app-menu-main__show-hovered .app-menu-entry:focus {
|
&.app-menu-main__show-hovered .app-menu-entry:focus {
|
||||||
img {
|
img {
|
||||||
margin-top: -8px;
|
margin-top: -6px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.app-menu-entry--label {
|
.app-menu-entry--label {
|
||||||
|
@ -299,42 +292,38 @@ $header-icon-size: 20px;
|
||||||
}
|
}
|
||||||
|
|
||||||
::v-deep .app-menu-more .button-vue--vue-tertiary {
|
::v-deep .app-menu-more .button-vue--vue-tertiary {
|
||||||
|
color: var(--color-primary-text);
|
||||||
opacity: .7;
|
opacity: .7;
|
||||||
margin: 3px;
|
margin: 3px;
|
||||||
filter: var(--background-image-invert-if-bright, var(--primary-invert-if-bright));
|
|
||||||
|
|
||||||
&:not([aria-expanded="true"]) {
|
&:hover {
|
||||||
color: var(--color-primary-element-text);
|
opacity: 1;
|
||||||
|
background-color: transparent !important;
|
||||||
&:hover {
|
|
||||||
opacity: 1;
|
|
||||||
background-color: transparent !important;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&:focus-visible {
|
&:focus-visible {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
outline: none !important;
|
background-color: transparent !important;
|
||||||
}
|
border-radius: var(--border-radius);
|
||||||
|
outline: none;
|
||||||
|
box-shadow: 0 0 0 2px var(--color-primary-text);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.app-menu-popover-entry {
|
.app-menu-popover-entry {
|
||||||
.app-icon {
|
.app-icon {
|
||||||
position: relative;
|
position: relative;
|
||||||
height: 44px;
|
height: 44px;
|
||||||
width: 48px;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: center;
|
|
||||||
filter: var(--background-invert-if-bright, var(--primary-invert-if-bright));
|
|
||||||
|
|
||||||
&.has-unread::after {
|
&.has-unread::after {
|
||||||
background-color: var(--color-main-text);
|
background-color: var(--color-main-text);
|
||||||
}
|
}
|
||||||
|
|
||||||
img {
|
img {
|
||||||
|
filter: var(--background-invert-if-bright);
|
||||||
width: $header-icon-size;
|
width: $header-icon-size;
|
||||||
height: $header-icon-size;
|
height: $header-icon-size;
|
||||||
|
padding: calc((50px - $header-icon-size) / 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -343,7 +332,7 @@ $header-icon-size: 20px;
|
||||||
content: "";
|
content: "";
|
||||||
width: 8px;
|
width: 8px;
|
||||||
height: 8px;
|
height: 8px;
|
||||||
background-color: var(--color-primary-element-text);
|
background-color: var(--color-primary-text);
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
display: block;
|
display: block;
|
||||||
|
|
|
@ -15,18 +15,11 @@ You should have received a copy of the GNU Affero General Public License
|
||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
-->
|
-->
|
||||||
<template>
|
<template>
|
||||||
<button class="side-menu-opener side-menu-closer" :arial-label="label">
|
<button class="side-menu-opener side-menu-closer"></button>
|
||||||
<span v-text="label"></span>
|
|
||||||
</button>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
export default {
|
export default {
|
||||||
name: 'CloserButton',
|
name: 'CloserButton',
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
label: t('side_menu', 'Close the menu'),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -15,18 +15,11 @@ You should have received a copy of the GNU Affero General Public License
|
||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
-->
|
-->
|
||||||
<template>
|
<template>
|
||||||
<button class="side-menu-opener" :arial-label="label">
|
<button class="side-menu-opener"></button>
|
||||||
<span v-text="label"></span>
|
|
||||||
</button>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
export default {
|
export default {
|
||||||
name: 'OpenerButton',
|
name: 'OpenerButton',
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
label: t('side_menu', 'Toggle the menu'),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -93,4 +93,3 @@
|
||||||
"Hide labels on mouse over": "Skrýt popisky při najetím ukazatele myši"
|
"Hide labels on mouse over": "Skrýt popisky při najetím ukazatele myši"
|
||||||
"Except the hovered app": "Except the hovered app"
|
"Except the hovered app": "Except the hovered app"
|
||||||
"Search": "Search"
|
"Search": "Search"
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
||||||
|
|
|
@ -93,4 +93,3 @@
|
||||||
"Hide labels on mouse over": "Labels ausblenden, wenn sich die Maus darüber befindet (Hover)"
|
"Hide labels on mouse over": "Labels ausblenden, wenn sich die Maus darüber befindet (Hover)"
|
||||||
"Except the hovered app": "Except the hovered app"
|
"Except the hovered app": "Except the hovered app"
|
||||||
"Search": "Search"
|
"Search": "Search"
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
||||||
|
|
|
@ -93,4 +93,3 @@
|
||||||
"Hide labels on mouse over": "Ocultar las etiquetas al pasar el ratón"
|
"Hide labels on mouse over": "Ocultar las etiquetas al pasar el ratón"
|
||||||
"Except the hovered app": "Except the hovered app"
|
"Except the hovered app": "Except the hovered app"
|
||||||
"Search": "Search"
|
"Search": "Search"
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
||||||
|
|
|
@ -93,4 +93,3 @@
|
||||||
"Hide labels on mouse over": "Masquer le libellé des applications au passage de la souris"
|
"Hide labels on mouse over": "Masquer le libellé des applications au passage de la souris"
|
||||||
"Except the hovered app": "À l'exception de l'application survolée"
|
"Except the hovered app": "À l'exception de l'application survolée"
|
||||||
"Search": "Rechercher"
|
"Search": "Rechercher"
|
||||||
"Toggle the menu": "Basculer le menu"
|
|
||||||
|
|
|
@ -1,96 +0,0 @@
|
||||||
"Custom menu": "Custom menu"
|
|
||||||
"Enable the custom menu": "Enable the custom menu"
|
|
||||||
"No": "No"
|
|
||||||
"Yes": "Yes"
|
|
||||||
"Menu": "Menu"
|
|
||||||
? 'Use the shortcut <span class="keyboard-key">Ctrl</span>+<span class="keyboard-key">o</span> to open and to hide the side menu. Use <span class="keyboard-key">tab</span> to navigate.'
|
|
||||||
: 'Use the shortcut <span class="keyboard-key">Ctrl</span>+<span class="keyboard-key">o</span> to open and to hide the side menu. Use <span class="keyboard-key">tab</span> to navigate.'
|
|
||||||
"Top menu": "Top menu"
|
|
||||||
"Apps that not must be moved in the side menu": "Apps that not must be moved in the side menu"
|
|
||||||
"If there is no selection then the global configuration is applied.": "If there is no selection then the global configuration is applied."
|
|
||||||
"Experimental": "Experimental"
|
|
||||||
"Save": "Save"
|
|
||||||
"You like this app and you want to support me?": "You like this app and you want to support me?"
|
|
||||||
"Buy me a coffee ☕": "Buy me a coffee ☕"
|
|
||||||
"Hidden": "Hidden"
|
|
||||||
"Small": "Small"
|
|
||||||
"Normal": "Normal"
|
|
||||||
"Big": "Big"
|
|
||||||
"Hidden icon": "Hidden icon"
|
|
||||||
"Small icon": "Small icon"
|
|
||||||
"Normal icon": "Normal icon"
|
|
||||||
"Big icon": "Big icon"
|
|
||||||
"Hidden text": "Hidden text"
|
|
||||||
"Small text": "Small text"
|
|
||||||
"Normal text": "Normal text"
|
|
||||||
"Big text": "Big text"
|
|
||||||
"Colors": "Colors"
|
|
||||||
"Background color": "Background color"
|
|
||||||
"Background color of current app": "Background color of current app"
|
|
||||||
"Text color": "Text color"
|
|
||||||
"Loader": "Loader"
|
|
||||||
"Icon": "Icon"
|
|
||||||
"Same color": "Same color"
|
|
||||||
"Opposite color": "Opposite color"
|
|
||||||
"Transparent": "Transparent"
|
|
||||||
"Opaque": "Opaque"
|
|
||||||
"Opener": "Opener"
|
|
||||||
"Default": "Default"
|
|
||||||
"Default (dark)": "Default (dark)"
|
|
||||||
"Hamburger": "Hamburger"
|
|
||||||
"Hamburger (dark)": "Hamburger (dark)"
|
|
||||||
"Hamburger 2": "Hamburger 2"
|
|
||||||
"Hamburger 2 (dark)": "Hamburger 2 (dark)"
|
|
||||||
"Before the logo": "Before the logo"
|
|
||||||
"After the logo": "After the logo"
|
|
||||||
"Position": "Position"
|
|
||||||
"Show only the opener (hidden logo)": "Show only the opener (hidden logo)"
|
|
||||||
"Do not display the side menu and the opener if there is no application (eg: public pages).": "Do not display the side menu and the opener if there is no application (eg: public pages)."
|
|
||||||
"Panel": "Panel"
|
|
||||||
"Open the menu when the mouse is hover the opener (automatically disabled on touch screens)": "Open the menu when the mouse is hover the opener (automatically disabled on touch screens)"
|
|
||||||
"Display the big menu": "Display the big menu"
|
|
||||||
"Display the logo": "Display the logo"
|
|
||||||
"Icons and texts": "Icons and texts"
|
|
||||||
"Loader enabled": "Loader enabled"
|
|
||||||
"Tips": "Tips"
|
|
||||||
"Always displayed": "Always displayed"
|
|
||||||
"This is the automatic behavior when the menu is always displayed.": "This is the automatic behavior when the menu is always displayed."
|
|
||||||
"Not compatible with touch screens.": "Not compatible with touch screens."
|
|
||||||
"Big menu": "Big menu"
|
|
||||||
"Live preview": "Live preview"
|
|
||||||
"Open apps in new tab": "Open apps in new tab"
|
|
||||||
"Use the global setting": "Use the global setting"
|
|
||||||
"Use my selection": "Use my selection"
|
|
||||||
"Show and hide the list of applications": "Show and hide the list of applications"
|
|
||||||
"Use the avatar instead of the logo": "Use the avatar instead of the logo"
|
|
||||||
"You do not have permission to change the settings.": "You do not have permission to change the settings."
|
|
||||||
"Force this configuration to users": "Force this configuration to users"
|
|
||||||
"Export the configuration": "Export the configuration"
|
|
||||||
"Purge the cache": "Purge the cache"
|
|
||||||
"Show the link to settings": "Show the link to settings"
|
|
||||||
"The menu is enabled by default for users": "The menu is enabled by default for users"
|
|
||||||
"Except when the configuration is forced.": "Except when the configuration is forced."
|
|
||||||
"Apps that should not be displayed in the menu": "Apps that should not be displayed in the menu"
|
|
||||||
"This feature is only compatible with the <code>big menu</code> display.": "This feature is only compatible with the <code>big menu</code> display."
|
|
||||||
"The logo is a link to the default app": "The logo is a link to the default app"
|
|
||||||
"Others": "Others"
|
|
||||||
"Categories": "Categories"
|
|
||||||
"Customize sorting": "Customize sorting"
|
|
||||||
"Order by": "Order by"
|
|
||||||
"Name": "Name"
|
|
||||||
"Customed": "Customed"
|
|
||||||
"Show and hide the list of categories": "Show and hide the list of categories"
|
|
||||||
"This parameters are used when Dark theme or Breeze Dark Theme are enabled.": "This parameters are used when Dark theme or Breeze Dark Theme are enabled."
|
|
||||||
"Dark mode colors": "Dark mode colors"
|
|
||||||
"With categories": "With categories"
|
|
||||||
"Custom categories": "Custom categories"
|
|
||||||
"Customize application categories": "Customize application categories"
|
|
||||||
"Reset to default": "Reset to default"
|
|
||||||
"Applications": "Applications"
|
|
||||||
"Applications kept in the top menu": "Applications kept in the top menu"
|
|
||||||
"Applications kept in the top menu but also shown in side menu": "Applications kept in the top menu but also shown in side menu"
|
|
||||||
"These applications must be selected in the previous option.": "These applications must be selected in the previous option."
|
|
||||||
"Hide labels on mouse over": "Hide labels on mouse over"
|
|
||||||
"Except the hovered app": "Except the hovered app"
|
|
||||||
"Search": "Search"
|
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
|
@ -93,4 +93,3 @@
|
||||||
"Hide labels on mouse over": "Hide labels on mouse over"
|
"Hide labels on mouse over": "Hide labels on mouse over"
|
||||||
"Except the hovered app": "Except the hovered app"
|
"Except the hovered app": "Except the hovered app"
|
||||||
"Search": "Search"
|
"Search": "Search"
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
||||||
|
|
|
@ -91,4 +91,3 @@
|
||||||
"Applications kept in the top menu but also shown in side menu": "Aplicativos mantidos no menu superior, mas também mostrados no menu lateral"
|
"Applications kept in the top menu but also shown in side menu": "Aplicativos mantidos no menu superior, mas também mostrados no menu lateral"
|
||||||
"These applications must be selected in the previous option.": "Estes aplicativos devem ser selecionados na opção anterior."
|
"These applications must be selected in the previous option.": "Estes aplicativos devem ser selecionados na opção anterior."
|
||||||
"Hide labels on mouse over": "Ocultar descrição ao passar o mouse"
|
"Hide labels on mouse over": "Ocultar descrição ao passar o mouse"
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
||||||
|
|
|
@ -93,4 +93,3 @@
|
||||||
"Hide labels on mouse over": "Скрыть название при наведении мыши"
|
"Hide labels on mouse over": "Скрыть название при наведении мыши"
|
||||||
"Except the hovered app": "Except the hovered app"
|
"Except the hovered app": "Except the hovered app"
|
||||||
"Search": "Search"
|
"Search": "Search"
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
||||||
|
|
|
@ -1,94 +1,93 @@
|
||||||
"Custom menu": "Custom menu"
|
"Custom menu": ""
|
||||||
"Enable the custom menu": "Enable the custom menu"
|
"Enable the custom menu": ""
|
||||||
"No": "No"
|
"No": ""
|
||||||
"Yes": "Yes"
|
"Yes": ""
|
||||||
"Menu": "Menu"
|
"Menu": ""
|
||||||
? 'Use the shortcut <span class="keyboard-key">Ctrl</span>+<span class="keyboard-key">o</span> to open and to hide the side menu. Use <span class="keyboard-key">tab</span> to navigate.'
|
? 'Use the shortcut <span class="keyboard-key">Ctrl</span>+<span class="keyboard-key">o</span> to open and to hide the side menu. Use <span class="keyboard-key">tab</span> to navigate.'
|
||||||
: 'Use the shortcut <span class="keyboard-key">Ctrl</span>+<span class="keyboard-key">o</span> to open and to hide the side menu. Use <span class="keyboard-key">tab</span> to navigate.'
|
: ''
|
||||||
"Top menu": "Top menu"
|
"Top menu": ""
|
||||||
"Apps that not must be moved in the side menu": "Apps that not must be moved in the side menu"
|
"Apps that not must be moved in the side menu": ""
|
||||||
"If there is no selection then the global configuration is applied.": "If there is no selection then the global configuration is applied."
|
"If there is no selection then the global configuration is applied.": ""
|
||||||
"Experimental": "Experimental"
|
"Experimental": ""
|
||||||
"Save": "Save"
|
"Save": ""
|
||||||
"You like this app and you want to support me?": "You like this app and you want to support me?"
|
"You like this app and you want to support me?": ""
|
||||||
"Buy me a coffee ☕": "Buy me a coffee ☕"
|
"Buy me a coffee ☕": ""
|
||||||
"Hidden": "Hidden"
|
"Hidden": ""
|
||||||
"Small": "Small"
|
"Small": ""
|
||||||
"Normal": "Normal"
|
"Normal": ""
|
||||||
"Big": "Big"
|
"Big": ""
|
||||||
"Hidden icon": "Hidden icon"
|
"Hidden icon": ""
|
||||||
"Small icon": "Small icon"
|
"Small icon": ""
|
||||||
"Normal icon": "Normal icon"
|
"Normal icon": ""
|
||||||
"Big icon": "Big icon"
|
"Big icon": ""
|
||||||
"Hidden text": "Hidden text"
|
"Hidden text": ""
|
||||||
"Small text": "Small text"
|
"Small text": ""
|
||||||
"Normal text": "Normal text"
|
"Normal text": ""
|
||||||
"Big text": "Big text"
|
"Big text": ""
|
||||||
"Colors": "Colors"
|
"Colors": ""
|
||||||
"Background color": "Background color"
|
"Background color": ""
|
||||||
"Background color of current app": "Background color of current app"
|
"Background color of current app": ""
|
||||||
"Text color": "Text color"
|
"Text color": ""
|
||||||
"Loader": "Loader"
|
"Loader": ""
|
||||||
"Icon": "Icon"
|
"Icon": ""
|
||||||
"Same color": "Same color"
|
"Same color": ""
|
||||||
"Opposite color": "Opposite color"
|
"Opposite color": ""
|
||||||
"Transparent": "Transparent"
|
"Transparent": ""
|
||||||
"Opaque": "Opaque"
|
"Opaque": ""
|
||||||
"Opener": "Opener"
|
"Opener": ""
|
||||||
"Default": "Default"
|
"Default": ""
|
||||||
"Default (dark)": "Default (dark)"
|
"Default (dark)": ""
|
||||||
"Hamburger": "Hamburger"
|
"Hamburger": ""
|
||||||
"Hamburger (dark)": "Hamburger (dark)"
|
"Hamburger (dark)": ""
|
||||||
"Hamburger 2": "Hamburger 2"
|
"Hamburger 2": ""
|
||||||
"Hamburger 2 (dark)": "Hamburger 2 (dark)"
|
"Hamburger 2 (dark)": ""
|
||||||
"Before the logo": "Before the logo"
|
"Before the logo": ""
|
||||||
"After the logo": "After the logo"
|
"After the logo": ""
|
||||||
"Position": "Position"
|
"Position": ""
|
||||||
"Show only the opener (hidden logo)": "Show only the opener (hidden logo)"
|
"Show only the opener (hidden logo)": ""
|
||||||
"Do not display the side menu and the opener if there is no application (eg: public pages).": "Do not display the side menu and the opener if there is no application (eg: public pages)."
|
"Do not display the side menu and the opener if there is no application (eg: public pages).": ""
|
||||||
"Panel": "Panel"
|
"Panel": ""
|
||||||
"Open the menu when the mouse is hover the opener (automatically disabled on touch screens)": "Open the menu when the mouse is hover the opener (automatically disabled on touch screens)"
|
"Open the menu when the mouse is hover the opener (automatically disabled on touch screens)": ""
|
||||||
"Display the big menu": "Display the big menu"
|
"Display the big menu": ""
|
||||||
"Display the logo": "Display the logo"
|
"Display the logo": ""
|
||||||
"Icons and texts": "Icons and texts"
|
"Icons and texts": ""
|
||||||
"Loader enabled": "Loader enabled"
|
"Loader enabled": ""
|
||||||
"Tips": "Tips"
|
"Tips": ""
|
||||||
"Always displayed": "Always displayed"
|
"Always displayed": ""
|
||||||
"This is the automatic behavior when the menu is always displayed.": "This is the automatic behavior when the menu is always displayed."
|
"This is the automatic behavior when the menu is always displayed.": ""
|
||||||
"Not compatible with touch screens.": "Not compatible with touch screens."
|
"Not compatible with touch screens.": ""
|
||||||
"Big menu": "Big menu"
|
"Big menu": ""
|
||||||
"Live preview": "Live preview"
|
"Live preview": ""
|
||||||
"Open apps in new tab": "Open apps in new tab"
|
"Open apps in new tab": ""
|
||||||
"Use the global setting": "Use the global setting"
|
"Use the global setting": ""
|
||||||
"Use my selection": "Use my selection"
|
"Use my selection": ""
|
||||||
"Show and hide the list of applications": "Show and hide the list of applications"
|
"Show and hide the list of applications": ""
|
||||||
"Use the avatar instead of the logo": "Use the avatar instead of the logo"
|
"Use the avatar instead of the logo": ""
|
||||||
"You do not have permission to change the settings.": "You do not have permission to change the settings."
|
"You do not have permission to change the settings.": ""
|
||||||
"Force this configuration to users": "Force this configuration to users"
|
"Force this configuration to users": ""
|
||||||
"Export the configuration": "Export the configuration"
|
"Export the configuration": ""
|
||||||
"Purge the cache": "Purge the cache"
|
"Purge the cache": ""
|
||||||
"Show the link to settings": "Show the link to settings"
|
"Show the link to settings": ""
|
||||||
"The menu is enabled by default for users": "The menu is enabled by default for users"
|
"The menu is enabled by default for users": ""
|
||||||
"Except when the configuration is forced.": "Except when the configuration is forced."
|
"Except when the configuration is forced.": ""
|
||||||
"Apps that should not be displayed in the menu": "Apps that should not be displayed in the menu"
|
"Apps that should not be displayed in the menu": ""
|
||||||
"This feature is only compatible with the <code>big menu</code> display.": "This feature is only compatible with the <code>big menu</code> display."
|
"This feature is only compatible with the <code>big menu</code> display.": ""
|
||||||
"The logo is a link to the default app": "The logo is a link to the default app"
|
"The logo is a link to the default app": ""
|
||||||
"Others": "Others"
|
"Others": ""
|
||||||
"Categories": "Categories"
|
"Categories": ""
|
||||||
"Customize sorting": "Customize sorting"
|
"Customize sorting": ""
|
||||||
"Order by": "Order by"
|
"Order by": ""
|
||||||
"Name": "Name"
|
"Name": ""
|
||||||
"Customed": "Customed"
|
"Customed": ""
|
||||||
"Show and hide the list of categories": "Show and hide the list of categories"
|
"Show and hide the list of categories": ""
|
||||||
"This parameters are used when Dark theme or Breeze Dark Theme are enabled.": "This parameters are used when Dark theme or Breeze Dark Theme are enabled."
|
"This parameters are used when Dark theme or Breeze Dark Theme are enabled.": ""
|
||||||
"Dark mode colors": "Dark mode colors"
|
"Dark mode colors": ""
|
||||||
"With categories": "With categories"
|
"With categories": ""
|
||||||
"Custom categories": "Custom categories"
|
"Custom categories": ""
|
||||||
"Customize application categories": "Customize application categories"
|
"Customize application categories": ""
|
||||||
"Reset to default": "Reset to default"
|
"Reset to default": ""
|
||||||
"Applications": "Applications"
|
"Applications": ""
|
||||||
"Applications kept in the top menu": "Applications kept in the top menu"
|
"Applications kept in the top menu": ""
|
||||||
"Applications kept in the top menu but also shown in side menu": "Applications kept in the top menu but also shown in side menu"
|
"Applications kept in the top menu but also shown in side menu": ""
|
||||||
"These applications must be selected in the previous option.": "These applications must be selected in the previous option."
|
"These applications must be selected in the previous option.": ""
|
||||||
"Hide labels on mouse over": "Hide labels on mouse over"
|
"Hide labels on mouse over": ""
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
||||||
|
|
|
@ -1,100 +1,97 @@
|
||||||
"Custom menu": "Custom menu"
|
"Custom menu": ""
|
||||||
"Enable the custom menu": "Enable the custom menu"
|
"Enable the custom menu": ""
|
||||||
"No": "No"
|
"No": ""
|
||||||
"Yes": "Yes"
|
"Yes": ""
|
||||||
"Menu": "Menu"
|
"Menu": ""
|
||||||
? 'Use the shortcut <span class="keyboard-key">Ctrl</span>+<span class="keyboard-key">o</span>
|
? 'Use the shortcut <span class="keyboard-key">Ctrl</span>+<span class="keyboard-key">o</span>
|
||||||
to open and to hide the side menu. Use <span class="keyboard-key">tab</span> to
|
to open and to hide the side menu. Use <span class="keyboard-key">tab</span> to
|
||||||
navigate.'
|
navigate.'
|
||||||
: 'Use the shortcut <span class="keyboard-key">Ctrl</span>+<span class="keyboard-key">o</span>
|
: ''
|
||||||
to open and to hide the side menu. Use <span class="keyboard-key">tab</span> to
|
"Top menu": ""
|
||||||
navigate.'
|
"Apps that not must be moved in the side menu": ""
|
||||||
"Top menu": "Top menu"
|
"If there is no selection then the global configuration is applied.": ""
|
||||||
"Apps that not must be moved in the side menu": "Apps that not must be moved in the side menu"
|
"Experimental": ""
|
||||||
"If there is no selection then the global configuration is applied.": "If there is no selection then the global configuration is applied."
|
"Save": ""
|
||||||
"Experimental": "Experimental"
|
"You like this app and you want to support me?": ""
|
||||||
"Save": "Save"
|
"Buy me a coffee ☕": ""
|
||||||
"You like this app and you want to support me?": "You like this app and you want to support me?"
|
"Hidden": ""
|
||||||
"Buy me a coffee ☕": "Buy me a coffee ☕"
|
"Small": ""
|
||||||
"Hidden": "Hidden"
|
"Normal": ""
|
||||||
"Small": "Small"
|
"Big": ""
|
||||||
"Normal": "Normal"
|
"Hidden icon": ""
|
||||||
"Big": "Big"
|
"Small icon": ""
|
||||||
"Hidden icon": "Hidden icon"
|
"Normal icon": ""
|
||||||
"Small icon": "Small icon"
|
"Big icon": ""
|
||||||
"Normal icon": "Normal icon"
|
"Hidden text": ""
|
||||||
"Big icon": "Big icon"
|
"Small text": ""
|
||||||
"Hidden text": "Hidden text"
|
"Normal text": ""
|
||||||
"Small text": "Small text"
|
"Big text": ""
|
||||||
"Normal text": "Normal text"
|
"Colors": ""
|
||||||
"Big text": "Big text"
|
"Background color": ""
|
||||||
"Colors": "Colors"
|
"Background color of current app": ""
|
||||||
"Background color": "Background color"
|
"Text color": ""
|
||||||
"Background color of current app": "Background color of current app"
|
"Loader": ""
|
||||||
"Text color": "Text color"
|
"Icon": ""
|
||||||
"Loader": "Loader"
|
"Same color": ""
|
||||||
"Icon": "Icon"
|
"Opposite color": ""
|
||||||
"Same color": "Same color"
|
"Transparent": ""
|
||||||
"Opposite color": "Opposite color"
|
"Opaque": ""
|
||||||
"Transparent": "Transparent"
|
"Opener": ""
|
||||||
"Opaque": "Opaque"
|
"Default": ""
|
||||||
"Opener": "Opener"
|
"Default (dark)": ""
|
||||||
"Default": "Default"
|
"Hamburger": ""
|
||||||
"Default (dark)": "Default (dark)"
|
"Hamburger (dark)": ""
|
||||||
"Hamburger": "Hamburger"
|
"Hamburger 2": ""
|
||||||
"Hamburger (dark)": "Hamburger (dark)"
|
"Hamburger 2 (dark)": ""
|
||||||
"Hamburger 2": "Hamburger 2"
|
"Before the logo": ""
|
||||||
"Hamburger 2 (dark)": "Hamburger 2 (dark)"
|
"After the logo": ""
|
||||||
"Before the logo": "Before the logo"
|
"Position": ""
|
||||||
"After the logo": "After the logo"
|
"Show only the opener (hidden logo)": ""
|
||||||
"Position": "Position"
|
"Do not display the side menu and the opener if there is no application (eg: public pages).": ""
|
||||||
"Show only the opener (hidden logo)": "Show only the opener (hidden logo)"
|
"Panel": ""
|
||||||
"Do not display the side menu and the opener if there is no application (eg: public pages).": "Do not display the side menu and the opener if there is no application (eg: public pages)."
|
"Open the menu when the mouse is hover the opener (automatically disabled on touch screens)": ""
|
||||||
"Panel": "Panel"
|
"Display the big menu": ""
|
||||||
"Open the menu when the mouse is hover the opener (automatically disabled on touch screens)": "Open the menu when the mouse is hover the opener (automatically disabled on touch screens)"
|
"Display the logo": ""
|
||||||
"Display the big menu": "Display the big menu"
|
"Icons and texts": ""
|
||||||
"Display the logo": "Display the logo"
|
"Loader enabled": ""
|
||||||
"Icons and texts": "Icons and texts"
|
"Tips": ""
|
||||||
"Loader enabled": "Loader enabled"
|
"Always displayed": ""
|
||||||
"Tips": "Tips"
|
"This is the automatic behavior when the menu is always displayed.": ""
|
||||||
"Always displayed": "Always displayed"
|
"Not compatible with touch screens.": ""
|
||||||
"This is the automatic behavior when the menu is always displayed.": "This is the automatic behavior when the menu is always displayed."
|
"Big menu": ""
|
||||||
"Not compatible with touch screens.": "Not compatible with touch screens."
|
"Live preview": ""
|
||||||
"Big menu": "Big menu"
|
"Open apps in new tab": ""
|
||||||
"Live preview": "Live preview"
|
"Use the global setting": ""
|
||||||
"Open apps in new tab": "Open apps in new tab"
|
"Use my selection": ""
|
||||||
"Use the global setting": "Use the global setting"
|
"Show and hide the list of applications": ""
|
||||||
"Use my selection": "Use my selection"
|
"Use the avatar instead of the logo": ""
|
||||||
"Show and hide the list of applications": "Show and hide the list of applications"
|
"You do not have permission to change the settings.": ""
|
||||||
"Use the avatar instead of the logo": "Use the avatar instead of the logo"
|
"Force this configuration to users": ""
|
||||||
"You do not have permission to change the settings.": "You do not have permission to change the settings."
|
"Export the configuration": ""
|
||||||
"Force this configuration to users": "Force this configuration to users"
|
"Purge the cache": ""
|
||||||
"Export the configuration": "Export the configuration"
|
"Show the link to settings": ""
|
||||||
"Purge the cache": "Purge the cache"
|
"The menu is enabled by default for users": ""
|
||||||
"Show the link to settings": "Show the link to settings"
|
"Except when the configuration is forced.": ""
|
||||||
"The menu is enabled by default for users": "The menu is enabled by default for users"
|
"Apps that should not be displayed in the menu": ""
|
||||||
"Except when the configuration is forced.": "Except when the configuration is forced."
|
"This feature is only compatible with the <code>big menu</code> display.": ""
|
||||||
"Apps that should not be displayed in the menu": "Apps that should not be displayed in the menu"
|
"The logo is a link to the default app": ""
|
||||||
"This feature is only compatible with the <code>big menu</code> display.": "This feature is only compatible with the <code>big menu</code> display."
|
"Others": ""
|
||||||
"The logo is a link to the default app": "The logo is a link to the default app"
|
"Categories": ""
|
||||||
"Others": "Others"
|
"Customize sorting": ""
|
||||||
"Categories": "Categories"
|
"Order by": ""
|
||||||
"Customize sorting": "Customize sorting"
|
"Name": ""
|
||||||
"Order by": "Order by"
|
"Customed": ""
|
||||||
"Name": "Name"
|
"Show and hide the list of categories": ""
|
||||||
"Customed": "Customed"
|
"This parameters are used when Dark theme or Breeze Dark Theme are enabled.": ""
|
||||||
"Show and hide the list of categories": "Show and hide the list of categories"
|
"Dark mode colors": ""
|
||||||
"This parameters are used when Dark theme or Breeze Dark Theme are enabled.": "This parameters are used when Dark theme or Breeze Dark Theme are enabled."
|
"With categories": ""
|
||||||
"Dark mode colors": "Dark mode colors"
|
"Custom categories": ""
|
||||||
"With categories": "With categories"
|
"Customize application categories": ""
|
||||||
"Custom categories": "Custom categories"
|
"Reset to default": ""
|
||||||
"Customize application categories": "Customize application categories"
|
"Applications": ""
|
||||||
"Reset to default": "Reset to default"
|
"Applications kept in the top menu": ""
|
||||||
"Applications": "Applications"
|
"Applications kept in the top menu but also shown in side menu": ""
|
||||||
"Applications kept in the top menu": "Applications kept in the top menu"
|
"These applications must be selected in the previous option.": ""
|
||||||
"Applications kept in the top menu but also shown in side menu": "Applications kept in the top menu but also shown in side menu"
|
"Hide labels on mouse over": ""
|
||||||
"These applications must be selected in the previous option.": "These applications must be selected in the previous option."
|
"Except the hovered app": ""
|
||||||
"Hide labels on mouse over": "Hide labels on mouse over"
|
"Search": ""
|
||||||
"Except the hovered app": "Except the hovered app"
|
|
||||||
"Search": "Search"
|
|
||||||
"Toggle the menu": "Toggle the menu"
|
|
||||||
|
|
|
@ -93,4 +93,3 @@
|
||||||
"Hide labels on mouse over": "Hide labels on mouse over"
|
"Hide labels on mouse over": "Hide labels on mouse over"
|
||||||
"Except the hovered app": "Except the hovered app"
|
"Except the hovered app": "Except the hovered app"
|
||||||
"Search": "Search"
|
"Search": "Search"
|
||||||
"Toggle menu": "Toggle menu"
|
|
||||||
|
|
|
@ -3,13 +3,7 @@ module.exports = (tagName, attributes) => {
|
||||||
|
|
||||||
if (typeof attributes === 'object') {
|
if (typeof attributes === 'object') {
|
||||||
for (let i in attributes) {
|
for (let i in attributes) {
|
||||||
if (i === 'text') {
|
element.setAttribute(i, attributes[i])
|
||||||
element.textContent = attributes[i]
|
|
||||||
} else if (i === 'html') {
|
|
||||||
element.innerHTML = attributes[i]
|
|
||||||
} else {
|
|
||||||
element.setAttribute(i, attributes[i])
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -42,11 +42,13 @@
|
||||||
top: 49px;
|
top: 49px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#side-menu.hide-opener .side-menu-header .side-menu-opener.side-menu-closer {
|
#side-menu.hide-opener .side-menu-header .side-menu-opener.side-menu-closer
|
||||||
|
{
|
||||||
visibility: hidden;
|
visibility: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
#side-menu.hide-opener.side-menu-with-categories .side-menu-search {
|
#side-menu.hide-opener.side-menu-with-categories .side-menu-search
|
||||||
|
{
|
||||||
float: none;
|
float: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,17 +14,12 @@ if ($_['always-displayed']) {
|
||||||
|
|
||||||
(function() {
|
(function() {
|
||||||
const sideMenuContainer = SMcreateElement('div', {id: 'side-menu-container'})
|
const sideMenuContainer = SMcreateElement('div', {id: 'side-menu-container'})
|
||||||
const sideMenuOpener = SMcreateElement('button', {
|
const sideMenuOpener = SMcreateElement('button', {'class': 'side-menu-opener'})
|
||||||
'class': 'side-menu-opener',
|
|
||||||
'arial-label': t('side_menu', 'Toggle the menu'),
|
|
||||||
'html': `<span>${t('side_menu', 'Toggle the menu')}</span>`
|
|
||||||
})
|
|
||||||
const sideMenu = SMcreateElement('div', {id: 'side-menu'})
|
const sideMenu = SMcreateElement('div', {id: 'side-menu'})
|
||||||
|
|
||||||
const body = document.querySelector('body')
|
const body = document.querySelector('body')
|
||||||
const html = document.querySelector('html')
|
const html = document.querySelector('html')
|
||||||
const nextcloud = document.querySelector('#nextcloud')
|
const nextcloud = document.querySelector('#nextcloud')
|
||||||
const logo = document.querySelector('.header-left .logo')
|
|
||||||
|
|
||||||
const isTouchDevice = window.matchMedia("(pointer: coarse)").matches
|
const isTouchDevice = window.matchMedia("(pointer: coarse)").matches
|
||||||
|
|
||||||
|
@ -40,15 +35,6 @@ if ($_['always-displayed']) {
|
||||||
sideMenu.setAttribute('data-sidewithcategories', '1')
|
sideMenu.setAttribute('data-sidewithcategories', '1')
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
|
|
||||||
const sideMenuFocus = () => {
|
|
||||||
let a = document.querySelector('#side-menu .side-menu-app.active a')
|
|
||||||
|| document.querySelector('#side-menu .side-menu-app a')
|
|
||||||
|
|
||||||
if (a) {
|
|
||||||
a.focus()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
document.querySelector('body').addEventListener('side-menu.apps', (e) => {
|
document.querySelector('body').addEventListener('side-menu.apps', (e) => {
|
||||||
const apps = e.detail.apps;
|
const apps = e.detail.apps;
|
||||||
|
|
||||||
|
@ -91,6 +77,22 @@ if ($_['always-displayed']) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sideMenuFocus = () => {
|
||||||
|
let a = document.querySelector('.side-menu-app.active a', sideMenu)
|
||||||
|
|
||||||
|
if (!a) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if (a.length === 0) {
|
||||||
|
a = sideMenu.querySelector('.side-menu-app:first-child a')
|
||||||
|
}
|
||||||
|
|
||||||
|
if (a.length > 0) {
|
||||||
|
a.focus()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
<?php if ($_['opener-hover']): ?>
|
<?php if ($_['opener-hover']): ?>
|
||||||
const sideMenuMouseLeave = () => {
|
const sideMenuMouseLeave = () => {
|
||||||
sideMenu.classList.remove('open')
|
sideMenu.classList.remove('open')
|
||||||
|
@ -122,8 +124,14 @@ if ($_['always-displayed']) {
|
||||||
|
|
||||||
headerMenuOpener.addEventListener('click', () => {
|
headerMenuOpener.addEventListener('click', () => {
|
||||||
sideMenu.classList.add('open')
|
sideMenu.classList.add('open')
|
||||||
|
|
||||||
|
const a = sideMenu.querySelector('.side-menu-app.active a')
|
||||||
|
|
||||||
|
if (a !== null) {
|
||||||
|
a.focus()
|
||||||
|
}
|
||||||
|
|
||||||
headerMenuOpener.blur()
|
headerMenuOpener.blur()
|
||||||
sideMenuFocus()
|
|
||||||
})
|
})
|
||||||
|
|
||||||
for (let opener of sideMenuOpener) {
|
for (let opener of sideMenuOpener) {
|
||||||
|
@ -171,10 +179,6 @@ if ($_['always-displayed']) {
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
|
|
||||||
if (nextcloud) {
|
if (nextcloud) {
|
||||||
if (logo && logo.parentNode !== nextcloud) {
|
|
||||||
nextcloud.appendChild(logo)
|
|
||||||
}
|
|
||||||
|
|
||||||
<?php if ($_['opener-position'] === 'before'): ?>
|
<?php if ($_['opener-position'] === 'before'): ?>
|
||||||
nextcloud.parentNode.insertBefore(sideMenuOpener, nextcloud)
|
nextcloud.parentNode.insertBefore(sideMenuOpener, nextcloud)
|
||||||
<?php else: ?>
|
<?php else: ?>
|
||||||
|
|
|
@ -1115,19 +1115,19 @@ $labelAlwaysDisplayed = 'Always displayed';
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="section" id="more">
|
<div class="section" id="more">
|
||||||
<button id="side-menu-save" class="btn btn-info" arial-label="<?php p($l->t('Save')); ?>">
|
<button id="side-menu-save" class="btn btn-info">
|
||||||
<?php p($l->t('Save')); ?>
|
<?php p($l->t('Save')); ?>
|
||||||
<progress max="100" value="0" id="side-menu-save-progress"></progress>
|
<progress max="100" value="0" id="side-menu-save-progress"></progress>
|
||||||
</button>
|
</button>
|
||||||
|
|
||||||
<a href="<?php echo $urlGenerator->linkToRoute('side_menu.AdminSetting.exportConfiguration') ?>" target="_blank" rel="noopener">
|
<a href="<?php echo $urlGenerator->linkToRoute('side_menu.AdminSetting.exportConfiguration') ?>" target="_blank" rel="noopener">
|
||||||
<button class="btn btn-primary" arial-label="<?php p($l->t('Export the configuration')); ?>">
|
<button class="btn btn-primary" >
|
||||||
<?php p($l->t('Export the configuration')); ?>
|
<?php p($l->t('Export the configuration')); ?>
|
||||||
</button>
|
</button>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<a href="<?php echo $urlGenerator->linkToRoute('side_menu.AdminSetting.removeCache') ?>">
|
<a href="<?php echo $urlGenerator->linkToRoute('side_menu.AdminSetting.removeCache') ?>">
|
||||||
<button class="btn btn-primary" arial-label="<?php p($l->t('Purge the cache')); ?>">
|
<button class="btn btn-primary" >
|
||||||
<?php p($l->t('Purge the cache')); ?> (<?php echo $cacheSize ?> Kb)
|
<?php p($l->t('Purge the cache')); ?> (<?php echo $cacheSize ?> Kb)
|
||||||
</button>
|
</button>
|
||||||
</a>
|
</a>
|
||||||
|
@ -1139,7 +1139,7 @@ $labelAlwaysDisplayed = 'Always displayed';
|
||||||
<?php p($l->t('You like this app and you want to support me?')); ?>
|
<?php p($l->t('You like this app and you want to support me?')); ?>
|
||||||
|
|
||||||
<a style="margin-left: 10px" target="_blank" href="https://www.buymeacoffee.com/deblan" rel="noopener">
|
<a style="margin-left: 10px" target="_blank" href="https://www.buymeacoffee.com/deblan" rel="noopener">
|
||||||
<button arial-label="<?php p($l->t('Buy me a coffee ☕')); ?>">
|
<button>
|
||||||
<?php p($l->t('Buy me a coffee ☕')); ?>
|
<?php p($l->t('Buy me a coffee ☕')); ?>
|
||||||
</button>
|
</button>
|
||||||
</a>
|
</a>
|
||||||
|
|
|
@ -240,7 +240,7 @@ $labelReset = 'Reset to default';
|
||||||
|
|
||||||
<div class="section">
|
<div class="section">
|
||||||
<?php if (!$_['force']): ?>
|
<?php if (!$_['force']): ?>
|
||||||
<button id="side-menu-save" class="btn btn-info" arial-label="<?php p($l->t('Save')); ?>">
|
<button id="side-menu-save" class="btn btn-info">
|
||||||
<?php p($l->t('Save')); ?>
|
<?php p($l->t('Save')); ?>
|
||||||
<progress max="100" value="0" id="side-menu-save-progress"></progress>
|
<progress max="100" value="0" id="side-menu-save-progress"></progress>
|
||||||
</button>
|
</button>
|
||||||
|
@ -255,7 +255,7 @@ $labelReset = 'Reset to default';
|
||||||
<?php p($l->t('You like this app and you want to support me?')); ?>
|
<?php p($l->t('You like this app and you want to support me?')); ?>
|
||||||
|
|
||||||
<a style="margin-left: 10px" target="_blank" href="https://www.buymeacoffee.com/deblan" rel="noopener">
|
<a style="margin-left: 10px" target="_blank" href="https://www.buymeacoffee.com/deblan" rel="noopener">
|
||||||
<button arial-label="<?php p($l->t('Buy me a coffee ☕')); ?>">
|
<button>
|
||||||
<?php p($l->t('Buy me a coffee ☕')); ?>
|
<?php p($l->t('Buy me a coffee ☕')); ?>
|
||||||
</button>
|
</button>
|
||||||
</a>
|
</a>
|
||||||
|
|
Loading…
Reference in a new issue