1 ;;; GNU Guix --- Functional package management for GNU
2 ;;; Copyright © 2017 Arun Isaac <arunisaac@systemreboot.net>
3 ;;; Copyright © 2017, 2019 Ricardo Wurmus <rekado@elephly.net>
4 ;;; Copyright © 2017, 2018 Tobias Geerinckx-Rice <me@tobias.gr>
5 ;;; Copyright © 2017, 2018, 2019, 2020 Efraim Flashner <efraim@flashner.co.il>
6 ;;; Copyright © 2018 Nicolas Goaziou <mail@nicolasgoaziou.fr>
8 ;;; This file is part of GNU Guix.
10 ;;; GNU Guix is free software; you can redistribute it and/or modify it
11 ;;; under the terms of the GNU General Public License as published by
12 ;;; the Free Software Foundation; either version 3 of the License, or (at
13 ;;; your option) any later version.
15 ;;; GNU Guix is distributed in the hope that it will be useful, but
16 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
17 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 ;;; GNU General Public License for more details.
20 ;;; You should have received a copy of the GNU General Public License
21 ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
23 (define-module (gnu packages javascript)
24 #:use-module ((guix licenses) #:prefix license:)
25 #:use-module (gnu packages)
26 #:use-module (gnu packages base)
27 #:use-module (gnu packages compression)
28 #:use-module (gnu packages lisp-xyz)
29 #:use-module (gnu packages readline)
30 #:use-module (guix packages)
31 #:use-module (guix download)
32 #:use-module (guix git-download)
33 #:use-module (guix build-system gnu)
34 #:use-module (guix build-system trivial)
35 #:use-module (guix build-system minify))
37 (define-public font-mathjax
45 (url "https://github.com/mathjax/MathJax")
47 (file-name (git-file-name name version))
50 "127j12g7v2hx6k7r00b8cp49s7nkrwhxy6l8p03pw34xpxbgbimm"))))
51 (build-system trivial-build-system)
53 `(#:modules ((guix build utils))
56 (use-modules (guix build utils)
58 (let ((install-directory (string-append %output "/share/fonts/mathjax")))
59 (mkdir-p install-directory)
60 (copy-recursively (string-append (assoc-ref %build-inputs "source")
62 install-directory)))))
63 (home-page "https://www.mathjax.org/")
64 (synopsis "Fonts for MathJax")
65 (description "This package contains the fonts required for MathJax.")
66 (license license:asl2.0)))
68 (define-public js-mathjax
70 (inherit font-mathjax)
73 `(#:modules ((guix build utils))
76 (use-modules (guix build utils)
80 (set-path-environment-variable
81 "PATH" '("bin") (map (match-lambda
85 (set-path-environment-variable
86 "GUIX_LOCPATH" '("lib/locale")
87 (list (assoc-ref %build-inputs "glibc-utf8-locales")))
88 (setenv "LANG" "en_US.UTF-8")
89 (let ((install-directory (string-append %output "/share/javascript/mathjax")))
90 (copy-recursively (string-append (assoc-ref %build-inputs "source") "/unpacked")
92 (mkdir-p install-directory)
93 (symlink (string-append (assoc-ref %build-inputs "font-mathjax")
94 "/share/fonts/mathjax")
95 (string-append install-directory "/fonts"))
99 (let ((installed (string-append install-directory
100 ;; remove prefix "./MathJax-unpacked"
101 (string-drop file 18))))
102 (format #t "~a -> ~a~%" file installed)
104 ((string-match "\\.js$" file)
105 (mkdir-p (dirname installed))
106 (let ((minified (open-pipe* OPEN_READ "uglify-js" file)))
107 (call-with-output-file installed
109 (dump-port minified port)))
111 (let ((exit (close-pipe minified)))
113 (error "dear, uglify-js failed" exit)))))
115 (install-file file (dirname installed))))))
120 `(("font-mathjax" ,font-mathjax)
121 ("glibc-utf8-locales" ,glibc-utf8-locales)
122 ("uglify-js" ,uglify-js)
123 ,@(package-native-inputs font-mathjax)))
124 (synopsis "JavaScript display engine for LaTeX, MathML, and AsciiMath")
125 (description "MathJax is a JavaScript display engine for LaTeX, MathML,
126 and AsciiMath notation that works in all modern browsers. It requires no
127 plugins or software to be installed on the browser. So the page author can
128 write web documents that include mathematics and be confident that readers will
129 be able to view it naturally and easily.")))
131 (define-public js-respond
138 (url "https://github.com/scottjehl/Respond")
140 (file-name (git-file-name name version))
143 "00xid731rirc7sdy1gc8qal3v9g0agr2qx15hm4x97l1lcbylyn2"))))
144 (build-system minify-build-system)
146 `(#:javascript-files '("src/matchmedia.addListener.js"
147 "src/matchmedia.polyfill.js"
149 (home-page "https://github.com/scottjehl/Respond")
150 (synopsis "Polyfill for min/max-width CSS3 Media Queries")
151 (description "The goal of this script is to provide a fast and lightweight
152 script to enable responsive web designs in browsers that don't support CSS3
154 (license license:expat)))
156 (define-public js-html5shiv
158 (name "js-html5shiv")
163 (url "https://github.com/aFarkas/html5shiv")
165 (file-name (git-file-name name version))
168 "0y1c5nyq0brl9fjdihhax33vks4s1ij9iv113879sg3zflmgqpd0"))))
169 (build-system minify-build-system)
170 (home-page "https://github.com/aFarkas/html5shiv")
171 (synopsis "Enable HTML5 sectioning elements in legacy browsers")
172 (description "The HTML5 Shiv enables use of HTML5 sectioning elements in
173 legacy Internet Explorer and provides basic HTML5 styling for Internet
174 Explorer 6-9, Safari 4.x (and iPhone 3.x), and Firefox 3.x.")
175 ;; From the file "MIT and GPL2 licenses.md":
177 ;; This software is licensed under a dual license system (MIT or GPL
178 ;; version 2). This means you are free to choose with which of both
179 ;; licenses (MIT or GPL version 2) you want to use this library.
180 (license (list license:expat license:gpl2))))
182 (define-public js-json2
183 (let ((commit "031b1d9e6971bd4c433ca85e216cc853f5a867bd")
187 (version (string-append "2016-10-28." revision "-" (string-take commit 7)))
191 (url "https://github.com/douglascrockford/JSON-js.git")
193 (file-name (string-append name "-" version "-checkout"))
196 "1fvb6b2y5sd3sqdgcj683sdxcbxdii34q0ysc9wg0dq1sy81l11v"))))
197 (build-system minify-build-system)
199 `(#:javascript-files '("json2.js"
201 "json_parse_state.js"
203 (home-page "https://github.com/douglascrockford/JSON-js")
204 (synopsis "JSON encoders and decoders")
205 (description "The files in this collection implement JSON
206 encoders/decoders in JavaScript.
208 @code{json2.js}: This file creates a JSON property in the global object, if
209 there isn't already one, setting its value to an object containing a stringify
210 method and a parse method. The @code{parse} method uses the @code{eval}
211 method to do the parsing, guarding it with several regular expressions to
212 defend against accidental code execution hazards. On current browsers, this
213 file does nothing, preferring the built-in JSON object.
215 @code{json_parse.js}: This file contains an alternative JSON @code{parse}
216 function that uses recursive descent instead of @code{eval}.
218 @code{json_parse_state.js}: This files contains an alternative JSON
219 @code{parse} function that uses a state machine instead of @code{eval}.
221 @code{cycle.js}: This file contains two functions, @code{JSON.decycle} and
222 @code{JSON.retrocycle}, which make it possible to encode cyclical structures
223 and DAGs in JSON, and to then recover them. This is a capability that is not
224 provided by ES5. @code{JSONPath} is used to represent the links.")
225 (license license:public-domain))))
227 (define-public js-strftime
234 (url"https://github.com/samsonjs/strftime")
235 (commit (string-append "v" version))))
236 (file-name (git-file-name name version))
239 "131nmlivazwxyba25kh9lda99749fq4xsyin6lzfalaaydviby4p"))))
240 (build-system minify-build-system)
242 `(#:javascript-files '("strftime.js")))
243 (home-page "https://github.com/samsonjs/strftime")
244 (synopsis "Implementation of strftime to JavaScript")
245 (description "This is an implementation of the @code{strftime} procedure
246 for JavaScript. It works in (at least) node.js and browsers. It supports
247 localization and timezones. Most standard specifiers from C are supported as
248 well as some other extensions from Ruby.")
249 (license license:expat)))
251 (define-public js-highlight
253 (name "js-highlight")
258 (url "https://github.com/isagalaev/highlight.js")
260 (file-name (git-file-name name version))
263 "12qz22qjpd6svj58pwgcwg2x2rzhihfdrxg6lgj39nfpaln6dris"))))
264 (build-system minify-build-system)
266 `(#:javascript-files '("src/highlight.js")))
267 (home-page "https://github.com/isagalaev/highlight.js")
268 (synopsis "Syntax highlighting for JavaScript")
269 (description "Highlight.js is a syntax highlighter written in JavaScript.
270 It works in the browser as well as on the server. It works with pretty much
271 any markup, doesn’t depend on any framework and has automatic language
273 (license license:bsd-3)))
275 (define-public js-datatables
277 (name "js-datatables")
281 (uri (string-append "https://datatables.net/releases/DataTables-"
285 "0cff8a1g7pjwbjdqq0yzqd963ar7pfi4splmm6rwdzganr77rkhb"))))
286 (build-system minify-build-system)
288 `(#:javascript-files '("media/js/dataTables.bootstrap.js"
289 "media/js/jquery.dataTables.js")))
292 (home-page "https://datatables.net")
293 (synopsis "DataTables plug-in for jQuery")
294 (description "DataTables is a table enhancing plug-in for the jQuery
295 Javascript library, adding sorting, paging and filtering abilities to plain
296 HTML tables with minimal effort.")
297 (license license:expat)))
299 (define-public js-requirejs
301 (name "js-requirejs")
306 (url "https://github.com/requirejs/requirejs.git")
308 (file-name (git-file-name name version))
311 "0cvd5y2mb3h6yil3niqn3gjqrzixdsxcz4rvc2f0hg4kzp5y0w86"))))
312 (build-system minify-build-system)
313 (arguments `(#:javascript-files '("require.js")))
314 (home-page "https://github.com/requirejs/requirejs/")
315 (synopsis "File and module loader for JavaScript")
316 (description "RequireJS loads plain JavaScript files as well as more
317 defined modules. It is optimized for in-browser use, including in a Web
318 Worker, but it can be used in other JavaScript environments.")
319 (license license:expat)))
321 (define-public js-selectize
323 (name "js-selectize")
328 (url "https://github.com/selectize/selectize.js")
329 (commit (string-append "v" version))))
330 (file-name (git-file-name name version))
333 "15gichl8wi6yxag2ps723nxrgyan15976dzsnvw9h9py8sbyyzjn"))))
334 (build-system minify-build-system)
335 (arguments `(#:javascript-files '("src/selectize.js")))
336 (home-page "https://selectize.github.io/selectize.js/")
337 (synopsis "Hybrid widget between a textbox and <select> box")
338 (description "Selectize is the hybrid of a textbox and @code{<select>}
339 box. It's jQuery based and it has autocomplete and native-feeling keyboard
340 navigation; it is useful for tagging, contact lists, etc.")
341 (license license:asl2.0)))
343 (define-public js-es5-shim
350 (url "https://github.com/es-shims/es5-shim")
351 (commit (string-append "v" version))))
352 (file-name (git-file-name name version))
355 "142w384fbyllq4yggv173g82lw3wix4jqcg6hkhx1ymq89vvnpmh"))))
356 (build-system minify-build-system)
357 (arguments `(#:javascript-files
360 (home-page "https://github.com/es-shims/es5-shim")
361 (synopsis "ECMAScript 5 compatibility shims for legacy JavaScript engines")
362 (description "@code{es5-shim.js} patches a JavaScript context to contain
363 all ECMAScript 5 methods that can be faithfully emulated with a legacy
364 JavaScript engine. @code{es5-sham.js} patches other ES5 methods as closely as
365 possible. Many of these shams are intended only to allow code to be written
366 to ES5 without causing run-time errors in older engines. In many cases, this
367 means that these shams cause many ES5 methods to silently fail.")
368 (license license:expat)))
370 (define-public js-filesaver
372 (name "js-filesaver")
377 (url "https://github.com/eligrey/FileSaver.js")
379 (file-name (git-file-name name version))
382 "0gvqk0hnr8fig0n4da7vj7q6z31bcyv52916xz3rbmdj3pgpiv1d"))))
383 (build-system minify-build-system)
386 (modify-phases %standard-phases
387 (add-after 'unpack 'fix-uglification
388 ;; Remove "export" keyword which prevents the file from being
389 ;; uglified by uglify-js. Moreover, that keyword is not present in
390 ;; the minified version of the library some projects are using,
392 ;; <https://github.com/jmoenig/Snap--Build-Your-Own-Blocks/blob/master/FileSaver.min.js>
394 (substitute* "src/FileSaver.js"
398 "https://eligrey.com/blog/saving-generated-files-on-the-client-side/")
399 (synopsis "HTML5 saveAs() FileSaver implementation")
400 (description "@file{FileSaver.js} implements the @code{saveAs()}
401 FileSaver interface in browsers that do not natively support it.
403 @file{FileSaver.js} is the solution to saving files on the
404 client-side, and is perfect for webapps that need to generate files,
405 or for saving sensitive information that shouldn't be sent to an
407 (license license:expat)))
415 (uri (string-append "https://mujs.com/downloads/mujs-"
419 "1q9w2dcspfp580pzx7sw7x9gbn8j0ak6dvj75wd1ml3f3q3i43df"))))
420 (build-system gnu-build-system)
423 (modify-phases %standard-phases
424 (delete 'configure) ; no configure
425 (add-after 'install 'install-shared-library
426 (lambda* (#:key (make-flags '()) #:allow-other-keys)
427 (apply invoke "make" "install-shared" make-flags))))
428 #:make-flags (list (string-append "prefix=" (assoc-ref %outputs "out"))
429 (string-append "CC=gcc"))
430 #:tests? #f)) ; no tests
432 `(("readline" ,readline)))
433 (home-page "https://mujs.com/")
434 (synopsis "JavaScript interpreter written in C")
435 (description "MuJS is a lightweight Javascript interpreter designed for
436 embedding in other software to extend them with scripting capabilities. MuJS
437 was designed with a focus on small size, correctness, and simplicity. It is
438 written in portable C and implements ECMAScript as specified by ECMA-262. The
439 interface for binding with native code is designed to be as simple as possible
440 to use, and is very similar to Lua. There is no need to interact with byzantine
441 C++ template mechanisms, or worry about marking and unmarking garbage collection
442 roots, or wrestle with obscure build systems.")
443 (license license:isc)))