@ministryofjustice/frontend 7.0.0 → 8.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (28) hide show
  1. package/moj/all.bundle.js +15 -7
  2. package/moj/all.bundle.js.map +1 -1
  3. package/moj/all.bundle.mjs +15 -7
  4. package/moj/all.bundle.mjs.map +1 -1
  5. package/moj/common/moj-frontend-version.mjs +1 -1
  6. package/moj/components/date-picker/date-picker.bundle.js +2 -4
  7. package/moj/components/date-picker/date-picker.bundle.js.map +1 -1
  8. package/moj/components/date-picker/date-picker.bundle.mjs +2 -4
  9. package/moj/components/date-picker/date-picker.bundle.mjs.map +1 -1
  10. package/moj/components/date-picker/date-picker.mjs +2 -4
  11. package/moj/components/date-picker/date-picker.mjs.map +1 -1
  12. package/moj/components/domain-specific/probation/header/README.md +20 -1
  13. package/moj/components/domain-specific/probation/header/_header.scss +2 -1
  14. package/moj/components/domain-specific/probation/header/_header.scss.map +1 -1
  15. package/moj/components/domain-specific/probation/header/header.bundle.js +12 -2
  16. package/moj/components/domain-specific/probation/header/header.bundle.js.map +1 -1
  17. package/moj/components/domain-specific/probation/header/header.bundle.mjs +12 -2
  18. package/moj/components/domain-specific/probation/header/header.bundle.mjs.map +1 -1
  19. package/moj/components/domain-specific/probation/header/header.mjs +12 -2
  20. package/moj/components/domain-specific/probation/header/header.mjs.map +1 -1
  21. package/moj/components/domain-specific/probation/header/template.njk +37 -0
  22. package/moj/core/_moj-frontend-properties.scss +1 -1
  23. package/moj/core/_moj-frontend-properties.scss.map +1 -1
  24. package/moj/moj-frontend.min.css +1 -1
  25. package/moj/moj-frontend.min.css.map +1 -1
  26. package/moj/moj-frontend.min.js +1 -1
  27. package/moj/moj-frontend.min.js.map +1 -1
  28. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"file":"date-picker.mjs","sources":["../../../../src/moj/components/date-picker/date-picker.mjs"],"sourcesContent":["import { ConfigurableComponent } from 'govuk-frontend'\n\n/**\n * @augments {ConfigurableComponent<DatePickerConfig>}\n */\nexport class DatePicker extends ConfigurableComponent {\n /**\n * @param {Element | null} $root - HTML element to use for date picker\n * @param {DatePickerConfig} [config] - Date picker config\n */\n constructor($root, config = {}) {\n super($root, config)\n\n const $input =\n this.config.input.element ??\n this.$root.querySelector(this.config.input.selector)\n\n if (!$input || !($input instanceof HTMLInputElement)) {\n return this\n }\n\n this.$input = $input\n\n this.dayLabels = [\n 'Monday',\n 'Tuesday',\n 'Wednesday',\n 'Thursday',\n 'Friday',\n 'Saturday',\n 'Sunday'\n ]\n\n this.monthLabels = [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December'\n ]\n\n this.currentDate = new Date()\n this.currentDate.setHours(0, 0, 0, 0)\n this.calendarDays = /** @type {DSCalendarDay[]} */ ([])\n this.excludedDates = /** @type {Date[]} */ ([])\n this.excludedDays = /** @type {number[]} */ ([])\n\n this.buttonClass = 'moj-datepicker__button'\n this.selectedDayButtonClass = 'moj-datepicker__button--selected'\n this.currentDayButtonClass = 'moj-datepicker__button--current'\n this.todayButtonClass = 'moj-datepicker__button--today'\n\n this.setOptions()\n this.initControls()\n }\n\n initControls() {\n this.id = `datepicker-${this.$input.id}`\n\n this.$dialog = this.createDialog()\n this.createCalendarHeaders()\n\n const $componentWrapper = document.createElement('div')\n const $inputWrapper = document.createElement('div')\n $componentWrapper.classList.add('moj-datepicker__wrapper')\n $inputWrapper.classList.add('govuk-input__wrapper')\n\n this.$input.parentElement.insertBefore($componentWrapper, this.$input)\n $componentWrapper.appendChild($inputWrapper)\n $inputWrapper.appendChild(this.$input)\n\n $inputWrapper.insertAdjacentHTML('beforeend', this.toggleTemplate())\n $componentWrapper.insertAdjacentElement('beforeend', this.$dialog)\n\n this.$calendarButton = /** @type {HTMLButtonElement} */ (\n this.$root.querySelector('.moj-js-datepicker-toggle')\n )\n\n this.$dialogTitle = /** @type {HTMLHeadingElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-month-year')\n )\n\n this.createCalendar()\n\n this.$prevMonthButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-prev-month')\n )\n\n this.$prevYearButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-prev-year')\n )\n\n this.$nextMonthButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-next-month')\n )\n\n this.$nextYearButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-next-year')\n )\n\n this.$cancelButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-cancel')\n )\n\n this.$okButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-ok')\n )\n\n // add event listeners\n this.$prevMonthButton.addEventListener('click', (event) =>\n this.focusPreviousMonth(event, false)\n )\n this.$prevYearButton.addEventListener('click', (event) =>\n this.focusPreviousYear(event, false)\n )\n this.$nextMonthButton.addEventListener('click', (event) =>\n this.focusNextMonth(event, false)\n )\n this.$nextYearButton.addEventListener('click', (event) =>\n this.focusNextYear(event, false)\n )\n this.$cancelButton.addEventListener('click', (event) => {\n event.preventDefault()\n this.closeDialog()\n })\n this.$okButton.addEventListener('click', () => {\n this.selectDate(this.currentDate)\n })\n\n const $dialogButtons = this.$dialog.querySelectorAll(\n 'button:not([disabled=\"true\"])'\n )\n\n this.$firstButtonInDialog = $dialogButtons[0]\n this.$lastButtonInDialog = $dialogButtons[$dialogButtons.length - 1]\n this.$firstButtonInDialog.addEventListener('keydown', (event) =>\n this.firstButtonKeydown(event)\n )\n this.$lastButtonInDialog.addEventListener('keydown', (event) =>\n this.lastButtonKeydown(event)\n )\n\n this.$calendarButton.addEventListener('click', (event) =>\n this.toggleDialog(event)\n )\n\n this.$dialog.addEventListener('keydown', (event) => {\n if (event.key === 'Escape') {\n this.closeDialog()\n event.preventDefault()\n event.stopPropagation()\n }\n })\n\n document.body.addEventListener('mouseup', (event) => {\n this.backgroundClick(event)\n })\n\n // populates calendar with initial dates, avoids Wave errors about null buttons\n this.updateCalendar()\n }\n\n createDialog() {\n const titleId = `datepicker-title-${this.$input.id}`\n const $dialog = document.createElement('div')\n\n $dialog.id = this.id\n $dialog.setAttribute('class', 'moj-datepicker__dialog')\n $dialog.setAttribute('role', 'dialog')\n $dialog.setAttribute('aria-modal', 'true')\n $dialog.setAttribute('aria-labelledby', titleId)\n $dialog.innerHTML = this.dialogTemplate(titleId)\n $dialog.hidden = true\n\n return $dialog\n }\n\n createCalendar() {\n const $tbody = this.$dialog.querySelector('tbody')\n let dayCount = 0\n for (let i = 0; i < 6; i++) {\n // create row\n const $row = $tbody.insertRow(i)\n\n for (let j = 0; j < 7; j++) {\n // create cell (day)\n const $cell = document.createElement('td')\n $row.appendChild($cell)\n const $dateButton = document.createElement('button')\n $dateButton.setAttribute('type', 'button')\n $cell.appendChild($dateButton)\n\n const calendarDay = new DSCalendarDay($dateButton, dayCount, i, j, this)\n this.calendarDays.push(calendarDay)\n dayCount++\n }\n }\n }\n\n toggleTemplate() {\n return `<button class=\"moj-datepicker__toggle moj-js-datepicker-toggle\" type=\"button\" aria-haspopup=\"dialog\" aria-controls=\"${this.id}\" aria-expanded=\"false\">\n <span class=\"govuk-visually-hidden\">Choose date</span>\n <svg width=\"32\" height=\"24\" focusable=\"false\" class=\"moj-datepicker-icon\" aria-hidden=\"true\" role=\"img\" viewBox=\"0 0 22 22\">\n <path\n fill=\"currentColor\"\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M16.1333 2.93333H5.86668V4.4C5.86668 5.21002 5.21003 5.86667 4.40002 5.86667C3.59 5.86667 2.93335 5.21002 2.93335 4.4V2.93333H2C0.895431 2.93333 0 3.82877 0 4.93334V19.2667C0 20.3712 0.89543 21.2667 2 21.2667H20C21.1046 21.2667 22 20.3712 22 19.2667V4.93333C22 3.82876 21.1046 2.93333 20 2.93333H19.0667V4.4C19.0667 5.21002 18.41 5.86667 17.6 5.86667C16.79 5.86667 16.1333 5.21002 16.1333 4.4V2.93333ZM20.5333 8.06667H1.46665V18.8C1.46665 19.3523 1.91436 19.8 2.46665 19.8H19.5333C20.0856 19.8 20.5333 19.3523 20.5333 18.8V8.06667Z\"\n ></path>\n <rect x=\"3.66669\" width=\"1.46667\" height=\"5.13333\" rx=\"0.733333\" fill=\"currentColor\"></rect>\n <rect x=\"16.8667\" width=\"1.46667\" height=\"5.13333\" rx=\"0.733333\" fill=\"currentColor\"></rect>\n </svg>\n </button>`\n }\n\n /**\n * HTML template for calendar dialog\n *\n * @param {string} [titleId] - Id attribute for dialog title\n * @returns {string}\n */\n dialogTemplate(titleId) {\n return `<div class=\"moj-datepicker__dialog-header\">\n <div class=\"moj-datepicker__dialog-navbuttons\">\n <button type=\"button\" class=\"moj-datepicker__button moj-js-datepicker-prev-year\">\n <span class=\"govuk-visually-hidden\">Previous year</span>\n <svg width=\"44\" height=\"40\" viewBox=\"0 0 44 40\" fill=\"none\" fill=\"none\" focusable=\"false\" aria-hidden=\"true\" role=\"img\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M23.1643 20L28.9572 14.2071L27.5429 12.7929L20.3358 20L27.5429 27.2071L28.9572 25.7929L23.1643 20Z\" fill=\"currentColor\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M17.1643 20L22.9572 14.2071L21.5429 12.7929L14.3358 20L21.5429 27.2071L22.9572 25.7929L17.1643 20Z\" fill=\"currentColor\"/>\n </svg>\n </button>\n\n <button type=\"button\" class=\"moj-datepicker__button moj-js-datepicker-prev-month\">\n <span class=\"govuk-visually-hidden\">Previous month</span>\n <svg width=\"44\" height=\"40\" viewBox=\"0 0 44 40\" fill=\"none\" focusable=\"false\" aria-hidden=\"true\" role=\"img\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M20.5729 20L25.7865 14.2071L24.5137 12.7929L18.0273 20L24.5137 27.2071L25.7865 25.7929L20.5729 20Z\" fill=\"currentColor\"/>\n </svg>\n </button>\n </div>\n\n <h2 id=\"${titleId}\" class=\"moj-datepicker__dialog-title moj-js-datepicker-month-year\" aria-live=\"polite\">June 2020</h2>\n\n <div class=\"moj-datepicker__dialog-navbuttons\">\n <button type=\"button\" class=\"moj-datepicker__button moj-js-datepicker-next-month\">\n <span class=\"govuk-visually-hidden\">Next month</span>\n <svg width=\"44\" height=\"40\" viewBox=\"0 0 44 40\" fill=\"none\" focusable=\"false\" aria-hidden=\"true\" role=\"img\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M23.4271 20L18.2135 14.2071L19.4863 12.7929L25.9727 20L19.4863 27.2071L18.2135 25.7929L23.4271 20Z\" fill=\"currentColor\"/>\n </svg>\n </button>\n\n <button type=\"button\" class=\"moj-datepicker__button moj-js-datepicker-next-year\">\n <span class=\"govuk-visually-hidden\">Next year</span>\n <svg width=\"44\" height=\"40\" viewBox=\"0 0 44 40\" fill=\"none\" fill=\"none\" focusable=\"false\" aria-hidden=\"true\" role=\"img\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M20.8357 20L15.0428 14.2071L16.4571 12.7929L23.6642 20L16.4571 27.2071L15.0428 25.7929L20.8357 20Z\" fill=\"currentColor\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M26.8357 20L21.0428 14.2071L22.4571 12.7929L29.6642 20L22.4571 27.2071L21.0428 25.7929L26.8357 20Z\" fill=\"currentColor\"/>\n </svg>\n </button>\n </div>\n </div>\n\n <table class=\"moj-datepicker__calendar moj-js-datepicker-grid\" role=\"application\" aria-labelledby=\"${titleId}\">\n <thead>\n <tr></tr>\n </thead>\n\n <tbody></tbody>\n </table>\n\n <div class=\"govuk-button-group\">\n <button type=\"button\" class=\"govuk-button moj-js-datepicker-ok\">Select</button>\n <button type=\"button\" class=\"govuk-button govuk-button--secondary moj-js-datepicker-cancel\">Close</button>\n </div>`\n }\n\n createCalendarHeaders() {\n this.dayLabels.forEach((day) => {\n const html = `<th scope=\"col\"><span aria-hidden=\"true\">${day.substring(0, 3)}</span><span class=\"govuk-visually-hidden\">${day}</span></th>`\n const $headerRow = this.$dialog.querySelector('thead > tr')\n $headerRow.insertAdjacentHTML('beforeend', html)\n })\n }\n\n /**\n * Pads given number with leading zeros\n *\n * @param {number} value - The value to be padded\n * @param {number} length - The length in characters of the output\n * @returns {string}\n */\n leadingZeros(value, length = 2) {\n let ret = value.toString()\n\n while (ret.length < length) {\n ret = `0${ret}`\n }\n\n return ret\n }\n\n setOptions() {\n this.setMinAndMaxDatesOnCalendar()\n this.setExcludedDates()\n this.setExcludedDays()\n this.setWeekStartDay()\n }\n\n setMinAndMaxDatesOnCalendar() {\n if (this.config.minDate) {\n this.minDate = this.formattedDateFromString(this.config.minDate, null)\n if (this.minDate && this.currentDate < this.minDate) {\n this.currentDate = this.minDate\n }\n }\n\n if (this.config.maxDate) {\n this.maxDate = this.formattedDateFromString(this.config.maxDate, null)\n if (this.maxDate && this.currentDate > this.maxDate) {\n this.currentDate = this.maxDate\n }\n }\n }\n\n setExcludedDates() {\n if (this.config.excludedDates) {\n this.excludedDates = this.config.excludedDates\n .replace(/\\s+/, ' ')\n .split(' ')\n .map((item) => {\n return item.includes('-')\n ? this.parseDateRangeString(item)\n : [this.formattedDateFromString(item)]\n })\n .reduce((dates, items) => dates.concat(items))\n .filter((date) => date)\n }\n }\n\n /**\n * Parses a daterange string into an array of dates\n *\n * @param {string} datestring - A daterange string in the format \"dd/mm/yyyy-dd/mm/yyyy\"\n */\n parseDateRangeString(datestring) {\n const dates = []\n const [startDate, endDate] = datestring\n .split('-')\n .map((d) => this.formattedDateFromString(d, null))\n\n if (startDate && endDate) {\n const date = new Date(startDate.getTime())\n /* eslint-disable no-unmodified-loop-condition */\n while (date <= endDate) {\n dates.push(new Date(date))\n date.setDate(date.getDate() + 1)\n }\n /* eslint-enable no-unmodified-loop-condition */\n }\n return dates\n }\n\n setExcludedDays() {\n if (this.config.excludedDays) {\n // lowercase and arrange dayLabels to put indexOf sunday == 0 for comparison\n // with getDay() function\n const weekDays = this.dayLabels.map((item) => item.toLowerCase())\n if (this.config.weekStartDay === 'monday') {\n weekDays.unshift(weekDays.pop())\n }\n\n this.excludedDays = this.config.excludedDays\n .replace(/\\s+/, ' ')\n .toLowerCase()\n .split(' ')\n .map((item) => weekDays.indexOf(item))\n .filter((item) => item !== -1)\n }\n }\n\n setWeekStartDay() {\n const weekStartDayParam = this.config.weekStartDay\n if (weekStartDayParam && weekStartDayParam.toLowerCase() === 'sunday') {\n this.config.weekStartDay = 'sunday'\n // Rotate dayLabels array to put Sunday as the first item\n this.dayLabels.unshift(this.dayLabels.pop())\n } else {\n this.config.weekStartDay = 'monday'\n }\n }\n\n /**\n * Determine if a date is selectable\n *\n * @param {Date} date - the date to check\n * @returns {boolean}\n */\n isExcludedDate(date) {\n // This comparison does not work correctly - it will exclude the mindate itself\n // see: https://github.com/ministryofjustice/moj-frontend/issues/923\n if (this.minDate && this.minDate > date) {\n return true\n }\n\n // This comparison works as expected - the maxdate will not be excluded\n if (this.maxDate && this.maxDate < date) {\n return true\n }\n\n for (const excludedDate of this.excludedDates) {\n if (date.toDateString() === excludedDate.toDateString()) {\n return true\n }\n }\n\n if (this.excludedDays.includes(date.getDay())) {\n return true\n }\n\n return false\n }\n\n /**\n * Get a Date object from a string\n *\n * @param {string} dateString - string in the format d/m/yyyy dd/mm/yyyy\n * @param {Date} fallback - date object to return if formatting fails\n * @returns {Date}\n */\n formattedDateFromString(dateString, fallback = new Date()) {\n let formattedDate = null\n // Accepts d/m/yyyy and dd/mm/yyyy\n const dateFormatPattern = /(\\d{1,2})([-/,. ])(\\d{1,2})\\2(\\d{4})/\n\n if (!dateFormatPattern.test(dateString)) return fallback\n\n const match = dateFormatPattern.exec(dateString)\n const day = match[1]\n const month = match[3]\n const year = match[4]\n\n formattedDate = new Date(Number(year), Number(month) - 1, Number(day))\n if (\n formattedDate instanceof Date &&\n Number.isFinite(formattedDate.getTime())\n ) {\n return formattedDate\n }\n return fallback\n }\n\n /**\n * Get a formatted date string from a Date object\n *\n * @param {Date} date - date to format to a string\n * @returns {string}\n */\n formattedDateFromDate(date) {\n if (this.config.leadingZeros) {\n return `${this.leadingZeros(date.getDate())}/${this.leadingZeros(date.getMonth() + 1)}/${date.getFullYear()}`\n }\n\n return `${date.getDate()}/${date.getMonth() + 1}/${date.getFullYear()}`\n }\n\n /**\n * Get a human readable date in the format Monday 2 March 2024\n *\n * @param {Date} date - Date to format\n * @returns {string}\n */\n formattedDateHuman(date) {\n return `${this.dayLabels[(date.getDay() + 6) % 7]} ${date.getDate()} ${this.monthLabels[date.getMonth()]} ${date.getFullYear()}`\n }\n\n /**\n * @param {MouseEvent} event - Click event\n */\n backgroundClick(event) {\n if (\n this.isOpen() &&\n event.target instanceof Node &&\n !this.$dialog.contains(event.target) &&\n !this.$input.contains(event.target) &&\n !this.$calendarButton.contains(event.target)\n ) {\n event.preventDefault()\n this.closeDialog()\n }\n }\n\n /**\n * @param {KeyboardEvent} event - Keydown event\n */\n firstButtonKeydown(event) {\n if (event.key === 'Tab' && event.shiftKey) {\n this.$lastButtonInDialog.focus()\n event.preventDefault()\n }\n }\n\n /**\n * @param {KeyboardEvent} event - Keydown event\n */\n lastButtonKeydown(event) {\n if (event.key === 'Tab' && !event.shiftKey) {\n this.$firstButtonInDialog.focus()\n event.preventDefault()\n }\n }\n\n // render calendar\n updateCalendar() {\n this.$dialogTitle.innerHTML = `${this.monthLabels[this.currentDate.getMonth()]} ${this.currentDate.getFullYear()}`\n\n const day = this.currentDate\n const firstOfMonth = new Date(day.getFullYear(), day.getMonth(), 1)\n let dayOfWeek\n\n if (this.config.weekStartDay === 'monday') {\n dayOfWeek = firstOfMonth.getDay() === 0 ? 6 : firstOfMonth.getDay() - 1 // Change logic to make Monday first day of week, i.e. 0\n } else {\n dayOfWeek = firstOfMonth.getDay()\n }\n\n firstOfMonth.setDate(firstOfMonth.getDate() - dayOfWeek)\n\n const thisDay = new Date(firstOfMonth)\n\n // loop through our days\n for (const calendarDay of this.calendarDays) {\n const hidden = thisDay.getMonth() !== day.getMonth()\n const disabled = this.isExcludedDate(thisDay)\n\n calendarDay.update(thisDay, hidden, disabled)\n\n thisDay.setDate(thisDay.getDate() + 1)\n }\n }\n\n /**\n * @param {boolean} [focus] - Focus the day button\n */\n setCurrentDate(focus = true) {\n const { currentDate } = this\n this.calendarDays.forEach((calendarDay) => {\n calendarDay.$button.classList.add('moj-datepicker__button')\n calendarDay.$button.classList.add('moj-datepicker__calendar-day')\n calendarDay.$button.setAttribute('tabindex', '-1')\n calendarDay.$button.classList.remove(this.selectedDayButtonClass)\n const calendarDayDate = calendarDay.date\n calendarDayDate.setHours(0, 0, 0, 0)\n\n const today = new Date()\n today.setHours(0, 0, 0, 0)\n\n if (\n calendarDayDate.getTime() ===\n currentDate.getTime() /* && !calendarDay.button.disabled */\n ) {\n if (focus) {\n calendarDay.$button.setAttribute('tabindex', '0')\n calendarDay.$button.focus()\n calendarDay.$button.classList.add(this.selectedDayButtonClass)\n }\n }\n\n if (\n this.inputDate &&\n calendarDayDate.getTime() === this.inputDate.getTime()\n ) {\n calendarDay.$button.classList.add(this.currentDayButtonClass)\n calendarDay.$button.setAttribute('aria-current', 'date')\n } else {\n calendarDay.$button.classList.remove(this.currentDayButtonClass)\n calendarDay.$button.removeAttribute('aria-current')\n }\n\n if (calendarDayDate.getTime() === today.getTime()) {\n calendarDay.$button.classList.add(this.todayButtonClass)\n } else {\n calendarDay.$button.classList.remove(this.todayButtonClass)\n }\n })\n\n // if no date is tab-able, make the first non-disabled date tab-able\n if (!focus) {\n const enabledDays = this.calendarDays.filter((calendarDay) => {\n return (\n window.getComputedStyle(calendarDay.$button).display === 'block' &&\n !calendarDay.$button.disabled\n )\n })\n\n enabledDays[0].$button.setAttribute('tabindex', '0')\n\n this.currentDate = enabledDays[0].date\n }\n }\n\n /**\n * @param {Date} date - Date to select\n */\n selectDate(date) {\n if (this.isExcludedDate(date)) {\n return\n }\n\n this.$calendarButton.querySelector('span').innerText =\n `Choose date. Selected date is ${this.formattedDateHuman(date)}`\n this.$input.value = this.formattedDateFromDate(date)\n\n const changeEvent = new Event('change', { bubbles: true, cancelable: true })\n this.$input.dispatchEvent(changeEvent)\n\n this.closeDialog()\n }\n\n isOpen() {\n return this.$dialog.classList.contains('moj-datepicker__dialog--open')\n }\n\n /**\n * @param {MouseEvent} event - Click event\n */\n toggleDialog(event) {\n event.preventDefault()\n if (this.isOpen()) {\n this.closeDialog()\n } else {\n this.setMinAndMaxDatesOnCalendar()\n this.openDialog()\n }\n }\n\n openDialog() {\n this.$dialog.hidden = false\n this.$dialog.classList.add('moj-datepicker__dialog--open')\n this.$calendarButton.setAttribute('aria-expanded', 'true')\n\n // position the dialog\n // if input is wider than dialog pin it to the right\n if (this.$input.offsetWidth > this.$dialog.offsetWidth) {\n this.$dialog.style.right = `0px`\n }\n this.$dialog.style.top = `${this.$input.offsetHeight + 3}px`\n\n // get the date from the input element\n this.inputDate = this.formattedDateFromString(this.$input.value)\n // move current date to the closest selectable date if it is out of range\n if (this.minDate && this.minDate > this.inputDate) {\n this.inputDate = new Date(this.minDate.getTime())\n }\n if (this.maxDate && this.maxDate < this.inputDate) {\n this.inputDate = new Date(this.maxDate.getTime())\n }\n if (this.minDate && this.maxDate && this.minDate > this.maxDate) {\n console.error('min date is after max date. No dates will be selectable')\n }\n\n this.currentDate = this.inputDate\n this.currentDate.setHours(0, 0, 0, 0)\n\n this.updateCalendar()\n this.setCurrentDate()\n }\n\n closeDialog() {\n this.$dialog.hidden = true\n this.$dialog.classList.remove('moj-datepicker__dialog--open')\n this.$calendarButton.setAttribute('aria-expanded', 'false')\n this.$calendarButton.focus()\n }\n\n /**\n * @param {Date} date - Date to go to\n * @param {boolean} [focus] - Focus the day button\n */\n goToDate(date, focus) {\n const current = this.currentDate\n this.currentDate = date\n\n if (\n current.getMonth() !== this.currentDate.getMonth() ||\n current.getFullYear() !== this.currentDate.getFullYear()\n ) {\n this.updateCalendar()\n }\n\n this.setCurrentDate(focus)\n }\n\n // day navigation\n focusNextDay() {\n const date = new Date(this.currentDate)\n date.setDate(date.getDate() + 1)\n this.goToDate(date)\n }\n\n focusPreviousDay() {\n const date = new Date(this.currentDate)\n date.setDate(date.getDate() - 1)\n this.goToDate(date)\n }\n\n // week navigation\n focusNextWeek() {\n const date = new Date(this.currentDate)\n date.setDate(date.getDate() + 7)\n this.goToDate(date)\n }\n\n focusPreviousWeek() {\n const date = new Date(this.currentDate)\n date.setDate(date.getDate() - 7)\n this.goToDate(date)\n }\n\n focusFirstDayOfWeek() {\n const date = new Date(this.currentDate)\n const firstDayOfWeekIndex = this.config.weekStartDay === 'sunday' ? 0 : 1\n const dayOfWeek = date.getDay()\n const diff =\n dayOfWeek >= firstDayOfWeekIndex\n ? dayOfWeek - firstDayOfWeekIndex\n : 6 - dayOfWeek\n\n date.setDate(date.getDate() - diff)\n date.setHours(0, 0, 0, 0)\n\n this.goToDate(date)\n }\n\n focusLastDayOfWeek() {\n const date = new Date(this.currentDate)\n const lastDayOfWeekIndex = this.config.weekStartDay === 'sunday' ? 6 : 0\n const dayOfWeek = date.getDay()\n const diff =\n dayOfWeek <= lastDayOfWeekIndex\n ? lastDayOfWeekIndex - dayOfWeek\n : 7 - dayOfWeek\n\n date.setDate(date.getDate() + diff)\n date.setHours(0, 0, 0, 0)\n\n this.goToDate(date)\n }\n\n /**\n * Month navigation\n *\n * @param {KeyboardEvent | MouseEvent} event - Key press or click event\n * @param {boolean} [focus] - Focus the day button\n */\n focusNextMonth(event, focus = true) {\n event.preventDefault()\n const date = new Date(this.currentDate)\n date.setMonth(date.getMonth() + 1, 1)\n this.goToDate(date, focus)\n }\n\n /**\n * @param {KeyboardEvent | MouseEvent} event - Key press or click event\n * @param {boolean} [focus] - Focus the day button\n */\n focusPreviousMonth(event, focus = true) {\n event.preventDefault()\n const date = new Date(this.currentDate)\n date.setMonth(date.getMonth() - 1, 1)\n this.goToDate(date, focus)\n }\n\n /**\n * Year navigation\n *\n * @param {KeyboardEvent | MouseEvent} event - Key press or click event\n * @param {boolean} [focus] - Focus the day button\n */\n focusNextYear(event, focus = true) {\n event.preventDefault()\n const date = new Date(this.currentDate)\n date.setFullYear(date.getFullYear() + 1, date.getMonth(), 1)\n this.goToDate(date, focus)\n }\n\n /**\n * @param {KeyboardEvent | MouseEvent} event - Key press or click event\n * @param {boolean} [focus] - Focus the day button\n */\n focusPreviousYear(event, focus = true) {\n event.preventDefault()\n const date = new Date(this.currentDate)\n date.setFullYear(date.getFullYear() - 1, date.getMonth(), 1)\n this.goToDate(date, focus)\n }\n\n /**\n * Name for the component used when initialising using data-module attributes.\n */\n static moduleName = 'moj-date-picker'\n\n /**\n * Date picker default config\n *\n * @type {DatePickerConfig}\n */\n static defaults = Object.freeze({\n leadingZeros: false,\n weekStartDay: 'monday',\n input: {\n selector: '.moj-js-datepicker-input'\n }\n })\n\n /**\n * Date picker config schema\n *\n * @satisfies {Schema<DatePickerConfig>}\n */\n static schema = Object.freeze(\n /** @type {const} */ ({\n properties: {\n excludedDates: { type: 'string' },\n excludedDays: { type: 'string' },\n leadingZeros: { type: 'boolean' },\n maxDate: { type: 'string' },\n minDate: { type: 'string' },\n weekStartDay: { type: 'string' },\n input: { type: 'object' }\n }\n })\n )\n}\n\nclass DSCalendarDay {\n /**\n *\n * @param {HTMLButtonElement} $button\n * @param {number} index\n * @param {number} row\n * @param {number} column\n * @param {DatePicker} picker\n */\n constructor($button, index, row, column, picker) {\n this.index = index\n this.row = row\n this.column = column\n this.$button = $button\n this.picker = picker\n this.date = new Date()\n this.$button.addEventListener('keydown', this.keyPress.bind(this))\n this.$button.addEventListener('click', this.click.bind(this))\n }\n\n /**\n * @param {Date} day - the Date for the calendar day\n * @param {boolean} hidden - visibility of the day\n * @param {boolean} disabled - is the day selectable or excluded\n */\n update(day, hidden, disabled) {\n const label = day.getDate()\n let accessibleLabel = this.picker.formattedDateHuman(day)\n\n if (disabled) {\n this.$button.setAttribute('aria-disabled', 'true')\n accessibleLabel = `Excluded date, ${accessibleLabel}`\n } else {\n this.$button.removeAttribute('aria-disabled')\n }\n\n if (hidden) {\n this.$button.style.display = 'none'\n } else {\n this.$button.style.display = 'block'\n }\n this.$button.setAttribute(\n 'data-testid',\n this.picker.formattedDateFromDate(day)\n )\n\n this.$button.innerHTML = `<span class=\"govuk-visually-hidden\">${accessibleLabel}</span><span aria-hidden=\"true\">${label}</span>`\n this.date = new Date(day)\n }\n\n /**\n * @param {MouseEvent} event - Click event\n */\n click(event) {\n this.picker.goToDate(this.date)\n this.picker.selectDate(this.date)\n\n event.stopPropagation()\n event.preventDefault()\n }\n\n /**\n * @param {KeyboardEvent} event - Keydown event\n */\n keyPress(event) {\n let calendarNavKey = true\n\n switch (event.key) {\n case 'ArrowLeft':\n this.picker.focusPreviousDay()\n break\n case 'ArrowRight':\n this.picker.focusNextDay()\n break\n case 'ArrowUp':\n this.picker.focusPreviousWeek()\n break\n case 'ArrowDown':\n this.picker.focusNextWeek()\n break\n case 'Home':\n this.picker.focusFirstDayOfWeek()\n break\n case 'End':\n this.picker.focusLastDayOfWeek()\n break\n case 'PageUp': {\n if (event.shiftKey) {\n this.picker.focusPreviousYear(event)\n } else {\n this.picker.focusPreviousMonth(event)\n }\n break\n }\n case 'PageDown': {\n if (event.shiftKey) {\n this.picker.focusNextYear(event)\n } else {\n this.picker.focusNextMonth(event)\n }\n break\n }\n default:\n calendarNavKey = false\n break\n }\n\n if (calendarNavKey) {\n event.preventDefault()\n event.stopPropagation()\n }\n }\n}\n\n/**\n * Date picker config\n *\n * @typedef {object} DatePickerConfig\n * @property {string} [excludedDates] - Dates that cannot be selected\n * @property {string} [excludedDays] - Days that cannot be selected\n * @property {boolean} [leadingZeros] - Whether to add leading zeroes when populating the field\n * @property {string} [minDate] - The earliest available date\n * @property {string} [maxDate] - The latest available date\n * @property {string} [weekStartDay] - First day of the week in calendar view\n * @property {object} [input] - Input config\n * @property {string} [input.selector] - Selector for the input element\n * @property {Element | null} [input.element] - HTML element for the input\n */\n\n/**\n * @import { Schema } from 'govuk-frontend/dist/govuk/common/configuration.mjs'\n */\n"],"names":["DatePicker","ConfigurableComponent","constructor","$root","config","_this$config$input$el","$input","input","element","querySelector","selector","HTMLInputElement","dayLabels","monthLabels","currentDate","Date","setHours","calendarDays","excludedDates","excludedDays","buttonClass","selectedDayButtonClass","currentDayButtonClass","todayButtonClass","setOptions","initControls","id","$dialog","createDialog","createCalendarHeaders","$componentWrapper","document","createElement","$inputWrapper","classList","add","parentElement","insertBefore","appendChild","insertAdjacentHTML","toggleTemplate","insertAdjacentElement","$calendarButton","$dialogTitle","createCalendar","$prevMonthButton","$prevYearButton","$nextMonthButton","$nextYearButton","$cancelButton","$okButton","addEventListener","event","focusPreviousMonth","focusPreviousYear","focusNextMonth","focusNextYear","preventDefault","closeDialog","selectDate","$dialogButtons","querySelectorAll","$firstButtonInDialog","$lastButtonInDialog","length","firstButtonKeydown","lastButtonKeydown","toggleDialog","key","stopPropagation","body","backgroundClick","updateCalendar","titleId","setAttribute","innerHTML","dialogTemplate","hidden","$tbody","dayCount","i","$row","insertRow","j","$cell","$dateButton","calendarDay","DSCalendarDay","push","forEach","day","html","substring","$headerRow","leadingZeros","value","ret","toString","setMinAndMaxDatesOnCalendar","setExcludedDates","setExcludedDays","setWeekStartDay","minDate","formattedDateFromString","maxDate","replace","split","map","item","includes","parseDateRangeString","reduce","dates","items","concat","filter","date","datestring","startDate","endDate","d","getTime","setDate","getDate","weekDays","toLowerCase","weekStartDay","unshift","pop","indexOf","weekStartDayParam","isExcludedDate","excludedDate","toDateString","getDay","dateString","fallback","formattedDate","dateFormatPattern","test","match","exec","month","year","Number","isFinite","formattedDateFromDate","getMonth","getFullYear","formattedDateHuman","isOpen","target","Node","contains","shiftKey","focus","firstOfMonth","dayOfWeek","thisDay","disabled","update","setCurrentDate","$button","remove","calendarDayDate","today","inputDate","removeAttribute","enabledDays","window","getComputedStyle","display","innerText","changeEvent","Event","bubbles","cancelable","dispatchEvent","openDialog","offsetWidth","style","right","top","offsetHeight","console","error","goToDate","current","focusNextDay","focusPreviousDay","focusNextWeek","focusPreviousWeek","focusFirstDayOfWeek","firstDayOfWeekIndex","diff","focusLastDayOfWeek","lastDayOfWeekIndex","setMonth","setFullYear","moduleName","defaults","Object","freeze","schema","properties","type","index","row","column","picker","keyPress","bind","click","label","accessibleLabel","calendarNavKey"],"mappings":"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"}
