# HG changeset patch # User # Date 2020-03-22 14:49:17 # Node ID 6b72d87e00d0a0578b26cc99ff7af08a5e4376e3 # Parent 44cead2862b98c5af200803e630eb38ad5a57b8e Some DOM stuff, VIEW diff --git a/extras/body.html b/extras/body.html --- a/extras/body.html +++ b/extras/body.html @@ -10,10 +10,14 @@
 
- - + +
+ +
+ +
diff --git a/extras/default.css b/extras/default.css --- a/extras/default.css +++ b/extras/default.css @@ -94,10 +94,21 @@ height: 50px; } -#qsp-btn-save { +#qsp-btn-save img { background: url(''); } -#qsp-btn-load { +#qsp-btn-open img { background: url(''); } + +#qsp-image-container { + position: absolute; + top: 0; + left: 0; + height: 100%; + width: 100%; + display: none; + justify-content: center; + align-items: center; +} diff --git a/src/api.ps b/src/api.ps --- a/src/api.ps +++ b/src/api.ps @@ -21,6 +21,22 @@ title "")) +(defm (root api init-dom) () + ;; Save/load buttons + (let ((btn (document.get-element-by-id "qsp-btn-save"))) + (setf (ps:@ btn onclick) this.savegame) + (setf (ps:@ btn href) "#")) + (let ((btn (document.get-element-by-id "qsp-btn-open"))) + (setf (ps:@ btn onclick) this.opengame) + (setf (ps:@ btn href) "#")) + ;; Close image on click + (setf (ps:@ (document.get-element-by-id "qsp-image-container") onclick) + (this.show-image nil)) + ;; Close the dropdown on any click + (setf window.onclick + (lambda (event) + (setf (ps:@ (api-call get-frame :dropdown) style display) "none")))) + ;; To be used in saving game (defm (root api stash-state) (args) (setf (root state-stash) @@ -285,3 +301,48 @@ :do (when (ps:@ v ended) (ps:delete (ps:@ (root playing) k))))) +(defm (root api show-image) (path) + (let ((img (document.get-element-by-id "qsp-image"))) + (cond (path + (setf img.src path) + (setf img.style.display "flex")) + (t + (setf img.src "") + (setf img.style.display "hidden"))))) + +;;; Saves + +(defm (root api opengame) () + (let ((element (document.create-element :input))) + (element.set-attribute :type :file) + (element.set-attribute :id :qsp-opengame) + (element.set-attribute :tabindex -1) + (element.set-attribute "aria-hidden" t) + (setf element.style.display :block) + (setf element.style.visibility :hidden) + (setf element.style.position :fixed) + (setf element.onchange + (lambda (event) + (let* ((file (elt event.target.files 0)) + (reader (ps:new (*file-reader)))) + (setf reader.onload + (lambda (ev) + (block nil + (let ((target ev.current-target)) + (unless target.result + (return)) + (api-call base64-to-state target.result) + (api-call unstash-state))))) + (reader.read-as-text file)))) + (document.body.append-child element) + (element.click) + (document.body.remove-child element))) + +(defm (root api savegame) () + (let ((element (document.create-element :a))) + (element.set-attribute :href (+ "data:text/plain;charset=utf-8," (api-call state-to-base64))) + (element.set-attribute :download "savegame.sav") + (setf element.style.display :none) + (document.body.append-child element) + (element.click) + (document.body.remove-child element))) diff --git a/src/intrinsic-macros.lisp b/src/intrinsic-macros.lisp --- a/src/intrinsic-macros.lisp +++ b/src/intrinsic-macros.lisp @@ -137,6 +137,9 @@ ;;; 18img +(ps:defpsmacro view (&optional path) + `(api-call show-image ,path)) + ;;; 19input ;;; 20time @@ -148,3 +151,15 @@ (api-call new-local ,(string (second var))) ,@(when expr `((set ,var ,expr))))) + +;;; 22for + +;;; misc + +(ps:defpsmacro opengame (&optional filename) + (declare (ignore filename)) + `(api-call opengame)) + +(ps:defpsmacro savegame (&optional filename) + (declare (ignore filename)) + `(api-call savegame)) diff --git a/src/intrinsics.ps b/src/intrinsics.ps --- a/src/intrinsics.ps +++ b/src/intrinsics.ps @@ -250,9 +250,9 @@ ;;; 18img -(defm (root lib refint) ()) - -(defm (root lib view) ()) +(defm (root lib refint) () + ;; "Force interface update" Uh... what exactly do we do here? + ) ;;; 19input @@ -278,6 +278,8 @@ ;;; 21local +;;; 22for + ;;; misc (defm (root lib rgb) ()) @@ -288,37 +290,3 @@ (defm (root lib killqst) ()) -(defm (root lib opengame) (&optional filename) - (let ((element (document.create-element :input))) - (element.set-attribute :type :file) - (element.set-attribute :id :qsp-opengame) - (element.set-attribute :tabindex -1) - (element.set-attribute "aria-hidden" t) - (setf element.style.display :block) - (setf element.style.visibility :hidden) - (setf element.style.position :fixed) - (setf element.onchange - (lambda (event) - (let* ((file (elt event.target.files 0)) - (reader (ps:new (*file-reader)))) - (setf reader.onload - (lambda (ev) - (block nil - (let ((target ev.current-target)) - (unless target.result - (return)) - (api-call base64-to-state target.result) - (api-call unstash-state))))) - (reader.read-as-text file)))) - (document.body.append-child element) - (element.click) - (document.body.remove-child element))) - -(defm (root lib savegame) (&optional filename) - (let ((element (document.create-element :a))) - (element.set-attribute :href (+ "data:text/plain;charset=utf-8," (api-call state-to-base64))) - (element.set-attribute :download "savegame.sav") - (setf element.style.display :none) - (document.body.append-child element) - (element.click) - (document.body.remove-child element))) diff --git a/src/main.ps b/src/main.ps --- a/src/main.ps +++ b/src/main.ps @@ -24,12 +24,9 @@ ;; Launch the game from the first location (setf window.onload (lambda () + (api-call init-dom) (funcall (ps:getprop (root locs) (ps:chain *object (keys (root locs)) 0)) (list)) (values))) -;; Close the dropdown on any click -(setf window.onclick - (lambda (event) - (setf (ps:@ (api-call get-frame :dropdown) style display) "none")))