Compare commits

..

No commits in common. "master" and "release-latest" have entirely different histories.

7 changed files with 422 additions and 445 deletions

View File

@ -4,11 +4,6 @@ name: Viewer build
on: on:
workflow_dispatch: workflow_dispatch:
# XXX this gets any push -- the pattern does not work???...
#push:
# branches: [ "master" ]
# tags: v**
release: release:
types: [published] types: [published]
@ -19,12 +14,8 @@ jobs:
strategy: strategy:
matrix: matrix:
# XXX the mac build is broken for now -- running blind as I do
# not have a mac to test on, but I will at least fix the
# build...
#os: [ ubuntu-latest, windows-latest, macos-latest ] #os: [ ubuntu-latest, windows-latest, macos-latest ]
os: [ ubuntu-latest, windows-latest ] os: [ ubuntu-latest, windows-latest ]
#os: [ macos-latest ]
runs-on: ${{ matrix.os }} runs-on: ${{ matrix.os }}
@ -35,8 +26,8 @@ jobs:
steps: steps:
- uses: actions/checkout@v4 - uses: actions/checkout@v4
- uses: actions/setup-node@v6
- uses: actions/setup-node@v6
- name: Windows-specific - name: Windows-specific
if: ${{ matrix.os == 'windows-latest' }} if: ${{ matrix.os == 'windows-latest' }}
@ -49,18 +40,8 @@ jobs:
# fixes an issue when running npx sandboxing... # fixes an issue when running npx sandboxing...
sudo sysctl -w kernel.apparmor_restrict_unprivileged_userns=0 sudo sysctl -w kernel.apparmor_restrict_unprivileged_userns=0
- name: MacOS-specific #- name: MacOS-specific
if: ${{ matrix.os == 'macos-latest' }} # if: ${{ matrix.os == 'macos-latest' }}
run: |
brew install gnu-sed zip
echo PATH="$HOMEBREW_PREFIX/opt/zip/bin:$PATH" >> $GITHUB_ENV
#- name: Env
# run: |
# echo "VERSION=$(make version)" >> $GITHUB_ENV
- name: Pre-Build - name: Pre-Build
run: make clean-all dev run: make clean-all dev

View File

@ -25,28 +25,6 @@ media
└── tree.sh └── tree.sh
``` ```
### Prerequisites
For the scripts to function they need the following in path:
- exiftool
- btrfs-utils (for the btrfs filesystem support)
And the ImageGrid Viewer CLI (the `ig` utility) either linked or globally
installed, to do this run the following from the `Viewer/` directory:
```shell
sudo make devel-cli
```
or:
```shell
sudo make cli
```
For additional dependencies run:
```shell
make check
```
### `README.md` ### `README.md`
A basic introductory description. This is here to introduce a new user A basic introductory description. This is here to introduce a new user

View File

