diff options
Diffstat (limited to 'PKGBUILD')
-rw-r--r-- | PKGBUILD | 111 |
1 files changed, 81 insertions, 30 deletions
@@ -1,50 +1,85 @@ -# Maintainer: kitsunyan <`echo a2l0c3VueWFuQGFpcm1haWwuY2MK | base64 -d`> +# Maintainer: Dmitry Valter <`echo ZHZhbHRlciA8YXQ+IHByb3Rvbm1haWwgPGRvdD4gY29tCg== | base64 -d`> pkgname=drawio-desktop -pkgver=10.9.6 +pkgver=24.1.0 pkgrel=1 pkgdesc='Diagram drawing application built on web technology' -arch=('x86_64') -url='https://github.com/jgraph/drawio' +arch=('any') +url='https://github.com/jgraph/drawio-desktop' license=('Apache') -depends=(electron gconf libnotify) -makedepends=(npm) -source=("drawio-desktop-$pkgver.zip::https://github.com/jgraph/drawio/releases/download/v$pkgver/draw.war") -noextract=("drawio-desktop-$pkgver.zip") -sha256sums=('1c0bf26f52c3c5f1a66f9be005d83946be47fea43737888d43819b7ff5202498') +_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" + "drawio.xml") +sha512sums=('617557bacdd2da2a4df63a87b61ed4b2f97519401075142b1c646b58dfa512b98ae94aa4e4f879eaeb89228ee4ea4c7588ff9fea9ff15b78662f1c9a4ba9e4c5' + '39a8a4ecc80d364d874dad4e0be91095f07460e5dc4fe9b787e998c86b49b2bf871f26f0314892a301f1dbcdff2217d935018c4973988615164360c6d83797a5' + '8899108b4112f065173a077ca68d4d915780bcc993c69924098e134fa05338a20cb0391720b7b45c27071f789fbe5a6a02228dd633570e91fb4482082c480539') -prepare() { - rm -rf "$srcdir/drawio-$pkgver" - mkdir "$srcdir/drawio-$pkgver" - cd "$srcdir/drawio-$pkgver" +build() { + rm -rf "$srcdir/drawio-desktop-$pkgver/drawio" + mv "$srcdir/drawio-$pkgver" "$srcdir/drawio-desktop-$pkgver/drawio" + cd "$srcdir/drawio-desktop-$pkgver" + + # clean unused files up + rm -rfv drawio/src/main/webapp/META-INF drawio/src/main/webapp/WEB-INF - bsdtar -xf "../drawio-desktop-$pkgver.zip" -C . - rm -rf "META-INF" "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' -build() { - cd "$srcdir/drawio-$pkgver" + # 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 + + 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 {} \; + find . -name '.bin' -exec rm -fvr {} + + find . -name 'well-known' -exec rm -fvr {} + + find . -name '.coveralls.yml' -exec rm -fv {} \; + find . -name '.gitignore' -exec rm -fv {} \; + find . -name '.github' -exec rm -fvr {} + + find . -name '.eslintrc*' -exec rm -fv {} \; + find . -name '.jscs.json' -exec rm -fv {} \; + find . -name '.npmignore' -exec rm -fv {} \; + 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 {} \; - npm install --cache ../npm-cache --only=production - rm -f 'package-lock.json' } package() { - cd "$srcdir/drawio-$pkgver" + 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 "$@" > /dev/null 2> /dev/null' \ + "exec electron$_electronver /usr/lib/draw.io \"\$@\"" \ > "$pkgdir/usr/bin/draw.io" chmod a+x "$pkgdir/usr/bin/draw.io" @@ -52,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 } |