diff options
Diffstat (limited to 'PKGBUILD')
-rw-r--r-- | PKGBUILD | 88 |
1 files changed, 59 insertions, 29 deletions
@@ -1,43 +1,52 @@ # Maintainer: Dmitry Valter <`echo ZHZhbHRlciA8YXQ+IHByb3Rvbm1haWwgPGRvdD4gY29tCg== | base64 -d`> pkgname=drawio-desktop -pkgver=12.5.3 -pkgrel=2 +pkgver=24.2.5 +pkgrel=1 pkgdesc='Diagram drawing application built on web technology' -arch=('x86_64') -url='https://github.com/jgraph/drawio' -license=('Apache') -depends=(electron libnotify) -makedepends=(yarn ant) +arch=('any') +url='https://github.com/jgraph/drawio-desktop' +license=('Apache-2.0') +_electronver=28 +depends=("electron$_electronver" libnotify shared-mime-info) +makedepends=(yarn 'nodejs>=12') +options=('!strip') source=("drawio-$pkgver.tar.gz::https://github.com/jgraph/drawio/archive/v$pkgver.tar.gz" - "drawio-desktop-$pkgver.tar.gz::https://github.com/jgraph/drawio-desktop/archive/v$pkgver.tar.gz") -sha256sums=('961844a59f5c0aba296e9276f4d2b531c0efa4f66e5b7eb2f592941dbfe15c19' - '439a83b5f7d6d8ebed2b5c07cd592fb85c441ea948d4139bf9076bfc7f204ff3') + "drawio-desktop-$pkgver.tar.gz::https://github.com/jgraph/drawio-desktop/archive/v$pkgver.tar.gz" + "drawio.xml") +sha512sums=('b850c87e296d19a7481f73d0e9e966d46996d407acc6841215cfa32912e7022f38f9266753ade9a58d7df999c066fee0e23c61735df81157f6f85a16165333b9' + '64fe04d1afd07d90f833a8eee64a3ebbbf186c9e039e8d53d957eaa902ae059497a06a9607199c826f9261acf57d825cb75877a2e3c0b8b548f3f8ebdc17fc6d' + '8899108b4112f065173a077ca68d4d915780bcc993c69924098e134fa05338a20cb0391720b7b45c27071f789fbe5a6a02228dd633570e91fb4482082c480539') build() { - cp "$srcdir/drawio-desktop-$pkgver"/{package.json,yarn.lock} "$srcdir/drawio-$pkgver"/src/main/webapp/ - cd "$srcdir/drawio-$pkgver"/etc/build - ant app - cd "$srcdir/drawio-$pkgver"/src/main/webapp + rm -rf "$srcdir/drawio-desktop-$pkgver/drawio" + mv "$srcdir/drawio-$pkgver" "$srcdir/drawio-desktop-$pkgver/drawio" + cd "$srcdir/drawio-desktop-$pkgver" - rm -rf "META-INF" "WEB-INF" + # clean unused files up + rm -rfv drawio/src/main/webapp/META-INF drawio/src/main/webapp/WEB-INF + + # Electron version compatibility check + echo "Checking electron version" + grep -qF "\"electron\": \"$_electronver." 'package.json' # disable updater sed -e '/electron-updater/d' -i 'package.json' + sed -e '/"electron":/d' -i 'package.json' + sed -e '/"electron-builder":/d' -i 'package.json' + sed -e '/"electron-notarize":/d' -i 'package.json' local updater='const autoUpdater = { on: () => {}, setFeedURL: () => {}, checkForUpdates: () => {} }' - sed -e 's/.*require("electron-updater").*/'"$updater"'/' -e '/checkForUpdates,/d' -i 'electron.js' + sed -e 's/.*require("electron-updater").*/'"$updater"'/' -e '/checkForUpdates,/d' -i 'src/main/electron.js' # fix version in package.json sed -i 's/"version": ".*"/"version": "'"$pkgver"'"/g' package.json + cd "$srcdir/drawio-desktop-$pkgver" yarn install --cache-folder ../npm-cache --prod yarn autoclean -I yarn autoclean -F - # remove paths refering build directories - find . -name 'package.json' -exec sed "s,$srcdir/src/drawio-$pkgver/src/main/webapp,/usr/lib/drawio,g" -i {} \; - - rm -f 'package-lock.json' + rm -fv 'package-lock.json' find . -name '.yarnclean' -exec rm -fv {} \; find . -name 'yarn.lock' -exec rm -fv {} \; find . -name '.airtap.yml' -exec rm -fv {} \; @@ -52,20 +61,25 @@ build() { find . -name '.prettierrc.js' -exec rm -fv {} \; find . -name '.travis.yml' -exec rm -fv {} \; find . -name '.tonic_example.js' -exec rm -fv {} \; + find . -name '.yarn-integrity' -exec rm -fv {} \; + find . -name '*.ts' -exec rm -fv {} \; } package() { - cd "$srcdir/drawio-$pkgver"/src/main/webapp + cd "$srcdir/drawio-desktop-$pkgver" + + mkdir -p "$pkgdir/usr/lib/draw.io" + cp -rp package.json *.js drawio src node_modules "$pkgdir/usr/lib/draw.io" - mkdir -p "$pkgdir/usr/lib" - cp -rp . "$pkgdir/usr/lib/draw.io" + # fix file permissions + chmod -R g+r,o+r "$pkgdir/usr/lib/draw.io" # create run script mkdir -p "$pkgdir/usr/bin" printf '%s\n' \ '#!/bin/sh' \ - 'exec electron /usr/lib/draw.io "$@"' \ + "exec electron$_electronver /usr/lib/draw.io \"\$@\"" \ > "$pkgdir/usr/bin/draw.io" chmod a+x "$pkgdir/usr/bin/draw.io" @@ -73,20 +87,36 @@ package() { mkdir -p "$pkgdir/usr/share/applications" printf '%s\n' \ '[Desktop Entry]' \ - 'Name=draw.io' \ + 'Name=drawio' \ 'Comment=draw.io desktop' \ 'Exec=/usr/bin/draw.io %U' \ 'Terminal=false' \ 'Type=Application' \ 'Icon=draw.io' \ + 'StartupWMClass=draw.io' \ 'Categories=Graphics;' \ > "$pkgdir/usr/share/applications/draw.io.desktop" + ln -s /usr/bin/draw.io "$pkgdir/usr/bin/drawio" + + # shared-mime-info defines vsdx differently from vsd, thus upstream setup seems to be incorrect + MIMETYPE="$(grep mimeType "$srcdir/drawio-desktop-$pkgver/electron-builder-linux-mac.json" | \ + sed 's/.*"mimeType":.*"\(.*\)".*/\1/g' | \ + sed 's/vnd\.visio/vnd.ms-visio.drawing.main+xml/g' | tr '\n' ';')" + if [[ -n "${MIMETYPE}" ]]; then + echo "MimeType=${MIMETYPE}" >> "$pkgdir/usr/share/applications/draw.io.desktop" + fi + # create icons - find 'images' -regex '.*/drawlogo[0-9]+\.png' | - grep -o '[0-9]\+' | + cd "$srcdir/drawio-desktop-$pkgver" + find 'build' -regex '.*/[0-9]+x[0-9]+\.png' | + grep -o '[0-9]\+' | + sort -u | while read size; do - install -Dm644 "images/drawlogo$size.png" \ - "$pkgdir/usr/share/icons/hicolor/${size}x${size}/apps/draw.io.png" + if [[ -f "build/${size}x${size}.png" ]]; then + install -Dm644 "build/${size}x${size}.png" \ + "$pkgdir/usr/share/icons/hicolor/${size}x${size}/apps/draw.io.png" + fi + install -Dm644 "$srcdir/drawio.xml" "$pkgdir/usr/share/mime/packages/drawio.xml" done } |