diff --git a/assets/scripts/routes/catalog.js b/assets/scripts/routes/catalog.js index e2744f6..3414188 100644 --- a/assets/scripts/routes/catalog.js +++ b/assets/scripts/routes/catalog.js @@ -30,7 +30,7 @@ export default { while ( elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H2' - ) { + ) { elems.push( elem.nextElementSibling ); elem = elem.nextElementSibling; } @@ -100,7 +100,7 @@ export default { while ( elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H3' - ) { + ) { elems.push( elem.nextElementSibling ); elem = elem.nextElementSibling; } diff --git a/assets/styles/aldine.scss b/assets/styles/aldine.scss index 0cbde1e..4ba9ec4 100644 --- a/assets/styles/aldine.scss +++ b/assets/styles/aldine.scss @@ -11,6 +11,7 @@ /** Import theme styles */ @import "common/global"; @import "components/book"; +@import "components/featured_book"; @import "components/forms"; @import "layouts/footer"; @import "layouts/header"; diff --git a/assets/styles/components/_book.scss b/assets/styles/components/_book.scss index fd40008..d566d55 100644 --- a/assets/styles/components/_book.scss +++ b/assets/styles/components/_book.scss @@ -3,16 +3,18 @@ flex-direction: column; justify-content: flex-start; width: 100%; - max-width: 18rem; - height: 25rem; - border: solid 1px var(--accent); + max-width: 22.9375rem; + height: 24.125rem; margin: 0 0 2rem; + padding: 1.5rem 1rem 2rem; + @media #{$breakpoint-not-small} { padding: 1.5rem 1.85rem 2.1875rem; } - &__cover { - width: 100%; - height: 80%; - background-repeat: no-repeat; - background-size: cover; + border: solid 2px var(--accent); + background: var(--accent); + + a, p { + font-family: $font-family-sans-serif; + color: var(--accent-fg); } a { @@ -23,9 +25,62 @@ } &__title { - display: flex; - justify-content: center; - align-items: center; + margin: 0; + font-size: 1.25rem; + @media #{$breakpoint-not-small} { font-size: 1.75rem; } + font-weight: 500; + line-height: 1.2; + text-align: left; + } + + &__subject { + margin: 0; + font-size: 0.75rem; + @media #{$breakpoint-not-small} { + font-size: 1rem; + } + + text-align: left; + } + + &__institutions { + margin: .5rem 0 0; + font-size: 0.875rem; + text-align: left; + display: box; + overflow: hidden; + -webkit-line-clamp: 2; + -webkit-box-orient: vertical; + } + + &__read-more { + margin: auto 0 0; + font-size: 1rem; + @media #{$breakpoint-not-small} { font-size: 1.125rem; } + + text-align: left; + + a { + svg { + width: 1rem; + height: 1rem; + @media #{$breakpoint-not-small} { + width: 1.125rem; + height: 1.125rem; + margin-left: 0.5rem; + } + + vertical-align: middle; + } + } + } + + &:last-child { + margin-bottom: 0; + + @media #{$breakpoint-large} { + margin-bottom: 2rem; + } } } diff --git a/assets/styles/components/_featured_book.scss b/assets/styles/components/_featured_book.scss new file mode 100644 index 0000000..4b82fbf --- /dev/null +++ b/assets/styles/components/_featured_book.scss @@ -0,0 +1,31 @@ +.featured_book { + display: flex; + flex-direction: column; + justify-content: flex-start; + width: 100%; + max-width: 18rem; + height: 25rem; + border: solid 1px var(--accent); + margin: 0 0 2rem; + + &__cover { + width: 100%; + height: 80%; + background-repeat: no-repeat; + background-size: cover; + } + + a { + margin: 0; + text-decoration: none; + text-align: center; + hyphens: auto; + } + + &__title { + display: flex; + justify-content: center; + align-items: center; + font-weight: 500; + } +} diff --git a/assets/styles/layouts/_page-catalog.scss b/assets/styles/layouts/_page-catalog.scss index a8213ef..54e44b2 100644 --- a/assets/styles/layouts/_page-catalog.scss +++ b/assets/styles/layouts/_page-catalog.scss @@ -1,6 +1,6 @@ // stylelint-disable no-descending-specificity -fieldset { +.network-catalog fieldset { border-top: solid 2px var(--accent); font-family: $font-family-sans-serif; @@ -128,7 +128,7 @@ fieldset { margin: 2rem 0 1rem 1rem; } - .book { + .book, .featured_book { height: 14.375rem; width: calc(50% - 1rem); margin: 0 1rem 1rem 0; diff --git a/assets/styles/layouts/_page-home.scss b/assets/styles/layouts/_page-home.scss index 8bd4201..c745873 100644 --- a/assets/styles/layouts/_page-home.scss +++ b/assets/styles/layouts/_page-home.scss @@ -79,7 +79,7 @@ flex-direction: row; justify-content: center; - .book { + .book, .featured_book { margin-right: 1rem; margin-left: 1rem; } diff --git a/dist/scripts/aldine.js b/dist/scripts/aldine.js index 49485a3..659e95d 100644 --- a/dist/scripts/aldine.js +++ b/dist/scripts/aldine.js @@ -27,7 +27,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _rou /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) { "use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* provided dependency */ var jQuery = __webpack_require__(/*! jquery */ \"./node_modules/jquery/dist/jquery.js\");\nvar Isotope = __webpack_require__(/*! isotope-layout */ \"./node_modules/isotope-layout/js/isotope.js\");\nvar jQueryBridget = __webpack_require__(/*! jquery-bridget */ \"./node_modules/jquery-bridget/jquery-bridget.js\");\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n /**\n *\n */init: function init() {\n // JavaScript to be fired on the catalog page\n (function () {\n // Get all the <h2> headings\n var headings = document.querySelectorAll('fieldset h2');\n Array.prototype.forEach.call(headings, function (heading) {\n // Give each <h3> a toggle button child\n heading.innerHTML = \"\\n\\t\\t\\t\\t<button type=\\\"button\\\" aria-expanded=\\\"false\\\">\\n\\t\\t\\t\\t\\t\".concat(heading.textContent, \"\\n\\t\\t\\t\\t\\t<svg aria-hidden=\\\"true\\\" focusable=\\\"false\\\" class=\\\"arrow\\\" width=\\\"13\\\" height=\\\"8\\\" viewBox=\\\"0 0 13 8\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M6.255 8L0 0h12.51z\\\" fill=\\\"currentColor\\\" fill-rule=\\\"evenodd\\\"></path></svg>\\n\\t\\t\\t\\t</button>\\n\\t\\t\\t \");\n\n // Function to create a node list\n // of the content between this <h2> and the next\n /**\n * @param elem\n */\n var getContent = function getContent(elem) {\n var elems = [];\n while (elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H2') {\n elems.push(elem.nextElementSibling);\n elem = elem.nextElementSibling;\n }\n\n // Delete the old versions of the content nodes\n elems.forEach(function (node) {\n node.parentNode.removeChild(node);\n });\n return elems;\n };\n\n // Assign the contents to be expanded/collapsed (array)\n var contents = getContent(heading);\n\n // Create a wrapper element for `contents` and hide it\n var wrapper = document.createElement('div');\n wrapper.hidden = true;\n\n // Add each element of `contents` to `wrapper`\n contents.forEach(function (node) {\n wrapper.appendChild(node);\n });\n\n // Add the wrapped content back into the DOM\n // after the heading\n heading.parentNode.insertBefore(wrapper, heading.nextElementSibling);\n\n // Assign the button\n var btn = heading.querySelector('button');\n\n /**\n *\n */\n btn.onclick = function () {\n // Cast the state as a boolean\n var expanded = btn.getAttribute('aria-expanded') === 'true' || false;\n\n // Switch the state\n btn.setAttribute('aria-expanded', !expanded);\n // Switch the content's visibility\n wrapper.hidden = expanded;\n };\n });\n })();\n (function () {\n // Get all the <h3> headings\n var headings = document.querySelectorAll('fieldset h3');\n Array.prototype.forEach.call(headings, function (heading) {\n // Give each <h3> a toggle button child\n heading.innerHTML = \"\\n\\t\\t\\t\\t<button type=\\\"button\\\" aria-expanded=\\\"false\\\">\\n\\t\\t\\t\\t\\t\".concat(heading.innerHTML, \"\\n\\t\\t\\t\\t\\t<svg class=\\\"arrow\\\" width=\\\"13\\\" height=\\\"8\\\" viewBox=\\\"0 0 13 8\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M6.255 8L0 0h12.51z\\\" fill=\\\"currentColor\\\" fill-rule=\\\"evenodd\\\"></path></svg>\\n\\t\\t\\t\\t</button>\\n\\t\\t\\t \");\n\n // Function to create a node list\n // of the content between this <h2> and the next\n /**\n * @param elem\n */\n var getContent = function getContent(elem) {\n var elems = [];\n while (elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H3') {\n elems.push(elem.nextElementSibling);\n elem = elem.nextElementSibling;\n }\n\n // Delete the old versions of the content nodes\n elems.forEach(function (node) {\n node.parentNode.removeChild(node);\n });\n return elems;\n };\n\n // Assign the contents to be expanded/collapsed (array)\n var contents = getContent(heading);\n\n // Create a wrapper element for `contents` and hide it\n var wrapper = document.createElement('div');\n wrapper.hidden = true;\n\n // Add each element of `contents` to `wrapper`\n contents.forEach(function (node) {\n wrapper.appendChild(node);\n });\n\n // Add the wrapped content back into the DOM\n // after the heading\n heading.parentNode.insertBefore(wrapper, heading.nextElementSibling);\n\n // Assign the button\n var btn = heading.querySelector('button');\n\n /**\n *\n */\n btn.onclick = function () {\n // Cast the state as a boolean\n var expanded = btn.getAttribute('aria-expanded') === 'true' || false;\n\n // Switch the state\n btn.setAttribute('aria-expanded', !expanded);\n // Switch the content's visibility\n wrapper.hidden = expanded;\n };\n });\n })();\n jQuery(function ($) {\n jQueryBridget('isotope', Isotope, $);\n var $grid = $('.books');\n $grid.isotope({\n itemSelector: '.book',\n getSortData: {\n title: '.book__title a',\n subject: '[data-subject]',\n latest: '[data-date-published]'\n },\n sortAscending: {\n title: true,\n subject: false,\n latest: false\n }\n });\n var licenses = document.querySelector('.license-filters');\n var subjects = document.querySelector('.subject-filters');\n var institutions = document.querySelector('.institution-filters');\n var sorts = document.querySelector('.sorts');\n var clearFilters = document.querySelector('.clear-filters');\n clearFilters.hidden = false;\n licenses.addEventListener('click', function (event) {\n if (event.target.type !== 'radio') {\n return;\n }\n var subject = subjects.querySelector('input[type=\"radio\"]:checked').value ? \"[data-subject=\\\"\".concat(subjects.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var institution = institutions.querySelector('input[type=\"radio\"]:checked').value ? \"[data-institution*=\\\"\".concat(institutions.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var license = event.target.value ? \"[data-license=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n $grid.isotope({\n filter: filterValue\n });\n });\n institutions.addEventListener('click', function (event) {\n if (event.target.type !== 'radio') {\n return;\n }\n var subject = subjects.querySelector('input[type=\"radio\"]:checked').value ? \"[data-subject=\\\"\".concat(subjects.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var license = licenses.querySelector('input[type=\"radio\"]:checked').value ? \"[data-license=\\\"\".concat(licenses.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var institution = event.target.value ? \"[data-institution*=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n $grid.isotope({\n filter: filterValue\n });\n });\n subjects.addEventListener('click', function (event) {\n if (event.target.type !== 'radio') {\n return;\n }\n var license = licenses.querySelector('input[type=\"radio\"]:checked').value ? \"[data-license=\\\"\".concat(licenses.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var institution = institutions.querySelector('input[type=\"radio\"]:checked').value ? \"[data-institution*=\\\"\".concat(institutions.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var subject = event.target.value ? \"[data-subject=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n $grid.isotope({\n filter: filterValue\n });\n });\n clearFilters.addEventListener('click', function () {\n var allLicenses = document.getElementById('all-licenses');\n var allSubjects = document.getElementById('all-subjects');\n var allInstitutions = document.getElementById('all-institutions');\n allLicenses.checked = true;\n allSubjects.checked = true;\n allInstitutions.checked = true;\n $grid.isotope({\n filter: '*'\n });\n });\n sorts.addEventListener('click', function (event) {\n if (event.target.type !== 'radio') {\n return;\n }\n $grid.isotope({\n sortBy: event.target.value\n });\n });\n // \t$('.filters > a').click(e => {\n // \t\te.preventDefault();\n // \t\t$('.filters').toggleClass('is-active');\n // \t\t$('.filter-groups > div').removeClass('is-active');\n // \t});\n // \t$('.filter-groups .subjects > a').click(e => {\n // \t\te.preventDefault();\n // \t\tlet id = $(e.currentTarget).attr('href');\n // \t\t$(`.filter-groups .subjects:not(${id})`).removeClass('is-active');\n // \t\t$(`.filter-groups ${id}`).toggleClass('is-active');\n // \t});\n // \t$('.licenses > a').click(e => {\n // \t\te.preventDefault();\n // \t\tlet id = $(e.currentTarget).attr('href');\n // \t\t$(id).toggleClass('is-active');\n // \t});\n // \t$('.subjects .filter-list a').click(e => {\n // \t\te.preventDefault();\n // \t\tif ($(e.currentTarget).hasClass('is-active')) {\n // \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n // \t\t\t$('.subjects').removeClass('has-active-child');\n // \t\t} else {\n // \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n // \t\t\t$(e.currentTarget).addClass('is-active');\n // \t\t\t$('.subjects').removeClass('has-active-child');\n // \t\t\t$(e.currentTarget)\n // \t\t\t\t.parent()\n // \t\t\t\t.parent()\n // \t\t\t\t.parent('.subjects')\n // \t\t\t\t.addClass('has-active-child');\n // \t\t}\n // \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n // \t\t\t'data-filter'\n // \t\t);\n // \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n // \t\t\t'data-filter'\n // \t\t);\n // \t\tif (typeof licenseValue === 'undefined') {\n // \t\t\tlicenseValue = '';\n // \t\t} else {\n // \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n // \t\t}\n // \t\tif (typeof subjectValue === 'undefined') {\n // \t\t\tsubjectValue = '';\n // \t\t} else {\n // \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n // \t\t}\n // \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n // \t});\n // \t$('.licenses .filter-list a').click(e => {\n // \t\te.preventDefault();\n // \t\tif ($(e.currentTarget).hasClass('is-active')) {\n // \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n // \t\t\t$('.licenses').removeClass('has-active-child');\n // \t\t} else {\n // \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n // \t\t\t$(e.currentTarget).addClass('is-active');\n // \t\t\t$('.licenses').addClass('has-active-child');\n // \t\t}\n // \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n // \t\t\t'data-filter'\n // \t\t);\n // \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n // \t\t\t'data-filter'\n // \t\t);\n // \t\tif (typeof licenseValue === 'undefined') {\n // \t\t\tlicenseValue = '';\n // \t\t} else {\n // \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n // \t\t}\n // \t\tif (typeof subjectValue === 'undefined') {\n // \t\t\tsubjectValue = '';\n // \t\t} else {\n // \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n // \t\t}\n // \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n // \t});\n // \t$('.sort > a').click(e => {\n // \t\te.preventDefault();\n // \t\t$('.sort').toggleClass('is-active');\n // \t});\n // \t$('.sorts a').click(e => {\n // \t\te.preventDefault();\n // \t\tlet sortBy = $(e.currentTarget).attr('data-sort');\n // \t\t$('.sorts a').removeClass('is-active');\n // \t\t$(e.currentTarget).addClass('is-active');\n // \t\t$grid.isotope({ sortBy: sortBy });\n // \t});\n });\n },\n /**\n *\n */finalize: function finalize() {}\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./assets/scripts/routes/catalog.js.js","mappings":"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","sources":["webpack://@pressbooks/pressbooks-aldine/./assets/scripts/routes/catalog.js?f5df"],"sourcesContent":["const Isotope = require( 'isotope-layout' );\nconst jQueryBridget = require( 'jquery-bridget' );\n\nexport default {\n\t/**\n\t *\n\t */\n\tinit() {\n\t\t// JavaScript to be fired on the catalog page\n\t\t( function () {\n\t\t\t// Get all the <h2> headings\n\t\t\tconst headings = document.querySelectorAll( 'fieldset h2' );\n\n\t\t\tArray.prototype.forEach.call( headings, heading => {\n\t\t\t\t// Give each <h3> a toggle button child\n\t\t\t\theading.innerHTML = `\n\t\t\t\t<button type=\"button\" aria-expanded=\"false\">\n\t\t\t\t\t${ heading.textContent }\n\t\t\t\t\t<svg aria-hidden=\"true\" focusable=\"false\" class=\"arrow\" width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.255 8L0 0h12.51z\" fill=\"currentColor\" fill-rule=\"evenodd\"></path></svg>\n\t\t\t\t</button>\n\t\t\t  `;\n\n\t\t\t\t// Function to create a node list\n\t\t\t\t// of the content between this <h2> and the next\n\t\t\t\t/**\n\t\t\t\t * @param elem\n\t\t\t\t */\n\t\t\t\tconst getContent = elem => {\n\t\t\t\t\tlet elems = [];\n\t\t\t\t\twhile (\n\t\t\t\t\t\telem.nextElementSibling &&\n\t\t\t\t\t\telem.nextElementSibling.tagName !== 'H2'\n\t\t\t\t\t\t) {\n\t\t\t\t\t\telems.push( elem.nextElementSibling );\n\t\t\t\t\t\telem = elem.nextElementSibling;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Delete the old versions of the content nodes\n\t\t\t\t\telems.forEach( node => {\n\t\t\t\t\t\tnode.parentNode.removeChild( node );\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn elems;\n\t\t\t\t};\n\n\t\t\t\t// Assign the contents to be expanded/collapsed (array)\n\t\t\t\tlet contents = getContent( heading );\n\n\t\t\t\t// Create a wrapper element for `contents` and hide it\n\t\t\t\tlet wrapper = document.createElement( 'div' );\n\t\t\t\twrapper.hidden = true;\n\n\t\t\t\t// Add each element of `contents` to `wrapper`\n\t\t\t\tcontents.forEach( node => {\n\t\t\t\t\twrapper.appendChild( node );\n\t\t\t\t} );\n\n\t\t\t\t// Add the wrapped content back into the DOM\n\t\t\t\t// after the heading\n\t\t\t\theading.parentNode.insertBefore( wrapper, heading.nextElementSibling );\n\n\t\t\t\t// Assign the button\n\t\t\t\tlet btn = heading.querySelector( 'button' );\n\n\t\t\t\t/**\n\t\t\t\t *\n\t\t\t\t */\n\t\t\t\tbtn.onclick = () => {\n\t\t\t\t\t// Cast the state as a boolean\n\t\t\t\t\tlet expanded = btn.getAttribute( 'aria-expanded' ) === 'true' || false;\n\n\t\t\t\t\t// Switch the state\n\t\t\t\t\tbtn.setAttribute( 'aria-expanded', ! expanded );\n\t\t\t\t\t// Switch the content's visibility\n\t\t\t\t\twrapper.hidden = expanded;\n\t\t\t\t};\n\t\t\t} );\n\t\t} )();\n\n\t\t( function () {\n\t\t\t// Get all the <h3> headings\n\t\t\tconst headings = document.querySelectorAll( 'fieldset h3' );\n\n\t\t\tArray.prototype.forEach.call( headings, heading => {\n\t\t\t\t// Give each <h3> a toggle button child\n\t\t\t\theading.innerHTML = `\n\t\t\t\t<button type=\"button\" aria-expanded=\"false\">\n\t\t\t\t\t${ heading.innerHTML }\n\t\t\t\t\t<svg class=\"arrow\" width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.255 8L0 0h12.51z\" fill=\"currentColor\" fill-rule=\"evenodd\"></path></svg>\n\t\t\t\t</button>\n\t\t\t  `;\n\n\t\t\t\t// Function to create a node list\n\t\t\t\t// of the content between this <h2> and the next\n\t\t\t\t/**\n\t\t\t\t * @param elem\n\t\t\t\t */\n\t\t\t\tconst getContent = elem => {\n\t\t\t\t\tlet elems = [];\n\t\t\t\t\twhile (\n\t\t\t\t\t\telem.nextElementSibling &&\n\t\t\t\t\t\telem.nextElementSibling.tagName !== 'H3'\n\t\t\t\t\t\t) {\n\t\t\t\t\t\telems.push( elem.nextElementSibling );\n\t\t\t\t\t\telem = elem.nextElementSibling;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Delete the old versions of the content nodes\n\t\t\t\t\telems.forEach( node => {\n\t\t\t\t\t\tnode.parentNode.removeChild( node );\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn elems;\n\t\t\t\t};\n\n\t\t\t\t// Assign the contents to be expanded/collapsed (array)\n\t\t\t\tlet contents = getContent( heading );\n\n\t\t\t\t// Create a wrapper element for `contents` and hide it\n\t\t\t\tlet wrapper = document.createElement( 'div' );\n\t\t\t\twrapper.hidden = true;\n\n\t\t\t\t// Add each element of `contents` to `wrapper`\n\t\t\t\tcontents.forEach( node => {\n\t\t\t\t\twrapper.appendChild( node );\n\t\t\t\t} );\n\n\t\t\t\t// Add the wrapped content back into the DOM\n\t\t\t\t// after the heading\n\t\t\t\theading.parentNode.insertBefore( wrapper, heading.nextElementSibling );\n\n\t\t\t\t// Assign the button\n\t\t\t\tlet btn = heading.querySelector( 'button' );\n\n\t\t\t\t/**\n\t\t\t\t *\n\t\t\t\t */\n\t\t\t\tbtn.onclick = () => {\n\t\t\t\t\t// Cast the state as a boolean\n\t\t\t\t\tlet expanded = btn.getAttribute( 'aria-expanded' ) === 'true' || false;\n\n\t\t\t\t\t// Switch the state\n\t\t\t\t\tbtn.setAttribute( 'aria-expanded', ! expanded );\n\t\t\t\t\t// Switch the content's visibility\n\t\t\t\t\twrapper.hidden = expanded;\n\t\t\t\t};\n\t\t\t} );\n\t\t} )();\n\n\t\tjQuery( $ => {\n\t\t\tjQueryBridget( 'isotope', Isotope, $ );\n\t\t\tlet $grid = $( '.books' );\n\t\t\t$grid.isotope( {\n\t\t\t\titemSelector: '.book',\n\t\t\t\tgetSortData: {\n\t\t\t\t\ttitle: '.book__title a',\n\t\t\t\t\tsubject: '[data-subject]',\n\t\t\t\t\tlatest: '[data-date-published]',\n\t\t\t\t},\n\t\t\t\tsortAscending: {\n\t\t\t\t\ttitle: true,\n\t\t\t\t\tsubject: false,\n\t\t\t\t\tlatest: false,\n\t\t\t\t},\n\t\t\t} );\n\t\t\tlet licenses = document.querySelector( '.license-filters' );\n\t\t\tlet subjects = document.querySelector( '.subject-filters' );\n\t\t\tlet institutions = document.querySelector( '.institution-filters' );\n\t\t\tlet sorts = document.querySelector( '.sorts' );\n\t\t\tlet clearFilters = document.querySelector( '.clear-filters' );\n\t\t\tclearFilters.hidden = false;\n\t\t\tlicenses.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst subject = subjects.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-subject=\"${ subjects.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = institutions.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-institution*=\"${ institutions.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst license = event.target.value\n\t\t\t\t\t? `[data-license=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tinstitutions.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst subject = subjects.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-subject=\"${ subjects.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst license = licenses.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-license=\"${ licenses.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = event.target.value\n\t\t\t\t\t? `[data-institution*=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tsubjects.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst license = licenses.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-license=\"${ licenses.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = institutions.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-institution*=\"${ institutions.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst subject = event.target.value\n\t\t\t\t\t? `[data-subject=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tclearFilters.addEventListener( 'click', function () {\n\t\t\t\tlet allLicenses = document.getElementById( 'all-licenses' );\n\t\t\t\tlet allSubjects = document.getElementById( 'all-subjects' );\n\t\t\t\tlet allInstitutions = document.getElementById( 'all-institutions' );\n\t\t\t\tallLicenses.checked = true;\n\t\t\t\tallSubjects.checked = true;\n\t\t\t\tallInstitutions.checked = true;\n\t\t\t\t$grid.isotope( { filter: '*' } );\n\t\t\t} );\n\t\t\tsorts.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\t$grid.isotope( { sortBy: event.target.value } );\n\t\t\t} );\n\t\t\t// \t$('.filters > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\t$('.filters').toggleClass('is-active');\n\t\t\t// \t\t$('.filter-groups > div').removeClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.filter-groups .subjects > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet id = $(e.currentTarget).attr('href');\n\t\t\t// \t\t$(`.filter-groups .subjects:not(${id})`).removeClass('is-active');\n\t\t\t// \t\t$(`.filter-groups ${id}`).toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.licenses > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet id = $(e.currentTarget).attr('href');\n\t\t\t// \t\t$(id).toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.subjects .filter-list a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tif ($(e.currentTarget).hasClass('is-active')) {\n\t\t\t// \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$('.subjects').removeClass('has-active-child');\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t\t$('.subjects').removeClass('has-active-child');\n\t\t\t// \t\t\t$(e.currentTarget)\n\t\t\t// \t\t\t\t.parent()\n\t\t\t// \t\t\t\t.parent()\n\t\t\t// \t\t\t\t.parent('.subjects')\n\t\t\t// \t\t\t\t.addClass('has-active-child');\n\t\t\t// \t\t}\n\t\t\t// \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tif (typeof licenseValue === 'undefined') {\n\t\t\t// \t\t\tlicenseValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\tif (typeof subjectValue === 'undefined') {\n\t\t\t// \t\t\tsubjectValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n\t\t\t// \t});\n\t\t\t// \t$('.licenses .filter-list a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tif ($(e.currentTarget).hasClass('is-active')) {\n\t\t\t// \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$('.licenses').removeClass('has-active-child');\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t\t$('.licenses').addClass('has-active-child');\n\t\t\t// \t\t}\n\t\t\t// \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tif (typeof licenseValue === 'undefined') {\n\t\t\t// \t\t\tlicenseValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\tif (typeof subjectValue === 'undefined') {\n\t\t\t// \t\t\tsubjectValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n\t\t\t// \t});\n\t\t\t// \t$('.sort > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\t$('.sort').toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.sorts a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet sortBy = $(e.currentTarget).attr('data-sort');\n\t\t\t// \t\t$('.sorts a').removeClass('is-active');\n\t\t\t// \t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t$grid.isotope({ sortBy: sortBy });\n\t\t\t// \t});\n\t\t} );\n\t},\n\t/**\n\t *\n\t */\n\tfinalize() {},\n};\n"],"names":["Isotope","require","jQueryBridget","init","headings","document","querySelectorAll","Array","prototype","forEach","call","heading","innerHTML","textContent","getContent","elem","elems","nextElementSibling","tagName","push","node","parentNode","removeChild","contents","wrapper","createElement","hidden","appendChild","insertBefore","btn","querySelector","onclick","expanded","getAttribute","setAttribute","jQuery","$","$grid","isotope","itemSelector","getSortData","title","subject","latest","sortAscending","licenses","subjects","institutions","sorts","clearFilters","addEventListener","event","target","type","value","institution","license","filterValue","filter","allLicenses","getElementById","allSubjects","allInstitutions","checked","sortBy","finalize"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./assets/scripts/routes/catalog.js\n"); +eval("__webpack_require__.r(__webpack_exports__);\n/* provided dependency */ var jQuery = __webpack_require__(/*! jquery */ \"./node_modules/jquery/dist/jquery.js\");\nvar Isotope = __webpack_require__(/*! isotope-layout */ \"./node_modules/isotope-layout/js/isotope.js\");\nvar jQueryBridget = __webpack_require__(/*! jquery-bridget */ \"./node_modules/jquery-bridget/jquery-bridget.js\");\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n /**\n *\n */init: function init() {\n // JavaScript to be fired on the catalog page\n (function () {\n // Get all the <h2> headings\n var headings = document.querySelectorAll('fieldset h2');\n Array.prototype.forEach.call(headings, function (heading) {\n // Give each <h3> a toggle button child\n heading.innerHTML = \"\\n\\t\\t\\t\\t<button type=\\\"button\\\" aria-expanded=\\\"false\\\">\\n\\t\\t\\t\\t\\t\".concat(heading.textContent, \"\\n\\t\\t\\t\\t\\t<svg aria-hidden=\\\"true\\\" focusable=\\\"false\\\" class=\\\"arrow\\\" width=\\\"13\\\" height=\\\"8\\\" viewBox=\\\"0 0 13 8\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M6.255 8L0 0h12.51z\\\" fill=\\\"currentColor\\\" fill-rule=\\\"evenodd\\\"></path></svg>\\n\\t\\t\\t\\t</button>\\n\\t\\t\\t \");\n\n // Function to create a node list\n // of the content between this <h2> and the next\n /**\n * @param elem\n */\n var getContent = function getContent(elem) {\n var elems = [];\n while (elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H2') {\n elems.push(elem.nextElementSibling);\n elem = elem.nextElementSibling;\n }\n\n // Delete the old versions of the content nodes\n elems.forEach(function (node) {\n node.parentNode.removeChild(node);\n });\n return elems;\n };\n\n // Assign the contents to be expanded/collapsed (array)\n var contents = getContent(heading);\n\n // Create a wrapper element for `contents` and hide it\n var wrapper = document.createElement('div');\n wrapper.hidden = true;\n\n // Add each element of `contents` to `wrapper`\n contents.forEach(function (node) {\n wrapper.appendChild(node);\n });\n\n // Add the wrapped content back into the DOM\n // after the heading\n heading.parentNode.insertBefore(wrapper, heading.nextElementSibling);\n\n // Assign the button\n var btn = heading.querySelector('button');\n\n /**\n *\n */\n btn.onclick = function () {\n // Cast the state as a boolean\n var expanded = btn.getAttribute('aria-expanded') === 'true' || false;\n\n // Switch the state\n btn.setAttribute('aria-expanded', !expanded);\n // Switch the content's visibility\n wrapper.hidden = expanded;\n };\n });\n })();\n (function () {\n // Get all the <h3> headings\n var headings = document.querySelectorAll('fieldset h3');\n Array.prototype.forEach.call(headings, function (heading) {\n // Give each <h3> a toggle button child\n heading.innerHTML = \"\\n\\t\\t\\t\\t<button type=\\\"button\\\" aria-expanded=\\\"false\\\">\\n\\t\\t\\t\\t\\t\".concat(heading.innerHTML, \"\\n\\t\\t\\t\\t\\t<svg class=\\\"arrow\\\" width=\\\"13\\\" height=\\\"8\\\" viewBox=\\\"0 0 13 8\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M6.255 8L0 0h12.51z\\\" fill=\\\"currentColor\\\" fill-rule=\\\"evenodd\\\"></path></svg>\\n\\t\\t\\t\\t</button>\\n\\t\\t\\t \");\n\n // Function to create a node list\n // of the content between this <h2> and the next\n /**\n * @param elem\n */\n var getContent = function getContent(elem) {\n var elems = [];\n while (elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H3') {\n elems.push(elem.nextElementSibling);\n elem = elem.nextElementSibling;\n }\n\n // Delete the old versions of the content nodes\n elems.forEach(function (node) {\n node.parentNode.removeChild(node);\n });\n return elems;\n };\n\n // Assign the contents to be expanded/collapsed (array)\n var contents = getContent(heading);\n\n // Create a wrapper element for `contents` and hide it\n var wrapper = document.createElement('div');\n wrapper.hidden = true;\n\n // Add each element of `contents` to `wrapper`\n contents.forEach(function (node) {\n wrapper.appendChild(node);\n });\n\n // Add the wrapped content back into the DOM\n // after the heading\n heading.parentNode.insertBefore(wrapper, heading.nextElementSibling);\n\n // Assign the button\n var btn = heading.querySelector('button');\n\n /**\n *\n */\n btn.onclick = function () {\n // Cast the state as a boolean\n var expanded = btn.getAttribute('aria-expanded') === 'true' || false;\n\n // Switch the state\n btn.setAttribute('aria-expanded', !expanded);\n // Switch the content's visibility\n wrapper.hidden = expanded;\n };\n });\n })();\n jQuery(function ($) {\n jQueryBridget('isotope', Isotope, $);\n var $grid = $('.books');\n $grid.isotope({\n itemSelector: '.book',\n getSortData: {\n title: '.book__title a',\n subject: '[data-subject]',\n latest: '[data-date-published]'\n },\n sortAscending: {\n title: true,\n subject: false,\n latest: false\n }\n });\n var licenses = document.querySelector('.license-filters');\n var subjects = document.querySelector('.subject-filters');\n var institutions = document.querySelector('.institution-filters');\n var sorts = document.querySelector('.sorts');\n var clearFilters = document.querySelector('.clear-filters');\n clearFilters.hidden = false;\n licenses.addEventListener('click', function (event) {\n if (event.target.type !== 'radio') {\n return;\n }\n var subject = subjects.querySelector('input[type=\"radio\"]:checked').value ? \"[data-subject=\\\"\".concat(subjects.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var institution = institutions.querySelector('input[type=\"radio\"]:checked').value ? \"[data-institution*=\\\"\".concat(institutions.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var license = event.target.value ? \"[data-license=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n $grid.isotope({\n filter: filterValue\n });\n });\n institutions.addEventListener('click', function (event) {\n if (event.target.type !== 'radio') {\n return;\n }\n var subject = subjects.querySelector('input[type=\"radio\"]:checked').value ? \"[data-subject=\\\"\".concat(subjects.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var license = licenses.querySelector('input[type=\"radio\"]:checked').value ? \"[data-license=\\\"\".concat(licenses.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var institution = event.target.value ? \"[data-institution*=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n $grid.isotope({\n filter: filterValue\n });\n });\n subjects.addEventListener('click', function (event) {\n if (event.target.type !== 'radio') {\n return;\n }\n var license = licenses.querySelector('input[type=\"radio\"]:checked').value ? \"[data-license=\\\"\".concat(licenses.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var institution = institutions.querySelector('input[type=\"radio\"]:checked').value ? \"[data-institution*=\\\"\".concat(institutions.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n var subject = event.target.value ? \"[data-subject=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n $grid.isotope({\n filter: filterValue\n });\n });\n clearFilters.addEventListener('click', function () {\n var allLicenses = document.getElementById('all-licenses');\n var allSubjects = document.getElementById('all-subjects');\n var allInstitutions = document.getElementById('all-institutions');\n allLicenses.checked = true;\n allSubjects.checked = true;\n allInstitutions.checked = true;\n $grid.isotope({\n filter: '*'\n });\n });\n sorts.addEventListener('click', function (event) {\n if (event.target.type !== 'radio') {\n return;\n }\n $grid.isotope({\n sortBy: event.target.value\n });\n });\n // \t$('.filters > a').click(e => {\n // \t\te.preventDefault();\n // \t\t$('.filters').toggleClass('is-active');\n // \t\t$('.filter-groups > div').removeClass('is-active');\n // \t});\n // \t$('.filter-groups .subjects > a').click(e => {\n // \t\te.preventDefault();\n // \t\tlet id = $(e.currentTarget).attr('href');\n // \t\t$(`.filter-groups .subjects:not(${id})`).removeClass('is-active');\n // \t\t$(`.filter-groups ${id}`).toggleClass('is-active');\n // \t});\n // \t$('.licenses > a').click(e => {\n // \t\te.preventDefault();\n // \t\tlet id = $(e.currentTarget).attr('href');\n // \t\t$(id).toggleClass('is-active');\n // \t});\n // \t$('.subjects .filter-list a').click(e => {\n // \t\te.preventDefault();\n // \t\tif ($(e.currentTarget).hasClass('is-active')) {\n // \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n // \t\t\t$('.subjects').removeClass('has-active-child');\n // \t\t} else {\n // \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n // \t\t\t$(e.currentTarget).addClass('is-active');\n // \t\t\t$('.subjects').removeClass('has-active-child');\n // \t\t\t$(e.currentTarget)\n // \t\t\t\t.parent()\n // \t\t\t\t.parent()\n // \t\t\t\t.parent('.subjects')\n // \t\t\t\t.addClass('has-active-child');\n // \t\t}\n // \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n // \t\t\t'data-filter'\n // \t\t);\n // \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n // \t\t\t'data-filter'\n // \t\t);\n // \t\tif (typeof licenseValue === 'undefined') {\n // \t\t\tlicenseValue = '';\n // \t\t} else {\n // \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n // \t\t}\n // \t\tif (typeof subjectValue === 'undefined') {\n // \t\t\tsubjectValue = '';\n // \t\t} else {\n // \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n // \t\t}\n // \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n // \t});\n // \t$('.licenses .filter-list a').click(e => {\n // \t\te.preventDefault();\n // \t\tif ($(e.currentTarget).hasClass('is-active')) {\n // \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n // \t\t\t$('.licenses').removeClass('has-active-child');\n // \t\t} else {\n // \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n // \t\t\t$(e.currentTarget).addClass('is-active');\n // \t\t\t$('.licenses').addClass('has-active-child');\n // \t\t}\n // \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n // \t\t\t'data-filter'\n // \t\t);\n // \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n // \t\t\t'data-filter'\n // \t\t);\n // \t\tif (typeof licenseValue === 'undefined') {\n // \t\t\tlicenseValue = '';\n // \t\t} else {\n // \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n // \t\t}\n // \t\tif (typeof subjectValue === 'undefined') {\n // \t\t\tsubjectValue = '';\n // \t\t} else {\n // \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n // \t\t}\n // \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n // \t});\n // \t$('.sort > a').click(e => {\n // \t\te.preventDefault();\n // \t\t$('.sort').toggleClass('is-active');\n // \t});\n // \t$('.sorts a').click(e => {\n // \t\te.preventDefault();\n // \t\tlet sortBy = $(e.currentTarget).attr('data-sort');\n // \t\t$('.sorts a').removeClass('is-active');\n // \t\t$(e.currentTarget).addClass('is-active');\n // \t\t$grid.isotope({ sortBy: sortBy });\n // \t});\n });\n },\n /**\n *\n */finalize: function finalize() {}\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./assets/scripts/routes/catalog.js.js","mappings":"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","sources":["webpack://@pressbooks/pressbooks-aldine/./assets/scripts/routes/catalog.js?f5df"],"sourcesContent":["const Isotope = require( 'isotope-layout' );\nconst jQueryBridget = require( 'jquery-bridget' );\n\nexport default {\n\t/**\n\t *\n\t */\n\tinit() {\n\t\t// JavaScript to be fired on the catalog page\n\t\t( function () {\n\t\t\t// Get all the <h2> headings\n\t\t\tconst headings = document.querySelectorAll( 'fieldset h2' );\n\n\t\t\tArray.prototype.forEach.call( headings, heading => {\n\t\t\t\t// Give each <h3> a toggle button child\n\t\t\t\theading.innerHTML = `\n\t\t\t\t<button type=\"button\" aria-expanded=\"false\">\n\t\t\t\t\t${ heading.textContent }\n\t\t\t\t\t<svg aria-hidden=\"true\" focusable=\"false\" class=\"arrow\" width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.255 8L0 0h12.51z\" fill=\"currentColor\" fill-rule=\"evenodd\"></path></svg>\n\t\t\t\t</button>\n\t\t\t  `;\n\n\t\t\t\t// Function to create a node list\n\t\t\t\t// of the content between this <h2> and the next\n\t\t\t\t/**\n\t\t\t\t * @param elem\n\t\t\t\t */\n\t\t\t\tconst getContent = elem => {\n\t\t\t\t\tlet elems = [];\n\t\t\t\t\twhile (\n\t\t\t\t\t\telem.nextElementSibling &&\n\t\t\t\t\t\telem.nextElementSibling.tagName !== 'H2'\n\t\t\t\t\t) {\n\t\t\t\t\t\telems.push( elem.nextElementSibling );\n\t\t\t\t\t\telem = elem.nextElementSibling;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Delete the old versions of the content nodes\n\t\t\t\t\telems.forEach( node => {\n\t\t\t\t\t\tnode.parentNode.removeChild( node );\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn elems;\n\t\t\t\t};\n\n\t\t\t\t// Assign the contents to be expanded/collapsed (array)\n\t\t\t\tlet contents = getContent( heading );\n\n\t\t\t\t// Create a wrapper element for `contents` and hide it\n\t\t\t\tlet wrapper = document.createElement( 'div' );\n\t\t\t\twrapper.hidden = true;\n\n\t\t\t\t// Add each element of `contents` to `wrapper`\n\t\t\t\tcontents.forEach( node => {\n\t\t\t\t\twrapper.appendChild( node );\n\t\t\t\t} );\n\n\t\t\t\t// Add the wrapped content back into the DOM\n\t\t\t\t// after the heading\n\t\t\t\theading.parentNode.insertBefore( wrapper, heading.nextElementSibling );\n\n\t\t\t\t// Assign the button\n\t\t\t\tlet btn = heading.querySelector( 'button' );\n\n\t\t\t\t/**\n\t\t\t\t *\n\t\t\t\t */\n\t\t\t\tbtn.onclick = () => {\n\t\t\t\t\t// Cast the state as a boolean\n\t\t\t\t\tlet expanded = btn.getAttribute( 'aria-expanded' ) === 'true' || false;\n\n\t\t\t\t\t// Switch the state\n\t\t\t\t\tbtn.setAttribute( 'aria-expanded', ! expanded );\n\t\t\t\t\t// Switch the content's visibility\n\t\t\t\t\twrapper.hidden = expanded;\n\t\t\t\t};\n\t\t\t} );\n\t\t} )();\n\n\t\t( function () {\n\t\t\t// Get all the <h3> headings\n\t\t\tconst headings = document.querySelectorAll( 'fieldset h3' );\n\n\t\t\tArray.prototype.forEach.call( headings, heading => {\n\t\t\t\t// Give each <h3> a toggle button child\n\t\t\t\theading.innerHTML = `\n\t\t\t\t<button type=\"button\" aria-expanded=\"false\">\n\t\t\t\t\t${ heading.innerHTML }\n\t\t\t\t\t<svg class=\"arrow\" width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.255 8L0 0h12.51z\" fill=\"currentColor\" fill-rule=\"evenodd\"></path></svg>\n\t\t\t\t</button>\n\t\t\t  `;\n\n\t\t\t\t// Function to create a node list\n\t\t\t\t// of the content between this <h2> and the next\n\t\t\t\t/**\n\t\t\t\t * @param elem\n\t\t\t\t */\n\t\t\t\tconst getContent = elem => {\n\t\t\t\t\tlet elems = [];\n\t\t\t\t\twhile (\n\t\t\t\t\t\telem.nextElementSibling &&\n\t\t\t\t\t\telem.nextElementSibling.tagName !== 'H3'\n\t\t\t\t\t) {\n\t\t\t\t\t\telems.push( elem.nextElementSibling );\n\t\t\t\t\t\telem = elem.nextElementSibling;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Delete the old versions of the content nodes\n\t\t\t\t\telems.forEach( node => {\n\t\t\t\t\t\tnode.parentNode.removeChild( node );\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn elems;\n\t\t\t\t};\n\n\t\t\t\t// Assign the contents to be expanded/collapsed (array)\n\t\t\t\tlet contents = getContent( heading );\n\n\t\t\t\t// Create a wrapper element for `contents` and hide it\n\t\t\t\tlet wrapper = document.createElement( 'div' );\n\t\t\t\twrapper.hidden = true;\n\n\t\t\t\t// Add each element of `contents` to `wrapper`\n\t\t\t\tcontents.forEach( node => {\n\t\t\t\t\twrapper.appendChild( node );\n\t\t\t\t} );\n\n\t\t\t\t// Add the wrapped content back into the DOM\n\t\t\t\t// after the heading\n\t\t\t\theading.parentNode.insertBefore( wrapper, heading.nextElementSibling );\n\n\t\t\t\t// Assign the button\n\t\t\t\tlet btn = heading.querySelector( 'button' );\n\n\t\t\t\t/**\n\t\t\t\t *\n\t\t\t\t */\n\t\t\t\tbtn.onclick = () => {\n\t\t\t\t\t// Cast the state as a boolean\n\t\t\t\t\tlet expanded = btn.getAttribute( 'aria-expanded' ) === 'true' || false;\n\n\t\t\t\t\t// Switch the state\n\t\t\t\t\tbtn.setAttribute( 'aria-expanded', ! expanded );\n\t\t\t\t\t// Switch the content's visibility\n\t\t\t\t\twrapper.hidden = expanded;\n\t\t\t\t};\n\t\t\t} );\n\t\t} )();\n\n\t\tjQuery( $ => {\n\t\t\tjQueryBridget( 'isotope', Isotope, $ );\n\t\t\tlet $grid = $( '.books' );\n\t\t\t$grid.isotope( {\n\t\t\t\titemSelector: '.book',\n\t\t\t\tgetSortData: {\n\t\t\t\t\ttitle: '.book__title a',\n\t\t\t\t\tsubject: '[data-subject]',\n\t\t\t\t\tlatest: '[data-date-published]',\n\t\t\t\t},\n\t\t\t\tsortAscending: {\n\t\t\t\t\ttitle: true,\n\t\t\t\t\tsubject: false,\n\t\t\t\t\tlatest: false,\n\t\t\t\t},\n\t\t\t} );\n\t\t\tlet licenses = document.querySelector( '.license-filters' );\n\t\t\tlet subjects = document.querySelector( '.subject-filters' );\n\t\t\tlet institutions = document.querySelector( '.institution-filters' );\n\t\t\tlet sorts = document.querySelector( '.sorts' );\n\t\t\tlet clearFilters = document.querySelector( '.clear-filters' );\n\t\t\tclearFilters.hidden = false;\n\t\t\tlicenses.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst subject = subjects.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-subject=\"${ subjects.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = institutions.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-institution*=\"${ institutions.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst license = event.target.value\n\t\t\t\t\t? `[data-license=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tinstitutions.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst subject = subjects.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-subject=\"${ subjects.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst license = licenses.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-license=\"${ licenses.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = event.target.value\n\t\t\t\t\t? `[data-institution*=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tsubjects.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst license = licenses.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-license=\"${ licenses.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = institutions.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-institution*=\"${ institutions.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst subject = event.target.value\n\t\t\t\t\t? `[data-subject=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tclearFilters.addEventListener( 'click', function () {\n\t\t\t\tlet allLicenses = document.getElementById( 'all-licenses' );\n\t\t\t\tlet allSubjects = document.getElementById( 'all-subjects' );\n\t\t\t\tlet allInstitutions = document.getElementById( 'all-institutions' );\n\t\t\t\tallLicenses.checked = true;\n\t\t\t\tallSubjects.checked = true;\n\t\t\t\tallInstitutions.checked = true;\n\t\t\t\t$grid.isotope( { filter: '*' } );\n\t\t\t} );\n\t\t\tsorts.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\t$grid.isotope( { sortBy: event.target.value } );\n\t\t\t} );\n\t\t\t// \t$('.filters > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\t$('.filters').toggleClass('is-active');\n\t\t\t// \t\t$('.filter-groups > div').removeClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.filter-groups .subjects > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet id = $(e.currentTarget).attr('href');\n\t\t\t// \t\t$(`.filter-groups .subjects:not(${id})`).removeClass('is-active');\n\t\t\t// \t\t$(`.filter-groups ${id}`).toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.licenses > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet id = $(e.currentTarget).attr('href');\n\t\t\t// \t\t$(id).toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.subjects .filter-list a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tif ($(e.currentTarget).hasClass('is-active')) {\n\t\t\t// \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$('.subjects').removeClass('has-active-child');\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t\t$('.subjects').removeClass('has-active-child');\n\t\t\t// \t\t\t$(e.currentTarget)\n\t\t\t// \t\t\t\t.parent()\n\t\t\t// \t\t\t\t.parent()\n\t\t\t// \t\t\t\t.parent('.subjects')\n\t\t\t// \t\t\t\t.addClass('has-active-child');\n\t\t\t// \t\t}\n\t\t\t// \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tif (typeof licenseValue === 'undefined') {\n\t\t\t// \t\t\tlicenseValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\tif (typeof subjectValue === 'undefined') {\n\t\t\t// \t\t\tsubjectValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n\t\t\t// \t});\n\t\t\t// \t$('.licenses .filter-list a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tif ($(e.currentTarget).hasClass('is-active')) {\n\t\t\t// \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$('.licenses').removeClass('has-active-child');\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t\t$('.licenses').addClass('has-active-child');\n\t\t\t// \t\t}\n\t\t\t// \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tif (typeof licenseValue === 'undefined') {\n\t\t\t// \t\t\tlicenseValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\tif (typeof subjectValue === 'undefined') {\n\t\t\t// \t\t\tsubjectValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n\t\t\t// \t});\n\t\t\t// \t$('.sort > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\t$('.sort').toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.sorts a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet sortBy = $(e.currentTarget).attr('data-sort');\n\t\t\t// \t\t$('.sorts a').removeClass('is-active');\n\t\t\t// \t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t$grid.isotope({ sortBy: sortBy });\n\t\t\t// \t});\n\t\t} );\n\t},\n\t/**\n\t *\n\t */\n\tfinalize() {},\n};\n"],"names":["Isotope","require","jQueryBridget","init","headings","document","querySelectorAll","Array","prototype","forEach","call","heading","innerHTML","textContent","getContent","elem","elems","nextElementSibling","tagName","push","node","parentNode","removeChild","contents","wrapper","createElement","hidden","appendChild","insertBefore","btn","querySelector","onclick","expanded","getAttribute","setAttribute","jQuery","$","$grid","isotope","itemSelector","getSortData","title","subject","latest","sortAscending","licenses","subjects","institutions","sorts","clearFilters","addEventListener","event","target","type","value","institution","license","filterValue","filter","allLicenses","getElementById","allSubjects","allInstitutions","checked","sortBy","finalize"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./assets/scripts/routes/catalog.js\n"); /***/ }), diff --git a/dist/scripts/aldine.js.LICENSE.txt b/dist/scripts/aldine.js.LICENSE.txt index aa91eb9..692dd6b 100644 --- a/dist/scripts/aldine.js.LICENSE.txt +++ b/dist/scripts/aldine.js.LICENSE.txt @@ -15,7 +15,7 @@ */ /*! - * Masonry v4.2.2 + * Masonry v4.2.1 * Cascading grid layout library * https://masonry.desandro.com * MIT License diff --git a/dist/styles/aldine.css b/dist/styles/aldine.css index 573f7de..cae2b0b 100644 --- a/dist/styles/aldine.css +++ b/dist/styles/aldine.css @@ -1840,6 +1840,104 @@ nav { } .book { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: start; + -ms-flex-pack: start; + justify-content: flex-start; + width: 100%; + max-width: 22.9375rem; + height: 24.125rem; + margin: 0 0 2rem; + padding: 1.5rem 1rem 2rem; + border: solid 2px var(--accent); + background: var(--accent); +} +@media screen and (min-width: 30rem) { + .book { + padding: 1.5rem 1.85rem 2.1875rem; + } +} +.book a, .book p { + font-family: "Karla", sans-serif; + color: var(--accent-fg); +} +.book a { + margin: 0; + text-decoration: none; + text-align: center; + -webkit-hyphens: auto; + -ms-hyphens: auto; + hyphens: auto; +} +.book__title { + margin: 0; + font-size: 1.25rem; + font-weight: 500; + line-height: 1.2; + text-align: left; +} +@media screen and (min-width: 30rem) { + .book__title { + font-size: 1.75rem; + } +} +.book__subject { + margin: 0; + font-size: 0.75rem; + text-align: left; +} +@media screen and (min-width: 30rem) { + .book__subject { + font-size: 1rem; + } +} +.book__institutions { + margin: 0.5rem 0 0; + font-size: 0.875rem; + text-align: left; + display: box; + overflow: hidden; + -webkit-line-clamp: 2; + -webkit-box-orient: vertical; +} +.book__read-more { + margin: auto 0 0; + font-size: 1rem; + text-align: left; +} +@media screen and (min-width: 30rem) { + .book__read-more { + font-size: 1.125rem; + } +} +.book__read-more a svg { + width: 1rem; + height: 1rem; + vertical-align: middle; +} +@media screen and (min-width: 30rem) { + .book__read-more a svg { + width: 1.125rem; + height: 1.125rem; + margin-left: 0.5rem; + } +} +.book:last-child { + margin-bottom: 0; +} +@media screen and (min-width: 60rem) { + .book:last-child { + margin-bottom: 2rem; + } +} + +.featured_book { display: -webkit-box; display: -ms-flexbox; display: flex; @@ -1856,13 +1954,13 @@ nav { border: solid 1px var(--accent); margin: 0 0 2rem; } -.book__cover { +.featured_book__cover { width: 100%; height: 80%; background-repeat: no-repeat; background-size: cover; } -.book a { +.featured_book a { margin: 0; text-decoration: none; text-align: center; @@ -1870,7 +1968,7 @@ nav { -ms-hyphens: auto; hyphens: auto; } -.book__title { +.featured_book__title { display: -webkit-box; display: -ms-flexbox; display: flex; @@ -2289,7 +2387,7 @@ body #content a.call-to-action { -ms-flex-pack: center; justify-content: center; } - .latest-books .books .book { + .latest-books .books .book, .latest-books .books .featured_book { margin-right: 1rem; margin-left: 1rem; } @@ -2312,24 +2410,24 @@ body #content a.call-to-action { text-align: center; } -fieldset { +.network-catalog fieldset { border-top: solid 2px var(--accent); font-family: "Karla", sans-serif; } -fieldset h2, -fieldset h3 { +.network-catalog fieldset h2, +.network-catalog fieldset h3 { margin-bottom: 0; font-size: 1rem; font-weight: bold; text-align: left; text-transform: none; } -fieldset h2::before, -fieldset h3::before { +.network-catalog fieldset h2::before, +.network-catalog fieldset h3::before { display: none; } -fieldset h2 button, -fieldset h3 button { +.network-catalog fieldset h2 button, +.network-catalog fieldset h3 button { display: -webkit-box; display: -ms-flexbox; display: flex; @@ -2346,36 +2444,36 @@ fieldset h3 button { margin: 0; border-top: 0; } -fieldset h2 button svg, -fieldset h3 button svg { +.network-catalog fieldset h2 button svg, +.network-catalog fieldset h3 button svg { display: block; float: right; margin-top: 0.5rem; } -fieldset h2 button:hover, fieldset h2 button:focus, -fieldset h3 button:hover, -fieldset h3 button:focus { +.network-catalog fieldset h2 button:hover, .network-catalog fieldset h2 button:focus, +.network-catalog fieldset h3 button:hover, +.network-catalog fieldset h3 button:focus { color: var(--primary); background: var(--bg-body); } -fieldset h2 button:active, -fieldset h3 button:active { +.network-catalog fieldset h2 button:active, +.network-catalog fieldset h3 button:active { -webkit-box-shadow: none; box-shadow: none; } -fieldset [aria-expanded=true] { +.network-catalog fieldset [aria-expanded=true] { color: var(--primary); } -fieldset [aria-expanded=true] svg { +.network-catalog fieldset [aria-expanded=true] svg { -webkit-transform: rotate(180deg); -o-transform: rotate(180deg); transform: rotate(180deg); } -fieldset h2 [aria-expanded=true] { +.network-catalog fieldset h2 [aria-expanded=true] { border-bottom: solid 2px var(--accent); background: var(--body-bg-alt); } -fieldset [type=radio] { +.network-catalog fieldset [type=radio] { position: absolute !important; width: 1px !important; height: 1px !important; @@ -2384,28 +2482,28 @@ fieldset [type=radio] { overflow: hidden !important; clip: rect(1px, 1px, 1px, 1px); } -fieldset .label { +.network-catalog fieldset .label { display: inline-block; width: calc(100% - 2rem); } -fieldset [type=radio] + label { +.network-catalog fieldset [type=radio] + label { cursor: pointer; display: block; padding: 1rem 1.1875rem; margin-bottom: 0; } -fieldset [type=radio] + label svg { +.network-catalog fieldset [type=radio] + label svg { display: none; } -fieldset [type=radio]:focus label { +.network-catalog fieldset [type=radio]:focus label { cursor: pointer; display: block; } -fieldset [type=radio]:checked + label { +.network-catalog fieldset [type=radio]:checked + label { color: var(--primary); font-weight: bold; } -fieldset [type=radio]:checked + label svg { +.network-catalog fieldset [type=radio]:checked + label svg { display: block; float: right; margin-top: 0.5rem; @@ -2413,7 +2511,7 @@ fieldset [type=radio]:checked + label svg { height: 1rem; fill: transparent; } -fieldset:last-of-type { +.network-catalog fieldset:last-of-type { border-bottom: solid 2px var(--accent); margin-bottom: 1rem; } @@ -2432,7 +2530,7 @@ fieldset:last-of-type { padding: 0; margin: 2rem 0 1rem 1rem; } -.page-template-page-catalog .book { +.page-template-page-catalog .book, .page-template-page-catalog .featured_book { height: 14.375rem; width: calc(50% - 1rem); margin: 0 1rem 1rem 0; diff --git a/inc/customizer/namespace.php b/inc/customizer/namespace.php index 241a538..b2a7385 100644 --- a/inc/customizer/namespace.php +++ b/inc/customizer/namespace.php @@ -209,6 +209,7 @@ function customize_register( \WP_Customize_Manager $wp_customize ) { $options = get_catalog_options(); $books = collect( $options['books'] )->pluck( 'title', 'id' )->toArray(); + $books = [ '' => __( 'Select a book', 'pressbooks-aldine' ) ] + $books; foreach ( range( 1, MAX_FEATURED_BOOKS ) as $i ) { $wp_customize->add_setting( diff --git a/inc/helpers/namespace.php b/inc/helpers/namespace.php index 0c9cf3f..9533865 100644 --- a/inc/helpers/namespace.php +++ b/inc/helpers/namespace.php @@ -70,8 +70,13 @@ function get_featured_books(): array { } } + if ( empty( $featured_books ) ) { + return []; + } + $args = [ 'site__in' => $featured_books, + 'sort_by_featured' => true, ]; return get_catalog_data( $args ); @@ -109,8 +114,114 @@ function get_catalog_data( array $args ): array { $books[] = $book; } } + // Sort by featured books. + if ( isset( $args['sort_by_featured'] ) ) { + usort( $books, function ( $a, $b ) use ( $args ) { + return array_search( $a['id'], $args['site__in'], true ) - array_search($b['id'], + $args['site__in'], true); + } ); + } + + return [ + 'books' => $books, + ]; +} + +/** + * Get paginated catalog data + * + * @param int $page Catalog page + * @param int $per_page Books per page + * @param string $orderby Sort order + * @param string $license Copyright license + * @param string $subject Subject + * + * @return array + */ +function get_paginated_catalog_data( $page = 1, $per_page = 10, $orderby = 'title', $license = '', $subject = '' ) { + + if ( ! defined( 'PB_PLUGIN_VERSION' ) ) { + return [ + 'pages' => 0, + 'books' => [], + ]; + } + + $dc = BookDataCollector::init(); + + /** + * Filter the WP_Site_Query args for the catalog display. + * + * @since 1.0.0 + */ + $args = apply_filters( + 'pb_aldine_catalog_query_args', + /** + * Deprecation notice + * + * @deprecated 1.0.0 + * + * @see Pressbooks Publisher + */ + apply_filters( + 'pb_publisher_catalog_query_args', + [ + 'number' => 1000000, + 'meta_key' => $dc::IN_CATALOG, // @codingStandardsIgnoreLine + 'meta_value' => 1, // @codingStandardsIgnoreLine + 'public' => 1, + 'archived' => 0, + 'spam' => 0, + 'deleted' => 0, + 'network_id' => get_network()->site_id, + ] + ) + ); + + /** + * WordPress site + * + * @var \WP_Site $site + */ + + $sites_in_catalog = []; + $sites = get_sites( $args ); + foreach ( $sites as $site ) { + $site->pb_title = $dc->get( $site->blog_id, $dc::TITLE ); + $sites_in_catalog[] = $site; + } + if ( $orderby === 'latest' ) { + $sites_in_catalog = wp_list_sort( $sites_in_catalog, 'last_updated', 'DESC' ); + } else { + $sites_in_catalog = wp_list_sort( $sites_in_catalog, 'pb_title', 'ASC' ); + } + + $total_pages = ceil( count( $sites_in_catalog ) / $per_page ); + $offset = ( $page - 1 ) * $per_page; + $books = []; + foreach ( $sites_in_catalog as $i => $site ) { + if ( $i < $offset ) { + continue; + } + + $book_information = $dc->get( $site->blog_id, $dc::BOOK_INFORMATION_ARRAY ); + if ( is_array( $book_information ) && ! empty( $book_information ) ) { + $schema = book_information_to_schema( $book_information ); + $book['title'] = $schema['name']; + $book['date-published'] = $schema['datePublished'] ?? ''; + $book['subject'] = $schema['about'][0]['identifier'] ?? ''; + $book['link'] = get_blogaddress_by_id( $site->blog_id ); + $book['metadata'] = $schema; + $books[] = $book; + } + + if ( count( $books ) >= $per_page ) { + break; + } + } return [ + 'pages' => $total_pages, 'books' => $books, ]; } diff --git a/languages/pressbooks-aldine.pot b/languages/pressbooks-aldine.pot index 0577f8e..a27ebfb 100644 --- a/languages/pressbooks-aldine.pot +++ b/languages/pressbooks-aldine.pot @@ -2,16 +2,16 @@ # This file is distributed under the GNU GPL v3 or later. msgid "" msgstr "" -"Project-Id-Version: Aldine 1.16.1\n" +"Project-Id-Version: Aldine 1.17.0\n" "Report-Msgid-Bugs-To: https://github.com/pressbooks/pressbooks-aldine/issues\n" "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n" "Language-Team: LANGUAGE <LL@li.org>\n" "MIME-Version: 1.0\n" "Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: 8bit\n" -"POT-Creation-Date: 2022-10-17T15:53:25+00:00\n" +"POT-Creation-Date: 2022-11-04T17:15:14+00:00\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" -"X-Generator: WP-CLI 2.7.0\n" +"X-Generator: WP-CLI 2.7.1\n" "X-Domain: pressbooks-aldine\n" #. Theme Name of the theme diff --git a/page-catalog.php b/page-catalog.php index 2610783..d94ebc4 100644 --- a/page-catalog.php +++ b/page-catalog.php @@ -18,15 +18,15 @@ use function Aldine\Helpers\get_available_institutions; use function Aldine\Helpers\get_available_licenses; use function Aldine\Helpers\get_available_subjects; use function Aldine\Helpers\get_catalog_licenses; -use function Aldine\Helpers\get_featured_books; use function Aldine\Helpers\get_institutions; +use function Aldine\Helpers\get_paginated_catalog_data; $current_page = ( get_query_var( 'paged' ) ) ? get_query_var( 'paged' ) : 1; $orderby = ( get_query_var( 'orderby' ) ) ? get_query_var( 'orderby' ) : 'title'; $subject = ( get_query_var( 'subject' ) ) ? get_query_var( 'subject' ) : ''; $license = ( get_query_var( 'license' ) ) ? get_query_var( 'license' ) : ''; $institution = get_query_var( 'institution' ) ?? ''; -$catalog_data = get_featured_books(); +$catalog_data = get_paginated_catalog_data(); $previous_page = ( $current_page > 1 ) ? $current_page - 1 : 0; $next_page = $current_page + 1; $licenses = get_catalog_licenses(); diff --git a/partials/book.php b/partials/book.php index 7dd6c58..01f05a9 100644 --- a/partials/book.php +++ b/partials/book.php @@ -6,10 +6,54 @@ */ use function \Aldine\Helpers\maybe_truncate_string; +use function \Pressbooks\Metadata\is_bisac; + +$subject = ( isset( $book['subject'] ) && ! is_bisac( $book['subject'] ) ) ? substr( $book['subject'], 0, 2 ) : ''; +$date = ( isset( $book['metadata']['datePublished'] ) ) ? str_replace( '-', '', $book['metadata']['datePublished'] ) : ''; +$institution_codes = array_map( static function ( $item ) { + return $item['code']; +}, $book['metadata']['institutions'] ?? [] ); +$institution_names = array_map( static function ( $item ) { + return \Pressbooks\Metadata\get_institution_name( $item['code'] ); +}, $book['metadata']['institutions'] ?? [] ); ?> -<div class="book"> - <div class="book__cover" style="background-image: url('<?php echo $book['metadata']['image']; ?>' );"></div> +<li class="book" + <?php + if ( $date ) { + ?> + data-date-published="<?php echo $date; ?>"<?php } ?> + data-license="<?php echo ( new \Pressbooks\Licensing() )->getLicenseFromUrl( $book['metadata']['license']['url'] ); ?>" + data-institution="<?php echo implode( ',', $institution_codes ); ?>" + <?php + if ( ! empty( $subject ) ) { + ?> + data-subject="<?php echo $subject ?>"<?php } ?> +> <p class="book__title"> <a href="<?php echo $book['link']; ?>"><?php echo maybe_truncate_string( $book['metadata']['name'] ); ?></a> </p> -</div> + <?php + /* + <?php if (isset( $book['metadata']['author'] ) ) { ?> + <p class="book__author"> + <?php _e( 'By', 'pressbooks-aldine' ); ?> <?php foreach ( $book['metadata']['author'] as $author ) { + echo $author['name']; + } ?> + </p> + <?php } ?> + */ + ?> + <?php if ( ! empty( $subject ) ) { ?> + <p class="book__subject"> + <a href="<?php echo network_home_url( "/catalog/#$subject" ) ?>"><?php echo \Pressbooks\Metadata\get_subject_from_thema( $book['subject'] ); ?></a> + </p> + <?php } ?> + <?php if ( $institution_names ) : ?> + <p class="book__institutions"> + <?php echo implode( ', ', $institution_names ); ?> + </p> + <?php endif; ?> + <p class="book__read-more"> + <a href="<?php echo $book['link']; ?>"><?php _e( 'About this book', 'pressbooks-aldine' ); ?> <svg aria-hidden="true"><use xlink:href="#arrow-right" /></svg></a> + </p> +</li> diff --git a/partials/content-front-page.php b/partials/content-front-page.php index 85bb0d6..f667307 100644 --- a/partials/content-front-page.php +++ b/partials/content-front-page.php @@ -56,7 +56,7 @@ if ( $catalog_page ) { <div class="books"> <?php foreach ( $catalog_data['books'] as $book ) : - include( locate_template( 'partials/book.php' ) ); + include( locate_template( 'partials/featured-book.php' ) ); endforeach; ?> </div> diff --git a/partials/content-page-catalog.php b/partials/content-page-catalog.php index 4d6b18e..97c4aa4 100644 --- a/partials/content-page-catalog.php +++ b/partials/content-page-catalog.php @@ -89,7 +89,7 @@ endforeach; ?> </ul> -<?php if ( isset($catalog_data['pages']) && $catalog_data['pages'] > 1 ) : ?> +<?php if ( isset( $catalog_data['pages'] ) && $catalog_data['pages'] > 1 ) : ?> <nav class="catalog-navigation"> <?php if ( $previous_page ) : diff --git a/partials/featured-book.php b/partials/featured-book.php new file mode 100644 index 0000000..09af159 --- /dev/null +++ b/partials/featured-book.php @@ -0,0 +1,15 @@ +<?php +/** + * Template for displaying books in network catalog + * + * @package Aldine + */ + +use function \Aldine\Helpers\maybe_truncate_string; +?> +<div class="featured_book"> + <div class="featured_book__cover" style="background-image: url('<?php echo $book['metadata']['image']; ?>' );"></div> + <p class="featured_book__title"> + <a href="<?php echo $book['link']; ?>"><?php echo maybe_truncate_string( $book['metadata']['name'] ); ?></a> + </p> +</div>