@ -294,16 +294,12 @@ else
ifeq ($(shell uname -s),Darwin) ifeq ($(shell uname -s),Darwin)
TARGET_OS ?= darwin TARGET_OS ?= darwin
NW_OS ?= osx NW_OS ?= osx
SED = gsed
endif endif
# set arch... # set arch...
ifeq ($(shell uname -m),x86_64) ifeq ($(shell uname -m),x86_64)
ARCH ?= x64 ARCH ?= x64
endif endif
ifeq ($(shell uname -m),arm64)
ARCH ?= arm64
endif
ifneq ($(filter %86,$(shell uname -p)),) ifneq ($(filter %86,$(shell uname -p)),)
ARCH ?= ia32 ARCH ?= ia32
endif endif
@ -342,8 +338,6 @@ RM += -r
MD = @mkdir -p MD = @mkdir -p
SED ?= sed
#********************************************************************** #**********************************************************************
# Paths and lists... # Paths and lists...
@ -408,7 +402,7 @@ PATCHES := $(REQUREJS)
#********************************************************************** #**********************************************************************
# dependencies to check... # dependencies to check...
# #
DEPENDENCIES_HELP = $(SED) grep printf DEPENDENCIES_HELP = sed grep printf
DEPENDENCIES_WEB = node npm npx DEPENDENCIES_WEB = node npm npx
DEPENDENCIES = $(DEPENDENCIES_WEB) \ DEPENDENCIES = $(DEPENDENCIES_WEB) \
@ -435,23 +429,23 @@ help:
help_lines=(`grep -Fh "##" $(MAKEFILE_LIST) \ help_lines=(`grep -Fh "##" $(MAKEFILE_LIST) \
| grep -Fv grep \ | grep -Fv grep \
| grep -Fv '"##' \ | grep -Fv '"##' \
| $(SED) -e 's/\\$$//'`); \ | sed -e 's/\\$$//'`); \
for help_line in $${help_lines[@]}; do \ for help_line in $${help_lines[@]}; do \
IFS=$$'#' ; \ IFS=$$'#' ; \
if [ -z "$${help_line/'#'#[#-]*/}" ] ; then \ if [ -z "$${help_line/'#'#[#-]*/}" ] ; then \
echo ; \ echo ; \
echo "$${help_line}" \ echo "$${help_line}" \
| $(SED) -e 's/#\+[- ]*//' \ | sed -e 's/#\+[- ]*//' \
-e 's/\s*\(...\|---\)\s*$$/:/'; \ -e 's/\s*\(...\|---\)\s*$$/:/'; \
elif [ -z "$${help_line/'#'*/}" ] ; then \ elif [ -z "$${help_line/'#'*/}" ] ; then \
echo "$${help_line}" \ echo "$${help_line}" \
| $(SED) 's/#\+[- ]*//' ; \ | sed 's/#\+[- ]*//' ; \
else \ else \
help_split=($$help_line) ; \ help_split=($$help_line) ; \
help_command=`echo $${help_split[0]} \ help_command=`echo $${help_split[0]} \
| $(SED) -e 's/^ *//' -e 's/ *$$//'` ; \ | sed -e 's/^ *//' -e 's/ *$$//'` ; \
help_info=`echo $${help_split[2]} \ help_info=`echo $${help_split[2]} \
| $(SED) -e 's/^ *//' -e 's/ *$$//'` ; \ | sed -e 's/^ *//' -e 's/ *$$//'` ; \
printf " %-30s %s\n" $$help_command $$help_info ; \ printf " %-30s %s\n" $$help_command $$help_info ; \
fi ; \ fi ; \
done done
@ -736,7 +730,7 @@ $(BUILD_INFO): $(CSS_FILES) $(NODE_DIR) $(PROJECT_FILES) \
# XXX revise $LAUNCHER -- should it be absolute or relative and when??? # XXX revise $LAUNCHER -- should it be absolute or relative and when???
%: %.tpl package.json %: %.tpl package.json
cat $< \ cat $< \
| $(SED) -e 's/\$$APP_NAME/$(APP_NAME)/' \ | sed -e 's/\$$APP_NAME/$(APP_NAME)/' \
-e 's/\$$COMMENT/$(subst \/,\/,$(COMMENT))/' \ -e 's/\$$COMMENT/$(subst \/,\/,$(COMMENT))/' \
-e 's/\$$CATEGORIES/$(subst \/,\/,$(CATEGORIES))/' \ -e 's/\$$CATEGORIES/$(subst \/,\/,$(CATEGORIES))/' \
-e 's/\$$VERSION/$(APP_VERSION)/' \ -e 's/\$$VERSION/$(APP_VERSION)/' \
@ -827,7 +821,7 @@ $(REQUREJS)$(BACKUP_EXT): $(NODE_DIR)
# HACK: for some reason requirejs breaks if we do not do this (see: NOTES) # HACK: for some reason requirejs breaks if we do not do this (see: NOTES)
cp -f $(REQUREJS){,$(BACKUP_EXT)} cp -f $(REQUREJS){,$(BACKUP_EXT)}
cat $(REQUREJS)$(BACKUP_EXT) \ cat $(REQUREJS)$(BACKUP_EXT) \
| $(SED) 's/^\(#!\/\)/\/\/\1/' \ | sed 's/^\(#!\/\)/\/\/\1/' \
> $(REQUREJS) > $(REQUREJS)
.PHONY: patched-requirejs .PHONY: patched-requirejs
@ -877,7 +871,7 @@ $(TARGET_DIR)/$(ELECTRON_DIST):
$(BUILD_DIR)/app.asar: $(PACK_FULL) $(BUILD_DIR)/app.asar: $(PACK_FULL)
# update package.json to start electron... # update package.json to start electron...
cd "$(BUILD_DIR)/$(APP_NAME)/" ; \ cd "$(BUILD_DIR)/$(APP_NAME)/" ; \
$(SED) -i 's/"index.html"/"e.js"/g' package.json sed -i 's/"index.html"/"e.js"/g' package.json
# remove electron from the dist... # remove electron from the dist...
rm -rf "$(BUILD_DIR)/$(APP_NAME)/$(NODE_DIR)/electron" rm -rf "$(BUILD_DIR)/$(APP_NAME)/$(NODE_DIR)/electron"
cd "$(BUILD_DIR)" ; \ cd "$(BUILD_DIR)" ; \
@ -891,14 +885,11 @@ $(BUILD_DIR)/app.asar: $(PACK_FULL)
# rules... # rules...
# XXX need to take nw/el version part into account... # XXX need to take nw/el version part into account...
# XXX need to setup app icons... # XXX need to setup app icons...
#.PRECIOUS: $(BUILD_DIR)/$(APP_NAME)-%/ .PRECIOUS: $(BUILD_DIR)/$(APP_NAME)-%/
#$(BUILD_DIR)/$(APP_NAME)-%/: $(TARGET_DIR)/$(ELECTRON_DIST) \ $(BUILD_DIR)/$(APP_NAME)-%/: $(TARGET_DIR)/$(ELECTRON_DIST) \
.PRECIOUS: $(BUILD_DIR)/$(APP_NAME).app/
$(BUILD_DIR)/$(APP_NAME).app/: $(TARGET_DIR)/$(ELECTRON_DIST) \
$(BUILD_DIR)/app.asar $(BUILD_INFO) $(LICENSE) $(BUILD_DIR)/app.asar $(BUILD_INFO) $(LICENSE)
unzip -u "$<" -d "$@" unzip -u "$<" -d "$@"
cp -r $(BUILD_DIR)/app.asar* "$@/$(ASAR_PATH)/" cp -r $(BUILD_DIR)/app.asar* "$@/$(ASAR_PATH)/"
mv "$@/LICENSE{,.electron}"
cp -f "$(BUILD_INFO)" "$(LICENSE)" "$@/" cp -f "$(BUILD_INFO)" "$(LICENSE)" "$@/"
# remove default_app.asar... # remove default_app.asar...
$(RM) "$@/$(ASAR_PATH)/default_app.asar" $(RM) "$@/$(ASAR_PATH)/default_app.asar"
@ -931,7 +922,7 @@ $(BUILD_DIR)/$(APP_NAME)-%.in-place.zip: $(TARGET_DIR)/$(ELECTRON_DIST) \
$(call zipDelFrom,"$(BUILD_DIR)",$@.tmp,"version") $(call zipDelFrom,"$(BUILD_DIR)",$@.tmp,"version")
# rename electron stuff... # rename electron stuff...
# # XXX rename "Electron Helper" on mac builds -- this needs Info.plist changes... # # XXX rename "Electron Helper" on mac builds -- this needs Info.plist changes...
# | $(SED) 's/\(^@ \(.*\)Electron Helper\(.*\)\)$$/\1\n@=\2$(APP_NAME) Helper\3/' # | sed 's/\(^@ \(.*\)Electron Helper\(.*\)\)$$/\1\n@=\2$(APP_NAME) Helper\3/'
unzip -p "$@.tmp" LICENSE > $(BUILD_DIR)/LICENSE.electron unzip -p "$@.tmp" LICENSE > $(BUILD_DIR)/LICENSE.electron
# rename app... # rename app...
# # XXX also rename MacOS/Electron -> $(APP_NAME) -- this needs Info.plist changes... # # XXX also rename MacOS/Electron -> $(APP_NAME) -- this needs Info.plist changes...