1
+ {"version":3,"file":"date-picker.mjs","sources":["../../../../src/moj/components/date-picker/date-picker.mjs"],"sourcesContent":["import { ConfigurableComponent } from 'govuk-frontend'\n\n/**\n * @augments {ConfigurableComponent<DatePickerConfig>}\n */\nexport class DatePicker extends ConfigurableComponent {\n /**\n * @param {Element | null} $root - HTML element to use for date picker\n * @param {DatePickerConfig} [config] - Date picker config\n */\n constructor($root, config = {}) {\n super($root, config)\n\n const $input =\n this.config.input.element ??\n this.$root.querySelector(this.config.input.selector)\n\n if (!$input || !($input instanceof HTMLInputElement)) {\n return this\n }\n\n this.$input = $input\n\n this.dayLabels = [\n 'Monday',\n 'Tuesday',\n 'Wednesday',\n 'Thursday',\n 'Friday',\n 'Saturday',\n 'Sunday'\n ]\n\n this.monthLabels = [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December'\n ]\n\n this.currentDate = new Date()\n this.currentDate.setHours(0, 0, 0, 0)\n this.calendarDays = /** @type {DSCalendarDay[]} */ ([])\n this.excludedDates = /** @type {Date[]} */ ([])\n this.excludedDays = /** @type {number[]} */ ([])\n\n this.buttonClass = 'moj-datepicker__button'\n this.selectedDayButtonClass = 'moj-datepicker__button--selected'\n this.currentDayButtonClass = 'moj-datepicker__button--current'\n this.todayButtonClass = 'moj-datepicker__button--today'\n\n this.setOptions()\n this.initControls()\n }\n\n initControls() {\n this.id = `datepicker-${this.$input.id}`\n\n this.$dialog = this.createDialog()\n this.createCalendarHeaders()\n\n const $componentWrapper = document.createElement('div')\n const $inputWrapper = document.createElement('div')\n $componentWrapper.classList.add('moj-datepicker__wrapper')\n $inputWrapper.classList.add('govuk-input__wrapper')\n\n this.$input.parentElement.insertBefore($componentWrapper, this.$input)\n $componentWrapper.appendChild($inputWrapper)\n $inputWrapper.appendChild(this.$input)\n\n $inputWrapper.insertAdjacentHTML('beforeend', this.toggleTemplate())\n $componentWrapper.insertAdjacentElement('beforeend', this.$dialog)\n\n this.$calendarButton = /** @type {HTMLButtonElement} */ (\n this.$root.querySelector('.moj-js-datepicker-toggle')\n )\n\n this.$dialogTitle = /** @type {HTMLHeadingElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-month-year')\n )\n\n this.createCalendar()\n\n this.$prevMonthButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-prev-month')\n )\n\n this.$prevYearButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-prev-year')\n )\n\n this.$nextMonthButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-next-month')\n )\n\n this.$nextYearButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-next-year')\n )\n\n this.$cancelButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-cancel')\n )\n\n this.$okButton = /** @type {HTMLButtonElement} */ (\n this.$dialog.querySelector('.moj-js-datepicker-ok')\n )\n\n // add event listeners\n this.$prevMonthButton.addEventListener('click', (event) =>\n this.focusPreviousMonth(event, false)\n )\n this.$prevYearButton.addEventListener('click', (event) =>\n this.focusPreviousYear(event, false)\n )\n this.$nextMonthButton.addEventListener('click', (event) =>\n this.focusNextMonth(event, false)\n )\n this.$nextYearButton.addEventListener('click', (event) =>\n this.focusNextYear(event, false)\n )\n this.$cancelButton.addEventListener('click', (event) => {\n event.preventDefault()\n this.closeDialog()\n })\n this.$okButton.addEventListener('click', () => {\n this.selectDate(this.currentDate)\n })\n\n const $dialogButtons = this.$dialog.querySelectorAll(\n 'button:not([disabled=\"true\"])'\n )\n\n this.$firstButtonInDialog = $dialogButtons[0]\n this.$lastButtonInDialog = $dialogButtons[$dialogButtons.length - 1]\n this.$firstButtonInDialog.addEventListener('keydown', (event) =>\n this.firstButtonKeydown(event)\n )\n this.$lastButtonInDialog.addEventListener('keydown', (event) =>\n this.lastButtonKeydown(event)\n )\n\n this.$calendarButton.addEventListener('click', (event) =>\n this.toggleDialog(event)\n )\n\n this.$dialog.addEventListener('keydown', (event) => {\n if (event.key === 'Escape') {\n this.closeDialog()\n event.preventDefault()\n event.stopPropagation()\n }\n })\n\n document.body.addEventListener('mouseup', (event) => {\n this.backgroundClick(event)\n })\n\n // populates calendar with initial dates, avoids Wave errors about null buttons\n this.updateCalendar()\n }\n\n createDialog() {\n const titleId = `datepicker-title-${this.$input.id}`\n const $dialog = document.createElement('div')\n\n $dialog.id = this.id\n $dialog.setAttribute('class', 'moj-datepicker__dialog')\n $dialog.setAttribute('role', 'dialog')\n $dialog.setAttribute('aria-modal', 'true')\n $dialog.setAttribute('aria-labelledby', titleId)\n $dialog.innerHTML = this.dialogTemplate(titleId)\n $dialog.hidden = true\n\n return $dialog\n }\n\n createCalendar() {\n const $tbody = this.$dialog.querySelector('tbody')\n let dayCount = 0\n for (let i = 0; i < 6; i++) {\n // create row\n const $row = $tbody.insertRow(i)\n\n for (let j = 0; j < 7; j++) {\n // create cell (day)\n const $cell = document.createElement('td')\n $row.appendChild($cell)\n const $dateButton = document.createElement('button')\n $dateButton.setAttribute('type', 'button')\n $cell.appendChild($dateButton)\n\n const calendarDay = new DSCalendarDay($dateButton, dayCount, i, j, this)\n this.calendarDays.push(calendarDay)\n dayCount++\n }\n }\n }\n\n toggleTemplate() {\n return `<button class=\"moj-datepicker__toggle moj-js-datepicker-toggle\" type=\"button\" aria-haspopup=\"dialog\" aria-controls=\"${this.id}\" aria-expanded=\"false\">\n <span class=\"govuk-visually-hidden\">Choose date</span>\n <svg width=\"32\" height=\"24\" focusable=\"false\" class=\"moj-datepicker-icon\" aria-hidden=\"true\" role=\"img\" viewBox=\"0 0 22 22\">\n <path\n fill=\"currentColor\"\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M16.1333 2.93333H5.86668V4.4C5.86668 5.21002 5.21003 5.86667 4.40002 5.86667C3.59 5.86667 2.93335 5.21002 2.93335 4.4V2.93333H2C0.895431 2.93333 0 3.82877 0 4.93334V19.2667C0 20.3712 0.89543 21.2667 2 21.2667H20C21.1046 21.2667 22 20.3712 22 19.2667V4.93333C22 3.82876 21.1046 2.93333 20 2.93333H19.0667V4.4C19.0667 5.21002 18.41 5.86667 17.6 5.86667C16.79 5.86667 16.1333 5.21002 16.1333 4.4V2.93333ZM20.5333 8.06667H1.46665V18.8C1.46665 19.3523 1.91436 19.8 2.46665 19.8H19.5333C20.0856 19.8 20.5333 19.3523 20.5333 18.8V8.06667Z\"\n ></path>\n <rect x=\"3.66669\" width=\"1.46667\" height=\"5.13333\" rx=\"0.733333\" fill=\"currentColor\"></rect>\n <rect x=\"16.8667\" width=\"1.46667\" height=\"5.13333\" rx=\"0.733333\" fill=\"currentColor\"></rect>\n </svg>\n </button>`\n }\n\n /**\n * HTML template for calendar dialog\n *\n * @param {string} [titleId] - Id attribute for dialog title\n * @returns {string}\n */\n dialogTemplate(titleId) {\n return `<div class=\"moj-datepicker__dialog-header\">\n <div class=\"moj-datepicker__dialog-navbuttons\">\n <button type=\"button\" class=\"moj-datepicker__button moj-js-datepicker-prev-year\">\n <span class=\"govuk-visually-hidden\">Previous year</span>\n <svg width=\"44\" height=\"40\" viewBox=\"0 0 44 40\" fill=\"none\" fill=\"none\" focusable=\"false\" aria-hidden=\"true\" role=\"img\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M23.1643 20L28.9572 14.2071L27.5429 12.7929L20.3358 20L27.5429 27.2071L28.9572 25.7929L23.1643 20Z\" fill=\"currentColor\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M17.1643 20L22.9572 14.2071L21.5429 12.7929L14.3358 20L21.5429 27.2071L22.9572 25.7929L17.1643 20Z\" fill=\"currentColor\"/>\n </svg>\n </button>\n\n <button type=\"button\" class=\"moj-datepicker__button moj-js-datepicker-prev-month\">\n <span class=\"govuk-visually-hidden\">Previous month</span>\n <svg width=\"44\" height=\"40\" viewBox=\"0 0 44 40\" fill=\"none\" focusable=\"false\" aria-hidden=\"true\" role=\"img\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M20.5729 20L25.7865 14.2071L24.5137 12.7929L18.0273 20L24.5137 27.2071L25.7865 25.7929L20.5729 20Z\" fill=\"currentColor\"/>\n </svg>\n </button>\n </div>\n\n <h2 id=\"${titleId}\" class=\"moj-datepicker__dialog-title moj-js-datepicker-month-year\" aria-live=\"polite\">June 2020</h2>\n\n <div class=\"moj-datepicker__dialog-navbuttons\">\n <button type=\"button\" class=\"moj-datepicker__button moj-js-datepicker-next-month\">\n <span class=\"govuk-visually-hidden\">Next month</span>\n <svg width=\"44\" height=\"40\" viewBox=\"0 0 44 40\" fill=\"none\" focusable=\"false\" aria-hidden=\"true\" role=\"img\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M23.4271 20L18.2135 14.2071L19.4863 12.7929L25.9727 20L19.4863 27.2071L18.2135 25.7929L23.4271 20Z\" fill=\"currentColor\"/>\n </svg>\n </button>\n\n <button type=\"button\" class=\"moj-datepicker__button moj-js-datepicker-next-year\">\n <span class=\"govuk-visually-hidden\">Next year</span>\n <svg width=\"44\" height=\"40\" viewBox=\"0 0 44 40\" fill=\"none\" fill=\"none\" focusable=\"false\" aria-hidden=\"true\" role=\"img\">\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M20.8357 20L15.0428 14.2071L16.4571 12.7929L23.6642 20L16.4571 27.2071L15.0428 25.7929L20.8357 20Z\" fill=\"currentColor\"/>\n <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M26.8357 20L21.0428 14.2071L22.4571 12.7929L29.6642 20L22.4571 27.2071L21.0428 25.7929L26.8357 20Z\" fill=\"currentColor\"/>\n </svg>\n </button>\n </div>\n </div>\n\n <table class=\"moj-datepicker__calendar moj-js-datepicker-grid\" role=\"application\" aria-labelledby=\"${titleId}\">\n <thead>\n <tr></tr>\n </thead>\n\n <tbody></tbody>\n </table>\n\n <div class=\"govuk-button-group\">\n <button type=\"button\" class=\"govuk-button moj-js-datepicker-ok\">Select</button>\n <button type=\"button\" class=\"govuk-button govuk-button--secondary moj-js-datepicker-cancel\">Close</button>\n </div>`\n }\n\n createCalendarHeaders() {\n this.dayLabels.forEach((day) => {\n const html = `<th scope=\"col\"><span aria-hidden=\"true\">${day.substring(0, 3)}</span><span class=\"govuk-visually-hidden\">${day}</span></th>`\n const $headerRow = this.$dialog.querySelector('thead > tr')\n $headerRow.insertAdjacentHTML('beforeend', html)\n })\n }\n\n /**\n * Pads given number with leading zeros\n *\n * @param {number} value - The value to be padded\n * @param {number} length - The length in characters of the output\n * @returns {string}\n */\n leadingZeros(value, length = 2) {\n let ret = value.toString()\n\n while (ret.length < length) {\n ret = `0${ret}`\n }\n\n return ret\n }\n\n setOptions() {\n this.setMinAndMaxDatesOnCalendar()\n this.setExcludedDates()\n this.setExcludedDays()\n this.setWeekStartDay()\n }\n\n setMinAndMaxDatesOnCalendar() {\n if (this.config.minDate) {\n this.minDate = this.formattedDateFromString(this.config.minDate, null)\n\n if (this.minDate && this.currentDate < this.minDate) {\n this.currentDate = this.minDate\n }\n }\n\n if (this.config.maxDate) {\n this.maxDate = this.formattedDateFromString(this.config.maxDate, null)\n\n if (this.maxDate && this.currentDate > this.maxDate) {\n this.currentDate = this.maxDate\n }\n }\n }\n\n setExcludedDates() {\n if (this.config.excludedDates) {\n this.excludedDates = this.config.excludedDates\n .replace(/\\s+/, ' ')\n .split(' ')\n .map((item) => {\n return item.includes('-')\n ? this.parseDateRangeString(item)\n : [this.formattedDateFromString(item)]\n })\n .reduce((dates, items) => dates.concat(items))\n .filter((date) => date)\n }\n }\n\n /**\n * Parses a daterange string into an array of dates\n *\n * @param {string} datestring - A daterange string in the format \"dd/mm/yyyy-dd/mm/yyyy\"\n */\n parseDateRangeString(datestring) {\n const dates = []\n const [startDate, endDate] = datestring\n .split('-')\n .map((d) => this.formattedDateFromString(d, null))\n\n if (startDate && endDate) {\n const date = new Date(startDate.getTime())\n /* eslint-disable no-unmodified-loop-condition */\n while (date <= endDate) {\n dates.push(new Date(date))\n date.setDate(date.getDate() + 1)\n }\n /* eslint-enable no-unmodified-loop-condition */\n }\n return dates\n }\n\n setExcludedDays() {\n if (this.config.excludedDays) {\n /* lowercase and arrange dayLabels to put indexOf sunday == 0 for comparison\n with getDay() function */\n const weekDays = this.dayLabels.map((item) => item.toLowerCase())\n if (this.config.weekStartDay === 'monday') {\n weekDays.unshift(weekDays.pop())\n }\n\n this.excludedDays = this.config.excludedDays\n .replace(/\\s+/, ' ')\n .toLowerCase()\n .split(' ')\n .map((item) => weekDays.indexOf(item))\n .filter((item) => item !== -1)\n }\n }\n\n setWeekStartDay() {\n const weekStartDayParam = this.config.weekStartDay\n if (weekStartDayParam && weekStartDayParam.toLowerCase() === 'sunday') {\n this.config.weekStartDay = 'sunday'\n // Rotate dayLabels array to put Sunday as the first item\n this.dayLabels.unshift(this.dayLabels.pop())\n } else {\n this.config.weekStartDay = 'monday'\n }\n }\n\n /**\n * Determine if a date is selectable\n *\n * @param {Date} date - the date to check\n * @returns {boolean}\n */\n isExcludedDate(date) {\n if (this.minDate && this.minDate > date) {\n return true\n }\n\n // This comparison works as expected - the maxdate will not be excluded\n if (this.maxDate && this.maxDate < date) {\n return true\n }\n\n for (const excludedDate of this.excludedDates) {\n if (date.toDateString() === excludedDate.toDateString()) {\n return true\n }\n }\n\n if (this.excludedDays.includes(date.getDay())) {\n return true\n }\n\n return false\n }\n\n /**\n * Get a Date object from a string\n *\n * @param {string} dateString - string in the format d/m/yyyy dd/mm/yyyy\n * @param {Date} fallback - date object to return if formatting fails\n * @returns {Date}\n */\n formattedDateFromString(dateString, fallback = new Date()) {\n let formattedDate = null\n // Accepts d/m/yyyy and dd/mm/yyyy\n const dateFormatPattern = /(\\d{1,2})([-/,. ])(\\d{1,2})\\2(\\d{4})/\n\n if (!dateFormatPattern.test(dateString)) return fallback\n\n const match = dateFormatPattern.exec(dateString)\n const day = match[1]\n const month = match[3]\n const year = match[4]\n\n formattedDate = new Date(Number(year), Number(month) - 1, Number(day))\n if (\n formattedDate instanceof Date &&\n Number.isFinite(formattedDate.getTime())\n ) {\n return formattedDate\n }\n return fallback\n }\n\n /**\n * Get a formatted date string from a Date object\n *\n * @param {Date} date - date to format to a string\n * @returns {string}\n */\n formattedDateFromDate(date) {\n if (this.config.leadingZeros) {\n return `${this.leadingZeros(date.getDate())}/${this.leadingZeros(date.getMonth() + 1)}/${date.getFullYear()}`\n }\n\n return `${date.getDate()}/${date.getMonth() + 1}/${date.getFullYear()}`\n }\n\n /**\n * Get a human readable date in the format Monday 2 March 2024\n *\n * @param {Date} date - Date to format\n * @returns {string}\n */\n formattedDateHuman(date) {\n return `${this.dayLabels[(date.getDay() + 6) % 7]} ${date.getDate()} ${this.monthLabels[date.getMonth()]} ${date.getFullYear()}`\n }\n\n /**\n * @param {MouseEvent} event - Click event\n */\n backgroundClick(event) {\n if (\n this.isOpen() &&\n event.target instanceof Node &&\n !this.$dialog.contains(event.target) &&\n !this.$input.contains(event.target) &&\n !this.$calendarButton.contains(event.target)\n ) {\n event.preventDefault()\n this.closeDialog()\n }\n }\n\n /**\n * @param {KeyboardEvent} event - Keydown event\n */\n firstButtonKeydown(event) {\n if (event.key === 'Tab' && event.shiftKey) {\n this.$lastButtonInDialog.focus()\n event.preventDefault()\n }\n }\n\n /**\n * @param {KeyboardEvent} event - Keydown event\n */\n lastButtonKeydown(event) {\n if (event.key === 'Tab' && !event.shiftKey) {\n this.$firstButtonInDialog.focus()\n event.preventDefault()\n }\n }\n\n // render calendar\n updateCalendar() {\n this.$dialogTitle.innerHTML = `${this.monthLabels[this.currentDate.getMonth()]} ${this.currentDate.getFullYear()}`\n\n const day = this.currentDate\n const firstOfMonth = new Date(day.getFullYear(), day.getMonth(), 1)\n let dayOfWeek\n\n if (this.config.weekStartDay === 'monday') {\n dayOfWeek = firstOfMonth.getDay() === 0 ? 6 : firstOfMonth.getDay() - 1 // Change logic to make Monday first day of week, i.e. 0\n } else {\n dayOfWeek = firstOfMonth.getDay()\n }\n\n firstOfMonth.setDate(firstOfMonth.getDate() - dayOfWeek)\n\n const thisDay = new Date(firstOfMonth)\n\n // loop through our days\n for (const calendarDay of this.calendarDays) {\n const hidden = thisDay.getMonth() !== day.getMonth()\n const disabled = this.isExcludedDate(thisDay)\n\n calendarDay.update(thisDay, hidden, disabled)\n\n thisDay.setDate(thisDay.getDate() + 1)\n }\n }\n\n /**\n * @param {boolean} [focus] - Focus the day button\n */\n setCurrentDate(focus = true) {\n const { currentDate } = this\n this.calendarDays.forEach((calendarDay) => {\n calendarDay.$button.classList.add('moj-datepicker__button')\n calendarDay.$button.classList.add('moj-datepicker__calendar-day')\n calendarDay.$button.setAttribute('tabindex', '-1')\n calendarDay.$button.classList.remove(this.selectedDayButtonClass)\n const calendarDayDate = calendarDay.date\n calendarDayDate.setHours(0, 0, 0, 0)\n\n const today = new Date()\n today.setHours(0, 0, 0, 0)\n\n if (\n calendarDayDate.getTime() ===\n currentDate.getTime() /* && !calendarDay.button.disabled */\n ) {\n if (focus) {\n calendarDay.$button.setAttribute('tabindex', '0')\n calendarDay.$button.focus()\n calendarDay.$button.classList.add(this.selectedDayButtonClass)\n }\n }\n\n if (\n this.inputDate &&\n calendarDayDate.getTime() === this.inputDate.getTime()\n ) {\n calendarDay.$button.classList.add(this.currentDayButtonClass)\n calendarDay.$button.setAttribute('aria-current', 'date')\n } else {\n calendarDay.$button.classList.remove(this.currentDayButtonClass)\n calendarDay.$button.removeAttribute('aria-current')\n }\n\n if (calendarDayDate.getTime() === today.getTime()) {\n calendarDay.$button.classList.add(this.todayButtonClass)\n } else {\n calendarDay.$button.classList.remove(this.todayButtonClass)\n }\n })\n\n // if no date is tab-able, make the first non-disabled date tab-able\n if (!focus) {\n const enabledDays = this.calendarDays.filter((calendarDay) => {\n return (\n window.getComputedStyle(calendarDay.$button).display === 'block' &&\n !calendarDay.$button.disabled\n )\n })\n\n enabledDays[0].$button.setAttribute('tabindex', '0')\n\n this.currentDate = enabledDays[0].date\n }\n }\n\n /**\n * @param {Date} date - Date to select\n */\n selectDate(date) {\n if (this.isExcludedDate(date)) {\n return\n }\n\n this.$calendarButton.querySelector('span').innerText =\n `Choose date. Selected date is ${this.formattedDateHuman(date)}`\n this.$input.value = this.formattedDateFromDate(date)\n\n const changeEvent = new Event('change', { bubbles: true, cancelable: true })\n this.$input.dispatchEvent(changeEvent)\n\n this.closeDialog()\n }\n\n isOpen() {\n return this.$dialog.classList.contains('moj-datepicker__dialog--open')\n }\n\n /**\n * @param {MouseEvent} event - Click event\n */\n toggleDialog(event) {\n event.preventDefault()\n if (this.isOpen()) {\n this.closeDialog()\n } else {\n this.setMinAndMaxDatesOnCalendar()\n this.openDialog()\n }\n }\n\n openDialog() {\n this.$dialog.hidden = false\n this.$dialog.classList.add('moj-datepicker__dialog--open')\n this.$calendarButton.setAttribute('aria-expanded', 'true')\n\n // position the dialog\n // if input is wider than dialog pin it to the right\n if (this.$input.offsetWidth > this.$dialog.offsetWidth) {\n this.$dialog.style.right = `0px`\n }\n this.$dialog.style.top = `${this.$input.offsetHeight + 3}px`\n\n // get the date from the input element\n this.inputDate = this.formattedDateFromString(this.$input.value)\n // move current date to the closest selectable date if it is out of range\n if (this.minDate && this.minDate > this.inputDate) {\n this.inputDate = new Date(this.minDate.getTime())\n }\n if (this.maxDate && this.maxDate < this.inputDate) {\n this.inputDate = new Date(this.maxDate.getTime())\n }\n if (this.minDate && this.maxDate && this.minDate > this.maxDate) {\n console.error('min date is after max date. No dates will be selectable')\n }\n\n this.currentDate = this.inputDate\n this.currentDate.setHours(0, 0, 0, 0)\n\n this.updateCalendar()\n this.setCurrentDate()\n }\n\n closeDialog() {\n this.$dialog.hidden = true\n this.$dialog.classList.remove('moj-datepicker__dialog--open')\n this.$calendarButton.setAttribute('aria-expanded', 'false')\n this.$calendarButton.focus()\n }\n\n /**\n * @param {Date} date - Date to go to\n * @param {boolean} [focus] - Focus the day button\n */\n goToDate(date, focus) {\n const current = this.currentDate\n this.currentDate = date\n\n if (\n current.getMonth() !== this.currentDate.getMonth() ||\n current.getFullYear() !== this.currentDate.getFullYear()\n ) {\n this.updateCalendar()\n }\n\n this.setCurrentDate(focus)\n }\n\n // day navigation\n focusNextDay() {\n const date = new Date(this.currentDate)\n date.setDate(date.getDate() + 1)\n this.goToDate(date)\n }\n\n focusPreviousDay() {\n const date = new Date(this.currentDate)\n date.setDate(date.getDate() - 1)\n this.goToDate(date)\n }\n\n // week navigation\n focusNextWeek() {\n const date = new Date(this.currentDate)\n date.setDate(date.getDate() + 7)\n this.goToDate(date)\n }\n\n focusPreviousWeek() {\n const date = new Date(this.currentDate)\n date.setDate(date.getDate() - 7)\n this.goToDate(date)\n }\n\n focusFirstDayOfWeek() {\n const date = new Date(this.currentDate)\n const firstDayOfWeekIndex = this.config.weekStartDay === 'sunday' ? 0 : 1\n const dayOfWeek = date.getDay()\n const diff =\n dayOfWeek >= firstDayOfWeekIndex\n ? dayOfWeek - firstDayOfWeekIndex\n : 6 - dayOfWeek\n\n date.setDate(date.getDate() - diff)\n date.setHours(0, 0, 0, 0)\n\n this.goToDate(date)\n }\n\n focusLastDayOfWeek() {\n const date = new Date(this.currentDate)\n const lastDayOfWeekIndex = this.config.weekStartDay === 'sunday' ? 6 : 0\n const dayOfWeek = date.getDay()\n const diff =\n dayOfWeek <= lastDayOfWeekIndex\n ? lastDayOfWeekIndex - dayOfWeek\n : 7 - dayOfWeek\n\n date.setDate(date.getDate() + diff)\n date.setHours(0, 0, 0, 0)\n\n this.goToDate(date)\n }\n\n /**\n * Month navigation\n *\n * @param {KeyboardEvent | MouseEvent} event - Key press or click event\n * @param {boolean} [focus] - Focus the day button\n */\n focusNextMonth(event, focus = true) {\n event.preventDefault()\n const date = new Date(this.currentDate)\n date.setMonth(date.getMonth() + 1, 1)\n this.goToDate(date, focus)\n }\n\n /**\n * @param {KeyboardEvent | MouseEvent} event - Key press or click event\n * @param {boolean} [focus] - Focus the day button\n */\n focusPreviousMonth(event, focus = true) {\n event.preventDefault()\n const date = new Date(this.currentDate)\n date.setMonth(date.getMonth() - 1, 1)\n this.goToDate(date, focus)\n }\n\n /**\n * Year navigation\n *\n * @param {KeyboardEvent | MouseEvent} event - Key press or click event\n * @param {boolean} [focus] - Focus the day button\n */\n focusNextYear(event, focus = true) {\n event.preventDefault()\n const date = new Date(this.currentDate)\n date.setFullYear(date.getFullYear() + 1, date.getMonth(), 1)\n this.goToDate(date, focus)\n }\n\n /**\n * @param {KeyboardEvent | MouseEvent} event - Key press or click event\n * @param {boolean} [focus] - Focus the day button\n */\n focusPreviousYear(event, focus = true) {\n event.preventDefault()\n const date = new Date(this.currentDate)\n date.setFullYear(date.getFullYear() - 1, date.getMonth(), 1)\n this.goToDate(date, focus)\n }\n\n /**\n * Name for the component used when initialising using data-module attributes.\n */\n static moduleName = 'moj-date-picker'\n\n /**\n * Date picker default config\n *\n * @type {DatePickerConfig}\n */\n static defaults = Object.freeze({\n leadingZeros: false,\n weekStartDay: 'monday',\n input: {\n selector: '.moj-js-datepicker-input'\n }\n })\n\n /**\n * Date picker config schema\n *\n * @satisfies {Schema<DatePickerConfig>}\n */\n static schema = Object.freeze(\n /** @type {const} */ ({\n properties: {\n excludedDates: { type: 'string' },\n excludedDays: { type: 'string' },\n leadingZeros: { type: 'boolean' },\n maxDate: { type: 'string' },\n minDate: { type: 'string' },\n weekStartDay: { type: 'string' },\n input: { type: 'object' }\n }\n })\n )\n}\n\nclass DSCalendarDay {\n /**\n *\n * @param {HTMLButtonElement} $button\n * @param {number} index\n * @param {number} row\n * @param {number} column\n * @param {DatePicker} picker\n */\n constructor($button, index, row, column, picker) {\n this.index = index\n this.row = row\n this.column = column\n this.$button = $button\n this.picker = picker\n this.date = new Date()\n this.$button.addEventListener('keydown', this.keyPress.bind(this))\n this.$button.addEventListener('click', this.click.bind(this))\n }\n\n /**\n * @param {Date} day - the Date for the calendar day\n * @param {boolean} hidden - visibility of the day\n * @param {boolean} disabled - is the day selectable or excluded\n */\n update(day, hidden, disabled) {\n const label = day.getDate()\n let accessibleLabel = this.picker.formattedDateHuman(day)\n\n if (disabled) {\n this.$button.setAttribute('aria-disabled', 'true')\n accessibleLabel = `Excluded date, ${accessibleLabel}`\n } else {\n this.$button.removeAttribute('aria-disabled')\n }\n\n if (hidden) {\n this.$button.style.display = 'none'\n } else {\n this.$button.style.display = 'block'\n }\n this.$button.setAttribute(\n 'data-testid',\n this.picker.formattedDateFromDate(day)\n )\n\n this.$button.innerHTML = `<span class=\"govuk-visually-hidden\">${accessibleLabel}</span><span aria-hidden=\"true\">${label}</span>`\n this.date = new Date(day)\n }\n\n /**\n * @param {MouseEvent} event - Click event\n */\n click(event) {\n this.picker.goToDate(this.date)\n this.picker.selectDate(this.date)\n\n event.stopPropagation()\n event.preventDefault()\n }\n\n /**\n * @param {KeyboardEvent} event - Keydown event\n */\n keyPress(event) {\n let calendarNavKey = true\n\n switch (event.key) {\n case 'ArrowLeft':\n this.picker.focusPreviousDay()\n break\n case 'ArrowRight':\n this.picker.focusNextDay()\n break\n case 'ArrowUp':\n this.picker.focusPreviousWeek()\n break\n case 'ArrowDown':\n this.picker.focusNextWeek()\n break\n case 'Home':\n this.picker.focusFirstDayOfWeek()\n break\n case 'End':\n this.picker.focusLastDayOfWeek()\n break\n case 'PageUp': {\n if (event.shiftKey) {\n this.picker.focusPreviousYear(event)\n } else {\n this.picker.focusPreviousMonth(event)\n }\n break\n }\n case 'PageDown': {\n if (event.shiftKey) {\n this.picker.focusNextYear(event)\n } else {\n this.picker.focusNextMonth(event)\n }\n break\n }\n default:\n calendarNavKey = false\n break\n }\n\n if (calendarNavKey) {\n event.preventDefault()\n event.stopPropagation()\n }\n }\n}\n\n/**\n * Date picker config\n *\n * @typedef {object} DatePickerConfig\n * @property {string} [excludedDates] - Dates that cannot be selected\n * @property {string} [excludedDays] - Days that cannot be selected\n * @property {boolean} [leadingZeros] - Whether to add leading zeroes when populating the field\n * @property {string} [minDate] - The earliest available date\n * @property {string} [maxDate] - The latest available date\n * @property {string} [weekStartDay] - First day of the week in calendar view\n * @property {object} [input] - Input config\n * @property {string} [input.selector] - Selector for the input element\n * @property {Element | null} [input.element] - HTML element for the input\n */\n\n/**\n * @import { Schema } from 'govuk-frontend/dist/govuk/common/configuration.mjs'\n */\n"],"names":["DatePicker","ConfigurableComponent","constructor","$root","config","_this$config$input$el","$input","input","element","querySelector","selector","HTMLInputElement","dayLabels","monthLabels","currentDate","Date","setHours","calendarDays","excludedDates","excludedDays","buttonClass","selectedDayButtonClass","currentDayButtonClass","todayButtonClass","setOptions","initControls","id","$dialog","createDialog","createCalendarHeaders","$componentWrapper","document","createElement","$inputWrapper","classList","add","parentElement","insertBefore","appendChild","insertAdjacentHTML","toggleTemplate","insertAdjacentElement","$calendarButton","$dialogTitle","createCalendar","$prevMonthButton","$prevYearButton","$nextMonthButton","$nextYearButton","$cancelButton","$okButton","addEventListener","event","focusPreviousMonth","focusPreviousYear","focusNextMonth","focusNextYear","preventDefault","closeDialog","selectDate","$dialogButtons","querySelectorAll","$firstButtonInDialog","$lastButtonInDialog","length","firstButtonKeydown","lastButtonKeydown","toggleDialog","key","stopPropagation","body","backgroundClick","updateCalendar","titleId","setAttribute","innerHTML","dialogTemplate","hidden","$tbody","dayCount","i","$row","insertRow","j","$cell","$dateButton","calendarDay","DSCalendarDay","push","forEach","day","html","substring","$headerRow","leadingZeros","value","ret","toString","setMinAndMaxDatesOnCalendar","setExcludedDates","setExcludedDays","setWeekStartDay","minDate","formattedDateFromString","maxDate","replace","split","map","item","includes","parseDateRangeString","reduce","dates","items","concat","filter","date","datestring","startDate","endDate","d","getTime","setDate","getDate","weekDays","toLowerCase","weekStartDay","unshift","pop","indexOf","weekStartDayParam","isExcludedDate","excludedDate","toDateString","getDay","dateString","fallback","formattedDate","dateFormatPattern","test","match","exec","month","year","Number","isFinite","formattedDateFromDate","getMonth","getFullYear","formattedDateHuman","isOpen","target","Node","contains","shiftKey","focus","firstOfMonth","dayOfWeek","thisDay","disabled","update","setCurrentDate","$button","remove","calendarDayDate","today","inputDate","removeAttribute","enabledDays","window","getComputedStyle","display","innerText","changeEvent","Event","bubbles","cancelable","dispatchEvent","openDialog","offsetWidth","style","right","top","offsetHeight","console","error","goToDate","current","focusNextDay","focusPreviousDay","focusNextWeek","focusPreviousWeek","focusFirstDayOfWeek","firstDayOfWeekIndex","diff","focusLastDayOfWeek","lastDayOfWeekIndex","setMonth","setFullYear","moduleName","defaults","Object","freeze","schema","properties","type","index","row","column","picker","keyPress","bind","click","label","accessibleLabel","calendarNavKey"],"mappings":"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"}
@@ -7,7 +7,15 @@
7
7
  environmentName: 'DEV',