View File

@ -509,10 +509,6 @@ var KeyboardActions = actions.Actions({
// The amount of keyboard "quiet" time to wait for when // The amount of keyboard "quiet" time to wait for when
// .pauseKeyboardRepeat(..) is called... // .pauseKeyboardRepeat(..) is called...
'keyboard-repeat-pause-check': 100, 'keyboard-repeat-pause-check': 100,
// Keyboard handling timeout after focus...
// XXX FOCUS_EVENT see: features.ui for more details...
//'keyboard-pause-post-focus': 100,
}, },
get keybindings(){ get keybindings(){
@ -952,20 +948,6 @@ module.Keyboard = core.ImageGridFeatures.Feature({
function(){ function(){
this.toggleKeyboardHandling('off') }], this.toggleKeyboardHandling('off') }],
// XXX FOCUS_EVENT see: features.ui for more details...
//['windowBlur',
// function(){
// this.config['keyboard-pause-post-focus'] > 0
// && this.toggleKeyboardHandling('off') }],
//['windowFocus',
// function(){
// var that = this
// this.config['keyboard-pause-post-focus'] > 0
// && setTimeout(
// function(){
// that.toggleKeyboardHandling('on') },
// this.config['keyboard-pause-post-focus']) }],
// pause keyboard repeat... // pause keyboard repeat...
['shiftImageUp.pre shiftImageDown.pre', ['shiftImageUp.pre shiftImageDown.pre',
function(){ function(){

View File

@ -23,10 +23,6 @@
* - auto-single-image * - auto-single-image
* - auto-ribbon * - auto-ribbon
* *
* XXX FOCUS_EVENT BUG: for some reason focus/blur events both on window
* and on ig.dom trigger only if anything in the ui is physically
* focused (e.g. clicked)
*
* *
**********************************************************************/ **********************************************************************/
((typeof define)[0]=='u'?function(f){module.exports=f(require)}:define) ((typeof define)[0]=='u'?function(f){module.exports=f(require)}:define)
@ -503,21 +499,6 @@ module.ViewerActions = actions.Actions({
//}, 0) //}, 0)
}], }],
// XXX FOCUS_EVENT these for some reason work only if the ui is clicked...
//windowFocus: ['- Interface/',
// core.doc``,
// core.Event(function(){
// // This is the window focus event...
// //
// // Not for direct use.
// })],
//windowBlur: ['- Interface/',
// core.doc``,
// core.Event(function(){
// // This is the window blur event...
// //
// // Not for direct use.
// })],
// Viewer/window resize event... // Viewer/window resize event...
resizingWindow: ['- Interface/', resizingWindow: ['- Interface/',
@ -781,7 +762,7 @@ module.Viewer = core.ImageGridFeatures.Feature({
} }
}], }],
// workspaces, resizing and other events... // workspaces and resizing...
['start', ['start',
function(){ function(){
var that = this var that = this
@ -796,19 +777,6 @@ module.Viewer = core.ImageGridFeatures.Feature({
this.config['ribbon-theme'] this.config['ribbon-theme']
&& this.toggleImageRendering(this.config['image-rendering']) && this.toggleImageRendering(this.config['image-rendering'])
// XXX FOCUS_EVENT
//// focus handling...
//// XXX focus/blur events do not seem to trigger unless we
//// actually focus something in the window...
//this.__window_focus_handler ??=
// function(){
// that.windowFocus() }
//this.dom[0].addEventListener('focus', this.__window_focus_handler)
//this.__window_blur_handler ??=
// function(){
// that.windowBlur() }
//this.dom.on('blur', this.__window_blur_handler)
// center viewer on resize events... // center viewer on resize events...
if(!this.__viewer_resize){ if(!this.__viewer_resize){
this.__viewer_resize = function(){ this.__viewer_resize = function(){
@ -834,9 +802,6 @@ module.Viewer = core.ImageGridFeatures.Feature({
['stop', ['stop',
function(){ function(){
if(this.__viewer_resize){ if(this.__viewer_resize){
// XXX FOCUS_EVENT
//$(window).off('focus', this.__window_focus_handler)
//$(window).off('blur', this.__window_blur_handler)
$(window).off('resize', this.__viewer_resize) $(window).off('resize', this.__viewer_resize)
delete this.__viewer_resize delete this.__viewer_resize
} }

686
Viewer/package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -18,33 +18,35 @@
"show": false "show": false
}, },
"dependencies": { "dependencies": {
"app-module-path": "*", "object-run": "*",
"async-json": "0.0.2", "ig-object": "*",
"cli-progress": "^3.9.0", "ig-types": "*",
"colors": "^1.4.0", "ig-actions": "*",
"ig-features": "*",
"ig-argv": "*",
"ig-doc": "*",
"guarantee-events": "*",
"generic-walk": "*",
"requirejs": "*",
"requirejs-plugins": "*",
"fs-extra": "*",
"glob": "*",
"wildglob": "*",
"electron": "^37.0.0", "electron": "^37.0.0",
"sharp": "*",
"sharp-phash": "^2.0.0",
"exif-reader": "^1.0.3", "exif-reader": "^1.0.3",
"exifreader": "*", "exifreader": "*",
"exiftool": "^0.0.3", "exiftool": "^0.0.3",
"fs-extra": "*", "cli-progress": "^3.9.0",
"fs-walk": "*", "colors": "^1.4.0",
"generic-walk": "*",
"glob": "*",
"guarantee-events": "*",
"ig-actions": "*",
"ig-argv": "*",
"ig-doc": "*",
"ig-features": "*",
"ig-object": "*",
"ig-types": "*",
"json5": "^2.2.0",
"object-run": "*",
"requirejs": "*",
"requirejs-plugins": "*",
"sharp": "^0.34.4",
"sharp-phash": "^2.0.0",
"v8-compile-cache": "^2.2.0", "v8-compile-cache": "^2.2.0",
"wildglob": "*" "app-module-path": "*",
"fs-walk": "*",
"async-json": "0.0.2",
"json5": "^2.2.0"
}, },
"-dependencies": { "-dependencies": {
"openseadragon": "^2.4.1", "openseadragon": "^2.4.1",