8
8
  environmentNameColour: 'govuk-tag--green',
9
9
  name: 'Account name',
10
- manageDetailsLink: '#'
10
+ manageDetailsLink: '#',
11
+ servicesLink: '#',
12
+ services: [
13
+ {
14
+ heading: 'Service 1',
15
+ href: '#',
16
+ target: '_blank'
17
+ }
18
+ ]
11
19
  }) }}
12
20
  ```
13
21
 
@@ -23,6 +31,17 @@ This component accepts the following arguments.
23
31
  | environmentNameColour | string | No | Custom colour for the environment tag, overriding the default. |
24
32
  | name | string | Yes | The display name of the user. |
25
33
  | manageDetailsLink | string | Yes | URL linking to the user account management page. |
34
+ | servicesLink | string | No | URL linking to a services page when JavaScript is disabled |
35
+ | services | list | Yes | List of services. See [services](#services) |
36
+
37
+ ### services
38
+
39
+ | Name | Type | Required | Description |
40
+ | ----------------- | ------ | -------- | --------------------------------------------------------------------------------------------- |
41
+ | href | string | Yes | URL linking to the service |
42
+ | heading | string | Yes | The service's label |
43
+ | target | string | No | The link's target |
44
+
26
45
 
27
46
 
28
47
  _Warning: If you’re using Nunjucks macros in production be aware that using HTML arguments, or ones ending with `.html` can be at risk from [cross-site scripting](https://en.wikipedia.org/wiki/Cross-site_scripting) attacks. More information about security vulnerabilities can be found in the [Nunjucks documentation](https://mozilla.github.io/nunjucks/api.html#user-defined-templates-warning)._
@@ -309,7 +309,8 @@
309
309
  width: 100%;
310
310
  margin-bottom: 0;
311
311
  font-weight: bold;
312
- grid-template-columns: 1fr 1fr 1fr;
312
+ grid-template-rows: 1fr 1fr 1fr 1fr;
313
+ grid-auto-flow: column;
313
314
  gap: 15px;
314
315
  justify-items: start;
315
316
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../src/moj/components/domain-specific/probation/header/_header.scss"],"names":[],"mappings":"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","file":"_header.scss","sourcesContent":["/* stylelint-disable max-nesting-depth, selector-no-qualifying-type */\n@use \"../../../../vendor/govuk-frontend\" as *;\n\n/* ==========================================================================\n PROBATION#HEADER\n ========================================================================== */\n\n.probation-common-header {\n [hidden] {\n display: none;\n }\n color: govuk-colour(\"white\");\n\n background-color: govuk-colour(\"black\");\n\n &__logo {\n @include govuk-responsive-margin(3, \"right\");\n position: relative;\n top: -2px;\n padding: 15px 0;\n fill: govuk-colour(\"white\");\n }\n\n &__title {\n display: flex;\n\n &__organisation-name {\n @include govuk-responsive-margin(2, \"right\");\n @include govuk-font($size: 24, $weight: \"bold\");\n display: flex;\n align-items: center;\n }\n\n .govuk-tag {\n margin: auto 0;\n\n @include govuk-media-query($until: 985px) {\n display: none;\n }\n }\n }\n\n &__submenu-link {\n @include govuk-link-common;\n @include govuk-link-style-no-visited-state;\n }\n\n &__link {\n @include govuk-link-common;\n @include govuk-link-style-default;\n\n &:link,\n &:visited,\n &:active {\n color: govuk-colour(\"white\");\n font-weight: normal;\n text-decoration: none;\n }\n\n &:focus {\n color: govuk-colour(\"black\");\n box-shadow: none;\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"black\");\n }\n\n svg {\n fill: govuk-colour(\"black\");\n }\n }\n\n &:hover {\n text-decoration: underline;\n }\n }\n\n &__button-width-container {\n position: relative;\n }\n\n &__button-container {\n @include govuk-media-query(925px) {\n position: absolute;\n top: -70px;\n right: 0;\n background-color: govuk-colour(\"black\");\n }\n }\n\n &__navigation {\n display: flex;\n height: 70px;\n margin: 0;\n padding: 0;\n list-style: none;\n flex-direction: row;\n align-items: center;\n\n &__item {\n position: relative;\n height: 100%;\n\n > button,\n > a {\n display: flex;\n height: 100%;\n padding: 0;\n overflow: hidden;\n border: none;\n color: govuk-colour(\"white\");\n background: govuk-colour(\"black\");\n cursor: pointer;\n align-items: center;\n justify-content: center;\n @include govuk-font(16);\n\n &:hover {\n color: govuk-colour(\"mid-grey\");\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"mid-grey\");\n }\n }\n\n &.probation-common-header__menu-toggle {\n padding: 10px 0;\n\n > span {\n display: flex;\n height: 100%;\n padding: 0 15px;\n border-left: 1px solid govuk-colour(\"white\");\n align-items: center;\n\n &::before {\n content: \"\";\n display: inline-block;\n width: 8px;\n height: 8px;\n margin: 3px 15px 0 3px;\n -ms-transform: translateY(-35%) rotate(45deg) scale(1);\n -webkit-transform: translateY(-35%) rotate(45deg) scale(1);\n transform: translateY(-35%) rotate(45deg) scale(1);\n border-right: 2px solid govuk-colour(\"white\");\n border-bottom: 2px solid govuk-colour(\"white\");\n vertical-align: middle;\n }\n }\n\n svg {\n margin: 0 15px 0 0;\n }\n\n &:hover {\n > span {\n &::before {\n border-right: 2px solid govuk-colour(\"mid-grey\");\n border-bottom: 2px solid govuk-colour(\"mid-grey\");\n }\n }\n }\n }\n\n &.probation-common-header__toggle-open {\n color: govuk-colour(\"blue\");\n background: govuk-colour(\"light-grey\");\n\n > span {\n &::before {\n -ms-transform: translateY(-0%) rotate(225deg) scale(1);\n -webkit-transform: translateY(-0%) rotate(225deg) scale(1);\n transform: translateY(-0%) rotate(225deg) scale(1);\n border-right: 2px solid govuk-colour(\"blue\");\n border-bottom: 2px solid govuk-colour(\"blue\");\n }\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"blue\");\n }\n }\n\n &:hover {\n color: govuk-colour(\"dark-grey\");\n }\n }\n\n &:focus-visible {\n outline: 3px solid transparent;\n color: govuk-colour(\"black\");\n background-color: govuk-colour(\"yellow\");\n box-shadow: none;\n text-decoration: none;\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"black\");\n }\n\n > span {\n &::before {\n border-right: 2px solid govuk-colour(\"black\");\n border-bottom: 2px solid govuk-colour(\"black\");\n }\n }\n }\n }\n\n &.item-open {\n + div {\n > button,\n > a {\n > span {\n border-left: 1px solid transparent;\n }\n }\n }\n }\n }\n }\n\n .probation-common-header__user-menu {\n position: relative;\n z-index: 10000000;\n padding: 15px;\n background: govuk-colour(\"light-grey\");\n\n a {\n display: block;\n margin-bottom: 15px;\n font-weight: 700;\n }\n }\n\n &__pushdown-menu {\n padding: 30px 0 60px;\n background: govuk-colour(\"light-grey\");\n }\n\n &__icon-link-wrapper {\n display: flex;\n position: relative;\n height: 100%;\n\n img,\n svg {\n margin: 0 15px 0 0;\n }\n\n a {\n box-sizing: border-box;\n display: block;\n width: 100%;\n padding: 10px 0;\n\n > span {\n display: flex;\n height: 100%;\n padding: 0 15px;\n border-left: 1px solid govuk-colour(\"white\");\n align-items: center;\n justify-content: center;\n }\n\n &:hover {\n color: govuk-colour(\"mid-grey\");\n text-decoration: none;\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"mid-grey\");\n }\n }\n }\n }\n\n &__services-menu {\n ul {\n display: grid;\n width: 100%;\n margin-bottom: 0;\n font-weight: bold;\n grid-template-columns: 1fr 1fr 1fr;\n gap: 15px;\n justify-items: start;\n }\n }\n\n &__user-menu-link {\n width: 181px;\n }\n\n &__services-menu-link {\n width: 107px;\n }\n\n &__menu-toggle-label {\n display: block;\n text-align: left;\n }\n\n @media print {\n display: none;\n }\n}\n"]}
1
+ {"version":3,"sources":["../../../../../../src/moj/components/domain-specific/probation/header/_header.scss"],"names":[],"mappings":"AAAA,qEAAqE;AACrE,6CAA6C;;AAE7C;;+EAE+E;;AAE/E;EACE;IACE,aAAa;EACf;EACA,4BAA4B;;EAE5B,uCAAuC;;EAEvC;IACE,4CAA4C;IAC5C,kBAAkB;IAClB,SAAS;IACT,eAAe;IACf,2BAA2B;EAC7B;;EAEA;IACE,aAAa;;IAEb;MACE,4CAA4C;MAC5C,+CAA+C;MAC/C,aAAa;MACb,mBAAmB;IACrB;;IAEA;MACE,cAAc;;MAEd;QACE,aAAa;MACf;IACF;EACF;;EAEA;IACE,0BAA0B;IAC1B,0CAA0C;EAC5C;;EAEA;IACE,0BAA0B;IAC1B,iCAAiC;;IAEjC;;;MAGE,4BAA4B;MAC5B,mBAAmB;MACnB,qBAAqB;IACvB;;IAEA;MACE,4BAA4B;MAC5B,gBAAgB;;MAEhB;QACE,WAAW;QACX,kBAAkB;QAClB,SAAS;QACT,WAAW;QACX,SAAS;QACT,UAAU;QACV,WAAW;QACX,iCAAiC;MACnC;;MAEA;QACE,2BAA2B;MAC7B;IACF;;IAEA;MACE,0BAA0B;IAC5B;EACF;;EAEA;IACE,kBAAkB;EACpB;;EAEA;IACE;MACE,kBAAkB;MAClB,UAAU;MACV,QAAQ;MACR,uCAAuC;IACzC;EACF;;EAEA;IACE,aAAa;IACb,YAAY;IACZ,SAAS;IACT,UAAU;IACV,gBAAgB;IAChB,mBAAmB;IACnB,mBAAmB;;IAEnB;MACE,kBAAkB;MAClB,YAAY;;MAEZ;;QAEE,aAAa;QACb,YAAY;QACZ,UAAU;QACV,gBAAgB;QAChB,YAAY;QACZ,4BAA4B;QAC5B,iCAAiC;QACjC,eAAe;QACf,mBAAmB;QACnB,uBAAuB;QACvB,uBAAuB;;QAEvB;UACE,+BAA+B;;UAE/B;YACE,WAAW;YACX,kBAAkB;YAClB,SAAS;YACT,WAAW;YACX,SAAS;YACT,UAAU;YACV,WAAW;YACX,oCAAoC;UACtC;QACF;;QAEA;UACE,eAAe;;UAEf;YACE,aAAa;YACb,YAAY;YACZ,eAAe;YACf,4CAA4C;YAC5C,mBAAmB;;YAEnB;cACE,WAAW;cACX,qBAAqB;cACrB,UAAU;cACV,WAAW;cACX,sBAAsB;cAGtB,kDAAkD;cAClD,6CAA6C;cAC7C,8CAA8C;cAC9C,sBAAsB;YACxB;UACF;;UAEA;YACE,kBAAkB;UACpB;;UAEA;YACE;cACE;gBACE,gDAAgD;gBAChD,iDAAiD;cACnD;YACF;UACF;QACF;;QAEA;UACE,2BAA2B;UAC3B,sCAAsC;;UAEtC;YACE;cAGE,kDAAkD;cAClD,4CAA4C;cAC5C,6CAA6C;YAC/C;;YAEA;cACE,WAAW;cACX,kBAAkB;cAClB,SAAS;cACT,WAAW;cACX,SAAS;cACT,UAAU;cACV,WAAW;cACX,gCAAgC;YAClC;UACF;;UAEA;YACE,gCAAgC;UAClC;QACF;;QAEA;UACE,8BAA8B;UAC9B,4BAA4B;UAC5B,wCAAwC;UACxC,gBAAgB;UAChB,qBAAqB;;UAErB;YACE,WAAW;YACX,kBAAkB;YAClB,SAAS;YACT,WAAW;YACX,SAAS;YACT,UAAU;YACV,WAAW;YACX,iCAAiC;UACnC;;UAEA;YACE;cACE,6CAA6C;cAC7C,8CAA8C;YAChD;UACF;QACF;MACF;;MAEA;QACE;UACE;;YAEE;cACE,kCAAkC;YACpC;UACF;QACF;MACF;IACF;EACF;;EAEA;IACE,kBAAkB;IAClB,iBAAiB;IACjB,aAAa;IACb,sCAAsC;;IAEtC;MACE,cAAc;MACd,mBAAmB;MACnB,gBAAgB;IAClB;EACF;;EAEA;IACE,oBAAoB;IACpB,sCAAsC;EACxC;;EAEA;IACE,aAAa;IACb,kBAAkB;IAClB,YAAY;;IAEZ;;MAEE,kBAAkB;IACpB;;IAEA;MACE,sBAAsB;MACtB,cAAc;MACd,WAAW;MACX,eAAe;;MAEf;QACE,aAAa;QACb,YAAY;QACZ,eAAe;QACf,4CAA4C;QAC5C,mBAAmB;QACnB,uBAAuB;MACzB;;MAEA;QACE,+BAA+B;QAC/B,qBAAqB;;QAErB;UACE,WAAW;UACX,kBAAkB;UAClB,SAAS;UACT,WAAW;UACX,SAAS;UACT,UAAU;UACV,WAAW;UACX,oCAAoC;QACtC;MACF;IACF;EACF;;EAEA;IACE;MACE,aAAa;MACb,WAAW;MACX,gBAAgB;MAChB,iBAAiB;MACjB,mCAAmC;MACnC,sBAAsB;MACtB,SAAS;MACT,oBAAoB;IACtB;EACF;;EAEA;IACE,YAAY;EACd;;EAEA;IACE,YAAY;EACd;;EAEA;IACE,cAAc;IACd,gBAAgB;EAClB;;EAEA;IACE,aAAa;EACf;AACF","file":"_header.scss","sourcesContent":["/* stylelint-disable max-nesting-depth, selector-no-qualifying-type */\n@use \"../../../../vendor/govuk-frontend\" as *;\n\n/* ==========================================================================\n PROBATION#HEADER\n ========================================================================== */\n\n.probation-common-header {\n [hidden] {\n display: none;\n }\n color: govuk-colour(\"white\");\n\n background-color: govuk-colour(\"black\");\n\n &__logo {\n @include govuk-responsive-margin(3, \"right\");\n position: relative;\n top: -2px;\n padding: 15px 0;\n fill: govuk-colour(\"white\");\n }\n\n &__title {\n display: flex;\n\n &__organisation-name {\n @include govuk-responsive-margin(2, \"right\");\n @include govuk-font($size: 24, $weight: \"bold\");\n display: flex;\n align-items: center;\n }\n\n .govuk-tag {\n margin: auto 0;\n\n @include govuk-media-query($until: 985px) {\n display: none;\n }\n }\n }\n\n &__submenu-link {\n @include govuk-link-common;\n @include govuk-link-style-no-visited-state;\n }\n\n &__link {\n @include govuk-link-common;\n @include govuk-link-style-default;\n\n &:link,\n &:visited,\n &:active {\n color: govuk-colour(\"white\");\n font-weight: normal;\n text-decoration: none;\n }\n\n &:focus {\n color: govuk-colour(\"black\");\n box-shadow: none;\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"black\");\n }\n\n svg {\n fill: govuk-colour(\"black\");\n }\n }\n\n &:hover {\n text-decoration: underline;\n }\n }\n\n &__button-width-container {\n position: relative;\n }\n\n &__button-container {\n @include govuk-media-query(925px) {\n position: absolute;\n top: -70px;\n right: 0;\n background-color: govuk-colour(\"black\");\n }\n }\n\n &__navigation {\n display: flex;\n height: 70px;\n margin: 0;\n padding: 0;\n list-style: none;\n flex-direction: row;\n align-items: center;\n\n &__item {\n position: relative;\n height: 100%;\n\n > button,\n > a {\n display: flex;\n height: 100%;\n padding: 0;\n overflow: hidden;\n border: none;\n color: govuk-colour(\"white\");\n background: govuk-colour(\"black\");\n cursor: pointer;\n align-items: center;\n justify-content: center;\n @include govuk-font(16);\n\n &:hover {\n color: govuk-colour(\"mid-grey\");\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"mid-grey\");\n }\n }\n\n &.probation-common-header__menu-toggle {\n padding: 10px 0;\n\n > span {\n display: flex;\n height: 100%;\n padding: 0 15px;\n border-left: 1px solid govuk-colour(\"white\");\n align-items: center;\n\n &::before {\n content: \"\";\n display: inline-block;\n width: 8px;\n height: 8px;\n margin: 3px 15px 0 3px;\n -ms-transform: translateY(-35%) rotate(45deg) scale(1);\n -webkit-transform: translateY(-35%) rotate(45deg) scale(1);\n transform: translateY(-35%) rotate(45deg) scale(1);\n border-right: 2px solid govuk-colour(\"white\");\n border-bottom: 2px solid govuk-colour(\"white\");\n vertical-align: middle;\n }\n }\n\n svg {\n margin: 0 15px 0 0;\n }\n\n &:hover {\n > span {\n &::before {\n border-right: 2px solid govuk-colour(\"mid-grey\");\n border-bottom: 2px solid govuk-colour(\"mid-grey\");\n }\n }\n }\n }\n\n &.probation-common-header__toggle-open {\n color: govuk-colour(\"blue\");\n background: govuk-colour(\"light-grey\");\n\n > span {\n &::before {\n -ms-transform: translateY(-0%) rotate(225deg) scale(1);\n -webkit-transform: translateY(-0%) rotate(225deg) scale(1);\n transform: translateY(-0%) rotate(225deg) scale(1);\n border-right: 2px solid govuk-colour(\"blue\");\n border-bottom: 2px solid govuk-colour(\"blue\");\n }\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"blue\");\n }\n }\n\n &:hover {\n color: govuk-colour(\"dark-grey\");\n }\n }\n\n &:focus-visible {\n outline: 3px solid transparent;\n color: govuk-colour(\"black\");\n background-color: govuk-colour(\"yellow\");\n box-shadow: none;\n text-decoration: none;\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"black\");\n }\n\n > span {\n &::before {\n border-right: 2px solid govuk-colour(\"black\");\n border-bottom: 2px solid govuk-colour(\"black\");\n }\n }\n }\n }\n\n &.item-open {\n + div {\n > button,\n > a {\n > span {\n border-left: 1px solid transparent;\n }\n }\n }\n }\n }\n }\n\n .probation-common-header__user-menu {\n position: relative;\n z-index: 10000000;\n padding: 15px;\n background: govuk-colour(\"light-grey\");\n\n a {\n display: block;\n margin-bottom: 15px;\n font-weight: 700;\n }\n }\n\n &__pushdown-menu {\n padding: 30px 0 60px;\n background: govuk-colour(\"light-grey\");\n }\n\n &__icon-link-wrapper {\n display: flex;\n position: relative;\n height: 100%;\n\n img,\n svg {\n margin: 0 15px 0 0;\n }\n\n a {\n box-sizing: border-box;\n display: block;\n width: 100%;\n padding: 10px 0;\n\n > span {\n display: flex;\n height: 100%;\n padding: 0 15px;\n border-left: 1px solid govuk-colour(\"white\");\n align-items: center;\n justify-content: center;\n }\n\n &:hover {\n color: govuk-colour(\"mid-grey\");\n text-decoration: none;\n\n &::after {\n content: \"\";\n position: absolute;\n top: auto;\n right: 15px;\n bottom: 0;\n left: 15px;\n height: 3px;\n background: govuk-colour(\"mid-grey\");\n }\n }\n }\n }\n\n &__services-menu {\n ul {\n display: grid;\n width: 100%;\n margin-bottom: 0;\n font-weight: bold;\n grid-template-rows: 1fr 1fr 1fr 1fr;\n grid-auto-flow: column;\n gap: 15px;\n justify-items: start;\n }\n }\n\n &__user-menu-link {\n width: 181px;\n }\n\n &__services-menu-link {\n width: 107px;\n }\n\n &__menu-toggle-label {\n display: block;\n text-align: left;\n }\n\n @media print {\n display: none;\n }\n}\n"]}
@@ -16,15 +16,23 @@
16
16
  this.$tabOpenClass = 'probation-common-header__toggle-open';
17
17
  const $userToggle = this.$root.querySelector('.probation-common-header__user-menu-toggle');
18
18
  const $userMenu = this.$root.querySelector('#probation-common-header-user-menu');
19
- if (!$userToggle || !$userMenu || !($userToggle instanceof HTMLElement) || !($userMenu instanceof HTMLElement)) {
19
+ const $servicesToggle = this.$root.querySelector('.probation-common-header__services-menu-toggle');
20
+ const $servicesMenu = this.$root.querySelector('#probation-common-header-services-menu');
21
+ if (!$userToggle || !$userMenu || !$servicesToggle || !$servicesMenu || !($userToggle instanceof HTMLElement) || !($userMenu instanceof HTMLElement) || !($servicesToggle instanceof HTMLElement) || !($servicesMenu instanceof HTMLElement)) {
20
22
  return 0;
21
23
  }
22
24
  this.hideFallbackLinks();
23
25
  $userToggle.removeAttribute('hidden');
24
- this.closeTabs([[$userToggle, $userMenu]]);
26
+ $servicesToggle.removeAttribute('hidden');
27
+ this.closeTabs([[$userToggle, $userMenu], [$servicesToggle, $servicesMenu]]);
25
28
  $userToggle.addEventListener('click', _event => {
29
+ this.closeTabs([[$servicesToggle, $servicesMenu]]);
26
30
  this.toggleMenu($userToggle, $userMenu);
27
31
  });
32
+ $servicesToggle.addEventListener('click', _event => {
33
+ this.closeTabs([[$userToggle, $userMenu]]);
34
+ this.toggleMenu($servicesToggle, $servicesMenu);
35
+ });
28
36
  }
29
37
 
30
38
  /**
@@ -60,7 +68,9 @@
60
68
  }
61
69
  hideFallbackLinks() {
62
70
  const $userLink = this.$root.querySelector('.probation-common-header__user-menu-link');
71
+ const $servicesLink = this.$root.querySelector('.probation-common-header__services-menu-link');
63
72
  if ($userLink) $userLink.setAttribute('hidden', 'hidden');
73
+ if ($servicesLink) $servicesLink.setAttribute('hidden', 'hidden');
64
74
  }
65
75
 
66
76
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"header.bundle.js","sources":["../../../../../../src/moj/components/domain-specific/probation/header/header.mjs"],"sourcesContent":["import { Component } from 'govuk-frontend'\n\nexport class PdsHeader extends Component {\n /**\n * @param {Element | null} $root - HTML element to use for PDS header\n */\n constructor($root) {\n super($root)\n this.initHeader()\n }\n\n initHeader() {\n this.$tabOpenClass = 'probation-common-header__toggle-open'\n const $userToggle = this.$root.querySelector(\n '.probation-common-header__user-menu-toggle'\n )\n const $userMenu = this.$root.querySelector(\n '#probation-common-header-user-menu'\n )\n\n if (\n !$userToggle ||\n !$userMenu ||\n !($userToggle instanceof HTMLElement) ||\n !($userMenu instanceof HTMLElement)\n ) {\n return 0\n }\n\n this.hideFallbackLinks()\n $userToggle.removeAttribute('hidden')\n\n this.closeTabs([[$userToggle, $userMenu]])\n\n $userToggle.addEventListener('click', (_event) => {\n this.toggleMenu($userToggle, $userMenu)\n })\n }\n\n /**\n * @param {[any, any][]} tabTuples\n */\n closeTabs(tabTuples) {\n tabTuples.forEach(([toggle, menu]) => {\n if (menu && toggle) {\n menu.setAttribute('hidden', 'hidden')\n toggle.classList.remove(this.$tabOpenClass)\n toggle.parentElement.classList.remove('item-open')\n toggle.setAttribute('aria-expanded', 'false')\n if (toggle.dataset.textForShow)\n toggle.setAttribute('aria-label', toggle.dataset.textForShow)\n }\n })\n }\n\n /**\n * @param {HTMLElement} toggle\n * @param {HTMLElement} menu\n */\n toggleMenu(toggle, menu) {\n const isOpen = !menu.getAttribute('hidden')\n\n if (isOpen) {\n this.closeTabs([[toggle, menu]])\n } else if (menu && toggle) {\n menu.removeAttribute('hidden')\n toggle.classList.add(this.$tabOpenClass)\n toggle.parentElement.classList.add('item-open')\n toggle.setAttribute('aria-expanded', 'true')\n if (toggle.dataset.textForHide)\n toggle.setAttribute('aria-label', toggle.dataset.textForHide)\n }\n }\n\n hideFallbackLinks() {\n const $userLink = this.$root.querySelector(\n '.probation-common-header__user-menu-link'\n )\n if ($userLink) $userLink.setAttribute('hidden', 'hidden')\n }\n\n /**\n * Name for the component used when initialising using data-module attributes.\n */\n static moduleName = 'pds-header'\n}\n"],"names":["PdsHeader","Component","constructor","$root","initHeader","$tabOpenClass","$userToggle","querySelector","$userMenu","HTMLElement","hideFallbackLinks","removeAttribute","closeTabs","addEventListener","_event","toggleMenu","tabTuples","forEach","toggle","menu","setAttribute","classList","remove","parentElement","dataset","textForShow","isOpen","getAttribute","add","textForHide","$userLink","moduleName"],"mappings":"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"}
1
+ {"version":3,"file":"header.bundle.js","sources":["../../../../../../src/moj/components/domain-specific/probation/header/header.mjs"],"sourcesContent":["import { Component } from 'govuk-frontend'\n\nexport class PdsHeader extends Component {\n /**\n * @param {Element | null} $root - HTML element to use for PDS header\n */\n constructor($root) {\n super($root)\n this.initHeader()\n }\n\n initHeader() {\n this.$tabOpenClass = 'probation-common-header__toggle-open'\n const $userToggle = this.$root.querySelector(\n '.probation-common-header__user-menu-toggle'\n )\n const $userMenu = this.$root.querySelector(\n '#probation-common-header-user-menu'\n )\n\n const $servicesToggle = this.$root.querySelector(\n '.probation-common-header__services-menu-toggle'\n )\n\n const $servicesMenu = this.$root.querySelector(\n '#probation-common-header-services-menu'\n )\n\n if (\n !$userToggle ||\n !$userMenu ||\n !$servicesToggle ||\n !$servicesMenu ||\n !($userToggle instanceof HTMLElement) ||\n !($userMenu instanceof HTMLElement) ||\n !($servicesToggle instanceof HTMLElement) ||\n !($servicesMenu instanceof HTMLElement)\n ) {\n return 0\n }\n\n this.hideFallbackLinks()\n $userToggle.removeAttribute('hidden')\n $servicesToggle.removeAttribute('hidden')\n\n this.closeTabs([\n [$userToggle, $userMenu],\n [$servicesToggle, $servicesMenu]\n ])\n\n $userToggle.addEventListener('click', (_event) => {\n this.closeTabs([[$servicesToggle, $servicesMenu]])\n this.toggleMenu($userToggle, $userMenu)\n })\n\n $servicesToggle.addEventListener('click', (_event) => {\n this.closeTabs([[$userToggle, $userMenu]])\n this.toggleMenu($servicesToggle, $servicesMenu)\n })\n }\n\n /**\n * @param {[any, any][]} tabTuples\n */\n closeTabs(tabTuples) {\n tabTuples.forEach(([toggle, menu]) => {\n if (menu && toggle) {\n menu.setAttribute('hidden', 'hidden')\n toggle.classList.remove(this.$tabOpenClass)\n toggle.parentElement.classList.remove('item-open')\n toggle.setAttribute('aria-expanded', 'false')\n if (toggle.dataset.textForShow)\n toggle.setAttribute('aria-label', toggle.dataset.textForShow)\n }\n })\n }\n\n /**\n * @param {HTMLElement} toggle\n * @param {HTMLElement} menu\n */\n toggleMenu(toggle, menu) {\n const isOpen = !menu.getAttribute('hidden')\n\n if (isOpen) {\n this.closeTabs([[toggle, menu]])\n } else if (menu && toggle) {\n menu.removeAttribute('hidden')\n toggle.classList.add(this.$tabOpenClass)\n toggle.parentElement.classList.add('item-open')\n toggle.setAttribute('aria-expanded', 'true')\n if (toggle.dataset.textForHide)\n toggle.setAttribute('aria-label', toggle.dataset.textForHide)\n }\n }\n\n hideFallbackLinks() {\n const $userLink = this.$root.querySelector(\n '.probation-common-header__user-menu-link'\n )\n const $servicesLink = this.$root.querySelector(\n '.probation-common-header__services-menu-link'\n )\n if ($userLink) $userLink.setAttribute('hidden', 'hidden')\n if ($servicesLink) $servicesLink.setAttribute('hidden', 'hidden')\n }\n\n /**\n * Name for the component used when initialising using data-module attributes.\n */\n static moduleName = 'pds-header'\n}\n"],"names":["PdsHeader","Component","constructor","$root","initHeader","$tabOpenClass","$userToggle","querySelector","$userMenu","$servicesToggle","$servicesMenu","HTMLElement","hideFallbackLinks","removeAttribute","closeTabs","addEventListener","_event","toggleMenu","tabTuples","forEach","toggle","menu","setAttribute","classList","remove","parentElement","dataset","textForShow","isOpen","getAttribute","add","textForHide","$userLink","$servicesLink","moduleName"],"mappings":"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"}
@@ -140,15 +140,23 @@ class PdsHeader extends Component {
140
140
  this.$tabOpenClass = 'probation-common-header__toggle-open';
141
141
  const $userToggle = this.$root.querySelector('.probation-common-header__user-menu-toggle');
142
142
  const $userMenu = this.$root.querySelector('#probation-common-header-user-menu');
143
- if (!$userToggle || !$userMenu || !($userToggle instanceof HTMLElement) || !($userMenu instanceof HTMLElement)) {
143
+ const $servicesToggle = this.$root.querySelector('.probation-common-header__services-menu-toggle');
144
+ const $servicesMenu = this.$root.querySelector('#probation-common-header-services-menu');
145
+ if (!$userToggle || !$userMenu || !$servicesToggle || !$servicesMenu || !($userToggle instanceof HTMLElement) || !($userMenu instanceof HTMLElement) || !($servicesToggle instanceof HTMLElement) || !($servicesMenu instanceof HTMLElement)) {
144
146
  return 0;
145
147
  }
146
148
  this.hideFallbackLinks();
147
149
  $userToggle.removeAttribute('hidden');
148
- this.closeTabs([[$userToggle, $userMenu]]);
150
+ $servicesToggle.removeAttribute('hidden');
151
+ this.closeTabs([[$userToggle, $userMenu], [$servicesToggle, $servicesMenu]]);
149
152
  $userToggle.addEventListener('click', _event => {
153
+ this.closeTabs([[$servicesToggle, $servicesMenu]]);
150
154
  this.toggleMenu($userToggle, $userMenu);
151
155
  });
156
+ $servicesToggle.addEventListener('click', _event => {
157
+ this.closeTabs([[$userToggle, $userMenu]]);
158
+ this.toggleMenu($servicesToggle, $servicesMenu);
159
+ });
152
160
  }
153
161
 
154
162
  /**
@@ -184,7 +192,9 @@ class PdsHeader extends Component {
184
192
  }
185
193
  hideFallbackLinks() {
186
194
  const $userLink = this.$root.querySelector('.probation-common-header__user-menu-link');
195
+ const $servicesLink = this.$root.querySelector('.probation-common-header__services-menu-link');
187
196
  if ($userLink) $userLink.setAttribute('hidden', 'hidden');
197
+ if ($servicesLink) $servicesLink.setAttribute('hidden', 'hidden');
188
198
  }
189
199
 
190
200
  /**