{"version":3,"sources":["./$_lazy_route_resource lazy namespace object","./node_modules/moment/locale sync ^\\.\\/.*$","./src/@fuse/components/confirm-dialog/confirm-dialog.component.html","./src/@fuse/components/countdown/countdown.component.html","./src/@fuse/components/demo/demo-content/demo-content.component.html","./src/@fuse/components/demo/demo-sidebar/demo-sidebar.component.html","./src/@fuse/components/difference-dialog/difference-dialog.component.html","./src/@fuse/components/material-color-picker/material-color-picker.component.html","./src/@fuse/components/navigation/navigation.component.html","./src/@fuse/components/navigation/vertical/collapsable/collapsable.component.html","./src/@fuse/components/navigation/vertical/group/group.component.html","./src/@fuse/components/navigation/vertical/item/item.component.html","./src/@fuse/components/progress-bar/progress-bar.component.html","./src/@fuse/components/search-bar/search-bar.component.html","./src/@fuse/components/shortcuts/shortcuts.component.html","./src/@fuse/components/sidebar/sidebar.component.html","./src/@fuse/components/widget/widget.component.html","./src/app/app.component.html","./src/app/layout/components/content/content.component.html","./src/app/layout/components/navbar/navbar.component.html","./src/app/layout/components/navbar/vertical/style-1/style-1.component.html","./src/app/layout/components/quick-panel/quick-panel.component.html","./src/app/layout/components/quick-panel/resend-trigger/resend-trigger.component.html","./src/app/layout/components/toolbar/toolbar.component.html","./src/app/layout/components/two-step-modal/two-step-modal.component.html","./src/app/layout/vertical/layout-1/layout-1.component.html","./src/app/main/pages/customers/customer-balance-adjustment/customer-balance-adjustment.component.html","./src/app/main/pages/customers/customer-maxlimit/customer-maxlimit.component.html","./src/app/main/pages/reports/payout-receipt/payout-receipt.component.html","./node_modules/tslib/tslib.es6.js","./src/@fuse/animations/index.ts","./src/@fuse/components/confirm-dialog/confirm-dialog.component.scss","./src/@fuse/components/confirm-dialog/confirm-dialog.component.ts","./src/@fuse/components/confirm-dialog/confirm-dialog.module.ts","./src/@fuse/components/countdown/countdown.component.scss","./src/@fuse/components/countdown/countdown.component.ts","./src/@fuse/components/countdown/countdown.module.ts","./src/@fuse/components/demo/demo-content/demo-content.component.scss","./src/@fuse/components/demo/demo-content/demo-content.component.ts","./src/@fuse/components/demo/demo-sidebar/demo-sidebar.component.scss","./src/@fuse/components/demo/demo-sidebar/demo-sidebar.component.ts","./src/@fuse/components/demo/demo.module.ts","./src/@fuse/components/difference-dialog/difference-dialog.component.scss","./src/@fuse/components/difference-dialog/difference-dialog.component.ts","./src/@fuse/components/difference-dialog/difference-dialog.module.ts","./src/@fuse/components/highlight/highlight.component.scss","./src/@fuse/components/highlight/highlight.component.ts","./src/@fuse/components/highlight/highlight.module.ts","./src/@fuse/components/highlight/prism-languages.ts","./src/@fuse/components/index.ts","./src/@fuse/components/material-color-picker/material-color-picker.component.scss","./src/@fuse/components/material-color-picker/material-color-picker.component.ts","./src/@fuse/components/material-color-picker/material-color-picker.module.ts","./src/@fuse/components/navigation/navigation.component.scss","./src/@fuse/components/navigation/navigation.component.ts","./src/@fuse/components/navigation/navigation.module.ts","./src/@fuse/components/navigation/navigation.service.ts","./src/@fuse/components/navigation/vertical/collapsable/collapsable.component.scss","./src/@fuse/components/navigation/vertical/collapsable/collapsable.component.ts","./src/@fuse/components/navigation/vertical/group/group.component.scss","./src/@fuse/components/navigation/vertical/group/group.component.ts","./src/@fuse/components/navigation/vertical/item/item.component.scss","./src/@fuse/components/navigation/vertical/item/item.component.ts","./src/@fuse/components/progress-bar/progress-bar.component.scss","./src/@fuse/components/progress-bar/progress-bar.component.ts","./src/@fuse/components/progress-bar/progress-bar.module.ts","./src/@fuse/components/progress-bar/progress-bar.service.ts","./src/@fuse/components/search-bar/search-bar.component.scss","./src/@fuse/components/search-bar/search-bar.component.ts","./src/@fuse/components/search-bar/search-bar.module.ts","./src/@fuse/components/shortcuts/shortcuts.component.scss","./src/@fuse/components/shortcuts/shortcuts.component.ts","./src/@fuse/components/shortcuts/shortcuts.module.ts","./src/@fuse/components/sidebar/sidebar.component.scss","./src/@fuse/components/sidebar/sidebar.component.ts","./src/@fuse/components/sidebar/sidebar.module.ts","./src/@fuse/components/sidebar/sidebar.service.ts","./src/@fuse/components/widget/widget-toggle.directive.ts","./src/@fuse/components/widget/widget.component.scss","./src/@fuse/components/widget/widget.component.ts","./src/@fuse/components/widget/widget.module.ts","./src/@fuse/directives/directives.ts","./src/@fuse/directives/fuse-if-on-dom/fuse-if-on-dom.directive.ts","./src/@fuse/directives/fuse-inner-scroll/fuse-inner-scroll.directive.ts","./src/@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.directive.ts","./src/@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.service.ts","./src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive.ts","./src/@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.interfaces.ts","./src/@fuse/fuse.module.ts","./src/@fuse/mat-colors/index.ts","./src/@fuse/pipes/camelCaseToDash.pipe.ts","./src/@fuse/pipes/dateTime.pipe.ts","./src/@fuse/pipes/filter.pipe.ts","./src/@fuse/pipes/getById.pipe.ts","./src/@fuse/pipes/htmlToPlaintext.pipe.ts","./src/@fuse/pipes/keys.pipe.ts","./src/@fuse/pipes/pipes.module.ts","./src/@fuse/pipes/sanitizeHtml.pipe.ts","./src/@fuse/services/config.service.ts","./src/@fuse/services/match-media.service.ts","./src/@fuse/services/splash-screen.service.ts","./src/@fuse/services/translation-loader.service.ts","./src/@fuse/shared.module.ts","./src/@fuse/utils/index.ts","./src/app/app.component.scss","./src/app/app.component.ts","./src/app/app.module.ts","./src/app/auth.guard.ts","./src/app/basic-auth.interceptor.ts","./src/app/constants.ts","./src/app/fake-db/academy.ts","./src/app/fake-db/calendar.ts","./src/app/fake-db/chat-panel.ts","./src/app/fake-db/chat.ts","./src/app/fake-db/contacts.ts","./src/app/fake-db/dashboard-analytics.ts","./src/app/fake-db/dashboard-project.ts","./src/app/fake-db/e-commerce.ts","./src/app/fake-db/fake-db.service.ts","./src/app/fake-db/faq.ts","./src/app/fake-db/file-manager.ts","./src/app/fake-db/icons.ts","./src/app/fake-db/invoice.ts","./src/app/fake-db/knowledge-base.ts","./src/app/fake-db/mail.ts","./src/app/fake-db/profile.ts","./src/app/fake-db/quick-panel.ts","./src/app/fake-db/scrumboard.ts","./src/app/fake-db/search.ts","./src/app/fake-db/todo.ts","./src/app/fuse-config/index.ts","./src/app/http-error.interceptor.ts","./src/app/layout/components/content/content.component.scss","./src/app/layout/components/content/content.component.ts","./src/app/layout/components/content/content.module.ts","./src/app/layout/components/navbar/navbar.component.scss","./src/app/layout/components/navbar/navbar.component.ts","./src/app/layout/components/navbar/navbar.module.ts","./src/app/layout/components/navbar/vertical/style-1/style-1.component.scss","./src/app/layout/components/navbar/vertical/style-1/style-1.component.ts","./src/app/layout/components/navbar/vertical/style-1/style-1.module.ts","./src/app/layout/components/quick-panel/quick-panel.component.scss","./src/app/layout/components/quick-panel/quick-panel.component.ts","./src/app/layout/components/quick-panel/quick-panel.module.ts","./src/app/layout/components/quick-panel/resend-trigger/resend-trigger.component.scss","./src/app/layout/components/quick-panel/resend-trigger/resend-trigger.component.ts","./src/app/layout/components/toolbar/toolbar.component.scss","./src/app/layout/components/toolbar/toolbar.component.ts","./src/app/layout/components/toolbar/toolbar.module.ts","./src/app/layout/components/two-step-modal/two-step-modal.component.scss","./src/app/layout/components/two-step-modal/two-step-modal.component.ts","./src/app/layout/components/two-step-modal/two-step-modal.module.ts","./src/app/layout/layout.module.ts","./src/app/layout/vertical/layout-1/layout-1.component.scss","./src/app/layout/vertical/layout-1/layout-1.component.ts","./src/app/layout/vertical/layout-1/layout-1.module.ts","./src/app/main/pages/company-point-accounts/point-accounts.service.ts","./src/app/main/pages/customers/customer-balance-adjustment/customer-balance-adjustment.component.scss","./src/app/main/pages/customers/customer-balance-adjustment/customer-balance-adjustment.component.ts","./src/app/main/pages/customers/customer-maxlimit/customer-maxlimit.component.scss","./src/app/main/pages/customers/customer-maxlimit/customer-maxlimit.component.ts","./src/app/main/pages/customers/customers-service.ts","./src/app/main/pages/page.service.ts","./src/app/main/pages/profile/profile.service.ts","./src/app/main/pages/reports/payout-receipt/payout-receipt.component.scss","./src/app/main/pages/reports/payout-receipt/payout-receipt.component.ts","./src/app/main/pages/reports/reports.service.ts","./src/app/navigation/navigation.ts","./src/app/shared/auth.service.ts","./src/app/shared/custom-translate.service.ts","./src/app/shared/preventAccess.guard.ts","./src/app/shared/rest.service.ts","./src/app/shared/share.service.ts","./src/app/shared/user.service.ts","./src/environments/environment.ts","./src/hmr.ts","./src/main.ts"],"names":[],"mappings":";;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,EAAE;AACF;AACA;AACA;AACA;AACA;AACA,qC;;;;;;;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;A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AAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;IAC9K,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;IAC9K,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;IAC9K,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;IAC9K,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;IAC9K,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;IAC9K,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS;IAC9K,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS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","file":"main-es2015.js","sourcesContent":["var map = {\n\t\"./main/pages/pages.module\": [\n\t\t\"./src/app/main/pages/pages.module.ts\",\n\t\t\"common\",\n\t\t\"main-pages-pages-module\"\n\t]\n};\nfunction webpackAsyncContext(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\treturn Promise.resolve().then(function() {\n\t\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\t\te.code = 'MODULE_NOT_FOUND';\n\t\t\tthrow e;\n\t\t});\n\t}\n\n\tvar ids = map[req], id = ids[0];\n\treturn Promise.all(ids.slice(1).map(__webpack_require__.e)).then(function() {\n\t\treturn __webpack_require__(id);\n\t});\n}\nwebpackAsyncContext.keys = function webpackAsyncContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackAsyncContext.id = \"./$$_lazy_route_resource lazy recursive\";\nmodule.exports = webpackAsyncContext;","var map = {\n\t\"./af\": \"./node_modules/moment/locale/af.js\",\n\t\"./af.js\": \"./node_modules/moment/locale/af.js\",\n\t\"./ar\": \"./node_modules/moment/locale/ar.js\",\n\t\"./ar-dz\": \"./node_modules/moment/locale/ar-dz.js\",\n\t\"./ar-dz.js\": \"./node_modules/moment/locale/ar-dz.js\",\n\t\"./ar-kw\": \"./node_modules/moment/locale/ar-kw.js\",\n\t\"./ar-kw.js\": \"./node_modules/moment/locale/ar-kw.js\",\n\t\"./ar-ly\": \"./node_modules/moment/locale/ar-ly.js\",\n\t\"./ar-ly.js\": \"./node_modules/moment/locale/ar-ly.js\",\n\t\"./ar-ma\": \"./node_modules/moment/locale/ar-ma.js\",\n\t\"./ar-ma.js\": \"./node_modules/moment/locale/ar-ma.js\",\n\t\"./ar-sa\": \"./node_modules/moment/locale/ar-sa.js\",\n\t\"./ar-sa.js\": \"./node_modules/moment/locale/ar-sa.js\",\n\t\"./ar-tn\": \"./node_modules/moment/locale/ar-tn.js\",\n\t\"./ar-tn.js\": \"./node_modules/moment/locale/ar-tn.js\",\n\t\"./ar.js\": \"./node_modules/moment/locale/ar.js\",\n\t\"./az\": \"./node_modules/moment/locale/az.js\",\n\t\"./az.js\": \"./node_modules/moment/locale/az.js\",\n\t\"./be\": \"./node_modules/moment/locale/be.js\",\n\t\"./be.js\": \"./node_modules/moment/locale/be.js\",\n\t\"./bg\": \"./node_modules/moment/locale/bg.js\",\n\t\"./bg.js\": \"./node_modules/moment/locale/bg.js\",\n\t\"./bm\": \"./node_modules/moment/locale/bm.js\",\n\t\"./bm.js\": \"./node_modules/moment/locale/bm.js\",\n\t\"./bn\": \"./node_modules/moment/locale/bn.js\",\n\t\"./bn.js\": \"./node_modules/moment/locale/bn.js\",\n\t\"./bo\": \"./node_modules/moment/locale/bo.js\",\n\t\"./bo.js\": \"./node_modules/moment/locale/bo.js\",\n\t\"./br\": \"./node_modules/moment/locale/br.js\",\n\t\"./br.js\": \"./node_modules/moment/locale/br.js\",\n\t\"./bs\": \"./node_modules/moment/locale/bs.js\",\n\t\"./bs.js\": \"./node_modules/moment/locale/bs.js\",\n\t\"./ca\": \"./node_modules/moment/locale/ca.js\",\n\t\"./ca.js\": \"./node_modules/moment/locale/ca.js\",\n\t\"./cs\": \"./node_modules/moment/locale/cs.js\",\n\t\"./cs.js\": \"./node_modules/moment/locale/cs.js\",\n\t\"./cv\": \"./node_modules/moment/locale/cv.js\",\n\t\"./cv.js\": \"./node_modules/moment/locale/cv.js\",\n\t\"./cy\": \"./node_modules/moment/locale/cy.js\",\n\t\"./cy.js\": \"./node_modules/moment/locale/cy.js\",\n\t\"./da\": \"./node_modules/moment/locale/da.js\",\n\t\"./da.js\": \"./node_modules/moment/locale/da.js\",\n\t\"./de\": \"./node_modules/moment/locale/de.js\",\n\t\"./de-at\": \"./node_modules/moment/locale/de-at.js\",\n\t\"./de-at.js\": \"./node_modules/moment/locale/de-at.js\",\n\t\"./de-ch\": \"./node_modules/moment/locale/de-ch.js\",\n\t\"./de-ch.js\": \"./node_modules/moment/locale/de-ch.js\",\n\t\"./de.js\": \"./node_modules/moment/locale/de.js\",\n\t\"./dv\": \"./node_modules/moment/locale/dv.js\",\n\t\"./dv.js\": \"./node_modules/moment/locale/dv.js\",\n\t\"./el\": \"./node_modules/moment/locale/el.js\",\n\t\"./el.js\": \"./node_modules/moment/locale/el.js\",\n\t\"./en-SG\": \"./node_modules/moment/locale/en-SG.js\",\n\t\"./en-SG.js\": \"./node_modules/moment/locale/en-SG.js\",\n\t\"./en-au\": \"./node_modules/moment/locale/en-au.js\",\n\t\"./en-au.js\": \"./node_modules/moment/locale/en-au.js\",\n\t\"./en-ca\": \"./node_modules/moment/locale/en-ca.js\",\n\t\"./en-ca.js\": \"./node_modules/moment/locale/en-ca.js\",\n\t\"./en-gb\": \"./node_modules/moment/locale/en-gb.js\",\n\t\"./en-gb.js\": \"./node_modules/moment/locale/en-gb.js\",\n\t\"./en-ie\": \"./node_modules/moment/locale/en-ie.js\",\n\t\"./en-ie.js\": \"./node_modules/moment/locale/en-ie.js\",\n\t\"./en-il\": \"./node_modules/moment/locale/en-il.js\",\n\t\"./en-il.js\": \"./node_modules/moment/locale/en-il.js\",\n\t\"./en-nz\": \"./node_modules/moment/locale/en-nz.js\",\n\t\"./en-nz.js\": \"./node_modules/moment/locale/en-nz.js\",\n\t\"./eo\": \"./node_modules/moment/locale/eo.js\",\n\t\"./eo.js\": \"./node_modules/moment/locale/eo.js\",\n\t\"./es\": \"./node_modules/moment/locale/es.js\",\n\t\"./es-do\": \"./node_modules/moment/locale/es-do.js\",\n\t\"./es-do.js\": \"./node_modules/moment/locale/es-do.js\",\n\t\"./es-us\": \"./node_modules/moment/locale/es-us.js\",\n\t\"./es-us.js\": \"./node_modules/moment/locale/es-us.js\",\n\t\"./es.js\": \"./node_modules/moment/locale/es.js\",\n\t\"./et\": \"./node_modules/moment/locale/et.js\",\n\t\"./et.js\": \"./node_modules/moment/locale/et.js\",\n\t\"./eu\": \"./node_modules/moment/locale/eu.js\",\n\t\"./eu.js\": \"./node_modules/moment/locale/eu.js\",\n\t\"./fa\": \"./node_modules/moment/locale/fa.js\",\n\t\"./fa.js\": \"./node_modules/moment/locale/fa.js\",\n\t\"./fi\": \"./node_modules/moment/locale/fi.js\",\n\t\"./fi.js\": \"./node_modules/moment/locale/fi.js\",\n\t\"./fo\": \"./node_modules/moment/locale/fo.js\",\n\t\"./fo.js\": \"./node_modules/moment/locale/fo.js\",\n\t\"./fr\": \"./node_modules/moment/locale/fr.js\",\n\t\"./fr-ca\": \"./node_modules/moment/locale/fr-ca.js\",\n\t\"./fr-ca.js\": \"./node_modules/moment/locale/fr-ca.js\",\n\t\"./fr-ch\": \"./node_modules/moment/locale/fr-ch.js\",\n\t\"./fr-ch.js\": \"./node_modules/moment/locale/fr-ch.js\",\n\t\"./fr.js\": \"./node_modules/moment/locale/fr.js\",\n\t\"./fy\": \"./node_modules/moment/locale/fy.js\",\n\t\"./fy.js\": \"./node_modules/moment/locale/fy.js\",\n\t\"./ga\": \"./node_modules/moment/locale/ga.js\",\n\t\"./ga.js\": \"./node_modules/moment/locale/ga.js\",\n\t\"./gd\": \"./node_modules/moment/locale/gd.js\",\n\t\"./gd.js\": \"./node_modules/moment/locale/gd.js\",\n\t\"./gl\": \"./node_modules/moment/locale/gl.js\",\n\t\"./gl.js\": \"./node_modules/moment/locale/gl.js\",\n\t\"./gom-latn\": \"./node_modules/moment/locale/gom-latn.js\",\n\t\"./gom-latn.js\": \"./node_modules/moment/locale/gom-latn.js\",\n\t\"./gu\": \"./node_modules/moment/locale/gu.js\",\n\t\"./gu.js\": \"./node_modules/moment/locale/gu.js\",\n\t\"./he\": \"./node_modules/moment/locale/he.js\",\n\t\"./he.js\": \"./node_modules/moment/locale/he.js\",\n\t\"./hi\": \"./node_modules/moment/locale/hi.js\",\n\t\"./hi.js\": \"./node_modules/moment/locale/hi.js\",\n\t\"./hr\": \"./node_modules/moment/locale/hr.js\",\n\t\"./hr.js\": \"./node_modules/moment/locale/hr.js\",\n\t\"./hu\": \"./node_modules/moment/locale/hu.js\",\n\t\"./hu.js\": \"./node_modules/moment/locale/hu.js\",\n\t\"./hy-am\": \"./node_modules/moment/locale/hy-am.js\",\n\t\"./hy-am.js\": \"./node_modules/moment/locale/hy-am.js\",\n\t\"./id\": \"./node_modules/moment/locale/id.js\",\n\t\"./id.js\": \"./node_modules/moment/locale/id.js\",\n\t\"./is\": \"./node_modules/moment/locale/is.js\",\n\t\"./is.js\": \"./node_modules/moment/locale/is.js\",\n\t\"./it\": \"./node_modules/moment/locale/it.js\",\n\t\"./it-ch\": \"./node_modules/moment/locale/it-ch.js\",\n\t\"./it-ch.js\": \"./node_modules/moment/locale/it-ch.js\",\n\t\"./it.js\": \"./node_modules/moment/locale/it.js\",\n\t\"./ja\": \"./node_modules/moment/locale/ja.js\",\n\t\"./ja.js\": \"./node_modules/moment/locale/ja.js\",\n\t\"./jv\": \"./node_modules/moment/locale/jv.js\",\n\t\"./jv.js\": \"./node_modules/moment/locale/jv.js\",\n\t\"./ka\": \"./node_modules/moment/locale/ka.js\",\n\t\"./ka.js\": \"./node_modules/moment/locale/ka.js\",\n\t\"./kk\": \"./node_modules/moment/locale/kk.js\",\n\t\"./kk.js\": \"./node_modules/moment/locale/kk.js\",\n\t\"./km\": \"./node_modules/moment/locale/km.js\",\n\t\"./km.js\": \"./node_modules/moment/locale/km.js\",\n\t\"./kn\": \"./node_modules/moment/locale/kn.js\",\n\t\"./kn.js\": \"./node_modules/moment/locale/kn.js\",\n\t\"./ko\": \"./node_modules/moment/locale/ko.js\",\n\t\"./ko.js\": \"./node_modules/moment/locale/ko.js\",\n\t\"./ku\": \"./node_modules/moment/locale/ku.js\",\n\t\"./ku.js\": \"./node_modules/moment/locale/ku.js\",\n\t\"./ky\": \"./node_modules/moment/locale/ky.js\",\n\t\"./ky.js\": \"./node_modules/moment/locale/ky.js\",\n\t\"./lb\": \"./node_modules/moment/locale/lb.js\",\n\t\"./lb.js\": \"./node_modules/moment/locale/lb.js\",\n\t\"./lo\": \"./node_modules/moment/locale/lo.js\",\n\t\"./lo.js\": \"./node_modules/moment/locale/lo.js\",\n\t\"./lt\": \"./node_modules/moment/locale/lt.js\",\n\t\"./lt.js\": \"./node_modules/moment/locale/lt.js\",\n\t\"./lv\": \"./node_modules/moment/locale/lv.js\",\n\t\"./lv.js\": \"./node_modules/moment/locale/lv.js\",\n\t\"./me\": \"./node_modules/moment/locale/me.js\",\n\t\"./me.js\": \"./node_modules/moment/locale/me.js\",\n\t\"./mi\": \"./node_modules/moment/locale/mi.js\",\n\t\"./mi.js\": \"./node_modules/moment/locale/mi.js\",\n\t\"./mk\": \"./node_modules/moment/locale/mk.js\",\n\t\"./mk.js\": \"./node_modules/moment/locale/mk.js\",\n\t\"./ml\": \"./node_modules/moment/locale/ml.js\",\n\t\"./ml.js\": \"./node_modules/moment/locale/ml.js\",\n\t\"./mn\": \"./node_modules/moment/locale/mn.js\",\n\t\"./mn.js\": \"./node_modules/moment/locale/mn.js\",\n\t\"./mr\": \"./node_modules/moment/locale/mr.js\",\n\t\"./mr.js\": \"./node_modules/moment/locale/mr.js\",\n\t\"./ms\": \"./node_modules/moment/locale/ms.js\",\n\t\"./ms-my\": \"./node_modules/moment/locale/ms-my.js\",\n\t\"./ms-my.js\": \"./node_modules/moment/locale/ms-my.js\",\n\t\"./ms.js\": \"./node_modules/moment/locale/ms.js\",\n\t\"./mt\": \"./node_modules/moment/locale/mt.js\",\n\t\"./mt.js\": \"./node_modules/moment/locale/mt.js\",\n\t\"./my\": \"./node_modules/moment/locale/my.js\",\n\t\"./my.js\": \"./node_modules/moment/locale/my.js\",\n\t\"./nb\": \"./node_modules/moment/locale/nb.js\",\n\t\"./nb.js\": \"./node_modules/moment/locale/nb.js\",\n\t\"./ne\": \"./node_modules/moment/locale/ne.js\",\n\t\"./ne.js\": \"./node_modules/moment/locale/ne.js\",\n\t\"./nl\": \"./node_modules/moment/locale/nl.js\",\n\t\"./nl-be\": \"./node_modules/moment/locale/nl-be.js\",\n\t\"./nl-be.js\": \"./node_modules/moment/locale/nl-be.js\",\n\t\"./nl.js\": \"./node_modules/moment/locale/nl.js\",\n\t\"./nn\": \"./node_modules/moment/locale/nn.js\",\n\t\"./nn.js\": \"./node_modules/moment/locale/nn.js\",\n\t\"./pa-in\": \"./node_modules/moment/locale/pa-in.js\",\n\t\"./pa-in.js\": \"./node_modules/moment/locale/pa-in.js\",\n\t\"./pl\": \"./node_modules/moment/locale/pl.js\",\n\t\"./pl.js\": \"./node_modules/moment/locale/pl.js\",\n\t\"./pt\": \"./node_modules/moment/locale/pt.js\",\n\t\"./pt-br\": \"./node_modules/moment/locale/pt-br.js\",\n\t\"./pt-br.js\": \"./node_modules/moment/locale/pt-br.js\",\n\t\"./pt.js\": \"./node_modules/moment/locale/pt.js\",\n\t\"./ro\": \"./node_modules/moment/locale/ro.js\",\n\t\"./ro.js\": \"./node_modules/moment/locale/ro.js\",\n\t\"./ru\": \"./node_modules/moment/locale/ru.js\",\n\t\"./ru.js\": \"./node_modules/moment/locale/ru.js\",\n\t\"./sd\": \"./node_modules/moment/locale/sd.js\",\n\t\"./sd.js\": \"./node_modules/moment/locale/sd.js\",\n\t\"./se\": \"./node_modules/moment/locale/se.js\",\n\t\"./se.js\": \"./node_modules/moment/locale/se.js\",\n\t\"./si\": \"./node_modules/moment/locale/si.js\",\n\t\"./si.js\": \"./node_modules/moment/locale/si.js\",\n\t\"./sk\": \"./node_modules/moment/locale/sk.js\",\n\t\"./sk.js\": \"./node_modules/moment/locale/sk.js\",\n\t\"./sl\": \"./node_modules/moment/locale/sl.js\",\n\t\"./sl.js\": \"./node_modules/moment/locale/sl.js\",\n\t\"./sq\": \"./node_modules/moment/locale/sq.js\",\n\t\"./sq.js\": \"./node_modules/moment/locale/sq.js\",\n\t\"./sr\": \"./node_modules/moment/locale/sr.js\",\n\t\"./sr-cyrl\": \"./node_modules/moment/locale/sr-cyrl.js\",\n\t\"./sr-cyrl.js\": \"./node_modules/moment/locale/sr-cyrl.js\",\n\t\"./sr.js\": \"./node_modules/moment/locale/sr.js\",\n\t\"./ss\": \"./node_modules/moment/locale/ss.js\",\n\t\"./ss.js\": \"./node_modules/moment/locale/ss.js\",\n\t\"./sv\": \"./node_modules/moment/locale/sv.js\",\n\t\"./sv.js\": \"./node_modules/moment/locale/sv.js\",\n\t\"./sw\": \"./node_modules/moment/locale/sw.js\",\n\t\"./sw.js\": \"./node_modules/moment/locale/sw.js\",\n\t\"./ta\": \"./node_modules/moment/locale/ta.js\",\n\t\"./ta.js\": \"./node_modules/moment/locale/ta.js\",\n\t\"./te\": \"./node_modules/moment/locale/te.js\",\n\t\"./te.js\": \"./node_modules/moment/locale/te.js\",\n\t\"./tet\": \"./node_modules/moment/locale/tet.js\",\n\t\"./tet.js\": \"./node_modules/moment/locale/tet.js\",\n\t\"./tg\": \"./node_modules/moment/locale/tg.js\",\n\t\"./tg.js\": \"./node_modules/moment/locale/tg.js\",\n\t\"./th\": \"./node_modules/moment/locale/th.js\",\n\t\"./th.js\": \"./node_modules/moment/locale/th.js\",\n\t\"./tl-ph\": \"./node_modules/moment/locale/tl-ph.js\",\n\t\"./tl-ph.js\": \"./node_modules/moment/locale/tl-ph.js\",\n\t\"./tlh\": \"./node_modules/moment/locale/tlh.js\",\n\t\"./tlh.js\": \"./node_modules/moment/locale/tlh.js\",\n\t\"./tr\": \"./node_modules/moment/locale/tr.js\",\n\t\"./tr.js\": \"./node_modules/moment/locale/tr.js\",\n\t\"./tzl\": \"./node_modules/moment/locale/tzl.js\",\n\t\"./tzl.js\": \"./node_modules/moment/locale/tzl.js\",\n\t\"./tzm\": \"./node_modules/moment/locale/tzm.js\",\n\t\"./tzm-latn\": \"./node_modules/moment/locale/tzm-latn.js\",\n\t\"./tzm-latn.js\": \"./node_modules/moment/locale/tzm-latn.js\",\n\t\"./tzm.js\": \"./node_modules/moment/locale/tzm.js\",\n\t\"./ug-cn\": \"./node_modules/moment/locale/ug-cn.js\",\n\t\"./ug-cn.js\": \"./node_modules/moment/locale/ug-cn.js\",\n\t\"./uk\": \"./node_modules/moment/locale/uk.js\",\n\t\"./uk.js\": \"./node_modules/moment/locale/uk.js\",\n\t\"./ur\": \"./node_modules/moment/locale/ur.js\",\n\t\"./ur.js\": \"./node_modules/moment/locale/ur.js\",\n\t\"./uz\": \"./node_modules/moment/locale/uz.js\",\n\t\"./uz-latn\": \"./node_modules/moment/locale/uz-latn.js\",\n\t\"./uz-latn.js\": \"./node_modules/moment/locale/uz-latn.js\",\n\t\"./uz.js\": \"./node_modules/moment/locale/uz.js\",\n\t\"./vi\": \"./node_modules/moment/locale/vi.js\",\n\t\"./vi.js\": \"./node_modules/moment/locale/vi.js\",\n\t\"./x-pseudo\": \"./node_modules/moment/locale/x-pseudo.js\",\n\t\"./x-pseudo.js\": \"./node_modules/moment/locale/x-pseudo.js\",\n\t\"./yo\": \"./node_modules/moment/locale/yo.js\",\n\t\"./yo.js\": \"./node_modules/moment/locale/yo.js\",\n\t\"./zh-cn\": \"./node_modules/moment/locale/zh-cn.js\",\n\t\"./zh-cn.js\": \"./node_modules/moment/locale/zh-cn.js\",\n\t\"./zh-hk\": \"./node_modules/moment/locale/zh-hk.js\",\n\t\"./zh-hk.js\": \"./node_modules/moment/locale/zh-hk.js\",\n\t\"./zh-tw\": \"./node_modules/moment/locale/zh-tw.js\",\n\t\"./zh-tw.js\": \"./node_modules/moment/locale/zh-tw.js\"\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = \"./node_modules/moment/locale sync recursive ^\\\\.\\\\/.*$\";","export default \"
\\r\\n

Confirm

\\r\\n
{{confirmMessage}}
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n\"","export default \"
\\r\\n\\r\\n
\\r\\n
\\r\\n {{countdown.days}}\\r\\n
\\r\\n
\\r\\n days\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n {{countdown.hours}}\\r\\n
\\r\\n
\\r\\n hours\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n {{countdown.minutes}}\\r\\n
\\r\\n
\\r\\n minutes\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n {{countdown.seconds}}\\r\\n
\\r\\n
\\r\\n seconds\\r\\n
\\r\\n
\\r\\n\\r\\n
\"","export default \"\\r\\n
\\r\\n\\r\\n

Early Sunrise in Winter

\\r\\n

Demo Content

\\r\\n\\r\\n

\\r\\n Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse tortor nibh, convallis sed purus nec,\\r\\n auctor venenatis nisl. Suspendisse potenti. Nullam sagittis nulla in diam finibus, sed pharetra velit\\r\\n vestibulum. Suspendisse euismod in urna eu posuere.\\r\\n

\\r\\n\\r\\n
\\r\\n

\\r\\n Nunc vel lacinia lorem. Nullam tincidunt sed purus eu placerat. Donec id dictum erat. Etiam enim ex, dapibus\\r\\n et tortor id, posuere pretium est. Maecenas fringilla ipsum vitae neque elementum, at eleifend ante\\r\\n sollicitudin. Donec viverra augue dolor, a venenatis tellus consectetur sit amet.\\r\\n

\\r\\n
\\r\\n John Doe\\r\\n
\\r\\n
\\r\\n\\r\\n

\\r\\n Ut ornare sit amet velit vel congue. Ut nec tristique eros. Lorem ipsum dolor sit amet, consectetur\\r\\n adipiscing elit. Vivamus sed lorem quis nibh porta iaculis. Vestibulum ut eleifend ante, at semper mi.\\r\\n Nam imperdiet est nisi, quis hendrerit tellus convallis et. Morbi in luctus neque. Curabitur elementum ut est et\\r\\n gravida. In hac habitasse platea dictumst. In et placerat eros, eu tempor turpis. Curabitur ac felis finibus,\\r\\n elementum lectus vitae, venenatis est. Integer mollis nisl a eros scelerisque varius. Etiam venenatis lectus vel\\r\\n erat condimentum tristique vel vel mi. Nulla id euismod mi, et mollis tellus.\\r\\n

\\r\\n\\r\\n

\\r\\n Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Class aptent taciti\\r\\n sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Curabitur vitae sagittis odio.\\r\\n Suspendisse ullamcorper nunc non pellentesque laoreet. Curabitur eu tortor id quam pretium mattis. Proin ut quam\\r\\n velit.\\r\\n

\\r\\n\\r\\n \\r\\n\\r\\n

\\r\\n Nullam tincidunt sed purus eu placerat. Donec id dictum erat. Etiam enim ex, dapibus et tortor id.\\r\\n

\\r\\n\\r\\n

\\r\\n Quisque sit amet risus enim. Aliquam sit amet interdum justo, at ultricies sapien. Suspendisse et semper urna,\\r\\n in gravida eros. Quisque id nibh iaculis, euismod urna sed, egestas nisi. Donec eros metus, congue a imperdiet\\r\\n feugiat, sagittis nec ipsum. Quisque dapibus mollis felis non tristique.\\r\\n

\\r\\n\\r\\n

\\r\\n Ut auctor, metus sed dapibus tempus, urna diam auctor odio, in malesuada odio risus vitae nisi. Etiam blandit\\r\\n ante urna, vitae placerat massa mollis in. Duis nec urna ac purus semper dictum ut eget justo. Aenean non\\r\\n sagittis augue. Sed venenatis rhoncus enim eget ornare. Donec viverra sed felis at venenatis.\\r\\n Mauris aliquam fringilla nulla, sit amet congue felis dignissim at.\\r\\n

\\r\\n\\r\\n \\r\\n\\r\\n

\\r\\n Quisque accumsan augue tempor ante mollis, sed placerat diam porttitor. Vestibulum dignissim sem vel velit\\r\\n eleifend, non pellentesque quam convallis. Pellentesque est dolor, dignissim ac tortor tristique, hendrerit\\r\\n iaculis metus. Praesent pulvinar quam eu leo consectetur faucibus. Vestibulum purus diam, gravida sagittis\\r\\n feugiat sit amet, tincidunt in ligula. Sed semper vestibulum magna. Lorem ipsum dolor sit amet, consectetur\\r\\n adipiscing elit. Suspendisse tortor nibh, convallis sed purus nec, auctor venenatis nisl. Suspendisse potenti.\\r\\n

\\r\\n\\r\\n

\\r\\n Nullam sagittis nulla in diam finibus, sed pharetra velit vestibulum. Suspendisse euismod in urna eu posuere.\\r\\n Etiam blandit nunc arcu, et consectetur orci blandit a. Aliquam condimentum pharetra quam at ultricies. Nunc vel\\r\\n lacinia lorem. Nullam tincidunt sed purus eu placerat. Donec id dictum erat. Etiam enim ex, dapibus et tortor\\r\\n id, posuere pretium est. Maecenas fringilla ipsum vitae neque elementum, at eleifend ante sollicitudin. Donec\\r\\n viverra augue dolor, a venenatis tellus consectetur sit amet.\\r\\n

\\r\\n
\\r\\n\\r\\n\"","export default \"
\\r\\n \\r\\n

Sidebar Demo

\\r\\n\\r\\n \\r\\n Sidebar Item 1\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 2\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 3\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 4\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 5\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 6\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 7\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 8\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 9\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 10\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 11\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 12\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 13\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 14\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 15\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n Sidebar Item 16\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n\"","export default \"
\\r\\n
\\r\\n

{{ pair.key }}:

\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n
\"","export default \"\\r\\n\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n {{selectedColor.palette}} {{selectedColor.hue}}\\r\\n \\r\\n\\r\\n \\r\\n Select a Color\\r\\n \\r\\n\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n\"","export default \"
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\"","export default \"\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n {{item.icon}}\\r\\n {{item.title}}\\r\\n \\r\\n {{item.badge.title}}\\r\\n \\r\\n keyboard_arrow_right\\r\\n \\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n\"","export default \"\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n\\r\\n
\"","export default \"\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n {{item.icon}}\\r\\n {{item.title}}\\r\\n \\r\\n {{item.badge.title}}\\r\\n \\r\\n \\r\\n\\r\\n\"","export default \"\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n\"","export default \"
\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\"","export default \"
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n {{shortcutItem.icon}}\\r\\n \\r\\n\\r\\n \\r\\n {{shortcutItem.title.substr(0, 1).toUpperCase()}}\\r\\n \\r\\n\\r\\n

{{shortcutItem.title}}

\\r\\n\\r\\n star\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n

\\r\\n No shortcuts yet!\\r\\n

\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n {{navigationItem.icon}}\\r\\n \\r\\n\\r\\n \\r\\n {{navigationItem.title.substr(0, 1).toUpperCase()}}\\r\\n \\r\\n\\r\\n

{{navigationItem.title}}

\\r\\n\\r\\n star\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\"","export default \"\"","export default \"\\r\\n\"","export default \"\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n\\r\\n\"","export default \"\\r\\n\"","export default \"\\r\\n\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n\"","export default \"
\\r\\n\\r\\n
\\r\\n \\r\\n {{companyName}}\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
{{companyName}}
\\r\\n
{{userEmail}}
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n edit\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n\"","export default \"
\\r\\n\\r\\n \\r\\n
\\r\\n
\\r\\n Customer Details\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n Customer Details\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n 1\\\">\\r\\n Select Point Account\\r\\n \\r\\n {{ PointAccounts.accountName }}\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n \\r\\n

Name

\\r\\n

{{CustomersService.customerDetails.firstName}}  {{CustomersService.customerDetails.lastName}}

\\r\\n
\\r\\n \\r\\n

External Customer ID

\\r\\n

{{CustomersService.customerDetails.externalCustomerID}}

\\r\\n
\\r\\n \\r\\n

Point Account Status

\\r\\n

{{CustomersService.customerPointBalancesDetails.accountStatus}}

\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n

Backoffice ID

\\r\\n

{{CustomersService.customerDetails.backofficeID}}

\\r\\n
\\r\\n \\r\\n

Email :

\\r\\n

{{CustomersService.customerDetails.email}}

\\r\\n
\\r\\n \\r\\n

Phone Number :

\\r\\n

{{CustomersService.customerDetails?.phoneNumber}}

\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n

Since :

\\r\\n

{{CustomersService.customerDetails.createdDate| date:'MMM d, y h:mm:ss a'}}

\\r\\n
\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n

Address 1

\\r\\n

{{CustomersService.customerDetails?.address1}}

\\r\\n
\\r\\n \\r\\n

Address 2

\\r\\n

{{CustomersService.customerDetails?.address2 }}

\\r\\n
\\r\\n \\r\\n

City

\\r\\n

{{CustomersService.customerDetails?.city}}

\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n

State

\\r\\n

{{CustomersService.customerDetails?.state }}

\\r\\n
\\r\\n \\r\\n

Zip

\\r\\n

{{CustomersService.customerDetails?.zip }}

\\r\\n
\\r\\n \\r\\n

Country

\\r\\n

{{CustomersService.customerDetails?.countryCode }}

\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n

Active Amount

\\r\\n

{{CustomersService.customerPointBalancesDetails.activeAmount | number : '1.2-2'}}

\\r\\n
\\r\\n \\r\\n

Total Amount

\\r\\n

{{CustomersService.customerPointBalancesDetails.amount | number : '1.2-2'}}

\\r\\n
\\r\\n \\r\\n

Hold Amount

\\r\\n

{{CustomersService.customerPointBalancesDetails.holdAmount | number : '1.2-2'}}

\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n

\\r\\n Date Filters\\r\\n

\\r\\n\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n Start Date\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n Invalid Date\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n End Date\\r\\n \\r\\n \\r\\n \\r\\n Invalid Date\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n Date\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n

{{element.lastupdated| date}}

\\r\\n {{element.lastupdated | dateTime}}\\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n Amount\\r\\n \\r\\n \\r\\n {{element.amount | number : '1.2-2'}}\\r\\n  \\r\\n Cr.\\r\\n  \\r\\n Dr.\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n Balance\\r\\n \\r\\n \\r\\n {{element.updatedBalance | number : '1.2-2'}} \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n RedeemType \\r\\n \\r\\n {{getRedeemType(element.redeemType)}} \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n Ref No\\r\\n \\r\\n \\r\\n {{element.referenceNo }} \\r\\n \\r\\n \\r\\n Transaction ID\\r\\n \\r\\n \\r\\n
\\r\\n {{element.id}}\\r\\n
\\r\\n \\r\\n {{element.id}}\\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n Source\\r\\n \\r\\n {{element.sourse}}\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n Comment\\r\\n \\r\\n {{element.comment}} \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n Secondary PointAccount\\r\\n \\r\\n \\r\\n {{ getPointAccName(element.secondaryPointAccountID )}} \\r\\n \\r\\n \\r\\n CreatedBy\\r\\n \\r\\n \\r\\n {{ element.createdBy }} \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
No records found\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n

\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n Hold\\r\\n Amount \\r\\n \\r\\n {{element.holdAmount}}\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n Issue\\r\\n Date \\r\\n \\r\\n {{element.createdDate| date}} \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n Release\\r\\n Date \\r\\n \\r\\n {{element.expiryDate| date}} \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n
No records found\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n \\r\\n
\\r\\n
\\r\\n
\"","export default \"
\\r\\n\\t\\r\\n\\t\\t\\r\\n\\t\\t\\tResend Triggers\\r\\n\\t\\t\\t\\r\\n\\t\\t\\r\\n\\t\\r\\n\\r\\n\\t
\\r\\n\\t\\t
\\r\\n\\t\\t\\t
\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\tSelect Resend Trigger\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\t\\t{{ t.name }}\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t
\\r\\n\\t\\t\\t
\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t
\\r\\n\\t\\t
\\r\\n\\t
\\r\\n
\"","export default \"\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n \\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n Account\\r\\n \\r\\n \\r\\n {{PointAccount.accountName}}\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n \\r\\n\\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\\r\\n
\\r\\n\"","export default \"
\\r\\n \\r\\n \\r\\n {{dialogTitle}}\\r\\n\\r\\n
\\r\\n \\r\\n \\r\\n \\r\\n
\\r\\n
\\r\\n
\\r\\n\\r\\n
\\r\\n
\\r\\n \\r\\n Verification Code\\r\\n \\r\\n verified_user\\r\\n \\r\\n Enter verification code\\r\\n \\r\\n
\\r\\n  \\r\\n \\r\\n
\\r\\n
\\r\\n
\"","export default \"\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n \\r\\n \\r\\n\\r\\n
\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n \\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n \\r\\n \\r\\n \\r\\n\\r\\n\\r\\n\"","export default \"
\\r\\n\\t\\r\\n\\t\\t\\r\\n\\t\\t\\t{{dialogTitle}}\\r\\n\\t\\t\\t\\r\\n\\t\\t\\r\\n\\t\\r\\n\\r\\n\\t
\\r\\n\\r\\n\\t\\t
\\r\\n\\t\\t\\t\\r\\n\\t\\t\\t
\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\tTransaction Type\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\t\\t{{transactionType.transactionTypeName}}\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\tPoint Account is required\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\t\\tAmount\\r\\n\\t\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\t\\tAmount is required\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t
\\r\\n\\t\\t\\t\\r\\n\\t\\t\\t
\\r\\n\\t\\t\\t\\t 1\\\">\\r\\n\\t\\t\\t\\t\\tAccount\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\t \\r\\n\\t\\t\\t\\t\\t\\t{{pointAccount.accountName}}\\r\\n\\t\\t\\t\\t\\t \\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\tAccount is required\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\tReason\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\tReason is required\\r\\n\\t\\t\\t\\t\\r\\n\\t\\t\\t
\\r\\n\\t\\t
\\r\\n\\t
\\r\\n\\r\\n\\t
\\r\\n\\t\\t\\r\\n\\r\\n\\t\\t\\r\\n\\t
\\r\\n
\"","export default \"
\\r\\n\\t\\r\\n\\t\\t\\r\\n\\t\\t\\t{{dialogTitle}}\\r\\n\\t\\t\\t\\r\\n\\t\\t\\r\\n\\t\\r\\n\\r\\n\\t
\\r\\n\\r\\n\\t\\t
\\r\\n\\t\\t\\t
\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\t\\tMax Transfer Weekly Limit\\r\\n\\t\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t\\t\\t\\tAmount is required\\r\\n\\t\\t\\t\\t\\t\\r\\n\\t\\t\\t
\\r\\n\\t\\t
\\r\\n\\t
\\r\\n\\r\\n\\t
\\r\\n\\t\\t\\r\\n\\r\\n\\t\\t\\r\\n\\t
\\r\\n
\"","export default \"
\\r\\n \\r\\n \\r\\n International Bank Withdrawal\\r\\n
\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n\\t\\t\\t
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n \\\"\\\"\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n {{_data.transactionID}}\\r\\n
\\r\\n
\\r\\n {{dealDate | date:'longDate'}}\\r\\n
\\r\\n
\\r\\n {{dealNumber}}\\r\\n
\\r\\n
\\r\\n {{currency}}\\r\\n
\\r\\n
\\r\\n {{conversionCurrency}}\\r\\n
\\r\\n
\\r\\n {{estimateCostCurrency}} {{EstimateCostAmount}}\\r\\n
\\r\\n \\r\\n
\\r\\n {{currency}} {{currencyRate}}\\r\\n
\\r\\n \\r\\n \\r\\n
\\r\\n {{SellCurrency}} {{SellAmount}}\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n                        Cambridge Mercantile Crop,\\r\\n                        212 King Street West, Suit 400\\r\\n                        Toronto, Ontario\\r\\n                        Canada, M5H 1K5\\r\\n                        Telephone: (416) 367-4653\\r\\n                        Fax: (800) 982-4778\\r\\n                        Toll Free: (800) 374-8077\\r\\n                        www.cambridgefx.com\\r\\n                    
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n
\\r\\n\"","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\r\n if (m) return m.call(o);\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n};\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n result.default = mod;\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n","import { sequence, trigger, animate, style, group, query, transition, animateChild, state, animation, useAnimation, stagger } from '@angular/animations';\r\n\r\nconst customAnimation = animation([\r\n style({\r\n opacity : '{{opacity}}',\r\n transform: 'scale({{scale}}) translate3d({{x}}, {{y}}, {{z}})'\r\n }),\r\n animate('{{duration}} {{delay}} cubic-bezier(0.0, 0.0, 0.2, 1)', style('*'))\r\n], {\r\n params: {\r\n duration: '200ms',\r\n delay : '0ms',\r\n opacity : '0',\r\n scale : '1',\r\n x : '0',\r\n y : '0',\r\n z : '0'\r\n }\r\n});\r\n\r\nexport const fuseAnimations = [\r\n\r\n trigger('animate', [transition('void => *', [useAnimation(customAnimation)])]),\r\n\r\n trigger('animateStagger', [\r\n state('50', style('*')),\r\n state('100', style('*')),\r\n state('200', style('*')),\r\n\r\n transition('void => 50',\r\n query('@*',\r\n [\r\n stagger('50ms', [\r\n animateChild()\r\n ])\r\n ], {optional: true})),\r\n transition('void => 100',\r\n query('@*',\r\n [\r\n stagger('100ms', [\r\n animateChild()\r\n ])\r\n ], {optional: true})),\r\n transition('void => 200',\r\n query('@*',\r\n [\r\n stagger('200ms', [\r\n animateChild()\r\n ])\r\n ], {optional: true}))\r\n ]),\r\n\r\n trigger('fadeInOut', [\r\n state('0, void', style({\r\n opacity: 0\r\n })),\r\n state('1, *', style({\r\n opacity: 1\r\n })),\r\n transition('1 => 0', animate('300ms ease-out')),\r\n transition('0 => 1', animate('300ms ease-in')),\r\n transition('void <=> *', animate('300ms ease-in'))\r\n ]),\r\n\r\n trigger('slideInOut', [\r\n state('0', style({\r\n height: '0px'\r\n })),\r\n state('1', style({\r\n height: '*'\r\n })),\r\n transition('1 => 0', animate('300ms ease-out')),\r\n transition('0 => 1', animate('300ms ease-in'))\r\n ]),\r\n\r\n trigger('slideIn', [\r\n transition('void => left', [\r\n style({\r\n transform: 'translateX(100%)'\r\n }),\r\n animate('300ms ease-in',\r\n style({\r\n transform: 'translateX(0)'\r\n })\r\n )\r\n ]\r\n ),\r\n transition('left => void', [\r\n style({\r\n transform: 'translateX(0)'\r\n }),\r\n animate('300ms ease-in',\r\n style({\r\n transform: 'translateX(-100%)'\r\n })\r\n )\r\n ]\r\n ),\r\n transition('void => right', [\r\n style({\r\n transform: 'translateX(-100%)'\r\n }),\r\n animate('300ms ease-in',\r\n style({\r\n transform: 'translateX(0)'\r\n })\r\n )\r\n ]\r\n ),\r\n transition('right => void', [\r\n style({\r\n transform: 'translateX(0)'\r\n }),\r\n animate('300ms ease-in',\r\n style({\r\n transform: 'translateX(100%)'\r\n })\r\n )\r\n ]\r\n )\r\n ]),\r\n\r\n trigger('slideInLeft', [\r\n state('void', style({\r\n transform: 'translateX(-100%)',\r\n })),\r\n state('*', style({\r\n transform: 'translateX(0)',\r\n })),\r\n transition('void => *', animate('300ms')),\r\n transition('* => void', animate('300ms'))\r\n ]),\r\n\r\n trigger('slideInRight', [\r\n state('void', style({\r\n transform: 'translateX(100%)',\r\n })),\r\n state('*', style({\r\n transform: 'translateX(0)',\r\n })),\r\n transition('void => *', animate('300ms')),\r\n transition('* => void', animate('300ms'))\r\n ]),\r\n\r\n trigger('slideInTop', [\r\n state('void', style({\r\n transform: 'translateY(-100%)',\r\n })),\r\n state('*', style({\r\n transform: 'translateY(0)',\r\n })),\r\n transition('void => *', animate('300ms')),\r\n transition('* => void', animate('300ms'))\r\n ]),\r\n\r\n trigger('slideInBottom', [\r\n state('void',\r\n style({\r\n transform: 'translateY(100%)',\r\n })),\r\n state('*', style({\r\n transform: 'translateY(0)',\r\n })),\r\n transition('void => *', animate('300ms')),\r\n transition('* => void', animate('300ms'))\r\n ]),\r\n\r\n trigger('expandCollapse', [\r\n state('void', style({\r\n height: '0px'\r\n })),\r\n state('*', style({\r\n height: '*'\r\n })),\r\n transition('void => *', animate('300ms ease-out')),\r\n transition('* => void', animate('300ms ease-in'))\r\n ]),\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Router animations\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n trigger('routerTransitionLeft', [\r\n\r\n transition('* => *', [\r\n query('content > :enter, content > :leave', [\r\n style({\r\n position: 'absolute',\r\n top : 0,\r\n bottom : 0,\r\n left : 0,\r\n right : 0\r\n })\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({\r\n transform: 'translateX(100%)',\r\n opacity : 0\r\n })\r\n ], {optional: true}),\r\n sequence([\r\n group([\r\n query('content > :leave', [\r\n style({\r\n transform: 'translateX(0)',\r\n opacity : 1\r\n }),\r\n animate('600ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n transform: 'translateX(-100%)',\r\n opacity : 0\r\n }))\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({transform: 'translateX(100%)'}),\r\n animate('600ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n transform: 'translateX(0%)',\r\n opacity : 1\r\n }))\r\n ], {optional: true})\r\n ]),\r\n query('content > :leave', animateChild(), {optional: true}),\r\n query('content > :enter', animateChild(), {optional: true})\r\n ])\r\n ])\r\n ]),\r\n\r\n trigger('routerTransitionRight', [\r\n\r\n transition('* => *', [\r\n query('content > :enter, content > :leave', [\r\n style({\r\n position: 'absolute',\r\n top : 0,\r\n bottom : 0,\r\n left : 0,\r\n right : 0\r\n })\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({\r\n transform: 'translateX(-100%)',\r\n opacity : 0\r\n })\r\n ], {optional: true}),\r\n sequence([\r\n group([\r\n query('content > :leave', [\r\n style({\r\n transform: 'translateX(0)',\r\n opacity : 1\r\n }),\r\n animate('600ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n transform: 'translateX(100%)',\r\n opacity : 0\r\n }))\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({transform: 'translateX(-100%)'}),\r\n animate('600ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n transform: 'translateX(0%)',\r\n opacity : 1\r\n }))\r\n ], {optional: true})\r\n ]),\r\n query('content > :leave', animateChild(), {optional: true}),\r\n query('content > :enter', animateChild(), {optional: true})\r\n ])\r\n ])\r\n ]),\r\n\r\n trigger('routerTransitionUp', [\r\n\r\n transition('* => *', [\r\n query('content > :enter, content > :leave', [\r\n style({\r\n position: 'absolute',\r\n top : 0,\r\n bottom : 0,\r\n left : 0,\r\n right : 0\r\n })\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({\r\n transform: 'translateY(100%)',\r\n opacity : 0\r\n })\r\n ], {optional: true}),\r\n group([\r\n query('content > :leave', [\r\n style({\r\n transform: 'translateY(0)',\r\n opacity : 1\r\n }),\r\n animate('600ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n transform: 'translateY(-100%)',\r\n opacity : 0\r\n }))\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({transform: 'translateY(100%)'}),\r\n animate('600ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n transform: 'translateY(0%)',\r\n opacity : 1\r\n }))\r\n ], {optional: true})\r\n ]),\r\n query('content > :leave', animateChild(), {optional: true}),\r\n query('content > :enter', animateChild(), {optional: true})\r\n ])\r\n ]),\r\n\r\n trigger('routerTransitionDown', [\r\n\r\n transition('* => *', [\r\n query('content > :enter, content > :leave', [\r\n style({\r\n position: 'absolute',\r\n top : 0,\r\n bottom : 0,\r\n left : 0,\r\n right : 0\r\n })\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({\r\n transform: 'translateY(-100%)',\r\n opacity : 0\r\n })\r\n ], {optional: true}),\r\n sequence([\r\n group([\r\n query('content > :leave', [\r\n style({\r\n transform: 'translateY(0)',\r\n opacity : 1\r\n }),\r\n animate('600ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n transform: 'translateY(100%)',\r\n opacity : 0\r\n }))\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({transform: 'translateY(-100%)'}),\r\n animate('600ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n transform: 'translateY(0%)',\r\n opacity : 1\r\n }))\r\n ], {optional: true})\r\n ]),\r\n query('content > :leave', animateChild(), {optional: true}),\r\n query('content > :enter', animateChild(), {optional: true})\r\n ])\r\n ])\r\n ]),\r\n\r\n trigger('routerTransitionFade', [\r\n\r\n transition('* => *', group([\r\n\r\n query('content > :enter, content > :leave ', [\r\n style({\r\n position: 'absolute',\r\n top : 0,\r\n bottom : 0,\r\n left : 0,\r\n right : 0\r\n })\r\n ], {optional: true}),\r\n\r\n query('content > :enter', [\r\n style({\r\n opacity: 0\r\n })\r\n ], {optional: true}),\r\n query('content > :leave', [\r\n style({\r\n opacity: 1\r\n }),\r\n animate('300ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n opacity: 0\r\n }))\r\n ], {optional: true}),\r\n query('content > :enter', [\r\n style({\r\n opacity: 0\r\n }),\r\n animate('300ms cubic-bezier(0.0, 0.0, 0.2, 1)',\r\n style({\r\n opacity: 1\r\n }))\r\n ], {optional: true}),\r\n query('content > :enter', animateChild(), {optional: true}),\r\n query('content > :leave', animateChild(), {optional: true})\r\n ]))\r\n ])\r\n];\r\n","export default \".confirm-dialog .mat-dialog-container {\\n padding: 24px !important;\\n}\\n\\n.customClass .mat-dialog-container {\\n overflow: hidden;\\n position: relative;\\n}\\n\\n.customClass .mat-dialog-title {\\n padding: 8% 0 0 8%;\\n}\\n\\n.customClass .mat-dialog-content {\\n margin-left: 2%;\\n max-width: 90%;\\n}\\n\\n.customClass .mat-dialog-actions {\\n margin-left: 8%;\\n margin-bottom: 2%;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL2NvbmZpcm0tZGlhbG9nL0M6XFxQcm9ncmFtRGF0YVxcSmVua2luc1xcLmplbmtpbnNcXHdvcmtzcGFjZVxcUlBNU1xcVUlcXExpdmUgKFVJIHJ1bm5pbmcgb24gUGF5bWVudHVyZSBBV1MpXFxwYXltZW50dXJlLmNvbS9zcmNcXEBmdXNlXFxjb21wb25lbnRzXFxjb25maXJtLWRpYWxvZ1xcY29uZmlybS1kaWFsb2cuY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy9jb25maXJtLWRpYWxvZy9jb25maXJtLWRpYWxvZy5jb21wb25lbnQuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDSTtFQUNJLHdCQUFBO0FDQVI7O0FESUk7RUFFSSxnQkFBQTtFQUVBLGtCQUFBO0FDSFI7O0FETU07RUFDRSxrQkFBQTtBQ0pSOztBRE9NO0VBQ0UsZUFBQTtFQUNBLGNBQUE7QUNMUjs7QURRTTtFQUNHLGVBQUE7RUFDQSxpQkFBQTtBQ05UIiwiZmlsZSI6InNyYy9AZnVzZS9jb21wb25lbnRzL2NvbmZpcm0tZGlhbG9nL2NvbmZpcm0tZGlhbG9nLmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLmNvbmZpcm0tZGlhbG9ne1xyXG4gICAgLm1hdC1kaWFsb2ctY29udGFpbmVye1xyXG4gICAgICAgIHBhZGRpbmc6IDI0cHggIWltcG9ydGFudDtcclxuICAgIH1cclxufVxyXG4uY3VzdG9tQ2xhc3N7XHJcbiAgICAubWF0LWRpYWxvZy1jb250YWluZXJ7XHJcbiAgICAgICAgLy8gaGVpZ2h0OiAzMCU7XHJcbiAgICAgICAgb3ZlcmZsb3c6aGlkZGVuO1xyXG4gICAgICAgIC8vIG1pbi13aWR0aDogNTAlO1xyXG4gICAgICAgIHBvc2l0aW9uOnJlbGF0aXZlO1xyXG4gICAgICB9XHJcbiAgICAgIFxyXG4gICAgICAubWF0LWRpYWxvZy10aXRsZXtcclxuICAgICAgICBwYWRkaW5nOiA4JSAwIDAgOCU7XHJcbiAgICAgIH1cclxuICAgICAgXHJcbiAgICAgIC5tYXQtZGlhbG9nLWNvbnRlbnR7XHJcbiAgICAgICAgbWFyZ2luLWxlZnQ6IDIlO1xyXG4gICAgICAgIG1heC13aWR0aDogOTAlO1xyXG4gICAgICB9XHJcbiAgICBcclxuICAgICAgLm1hdC1kaWFsb2ctYWN0aW9uc3tcclxuICAgICAgICAgbWFyZ2luLWxlZnQ6IDglO1xyXG4gICAgICAgICBtYXJnaW4tYm90dG9tOjIlO1xyXG4gICAgICB9XHJcbn1cclxuIiwiLmNvbmZpcm0tZGlhbG9nIC5tYXQtZGlhbG9nLWNvbnRhaW5lciB7XG4gIHBhZGRpbmc6IDI0cHggIWltcG9ydGFudDtcbn1cblxuLmN1c3RvbUNsYXNzIC5tYXQtZGlhbG9nLWNvbnRhaW5lciB7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbn1cbi5jdXN0b21DbGFzcyAubWF0LWRpYWxvZy10aXRsZSB7XG4gIHBhZGRpbmc6IDglIDAgMCA4JTtcbn1cbi5jdXN0b21DbGFzcyAubWF0LWRpYWxvZy1jb250ZW50IHtcbiAgbWFyZ2luLWxlZnQ6IDIlO1xuICBtYXgtd2lkdGg6IDkwJTtcbn1cbi5jdXN0b21DbGFzcyAubWF0LWRpYWxvZy1hY3Rpb25zIHtcbiAgbWFyZ2luLWxlZnQ6IDglO1xuICBtYXJnaW4tYm90dG9tOiAyJTtcbn0iXX0= */\"","import { Component ,Inject,OnInit,ViewEncapsulation} from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\n\r\n@Component({\r\n selector : 'fuse-confirm-dialog',\r\n templateUrl: './confirm-dialog.component.html',\r\n styleUrls : ['./confirm-dialog.component.scss'],\r\n encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class FuseConfirmDialogComponent implements OnInit\r\n{\r\n customClass:any;\r\n public confirmMessage: string;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {MatDialogRef} dialogRef\r\n */\r\n constructor(\r\n @Inject(MAT_DIALOG_DATA) private _data: any,\r\n public dialogRef: MatDialogRef\r\n )\r\n {\r\n }\r\n\r\n ngOnInit(){\r\n // try{\r\n // this.customClass = this._data.customClass; \r\n // }catch(err){\r\n // console.log(err);\r\n // }\r\n this.customClass = this._data ? this._data.customClass: \"\";\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatDialogModule } from '@angular/material/dialog';\r\n\r\nimport { FuseConfirmDialogComponent } from '@fuse/components/confirm-dialog/confirm-dialog.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseConfirmDialogComponent\r\n ],\r\n imports: [\r\n MatDialogModule,\r\n MatButtonModule\r\n ],\r\n entryComponents: [\r\n FuseConfirmDialogComponent\r\n ],\r\n})\r\nexport class FuseConfirmDialogModule\r\n{\r\n}\r\n","export default \"fuse-countdown {\\n display: flex;\\n flex-direction: row;\\n align-items: center;\\n justify-content: center;\\n}\\nfuse-countdown .fuse-countdown {\\n display: flex;\\n flex-direction: row;\\n align-items: center;\\n justify-content: center;\\n text-align: center;\\n}\\nfuse-countdown .fuse-countdown .time {\\n display: flex;\\n flex-direction: column;\\n padding: 0 12px;\\n}\\nfuse-countdown .fuse-countdown .time .value {\\n font-size: 34px;\\n line-height: 34px;\\n padding-bottom: 8px;\\n}\\nfuse-countdown .fuse-countdown .time .title {\\n color: rgba(0, 0, 0, 0.54);\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL2NvdW50ZG93bi9DOlxcUHJvZ3JhbURhdGFcXEplbmtpbnNcXC5qZW5raW5zXFx3b3Jrc3BhY2VcXFJQTVNcXFVJXFxMaXZlIChVSSBydW5uaW5nIG9uIFBheW1lbnR1cmUgQVdTKVxccGF5bWVudHVyZS5jb20vc3JjXFxAZnVzZVxcY29tcG9uZW50c1xcY291bnRkb3duXFxjb3VudGRvd24uY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy9jb3VudGRvd24vY291bnRkb3duLmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0ksYUFBQTtFQUNBLG1CQUFBO0VBQ0EsbUJBQUE7RUFDQSx1QkFBQTtBQ0NKO0FEQ0k7RUFDSSxhQUFBO0VBQ0EsbUJBQUE7RUFDQSxtQkFBQTtFQUNBLHVCQUFBO0VBQ0Esa0JBQUE7QUNDUjtBRENRO0VBQ0ksYUFBQTtFQUNBLHNCQUFBO0VBQ0EsZUFBQTtBQ0NaO0FEQ1k7RUFDSSxlQUFBO0VBQ0EsaUJBQUE7RUFDQSxtQkFBQTtBQ0NoQjtBREVZO0VBQ0ksMEJBQUE7QUNBaEIiLCJmaWxlIjoic3JjL0BmdXNlL2NvbXBvbmVudHMvY291bnRkb3duL2NvdW50ZG93bi5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbImZ1c2UtY291bnRkb3duIHtcclxuICAgIGRpc3BsYXk6IGZsZXg7XHJcbiAgICBmbGV4LWRpcmVjdGlvbjogcm93O1xyXG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcclxuICAgIGp1c3RpZnktY29udGVudDogY2VudGVyO1xyXG5cclxuICAgIC5mdXNlLWNvdW50ZG93biB7XHJcbiAgICAgICAgZGlzcGxheTogZmxleDtcclxuICAgICAgICBmbGV4LWRpcmVjdGlvbjogcm93O1xyXG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XHJcbiAgICAgICAgdGV4dC1hbGlnbjogY2VudGVyO1xyXG5cclxuICAgICAgICAudGltZSB7XHJcbiAgICAgICAgICAgIGRpc3BsYXk6IGZsZXg7XHJcbiAgICAgICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XHJcbiAgICAgICAgICAgIHBhZGRpbmc6IDAgMTJweDtcclxuXHJcbiAgICAgICAgICAgIC52YWx1ZSB7XHJcbiAgICAgICAgICAgICAgICBmb250LXNpemU6IDM0cHg7XHJcbiAgICAgICAgICAgICAgICBsaW5lLWhlaWdodDogMzRweDtcclxuICAgICAgICAgICAgICAgIHBhZGRpbmctYm90dG9tOiA4cHg7XHJcbiAgICAgICAgICAgIH1cclxuXHJcbiAgICAgICAgICAgIC50aXRsZSB7XHJcbiAgICAgICAgICAgICAgICBjb2xvcjogcmdiYSgwLCAwLCAwLCAwLjU0KTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgIH1cclxufSIsImZ1c2UtY291bnRkb3duIHtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG59XG5mdXNlLWNvdW50ZG93biAuZnVzZS1jb3VudGRvd24ge1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xufVxuZnVzZS1jb3VudGRvd24gLmZ1c2UtY291bnRkb3duIC50aW1lIHtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgcGFkZGluZzogMCAxMnB4O1xufVxuZnVzZS1jb3VudGRvd24gLmZ1c2UtY291bnRkb3duIC50aW1lIC52YWx1ZSB7XG4gIGZvbnQtc2l6ZTogMzRweDtcbiAgbGluZS1oZWlnaHQ6IDM0cHg7XG4gIHBhZGRpbmctYm90dG9tOiA4cHg7XG59XG5mdXNlLWNvdW50ZG93biAuZnVzZS1jb3VudGRvd24gLnRpbWUgLnRpdGxlIHtcbiAgY29sb3I6IHJnYmEoMCwgMCwgMCwgMC41NCk7XG59Il19 */\"","import { Component, Input, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\r\nimport { interval, Subject } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport * as moment from 'moment';\r\n\r\n@Component({\r\n selector : 'fuse-countdown',\r\n templateUrl: './countdown.component.html',\r\n styleUrls : ['./countdown.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\nexport class FuseCountdownComponent implements OnInit, OnDestroy\r\n{\r\n // Event date\r\n @Input('eventDate')\r\n eventDate;\r\n\r\n countdown: any;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n */\r\n constructor()\r\n {\r\n // Set the defaults\r\n this.countdown = {\r\n days : '',\r\n hours : '',\r\n minutes: '',\r\n seconds: ''\r\n };\r\n\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n const currDate = moment();\r\n const eventDate = moment(this.eventDate);\r\n\r\n // Get the difference in between the current date and event date in seconds\r\n let diff = eventDate.diff(currDate, 'seconds');\r\n\r\n // Calculate the remaining time for the first time so there will be no\r\n // delay on the countdown\r\n this.countdown = this._secondsToRemaining(diff);\r\n\r\n // Create a subscribable interval\r\n const countDown = interval(1000)\r\n .pipe(\r\n map(value => {\r\n return diff = diff - 1;\r\n }),\r\n map(value => {\r\n return this._secondsToRemaining(value);\r\n })\r\n );\r\n\r\n // Subscribe to the countdown interval\r\n countDown\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(value => {\r\n this.countdown = value;\r\n });\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Private methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Converts given seconds to a remaining time\r\n *\r\n * @param seconds\r\n * @private\r\n */\r\n private _secondsToRemaining(seconds): any\r\n {\r\n const timeLeft = moment.duration(seconds, 'seconds');\r\n\r\n return {\r\n days : timeLeft.asDays().toFixed(0),\r\n hours : timeLeft.hours(),\r\n minutes: timeLeft.minutes(),\r\n seconds: timeLeft.seconds()\r\n };\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { FuseCountdownComponent } from '@fuse/components/countdown/countdown.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseCountdownComponent\r\n ],\r\n exports: [\r\n FuseCountdownComponent\r\n ],\r\n})\r\nexport class FuseCountdownModule\r\n{\r\n}\r\n","export default \"\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJzcmMvQGZ1c2UvY29tcG9uZW50cy9kZW1vL2RlbW8tY29udGVudC9kZW1vLWNvbnRlbnQuY29tcG9uZW50LnNjc3MifQ== */\"","import { Component } from '@angular/core';\r\n\r\n@Component({\r\n selector : 'fuse-demo-content',\r\n templateUrl: './demo-content.component.html',\r\n styleUrls : ['./demo-content.component.scss']\r\n})\r\nexport class FuseDemoContentComponent\r\n{\r\n /**\r\n * Constructor\r\n */\r\n constructor()\r\n {\r\n }\r\n}\r\n","export default \"\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJzcmMvQGZ1c2UvY29tcG9uZW50cy9kZW1vL2RlbW8tc2lkZWJhci9kZW1vLXNpZGViYXIuY29tcG9uZW50LnNjc3MifQ== */\"","import { Component } from '@angular/core';\r\n\r\n@Component({\r\n selector : 'fuse-demo-sidebar',\r\n templateUrl: './demo-sidebar.component.html',\r\n styleUrls : ['./demo-sidebar.component.scss']\r\n})\r\nexport class FuseDemoSidebarComponent\r\n{\r\n /**\r\n * Constructor\r\n */\r\n constructor()\r\n {\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { MatDividerModule } from '@angular/material/divider';\r\nimport { MatListModule } from '@angular/material/list';\r\n\r\nimport { FuseDemoContentComponent } from './demo-content/demo-content.component';\r\nimport { FuseDemoSidebarComponent } from './demo-sidebar/demo-sidebar.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseDemoContentComponent,\r\n FuseDemoSidebarComponent\r\n ],\r\n imports : [\r\n RouterModule,\r\n\r\n MatDividerModule,\r\n MatListModule\r\n ],\r\n exports : [\r\n FuseDemoContentComponent,\r\n FuseDemoSidebarComponent\r\n ]\r\n})\r\nexport class FuseDemoModule\r\n{\r\n}\r\n","export default \".confirm-dialog .mat-dialog-container {\\n padding: 24px !important;\\n}\\n\\n.pad-14 {\\n padding: 14px !important;\\n}\\n\\n.customClass .mat-dialog-container {\\n overflow: hidden;\\n position: relative;\\n}\\n\\n.customClass .mat-dialog-title {\\n padding: 8% 0 0 8%;\\n}\\n\\n.customClass .mat-dialog-content {\\n margin-left: 2%;\\n max-width: 90%;\\n}\\n\\n.customClass .mat-dialog-actions {\\n margin-left: 8%;\\n margin-bottom: 2%;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL2RpZmZlcmVuY2UtZGlhbG9nL0M6XFxQcm9ncmFtRGF0YVxcSmVua2luc1xcLmplbmtpbnNcXHdvcmtzcGFjZVxcUlBNU1xcVUlcXExpdmUgKFVJIHJ1bm5pbmcgb24gUGF5bWVudHVyZSBBV1MpXFxwYXltZW50dXJlLmNvbS9zcmNcXEBmdXNlXFxjb21wb25lbnRzXFxkaWZmZXJlbmNlLWRpYWxvZ1xcZGlmZmVyZW5jZS1kaWFsb2cuY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy9kaWZmZXJlbmNlLWRpYWxvZy9kaWZmZXJlbmNlLWRpYWxvZy5jb21wb25lbnQuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDSTtFQUNJLHdCQUFBO0FDQVI7O0FER0E7RUFDSSx3QkFBQTtBQ0FKOztBREdJO0VBRUksZ0JBQUE7RUFFQSxrQkFBQTtBQ0ZSOztBREtNO0VBQ0Usa0JBQUE7QUNIUjs7QURNTTtFQUNFLGVBQUE7RUFDQSxjQUFBO0FDSlI7O0FET007RUFDRyxlQUFBO0VBQ0EsaUJBQUE7QUNMVCIsImZpbGUiOiJzcmMvQGZ1c2UvY29tcG9uZW50cy9kaWZmZXJlbmNlLWRpYWxvZy9kaWZmZXJlbmNlLWRpYWxvZy5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbIi5jb25maXJtLWRpYWxvZ3tcclxuICAgIC5tYXQtZGlhbG9nLWNvbnRhaW5lcntcclxuICAgICAgICBwYWRkaW5nOiAyNHB4ICFpbXBvcnRhbnQ7XHJcbiAgICB9XHJcbn1cclxuLnBhZC0xNHtcclxuICAgIHBhZGRpbmc6IDE0cHggIWltcG9ydGFudDtcclxufVxyXG4uY3VzdG9tQ2xhc3N7XHJcbiAgICAubWF0LWRpYWxvZy1jb250YWluZXJ7XHJcbiAgICAgICAgLy8gaGVpZ2h0OiAzMCU7XHJcbiAgICAgICAgb3ZlcmZsb3c6aGlkZGVuO1xyXG4gICAgICAgIC8vIG1pbi13aWR0aDogNTAlO1xyXG4gICAgICAgIHBvc2l0aW9uOnJlbGF0aXZlO1xyXG4gICAgICB9XHJcbiAgICAgIFxyXG4gICAgICAubWF0LWRpYWxvZy10aXRsZXtcclxuICAgICAgICBwYWRkaW5nOiA4JSAwIDAgOCU7XHJcbiAgICAgIH1cclxuICAgICAgXHJcbiAgICAgIC5tYXQtZGlhbG9nLWNvbnRlbnR7XHJcbiAgICAgICAgbWFyZ2luLWxlZnQ6IDIlO1xyXG4gICAgICAgIG1heC13aWR0aDogOTAlO1xyXG4gICAgICB9XHJcbiAgICBcclxuICAgICAgLm1hdC1kaWFsb2ctYWN0aW9uc3tcclxuICAgICAgICAgbWFyZ2luLWxlZnQ6IDglO1xyXG4gICAgICAgICBtYXJnaW4tYm90dG9tOjIlO1xyXG4gICAgICB9XHJcbn1cclxuIiwiLmNvbmZpcm0tZGlhbG9nIC5tYXQtZGlhbG9nLWNvbnRhaW5lciB7XG4gIHBhZGRpbmc6IDI0cHggIWltcG9ydGFudDtcbn1cblxuLnBhZC0xNCB7XG4gIHBhZGRpbmc6IDE0cHggIWltcG9ydGFudDtcbn1cblxuLmN1c3RvbUNsYXNzIC5tYXQtZGlhbG9nLWNvbnRhaW5lciB7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbn1cbi5jdXN0b21DbGFzcyAubWF0LWRpYWxvZy10aXRsZSB7XG4gIHBhZGRpbmc6IDglIDAgMCA4JTtcbn1cbi5jdXN0b21DbGFzcyAubWF0LWRpYWxvZy1jb250ZW50IHtcbiAgbWFyZ2luLWxlZnQ6IDIlO1xuICBtYXgtd2lkdGg6IDkwJTtcbn1cbi5jdXN0b21DbGFzcyAubWF0LWRpYWxvZy1hY3Rpb25zIHtcbiAgbWFyZ2luLWxlZnQ6IDglO1xuICBtYXJnaW4tYm90dG9tOiAyJTtcbn0iXX0= */\"","import { Component ,Inject,OnInit,ViewEncapsulation} from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { Pipe, PipeTransform } from '@angular/core';\r\n\r\n\r\n@Pipe({\r\n name: 'keyValuePairs'\r\n})\r\nexport class KeyValuePairsPipe implements PipeTransform {\r\n transform(value: object): any[] {\r\n if (!value) return [];\r\n\r\n return Object.keys(value).map(key => ({ key, value: value[key] }));\r\n }\r\n}\r\n@Component({\r\n selector: 'app-difference-dialog',\r\n templateUrl: './difference-dialog.component.html',\r\n styleUrls: ['./difference-dialog.component.scss']\r\n})\r\nexport class DifferenceDialogComponent implements OnInit {\r\n\r\n customClass:any;\r\n public confirmMessage: any;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {MatDialogRef} dialogRef\r\n */\r\n constructor(\r\n @Inject(MAT_DIALOG_DATA) private _data: any,\r\n public dialogRef: MatDialogRef\r\n )\r\n {\r\n }\r\n\r\n ngOnInit() {\r\n this.customClass = this._data ? this._data.customClass: \"\";\r\n this.getKeyPairs(this.confirmMessage);\r\n }\r\n getKeyPairs(obj: object): { key: string, value: any }[] {\r\n if (!obj) return [];\r\n return Object.keys(obj).map(key => ({ key, value: obj[key] }));\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatDialogModule } from '@angular/material/dialog';\r\nimport { DifferenceDialogComponent, KeyValuePairsPipe } from './difference-dialog.component';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n@NgModule({\r\n declarations: [\r\n DifferenceDialogComponent,KeyValuePairsPipe\r\n ],\r\n imports: [\r\n MatDialogModule,\r\n MatButtonModule,\r\n CommonModule\r\n ],\r\n entryComponents: [\r\n DifferenceDialogComponent\r\n ],\r\n})\r\nexport class differenceDialogModule\r\n{\r\n}\r\n","export default \":host {\\n display: block;\\n width: 100%;\\n padding: 8px;\\n background: #263238;\\n cursor: text;\\n overflow: auto;\\n -webkit-overflow-scrolling: touch;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL2hpZ2hsaWdodC9DOlxcUHJvZ3JhbURhdGFcXEplbmtpbnNcXC5qZW5raW5zXFx3b3Jrc3BhY2VcXFJQTVNcXFVJXFxMaXZlIChVSSBydW5uaW5nIG9uIFBheW1lbnR1cmUgQVdTKVxccGF5bWVudHVyZS5jb20vc3JjXFxAZnVzZVxcY29tcG9uZW50c1xcaGlnaGxpZ2h0XFxoaWdobGlnaHQuY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy9oaWdobGlnaHQvaGlnaGxpZ2h0LmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0ksY0FBQTtFQUNBLFdBQUE7RUFDQSxZQUFBO0VBQ0EsbUJBQUE7RUFDQSxZQUFBO0VBQ0EsY0FBQTtFQUNBLGlDQUFBO0FDQ0oiLCJmaWxlIjoic3JjL0BmdXNlL2NvbXBvbmVudHMvaGlnaGxpZ2h0L2hpZ2hsaWdodC5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbIjpob3N0IHtcclxuICAgIGRpc3BsYXk6IGJsb2NrO1xyXG4gICAgd2lkdGg6IDEwMCU7XHJcbiAgICBwYWRkaW5nOiA4cHg7XHJcbiAgICBiYWNrZ3JvdW5kOiAjMjYzMjM4O1xyXG4gICAgY3Vyc29yOiB0ZXh0O1xyXG4gICAgb3ZlcmZsb3c6IGF1dG87XHJcbiAgICAtd2Via2l0LW92ZXJmbG93LXNjcm9sbGluZzogdG91Y2g7XHJcbn0iLCI6aG9zdCB7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICB3aWR0aDogMTAwJTtcbiAgcGFkZGluZzogOHB4O1xuICBiYWNrZ3JvdW5kOiAjMjYzMjM4O1xuICBjdXJzb3I6IHRleHQ7XG4gIG92ZXJmbG93OiBhdXRvO1xuICAtd2Via2l0LW92ZXJmbG93LXNjcm9sbGluZzogdG91Y2g7XG59Il19 */\"","import { Component, ContentChild, ElementRef, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport * as Prism from 'prismjs/prism';\r\nimport '@fuse/components/highlight/prism-languages';\r\n\r\n@Component({\r\n selector : 'fuse-highlight',\r\n template : '',\r\n styleUrls: ['./highlight.component.scss']\r\n})\r\nexport class FuseHighlightComponent implements OnInit, OnDestroy\r\n{\r\n // Source\r\n @ContentChild('source', {static: true})\r\n source: ElementRef;\r\n\r\n // Lang\r\n @Input('lang')\r\n lang: string;\r\n\r\n // Path\r\n @Input('path')\r\n path: string;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {ElementRef} _elementRef\r\n * @param {HttpClient} _httpClient\r\n */\r\n constructor(\r\n private _elementRef: ElementRef,\r\n private _httpClient: HttpClient\r\n )\r\n {\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // If there is no language defined, return...\r\n if ( !this.lang )\r\n {\r\n return;\r\n }\r\n\r\n // If the path is defined...\r\n if ( this.path )\r\n {\r\n // Get the source\r\n this._httpClient.get(this.path, {responseType: 'text'})\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((response) => {\r\n\r\n // Highlight it\r\n this.highlight(response);\r\n });\r\n }\r\n\r\n // If the path is not defined and the source element exists...\r\n if ( !this.path && this.source )\r\n {\r\n // Highlight it\r\n this.highlight(this.source.nativeElement.value);\r\n }\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Highlight the given source code\r\n *\r\n * @param sourceCode\r\n */\r\n highlight(sourceCode): void\r\n {\r\n // Split the source into lines\r\n const sourceLines = sourceCode.split('\\n');\r\n\r\n // Remove the first and the last line of the source\r\n // code if they are blank lines. This way, the html\r\n // can be formatted properly while using fuse-highlight\r\n // component\r\n if ( !sourceLines[0].trim() )\r\n {\r\n sourceLines.shift();\r\n }\r\n\r\n if ( !sourceLines[sourceLines.length - 1].trim() )\r\n {\r\n sourceLines.pop();\r\n }\r\n\r\n // Find the first non-whitespace char index in\r\n // the first line of the source code\r\n const indexOfFirstChar = sourceLines[0].search(/\\S|$/);\r\n\r\n // Generate the trimmed source\r\n let source = '';\r\n\r\n // Iterate through all the lines\r\n sourceLines.forEach((line, index) => {\r\n\r\n // Trim the beginning white space depending on the index\r\n // and concat the source code\r\n source = source + line.substr(indexOfFirstChar, line.length);\r\n\r\n // If it's not the last line...\r\n if ( index !== sourceLines.length - 1 )\r\n {\r\n // Add a line break at the end\r\n source = source + '\\n';\r\n }\r\n });\r\n\r\n // Generate the highlighted code\r\n const highlightedCode = Prism.highlight(source, Prism.languages[this.lang]);\r\n\r\n // Replace the innerHTML of the component with the highlighted code\r\n this._elementRef.nativeElement.innerHTML =\r\n '
' + highlightedCode + '
';\r\n }\r\n}\r\n\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { FuseHighlightComponent } from '@fuse/components/highlight/highlight.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseHighlightComponent\r\n ],\r\n exports: [\r\n FuseHighlightComponent\r\n ],\r\n})\r\nexport class FuseHighlightModule\r\n{\r\n}\r\n","import 'prismjs/prism';\r\nimport 'prismjs/components/prism-bash';\r\nimport 'prismjs/components/prism-c';\r\nimport 'prismjs/components/prism-cpp';\r\nimport 'prismjs/components/prism-csharp';\r\nimport 'prismjs/components/prism-css';\r\nimport 'prismjs/components/prism-diff';\r\nimport 'prismjs/components/prism-markup';\r\nimport 'prismjs/components/prism-markup-templating';\r\nimport 'prismjs/components/prism-java';\r\nimport 'prismjs/components/prism-javascript';\r\nimport 'prismjs/components/prism-json';\r\nimport 'prismjs/components/prism-perl';\r\nimport 'prismjs/components/prism-php';\r\nimport 'prismjs/components/prism-python';\r\nimport 'prismjs/components/prism-sass';\r\nimport 'prismjs/components/prism-scss';\r\nimport 'prismjs/components/prism-typescript';\r\n","export * from './confirm-dialog/confirm-dialog.module';\r\nexport * from './countdown/countdown.module';\r\nexport * from './demo/demo.module';\r\nexport * from './highlight/highlight.module';\r\nexport * from './material-color-picker/material-color-picker.module';\r\nexport * from './navigation/navigation.module';\r\nexport * from './progress-bar/progress-bar.module';\r\nexport * from './search-bar/search-bar.module';\r\nexport * from './shortcuts/shortcuts.module';\r\nexport * from './sidebar/sidebar.module';\r\nexport * from './widget/widget.module';\r\n","export default \".fuse-material-color-picker-menu {\\n width: 245px;\\n}\\n.fuse-material-color-picker-menu .mat-menu-content {\\n padding: 0;\\n}\\n.fuse-material-color-picker-menu .mat-menu-content .views {\\n display: flex;\\n flex-direction: column;\\n min-height: 165px;\\n}\\n.fuse-material-color-picker-menu .mat-menu-content .views .view {\\n overflow: hidden;\\n}\\n.fuse-material-color-picker-menu .mat-menu-content .views .view .colors {\\n padding: 1px 0 0 0;\\n margin-left: -1px;\\n}\\n.fuse-material-color-picker-menu .mat-menu-content .views .view .colors .color {\\n width: 40px;\\n height: 40px;\\n margin: 0 0 1px 1px;\\n border-radius: 0;\\n cursor: pointer;\\n transition: border-radius 0.4s cubic-bezier(0.25, 0.8, 0.25, 1);\\n}\\n.fuse-material-color-picker-menu .mat-menu-content .views .view .colors .color:hover {\\n border-radius: 20%;\\n}\\n.fuse-material-color-picker-menu .mat-menu-content .views .view .colors .color.selected {\\n border-radius: 50% !important;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL21hdGVyaWFsLWNvbG9yLXBpY2tlci9DOlxcUHJvZ3JhbURhdGFcXEplbmtpbnNcXC5qZW5raW5zXFx3b3Jrc3BhY2VcXFJQTVNcXFVJXFxMaXZlIChVSSBydW5uaW5nIG9uIFBheW1lbnR1cmUgQVdTKVxccGF5bWVudHVyZS5jb20vc3JjXFxAZnVzZVxcY29tcG9uZW50c1xcbWF0ZXJpYWwtY29sb3ItcGlja2VyXFxtYXRlcmlhbC1jb2xvci1waWNrZXIuY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy9tYXRlcmlhbC1jb2xvci1waWNrZXIvbWF0ZXJpYWwtY29sb3ItcGlja2VyLmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0ksWUFBQTtBQ0NKO0FEQ0k7RUFDSSxVQUFBO0FDQ1I7QURDUTtFQUNJLGFBQUE7RUFDQSxzQkFBQTtFQUNBLGlCQUFBO0FDQ1o7QURDWTtFQUNJLGdCQUFBO0FDQ2hCO0FEQ2dCO0VBQ0ksa0JBQUE7RUFDQSxpQkFBQTtBQ0NwQjtBRENvQjtFQUNJLFdBQUE7RUFDQSxZQUFBO0VBQ0EsbUJBQUE7RUFDQSxnQkFBQTtFQUNBLGVBQUE7RUFDQSwrREFBQTtBQ0N4QjtBREN3QjtFQUNJLGtCQUFBO0FDQzVCO0FERXdCO0VBQ0ksNkJBQUE7QUNBNUIiLCJmaWxlIjoic3JjL0BmdXNlL2NvbXBvbmVudHMvbWF0ZXJpYWwtY29sb3ItcGlja2VyL21hdGVyaWFsLWNvbG9yLXBpY2tlci5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbIi5mdXNlLW1hdGVyaWFsLWNvbG9yLXBpY2tlci1tZW51IHtcclxuICAgIHdpZHRoOiAyNDVweDtcclxuXHJcbiAgICAubWF0LW1lbnUtY29udGVudCB7XHJcbiAgICAgICAgcGFkZGluZzogMDtcclxuXHJcbiAgICAgICAgLnZpZXdzIHtcclxuICAgICAgICAgICAgZGlzcGxheTogZmxleDtcclxuICAgICAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcclxuICAgICAgICAgICAgbWluLWhlaWdodDogMTY1cHg7XHJcblxyXG4gICAgICAgICAgICAudmlldyB7XHJcbiAgICAgICAgICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xyXG5cclxuICAgICAgICAgICAgICAgIC5jb2xvcnMge1xyXG4gICAgICAgICAgICAgICAgICAgIHBhZGRpbmc6IDFweCAwIDAgMDtcclxuICAgICAgICAgICAgICAgICAgICBtYXJnaW4tbGVmdDogLTFweDtcclxuXHJcbiAgICAgICAgICAgICAgICAgICAgLmNvbG9yIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgd2lkdGg6IDQwcHg7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGhlaWdodDogNDBweDtcclxuICAgICAgICAgICAgICAgICAgICAgICAgbWFyZ2luOiAwIDAgMXB4IDFweDtcclxuICAgICAgICAgICAgICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogMDtcclxuICAgICAgICAgICAgICAgICAgICAgICAgY3Vyc29yOiBwb2ludGVyO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICB0cmFuc2l0aW9uOiBib3JkZXItcmFkaXVzIC40cyBjdWJpYy1iZXppZXIoLjI1LCAuOCwgLjI1LCAxKTtcclxuXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICY6aG92ZXIge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgYm9yZGVyLXJhZGl1czogMjAlO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICAgICAgICAgICAgICAmLnNlbGVjdGVkIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDUwJSAhaW1wb3J0YW50O1xyXG4gICAgICAgICAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbiIsIi5mdXNlLW1hdGVyaWFsLWNvbG9yLXBpY2tlci1tZW51IHtcbiAgd2lkdGg6IDI0NXB4O1xufVxuLmZ1c2UtbWF0ZXJpYWwtY29sb3ItcGlja2VyLW1lbnUgLm1hdC1tZW51LWNvbnRlbnQge1xuICBwYWRkaW5nOiAwO1xufVxuLmZ1c2UtbWF0ZXJpYWwtY29sb3ItcGlja2VyLW1lbnUgLm1hdC1tZW51LWNvbnRlbnQgLnZpZXdzIHtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgbWluLWhlaWdodDogMTY1cHg7XG59XG4uZnVzZS1tYXRlcmlhbC1jb2xvci1waWNrZXItbWVudSAubWF0LW1lbnUtY29udGVudCAudmlld3MgLnZpZXcge1xuICBvdmVyZmxvdzogaGlkZGVuO1xufVxuLmZ1c2UtbWF0ZXJpYWwtY29sb3ItcGlja2VyLW1lbnUgLm1hdC1tZW51LWNvbnRlbnQgLnZpZXdzIC52aWV3IC5jb2xvcnMge1xuICBwYWRkaW5nOiAxcHggMCAwIDA7XG4gIG1hcmdpbi1sZWZ0OiAtMXB4O1xufVxuLmZ1c2UtbWF0ZXJpYWwtY29sb3ItcGlja2VyLW1lbnUgLm1hdC1tZW51LWNvbnRlbnQgLnZpZXdzIC52aWV3IC5jb2xvcnMgLmNvbG9yIHtcbiAgd2lkdGg6IDQwcHg7XG4gIGhlaWdodDogNDBweDtcbiAgbWFyZ2luOiAwIDAgMXB4IDFweDtcbiAgYm9yZGVyLXJhZGl1czogMDtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICB0cmFuc2l0aW9uOiBib3JkZXItcmFkaXVzIDAuNHMgY3ViaWMtYmV6aWVyKDAuMjUsIDAuOCwgMC4yNSwgMSk7XG59XG4uZnVzZS1tYXRlcmlhbC1jb2xvci1waWNrZXItbWVudSAubWF0LW1lbnUtY29udGVudCAudmlld3MgLnZpZXcgLmNvbG9ycyAuY29sb3I6aG92ZXIge1xuICBib3JkZXItcmFkaXVzOiAyMCU7XG59XG4uZnVzZS1tYXRlcmlhbC1jb2xvci1waWNrZXItbWVudSAubWF0LW1lbnUtY29udGVudCAudmlld3MgLnZpZXcgLmNvbG9ycyAuY29sb3Iuc2VsZWN0ZWQge1xuICBib3JkZXItcmFkaXVzOiA1MCUgIWltcG9ydGFudDtcbn0iXX0= */\"","import { Component, EventEmitter, forwardRef, Input, Output, ViewEncapsulation } from '@angular/core';\r\n\r\nimport { fuseAnimations } from '@fuse/animations';\r\nimport { MatColors } from '@fuse/mat-colors';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nexport const FUSE_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR: any = {\r\n provide : NG_VALUE_ACCESSOR,\r\n useExisting: forwardRef(() => FuseMaterialColorPickerComponent),\r\n multi : true\r\n};\r\n\r\n@Component({\r\n selector : 'fuse-material-color-picker',\r\n templateUrl : './material-color-picker.component.html',\r\n styleUrls : ['./material-color-picker.component.scss'],\r\n animations : fuseAnimations,\r\n encapsulation: ViewEncapsulation.None,\r\n providers : [FUSE_MATERIAL_COLOR_PICKER_VALUE_ACCESSOR]\r\n})\r\nexport class FuseMaterialColorPickerComponent implements ControlValueAccessor\r\n{\r\n colors: any;\r\n hues: string[];\r\n view: string;\r\n selectedColor: any;\r\n selectedPalette: string;\r\n selectedHue: string;\r\n\r\n // Color changed\r\n @Output()\r\n colorChanged: EventEmitter;\r\n\r\n // Private\r\n private _color: string;\r\n private _modelChange: (value: any) => void;\r\n private _modelTouched: (value: any) => void;\r\n\r\n /**\r\n * Constructor\r\n */\r\n constructor()\r\n {\r\n // Set the defaults\r\n this.colorChanged = new EventEmitter();\r\n this.colors = MatColors.all;\r\n this.hues = ['50', '100', '200', '300', '400', '500', '600', '700', '800', '900', 'A100', 'A200', 'A400', 'A700'];\r\n this.selectedHue = '500';\r\n this.view = 'palettes';\r\n\r\n // Set the private defaults\r\n this._color = '';\r\n this._modelChange = () => {\r\n };\r\n this._modelTouched = () => {\r\n };\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Selected class\r\n *\r\n * @param value\r\n */\r\n @Input()\r\n set color(value)\r\n {\r\n if ( !value || value === '' || this._color === value )\r\n {\r\n return;\r\n }\r\n\r\n // Split the color value (red-400, blue-500, fuse-navy-700 etc.)\r\n const colorParts = value.split('-');\r\n\r\n // Take the very last part as the selected hue value\r\n this.selectedHue = colorParts[colorParts.length - 1];\r\n\r\n // Remove the last part\r\n colorParts.pop();\r\n\r\n // Rejoin the remaining parts as the selected palette name\r\n this.selectedPalette = colorParts.join('-');\r\n\r\n // Store the color value\r\n this._color = value;\r\n }\r\n\r\n get color(): string\r\n {\r\n return this._color;\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Control Value Accessor implementation\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Register on change function\r\n *\r\n * @param fn\r\n */\r\n registerOnChange(fn: any): void\r\n {\r\n this._modelChange = fn;\r\n }\r\n\r\n /**\r\n * Register on touched function\r\n *\r\n * @param fn\r\n */\r\n registerOnTouched(fn: any): void\r\n {\r\n this._modelTouched = fn;\r\n }\r\n\r\n /**\r\n * Write value to the view from model\r\n *\r\n * @param color\r\n */\r\n writeValue(color: any): void\r\n {\r\n // Return if null\r\n if ( !color )\r\n {\r\n return;\r\n }\r\n\r\n // Set the color\r\n this.color = color;\r\n\r\n // Update the selected color\r\n this.updateSelectedColor();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Select palette\r\n *\r\n * @param event\r\n * @param palette\r\n */\r\n selectPalette(event, palette): void\r\n {\r\n // Stop propagation\r\n event.stopPropagation();\r\n\r\n // Go to 'hues' view\r\n this.view = 'hues';\r\n\r\n // Update the selected palette\r\n this.selectedPalette = palette;\r\n\r\n // Update the selected color\r\n this.updateSelectedColor();\r\n }\r\n\r\n /**\r\n * Select hue\r\n *\r\n * @param event\r\n * @param hue\r\n */\r\n selectHue(event, hue): void\r\n {\r\n // Stop propagation\r\n event.stopPropagation();\r\n\r\n // Update the selected huse\r\n this.selectedHue = hue;\r\n\r\n // Update the selected color\r\n this.updateSelectedColor();\r\n }\r\n\r\n /**\r\n * Remove color\r\n *\r\n * @param event\r\n */\r\n removeColor(event): void\r\n {\r\n // Stop propagation\r\n event.stopPropagation();\r\n\r\n // Return to the 'palettes' view\r\n this.view = 'palettes';\r\n\r\n // Clear the selected palette and hue\r\n this.selectedPalette = '';\r\n this.selectedHue = '';\r\n\r\n // Update the selected color\r\n this.updateSelectedColor();\r\n }\r\n\r\n /**\r\n * Update selected color\r\n */\r\n updateSelectedColor(): void\r\n {\r\n if ( this.selectedColor && this.selectedColor.palette === this.selectedPalette && this.selectedColor.hue === this.selectedHue )\r\n {\r\n return;\r\n }\r\n\r\n // Set the selected color object\r\n this.selectedColor = {\r\n palette: this.selectedPalette,\r\n hue : this.selectedHue,\r\n class : this.selectedPalette + '-' + this.selectedHue,\r\n bg : this.selectedPalette === '' ? '' : MatColors.getColor(this.selectedPalette)[this.selectedHue],\r\n fg : this.selectedPalette === '' ? '' : MatColors.getColor(this.selectedPalette).contrast[this.selectedHue]\r\n };\r\n\r\n // Emit the color changed event\r\n this.colorChanged.emit(this.selectedColor);\r\n\r\n // Mark the model as touched\r\n this._modelTouched(this.selectedColor.class);\r\n\r\n // Update the model\r\n this._modelChange(this.selectedColor.class);\r\n }\r\n\r\n /**\r\n * Go to palettes view\r\n *\r\n * @param event\r\n */\r\n goToPalettesView(event): void\r\n {\r\n // Stop propagation\r\n event.stopPropagation();\r\n\r\n this.view = 'palettes';\r\n }\r\n\r\n /**\r\n * On menu open\r\n */\r\n onMenuOpen(): void\r\n {\r\n if ( this.selectedPalette === '' )\r\n {\r\n this.view = 'palettes';\r\n }\r\n else\r\n {\r\n this.view = 'hues';\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FlexLayoutModule } from '@angular/flex-layout';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\n\r\nimport { FusePipesModule } from '@fuse/pipes/pipes.module';\r\n\r\nimport { FuseMaterialColorPickerComponent } from '@fuse/components/material-color-picker/material-color-picker.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseMaterialColorPickerComponent\r\n ],\r\n imports: [\r\n CommonModule,\r\n\r\n FlexLayoutModule,\r\n\r\n MatButtonModule,\r\n MatIconModule,\r\n MatMenuModule,\r\n MatTooltipModule,\r\n\r\n FusePipesModule\r\n ],\r\n exports: [\r\n FuseMaterialColorPickerComponent\r\n ],\r\n})\r\nexport class FuseMaterialColorPickerModule\r\n{\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\nfuse-navigation {\\n display: flex;\\n flex: 1 0 auto;\\n}\\nfuse-navigation > .nav {\\n margin: 0;\\n padding: 0;\\n width: 100%;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/@fuse/components/navigation/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/@fuse/components/navigation/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\components\\navigation\\navigation.component.scss","src/@fuse/components/navigation/navigation.component.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC95FA;EACI,aAAA;EACA,cAAA;ACEJ;ADAI;EACI,SAAA;EACA,UAAA;EACA,WAAA;ACER","file":"src/@fuse/components/navigation/navigation.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import 'src/@fuse/scss/fuse';\r\n\r\nfuse-navigation {\r\n    display: flex;\r\n    flex: 1 0 auto;\r\n\r\n    > .nav {\r\n        margin: 0;\r\n        padding: 0;\r\n        width: 100%;\r\n    }\r\n}\r\n","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\nfuse-navigation {\n  display: flex;\n  flex: 1 0 auto;\n}\nfuse-navigation > .nav {\n  margin: 0;\n  padding: 0;\n  width: 100%;\n}"]} */\"","import {\r\n ChangeDetectionStrategy,\r\n ChangeDetectorRef,\r\n Component,\r\n Input,\r\n OnInit,\r\n ViewEncapsulation,\r\n} from \"@angular/core\";\r\nimport { merge, Subject } from \"rxjs\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\n\r\nimport { FuseNavigationService } from \"@fuse/components/navigation/navigation.service\";\r\n\r\n@Component({\r\n selector: \"fuse-navigation\",\r\n templateUrl: \"./navigation.component.html\",\r\n styleUrls: [\"./navigation.component.scss\"],\r\n encapsulation: ViewEncapsulation.None,\r\n changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class FuseNavigationComponent implements OnInit {\r\n userDetails: any = JSON.parse(localStorage.getItem(\"LoggedInUserData\")) || {};\r\n pageViews: any[] = [];\r\n @Input()\r\n layout = \"vertical\";\r\n\r\n @Input()\r\n navigation: any;\r\n\r\n @Input()\r\n Rolenavigation: any;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n *\r\n * @param {ChangeDetectorRef} _changeDetectorRef\r\n * @param {FuseNavigationService} _fuseNavigationService\r\n */\r\n constructor(\r\n private _changeDetectorRef: ChangeDetectorRef,\r\n private _fuseNavigationService: FuseNavigationService\r\n ) {\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void {\r\n if (localStorage.getItem(\"LoggedInUserData\")) {\r\n this.userDetails = JSON.parse(\r\n localStorage.getItem(\"LoggedInUserData\")\r\n );\r\n }\r\n\r\n // Load the navigation either from the input or from the service\r\n this.navigation =\r\n this.navigation ||\r\n this._fuseNavigationService.getCurrentNavigation();\r\n\r\n // Subscribe to the current navigation changes\r\n this._fuseNavigationService.onNavigationChanged\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(() => {\r\n // Load the navigation\r\n this.navigation =\r\n this._fuseNavigationService.getCurrentNavigation();\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n });\r\n if(Object.keys(this.userDetails).length > 0){\r\n this.Rolenavigation = this.navigation.find(\r\n (x) => x.role == this.userDetails.role\r\n );\r\n if (this.userDetails.role == 3) {\r\n if (this.userDetails.permissions.length > 0) {\r\n this.pageViews = [];\r\n this.Rolenavigation.children.forEach(\r\n (pageObj: any, pageIndex: number) => {\r\n if (\r\n pageObj.type === \"item\" &&\r\n this.isPageExist(\r\n this.userDetails.permissions,\r\n pageObj.id\r\n )\r\n ) {\r\n this.pageViews.push(pageObj);\r\n } else if (pageObj.type === \"collapsable\") {\r\n let group: any = {};\r\n let groupChildren: any = [];\r\n pageObj.children.forEach(\r\n (groupObj: any, groupIndex: number) => {\r\n if (\r\n groupObj.type === \"item\" &&\r\n this.isPageExist(\r\n this.userDetails.permissions,\r\n groupObj.id\r\n )\r\n ) {\r\n groupChildren.push(groupObj);\r\n }\r\n }\r\n );\r\n if (groupChildren.length > 0) {\r\n group.id = pageObj.id;\r\n group.title = pageObj.title;\r\n group.type = pageObj.type;\r\n group.icon = pageObj.icon;\r\n group.children = groupChildren;\r\n this.pageViews.push(group);\r\n }\r\n }\r\n }\r\n );\r\n \r\n // this.Rolenavigation.children = pageViews;\r\n } else {\r\n this.pageViews = this.Rolenavigation.children;\r\n }\r\n } else {\r\n this.pageViews = this.Rolenavigation.children;\r\n }\r\n }\r\n // Subscribe to navigation item\r\n merge(\r\n this._fuseNavigationService.onNavigationItemAdded,\r\n this._fuseNavigationService.onNavigationItemUpdated,\r\n this._fuseNavigationService.onNavigationItemRemoved\r\n )\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(() => {\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n });\r\n }\r\n isPageExist(arr: any, page: string) {\r\n return arr.some(function (el) {\r\n return el == page;\r\n });\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { RouterModule } from '@angular/router';\r\nimport { MatRippleModule } from '@angular/material/core';\r\nimport { MatIconModule } from '@angular/material/icon';\r\n\r\nimport { TranslateModule } from '@ngx-translate/core';\r\n\r\nimport { FuseNavigationComponent } from './navigation.component';\r\nimport { FuseNavVerticalItemComponent } from './vertical/item/item.component';\r\nimport { FuseNavVerticalCollapsableComponent } from './vertical/collapsable/collapsable.component';\r\nimport { FuseNavVerticalGroupComponent } from './vertical/group/group.component';\r\n\r\n@NgModule({\r\n imports : [\r\n CommonModule,\r\n RouterModule,\r\n\r\n MatIconModule,\r\n MatRippleModule,\r\n\r\n TranslateModule.forChild()\r\n ],\r\n exports : [\r\n FuseNavigationComponent\r\n ],\r\n declarations: [\r\n FuseNavigationComponent,\r\n FuseNavVerticalGroupComponent,\r\n FuseNavVerticalItemComponent,\r\n FuseNavVerticalCollapsableComponent,\r\n ]\r\n})\r\nexport class FuseNavigationModule\r\n{\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\r\nimport * as _ from 'lodash';\r\n\r\nimport { FuseNavigationItem } from '@fuse/types';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class FuseNavigationService\r\n{\r\n onItemCollapsed: Subject;\r\n onItemCollapseToggled: Subject;\r\n\r\n // Private\r\n private _onNavigationChanged: BehaviorSubject;\r\n private _onNavigationRegistered: BehaviorSubject;\r\n private _onNavigationUnregistered: BehaviorSubject;\r\n private _onNavigationItemAdded: BehaviorSubject;\r\n private _onNavigationItemUpdated: BehaviorSubject;\r\n private _onNavigationItemRemoved: BehaviorSubject;\r\n\r\n private _currentNavigationKey: string;\r\n private _registry: { [key: string]: any } = {};\r\n\r\n /**\r\n * Constructor\r\n */\r\n constructor()\r\n {\r\n // Set the defaults\r\n this.onItemCollapsed = new Subject();\r\n this.onItemCollapseToggled = new Subject();\r\n\r\n // Set the private defaults\r\n this._currentNavigationKey = null;\r\n this._onNavigationChanged = new BehaviorSubject(null);\r\n this._onNavigationRegistered = new BehaviorSubject(null);\r\n this._onNavigationUnregistered = new BehaviorSubject(null);\r\n this._onNavigationItemAdded = new BehaviorSubject(null);\r\n this._onNavigationItemUpdated = new BehaviorSubject(null);\r\n this._onNavigationItemRemoved = new BehaviorSubject(null);\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Get onNavigationChanged\r\n *\r\n * @returns {Observable}\r\n */\r\n get onNavigationChanged(): Observable\r\n {\r\n return this._onNavigationChanged.asObservable();\r\n }\r\n\r\n /**\r\n * Get onNavigationRegistered\r\n *\r\n * @returns {Observable}\r\n */\r\n get onNavigationRegistered(): Observable\r\n {\r\n return this._onNavigationRegistered.asObservable();\r\n }\r\n\r\n /**\r\n * Get onNavigationUnregistered\r\n *\r\n * @returns {Observable}\r\n */\r\n get onNavigationUnregistered(): Observable\r\n {\r\n return this._onNavigationUnregistered.asObservable();\r\n }\r\n\r\n /**\r\n * Get onNavigationItemAdded\r\n *\r\n * @returns {Observable}\r\n */\r\n get onNavigationItemAdded(): Observable\r\n {\r\n return this._onNavigationItemAdded.asObservable();\r\n }\r\n\r\n /**\r\n * Get onNavigationItemUpdated\r\n *\r\n * @returns {Observable}\r\n */\r\n get onNavigationItemUpdated(): Observable\r\n {\r\n return this._onNavigationItemUpdated.asObservable();\r\n }\r\n\r\n /**\r\n * Get onNavigationItemRemoved\r\n *\r\n * @returns {Observable}\r\n */\r\n get onNavigationItemRemoved(): Observable\r\n {\r\n return this._onNavigationItemRemoved.asObservable();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Register the given navigation\r\n * with the given key\r\n *\r\n * @param key\r\n * @param navigation\r\n */\r\n register(key, navigation): void\r\n {\r\n // Check if the key already being used\r\n if ( this._registry[key] )\r\n {\r\n console.error(`The navigation with the key '${key}' already exists. Either unregister it first or use a unique key.`);\r\n\r\n return;\r\n }\r\n\r\n // Add to the registry\r\n this._registry[key] = navigation;\r\n\r\n // Notify the subject\r\n this._onNavigationRegistered.next([key, navigation]);\r\n }\r\n\r\n /**\r\n * Unregister the navigation from the registry\r\n * @param key\r\n */\r\n unregister(key): void\r\n {\r\n // Check if the navigation exists\r\n if ( !this._registry[key] )\r\n {\r\n console.warn(`The navigation with the key '${key}' doesn't exist in the registry.`);\r\n }\r\n\r\n // Unregister the sidebar\r\n delete this._registry[key];\r\n\r\n // Notify the subject\r\n this._onNavigationUnregistered.next(key);\r\n }\r\n\r\n /**\r\n * Get navigation from registry by key\r\n *\r\n * @param key\r\n * @returns {any}\r\n */\r\n getNavigation(key): any\r\n {\r\n // Check if the navigation exists\r\n if ( !this._registry[key] )\r\n {\r\n console.warn(`The navigation with the key '${key}' doesn't exist in the registry.`);\r\n\r\n return;\r\n }\r\n\r\n // Return the sidebar\r\n return this._registry[key];\r\n }\r\n\r\n /**\r\n * Get flattened navigation array\r\n *\r\n * @param navigation\r\n * @param flatNavigation\r\n * @returns {any[]}\r\n */\r\n getFlatNavigation(navigation, flatNavigation: FuseNavigationItem[] = []): any\r\n {\r\n for ( const item of navigation )\r\n {\r\n if ( item.type === 'item' )\r\n {\r\n flatNavigation.push(item);\r\n\r\n continue;\r\n }\r\n\r\n if ( item.type === 'collapsable' || item.type === 'group' )\r\n {\r\n if ( item.children )\r\n {\r\n this.getFlatNavigation(item.children, flatNavigation);\r\n }\r\n }\r\n }\r\n\r\n return flatNavigation;\r\n }\r\n\r\n /**\r\n * Get the current navigation\r\n *\r\n * @returns {any}\r\n */\r\n getCurrentNavigation(): any\r\n {\r\n if ( !this._currentNavigationKey )\r\n {\r\n console.warn(`The current navigation is not set.`);\r\n\r\n return;\r\n }\r\n\r\n return this.getNavigation(this._currentNavigationKey);\r\n }\r\n\r\n /**\r\n * Set the navigation with the key\r\n * as the current navigation\r\n *\r\n * @param key\r\n */\r\n setCurrentNavigation(key): void\r\n {\r\n // Check if the sidebar exists\r\n if ( !this._registry[key] )\r\n {\r\n console.warn(`The navigation with the key '${key}' doesn't exist in the registry.`);\r\n\r\n return;\r\n }\r\n\r\n // Set the current navigation key\r\n this._currentNavigationKey = key;\r\n\r\n // Notify the subject\r\n this._onNavigationChanged.next(key);\r\n }\r\n\r\n /**\r\n * Get navigation item by id from the\r\n * current navigation\r\n *\r\n * @param id\r\n * @param {any} navigation\r\n * @returns {any | boolean}\r\n */\r\n getNavigationItem(id, navigation = null): any | boolean\r\n {\r\n if ( !navigation )\r\n {\r\n navigation = this.getCurrentNavigation();\r\n }\r\n\r\n for ( const item of navigation )\r\n {\r\n if ( item.id === id )\r\n {\r\n return item;\r\n }\r\n\r\n if ( item.children )\r\n {\r\n const childItem = this.getNavigationItem(id, item.children);\r\n\r\n if ( childItem )\r\n {\r\n return childItem;\r\n }\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n\r\n /**\r\n * Get the parent of the navigation item\r\n * with the id\r\n *\r\n * @param id\r\n * @param {any} navigation\r\n * @param parent\r\n */\r\n getNavigationItemParent(id, navigation = null, parent = null): any\r\n {\r\n if ( !navigation )\r\n {\r\n navigation = this.getCurrentNavigation();\r\n parent = navigation;\r\n }\r\n\r\n for ( const item of navigation )\r\n {\r\n if ( item.id === id )\r\n {\r\n return parent;\r\n }\r\n\r\n if ( item.children )\r\n {\r\n const childItem = this.getNavigationItemParent(id, item.children, item);\r\n\r\n if ( childItem )\r\n {\r\n return childItem;\r\n }\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n\r\n /**\r\n * Add a navigation item to the specified location\r\n *\r\n * @param item\r\n * @param id\r\n */\r\n addNavigationItem(item, id): void\r\n {\r\n // Get the current navigation\r\n const navigation: any[] = this.getCurrentNavigation();\r\n\r\n // Add to the end of the navigation\r\n if ( id === 'end' )\r\n {\r\n navigation.push(item);\r\n\r\n // Trigger the observable\r\n this._onNavigationItemAdded.next(true);\r\n\r\n return;\r\n }\r\n\r\n // Add to the start of the navigation\r\n if ( id === 'start' )\r\n {\r\n navigation.unshift(item);\r\n\r\n // Trigger the observable\r\n this._onNavigationItemAdded.next(true);\r\n\r\n return;\r\n }\r\n\r\n // Add it to a specific location\r\n const parent: any = this.getNavigationItem(id);\r\n\r\n if ( parent )\r\n {\r\n // Check if parent has a children entry,\r\n // and add it if it doesn't\r\n if ( !parent.children )\r\n {\r\n parent.children = [];\r\n }\r\n\r\n // Add the item\r\n parent.children.push(item);\r\n }\r\n\r\n // Trigger the observable\r\n this._onNavigationItemAdded.next(true);\r\n }\r\n\r\n /**\r\n * Update navigation item with the given id\r\n *\r\n * @param id\r\n * @param properties\r\n */\r\n updateNavigationItem(id, properties): void\r\n {\r\n // Get the navigation item\r\n const navigationItem = this.getNavigationItem(id);\r\n\r\n // If there is no navigation with the give id, return\r\n if ( !navigationItem )\r\n {\r\n return;\r\n }\r\n\r\n // Merge the navigation properties\r\n _.merge(navigationItem, properties);\r\n\r\n // Trigger the observable\r\n this._onNavigationItemUpdated.next(true);\r\n }\r\n\r\n /**\r\n * Remove navigation item with the given id\r\n *\r\n * @param id\r\n */\r\n removeNavigationItem(id): void\r\n {\r\n const item = this.getNavigationItem(id);\r\n\r\n // Return, if there is not such an item\r\n if ( !item )\r\n {\r\n return;\r\n }\r\n\r\n // Get the parent of the item\r\n let parent = this.getNavigationItemParent(id);\r\n\r\n // This check is required because of the first level\r\n // of the navigation, since the first level is not\r\n // inside the 'children' array\r\n parent = parent.children || parent;\r\n\r\n // Remove the item\r\n parent.splice(parent.indexOf(item), 1);\r\n\r\n // Trigger the observable\r\n this._onNavigationItemRemoved.next(true);\r\n }\r\n}\r\n","export default \".folded:not(.unfolded) :host .nav-link > span {\\n opacity: 0;\\n transition: opacity 200ms ease;\\n}\\n.folded:not(.unfolded) :host.open .children {\\n display: none !important;\\n}\\n:host .nav-link .collapsable-arrow {\\n transition: transform 0.3s ease-in-out, opacity 0.25s ease-in-out 0.1s;\\n transform: rotate(0);\\n}\\n:host > .children {\\n overflow: hidden;\\n}\\n:host.open > .nav-link .collapsable-arrow {\\n transform: rotate(90deg);\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL25hdmlnYXRpb24vdmVydGljYWwvY29sbGFwc2FibGUvQzpcXFByb2dyYW1EYXRhXFxKZW5raW5zXFwuamVua2luc1xcd29ya3NwYWNlXFxSUE1TXFxVSVxcTGl2ZSAoVUkgcnVubmluZyBvbiBQYXltZW50dXJlIEFXUylcXHBheW1lbnR1cmUuY29tL3NyY1xcQGZ1c2VcXGNvbXBvbmVudHNcXG5hdmlnYXRpb25cXHZlcnRpY2FsXFxjb2xsYXBzYWJsZVxcY29sbGFwc2FibGUuY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy9uYXZpZ2F0aW9uL3ZlcnRpY2FsL2NvbGxhcHNhYmxlL2NvbGxhcHNhYmxlLmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU1ZO0VBQ0ksVUFBQTtFQUNBLDhCQUFBO0FDTGhCO0FEV1k7RUFDSSx3QkFBQTtBQ1RoQjtBRGdCUTtFQUNJLHNFQUFBO0VBQ0Esb0JBQUE7QUNkWjtBRGtCSTtFQUNJLGdCQUFBO0FDaEJSO0FEdUJZO0VBQ0ksd0JBQUE7QUNyQmhCIiwiZmlsZSI6InNyYy9AZnVzZS9jb21wb25lbnRzL25hdmlnYXRpb24vdmVydGljYWwvY29sbGFwc2FibGUvY29sbGFwc2FibGUuY29tcG9uZW50LnNjc3MiLCJzb3VyY2VzQ29udGVudCI6WyI6aG9zdCB7XHJcblxyXG4gICAgLmZvbGRlZDpub3QoLnVuZm9sZGVkKSAmIHtcclxuXHJcbiAgICAgICAgLm5hdi1saW5rIHtcclxuXHJcbiAgICAgICAgICAgID4gc3BhbiB7XHJcbiAgICAgICAgICAgICAgICBvcGFjaXR5OiAwO1xyXG4gICAgICAgICAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICAmLm9wZW4ge1xyXG5cclxuICAgICAgICAgICAgLmNoaWxkcmVuIHtcclxuICAgICAgICAgICAgICAgIGRpc3BsYXk6IG5vbmUgIWltcG9ydGFudDtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICAubmF2LWxpbmsge1xyXG5cclxuICAgICAgICAuY29sbGFwc2FibGUtYXJyb3cge1xyXG4gICAgICAgICAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gLjNzIGVhc2UtaW4tb3V0LCBvcGFjaXR5IC4yNXMgZWFzZS1pbi1vdXQgLjFzO1xyXG4gICAgICAgICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgwKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgPiAuY2hpbGRyZW4ge1xyXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XHJcbiAgICB9XHJcblxyXG4gICAgJi5vcGVuIHtcclxuXHJcbiAgICAgICAgPiAubmF2LWxpbmsge1xyXG5cclxuICAgICAgICAgICAgLmNvbGxhcHNhYmxlLWFycm93IHtcclxuICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogcm90YXRlKDkwZGVnKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgIH1cclxufVxyXG4iLCIuZm9sZGVkOm5vdCgudW5mb2xkZWQpIDpob3N0IC5uYXYtbGluayA+IHNwYW4ge1xuICBvcGFjaXR5OiAwO1xuICB0cmFuc2l0aW9uOiBvcGFjaXR5IDIwMG1zIGVhc2U7XG59XG4uZm9sZGVkOm5vdCgudW5mb2xkZWQpIDpob3N0Lm9wZW4gLmNoaWxkcmVuIHtcbiAgZGlzcGxheTogbm9uZSAhaW1wb3J0YW50O1xufVxuOmhvc3QgLm5hdi1saW5rIC5jb2xsYXBzYWJsZS1hcnJvdyB7XG4gIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjNzIGVhc2UtaW4tb3V0LCBvcGFjaXR5IDAuMjVzIGVhc2UtaW4tb3V0IDAuMXM7XG4gIHRyYW5zZm9ybTogcm90YXRlKDApO1xufVxuOmhvc3QgPiAuY2hpbGRyZW4ge1xuICBvdmVyZmxvdzogaGlkZGVuO1xufVxuOmhvc3Qub3BlbiA+IC5uYXYtbGluayAuY29sbGFwc2FibGUtYXJyb3cge1xuICB0cmFuc2Zvcm06IHJvdGF0ZSg5MGRlZyk7XG59Il19 */\"","import { ChangeDetectorRef, Component, HostBinding, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { merge, Subject } from 'rxjs';\r\nimport { filter, takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseNavigationItem } from '@fuse/types';\r\nimport { fuseAnimations } from '@fuse/animations';\r\nimport { FuseNavigationService } from '@fuse/components/navigation/navigation.service';\r\n\r\n@Component({\r\n selector : 'fuse-nav-vertical-collapsable',\r\n templateUrl: './collapsable.component.html',\r\n styleUrls : ['./collapsable.component.scss'],\r\n animations : fuseAnimations\r\n})\r\nexport class FuseNavVerticalCollapsableComponent implements OnInit, OnDestroy\r\n{\r\n @Input()\r\n item: FuseNavigationItem;\r\n\r\n @HostBinding('class')\r\n classes = 'nav-collapsable nav-item';\r\n\r\n @HostBinding('class.open')\r\n public isOpen = false;\r\n public comp:any;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {ChangeDetectorRef} _changeDetectorRef\r\n * @param {FuseNavigationService} _fuseNavigationService\r\n * @param {Router} _router\r\n */\r\n constructor(\r\n private _changeDetectorRef: ChangeDetectorRef,\r\n private _fuseNavigationService: FuseNavigationService,\r\n private _router: Router\r\n )\r\n {\r\n \r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n this.comp = JSON.parse(localStorage.getItem('LoggedInUserData'))\r\n \r\n // Listen for router events\r\n this._router.events\r\n .pipe(\r\n filter(event => event instanceof NavigationEnd),\r\n takeUntil(this._unsubscribeAll)\r\n )\r\n .subscribe((event: NavigationEnd) => {\r\n\r\n // Check if the url can be found in\r\n // one of the children of this item\r\n if ( this.isUrlInChildren(this.item, event.urlAfterRedirects) )\r\n {\r\n this.expand();\r\n }\r\n else\r\n {\r\n this.collapse();\r\n }\r\n });\r\n\r\n // Listen for collapsing of any navigation item\r\n this._fuseNavigationService.onItemCollapsed\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(\r\n (clickedItem) => {\r\n if ( clickedItem && clickedItem.children )\r\n {\r\n // Check if the clicked item is one\r\n // of the children of this item\r\n if ( this.isChildrenOf(this.item, clickedItem) )\r\n {\r\n return;\r\n }\r\n\r\n // Check if the url can be found in\r\n // one of the children of this item\r\n if ( this.isUrlInChildren(this.item, this._router.url) )\r\n {\r\n return;\r\n }\r\n\r\n // If the clicked item is not this item, collapse...\r\n if ( this.item !== clickedItem )\r\n {\r\n this.collapse();\r\n }\r\n }\r\n }\r\n );\r\n\r\n // Check if the url can be found in\r\n // one of the children of this item\r\n if ( this.isUrlInChildren(this.item, this._router.url) )\r\n {\r\n this.expand();\r\n }\r\n else\r\n {\r\n this.collapse();\r\n }\r\n\r\n // Subscribe to navigation item\r\n merge(\r\n this._fuseNavigationService.onNavigationItemAdded,\r\n this._fuseNavigationService.onNavigationItemUpdated,\r\n this._fuseNavigationService.onNavigationItemRemoved\r\n ).pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(() => {\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n });\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Toggle collapse\r\n *\r\n * @param ev\r\n */\r\n toggleOpen(ev): void\r\n {\r\n ev.preventDefault();\r\n\r\n this.isOpen = !this.isOpen;\r\n\r\n // Navigation collapse toggled...\r\n this._fuseNavigationService.onItemCollapsed.next(this.item);\r\n this._fuseNavigationService.onItemCollapseToggled.next();\r\n }\r\n\r\n /**\r\n * Expand the collapsable navigation\r\n */\r\n expand(): void\r\n {\r\n if ( this.isOpen )\r\n {\r\n return;\r\n }\r\n\r\n this.isOpen = true;\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n\r\n this._fuseNavigationService.onItemCollapseToggled.next();\r\n }\r\n\r\n /**\r\n * Collapse the collapsable navigation\r\n */\r\n collapse(): void\r\n {\r\n if ( !this.isOpen )\r\n {\r\n return;\r\n }\r\n\r\n this.isOpen = false;\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n\r\n this._fuseNavigationService.onItemCollapseToggled.next();\r\n }\r\n\r\n /**\r\n * Check if the given parent has the\r\n * given item in one of its children\r\n *\r\n * @param parent\r\n * @param item\r\n * @returns {boolean}\r\n */\r\n isChildrenOf(parent, item): boolean\r\n {\r\n const children = parent.children;\r\n\r\n if ( !children )\r\n {\r\n return false;\r\n }\r\n\r\n if ( children.indexOf(item) > -1 )\r\n {\r\n return true;\r\n }\r\n\r\n for ( const child of children )\r\n {\r\n if ( child.children )\r\n {\r\n if ( this.isChildrenOf(child, item) )\r\n {\r\n return true;\r\n }\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n\r\n /**\r\n * Check if the given url can be found\r\n * in one of the given parent's children\r\n *\r\n * @param parent\r\n * @param url\r\n * @returns {boolean}\r\n */\r\n isUrlInChildren(parent, url): boolean\r\n {\r\n const children = parent.children;\r\n\r\n if ( !children )\r\n {\r\n return false;\r\n }\r\n\r\n for ( const child of children )\r\n {\r\n if ( child.children )\r\n {\r\n if ( this.isUrlInChildren(child, url) )\r\n {\r\n return true;\r\n }\r\n }\r\n\r\n if ( child.url === url || url.includes(child.url) )\r\n {\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n }\r\n\r\n}\r\n","export default \".folded:not(.unfolded) :host > .group-title {\\n align-items: center;\\n}\\n.folded:not(.unfolded) :host > .group-title > span {\\n opacity: 0;\\n transition: opacity 200ms ease;\\n}\\n.folded:not(.unfolded) :host > .group-title:before {\\n content: \\\"\\\";\\n display: block;\\n position: absolute;\\n min-width: 1.6rem;\\n border-top: 2px solid;\\n opacity: 0.2;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL25hdmlnYXRpb24vdmVydGljYWwvZ3JvdXAvQzpcXFByb2dyYW1EYXRhXFxKZW5raW5zXFwuamVua2luc1xcd29ya3NwYWNlXFxSUE1TXFxVSVxcTGl2ZSAoVUkgcnVubmluZyBvbiBQYXltZW50dXJlIEFXUylcXHBheW1lbnR1cmUuY29tL3NyY1xcQGZ1c2VcXGNvbXBvbmVudHNcXG5hdmlnYXRpb25cXHZlcnRpY2FsXFxncm91cFxcZ3JvdXAuY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy9uYXZpZ2F0aW9uL3ZlcnRpY2FsL2dyb3VwL2dyb3VwLmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlRO0VBQ0ksbUJBQUE7QUNIWjtBREtZO0VBQ0ksVUFBQTtFQUNBLDhCQUFBO0FDSGhCO0FETVk7RUFDSSxXQUFBO0VBQ0EsY0FBQTtFQUNBLGtCQUFBO0VBQ0EsaUJBQUE7RUFDQSxxQkFBQTtFQUNBLFlBQUE7QUNKaEIiLCJmaWxlIjoic3JjL0BmdXNlL2NvbXBvbmVudHMvbmF2aWdhdGlvbi92ZXJ0aWNhbC9ncm91cC9ncm91cC5jb21wb25lbnQuc2NzcyIsInNvdXJjZXNDb250ZW50IjpbIjpob3N0IHtcclxuXHJcbiAgICAuZm9sZGVkOm5vdCgudW5mb2xkZWQpICYge1xyXG5cclxuICAgICAgICA+IC5ncm91cC10aXRsZSB7XHJcbiAgICAgICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcblxyXG4gICAgICAgICAgICA+IHNwYW4ge1xyXG4gICAgICAgICAgICAgICAgb3BhY2l0eTogMDtcclxuICAgICAgICAgICAgICAgIHRyYW5zaXRpb246IG9wYWNpdHkgMjAwbXMgZWFzZTtcclxuICAgICAgICAgICAgfVxyXG5cclxuICAgICAgICAgICAgJjpiZWZvcmUge1xyXG4gICAgICAgICAgICAgICAgY29udGVudDogJyc7XHJcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiBibG9jaztcclxuICAgICAgICAgICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcclxuICAgICAgICAgICAgICAgIG1pbi13aWR0aDogMS42cmVtO1xyXG4gICAgICAgICAgICAgICAgYm9yZGVyLXRvcDogMnB4IHNvbGlkO1xyXG4gICAgICAgICAgICAgICAgb3BhY2l0eTogMC4yO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbiIsIi5mb2xkZWQ6bm90KC51bmZvbGRlZCkgOmhvc3QgPiAuZ3JvdXAtdGl0bGUge1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xufVxuLmZvbGRlZDpub3QoLnVuZm9sZGVkKSA6aG9zdCA+IC5ncm91cC10aXRsZSA+IHNwYW4ge1xuICBvcGFjaXR5OiAwO1xuICB0cmFuc2l0aW9uOiBvcGFjaXR5IDIwMG1zIGVhc2U7XG59XG4uZm9sZGVkOm5vdCgudW5mb2xkZWQpIDpob3N0ID4gLmdyb3VwLXRpdGxlOmJlZm9yZSB7XG4gIGNvbnRlbnQ6IFwiXCI7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIG1pbi13aWR0aDogMS42cmVtO1xuICBib3JkZXItdG9wOiAycHggc29saWQ7XG4gIG9wYWNpdHk6IDAuMjtcbn0iXX0= */\"","import { ChangeDetectorRef, Component, HostBinding, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { merge, Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseNavigationItem } from '@fuse/types';\r\nimport { FuseNavigationService } from '@fuse/components/navigation/navigation.service';\r\n\r\n@Component({\r\n selector : 'fuse-nav-vertical-group',\r\n templateUrl: './group.component.html',\r\n styleUrls : ['./group.component.scss']\r\n})\r\nexport class FuseNavVerticalGroupComponent implements OnInit, OnDestroy\r\n{\r\n @HostBinding('class')\r\n classes = 'nav-group nav-item';\r\n\r\n @Input()\r\n item: FuseNavigationItem;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n */\r\n\r\n /**\r\n *\r\n * @param {ChangeDetectorRef} _changeDetectorRef\r\n * @param {FuseNavigationService} _fuseNavigationService\r\n */\r\n constructor(\r\n private _changeDetectorRef: ChangeDetectorRef,\r\n private _fuseNavigationService: FuseNavigationService\r\n )\r\n {\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Subscribe to navigation item\r\n merge(\r\n this._fuseNavigationService.onNavigationItemAdded,\r\n this._fuseNavigationService.onNavigationItemUpdated,\r\n this._fuseNavigationService.onNavigationItemRemoved\r\n ).pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(() => {\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n });\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n}\r\n","export default \".folded:not(.unfolded) :host .nav-link > .nav-link-title,\\n.folded:not(.unfolded) :host .nav-link > .nav-link-badge {\\n opacity: 0;\\n transition: opacity 200ms ease;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL25hdmlnYXRpb24vdmVydGljYWwvaXRlbS9DOlxcUHJvZ3JhbURhdGFcXEplbmtpbnNcXC5qZW5raW5zXFx3b3Jrc3BhY2VcXFJQTVNcXFVJXFxMaXZlIChVSSBydW5uaW5nIG9uIFBheW1lbnR1cmUgQVdTKVxccGF5bWVudHVyZS5jb20vc3JjXFxAZnVzZVxcY29tcG9uZW50c1xcbmF2aWdhdGlvblxcdmVydGljYWxcXGl0ZW1cXGl0ZW0uY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy9uYXZpZ2F0aW9uL3ZlcnRpY2FsL2l0ZW0vaXRlbS5jb21wb25lbnQuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNWTs7RUFFSSxVQUFBO0VBQ0EsOEJBQUE7QUNMaEIiLCJmaWxlIjoic3JjL0BmdXNlL2NvbXBvbmVudHMvbmF2aWdhdGlvbi92ZXJ0aWNhbC9pdGVtL2l0ZW0uY29tcG9uZW50LnNjc3MiLCJzb3VyY2VzQ29udGVudCI6WyI6aG9zdCB7XHJcblxyXG4gICAgLmZvbGRlZDpub3QoLnVuZm9sZGVkKSAmIHtcclxuXHJcbiAgICAgICAgLm5hdi1saW5rIHtcclxuXHJcbiAgICAgICAgICAgID4gLm5hdi1saW5rLXRpdGxlLFxyXG4gICAgICAgICAgICA+IC5uYXYtbGluay1iYWRnZSB7XHJcbiAgICAgICAgICAgICAgICBvcGFjaXR5OiAwO1xyXG4gICAgICAgICAgICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAyMDBtcyBlYXNlO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbiIsIi5mb2xkZWQ6bm90KC51bmZvbGRlZCkgOmhvc3QgLm5hdi1saW5rID4gLm5hdi1saW5rLXRpdGxlLFxuLmZvbGRlZDpub3QoLnVuZm9sZGVkKSA6aG9zdCAubmF2LWxpbmsgPiAubmF2LWxpbmstYmFkZ2Uge1xuICBvcGFjaXR5OiAwO1xuICB0cmFuc2l0aW9uOiBvcGFjaXR5IDIwMG1zIGVhc2U7XG59Il19 */\"","import { ChangeDetectorRef, Component, HostBinding, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { merge, Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseNavigationItem } from '@fuse/types';\r\nimport { FuseNavigationService } from '@fuse/components/navigation/navigation.service';\r\n\r\n@Component({\r\n selector : 'fuse-nav-vertical-item',\r\n templateUrl: './item.component.html',\r\n styleUrls : ['./item.component.scss']\r\n})\r\nexport class FuseNavVerticalItemComponent implements OnInit, OnDestroy\r\n{\r\n @HostBinding('class')\r\n classes = 'nav-item';\r\n\r\n @Input()\r\n item: FuseNavigationItem;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n */\r\n\r\n /**\r\n *\r\n * @param {ChangeDetectorRef} _changeDetectorRef\r\n * @param {FuseNavigationService} _fuseNavigationService\r\n */\r\n constructor(\r\n private _changeDetectorRef: ChangeDetectorRef,\r\n private _fuseNavigationService: FuseNavigationService\r\n )\r\n {\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Subscribe to navigation item\r\n merge(\r\n this._fuseNavigationService.onNavigationItemAdded,\r\n this._fuseNavigationService.onNavigationItemUpdated,\r\n this._fuseNavigationService.onNavigationItemRemoved\r\n ).pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(() => {\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n });\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\nfuse-progress-bar {\\n position: absolute;\\n top: 0;\\n left: 0;\\n right: 0;\\n width: 100%;\\n z-index: 99998;\\n}\\nfuse-progress-bar mat-progress-bar .mat-progress-bar-buffer {\\n background-color: #C5C6CB !important;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/@fuse/components/progress-bar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/@fuse/components/progress-bar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\components\\progress-bar\\progress-bar.component.scss","src/@fuse/components/progress-bar/progress-bar.component.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC95FA;EACI,kBAAA;EACA,MAAA;EACA,OAAA;EACA,QAAA;EACA,WAAA;EACA,cAAA;ACEJ;ADEQ;EACI,oCAAA;ACAZ","file":"src/@fuse/components/progress-bar/progress-bar.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\n\r\nfuse-progress-bar {\r\n    position: absolute;\r\n    top: 0;\r\n    left: 0;\r\n    right: 0;\r\n    width: 100%;\r\n    z-index: 99998;\r\n\r\n    mat-progress-bar {\r\n\r\n        .mat-progress-bar-buffer {\r\n            background-color: #C5C6CB !important;\r\n        }\r\n    }\r\n}\r\n","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\nfuse-progress-bar {\n  position: absolute;\n  top: 0;\n  left: 0;\n  right: 0;\n  width: 100%;\n  z-index: 99998;\n}\nfuse-progress-bar mat-progress-bar .mat-progress-bar-buffer {\n  background-color: #C5C6CB !important;\n}"]} */\"","import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseProgressBarService } from '@fuse/components/progress-bar/progress-bar.service';\r\n\r\n@Component({\r\n selector : 'fuse-progress-bar',\r\n templateUrl : './progress-bar.component.html',\r\n styleUrls : ['./progress-bar.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\nexport class FuseProgressBarComponent implements OnInit, OnDestroy\r\n{\r\n bufferValue: number;\r\n mode: 'determinate' | 'indeterminate' | 'buffer' | 'query';\r\n value: number;\r\n visible: boolean;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {FuseProgressBarService} _fuseProgressBarService\r\n */\r\n constructor(\r\n private _fuseProgressBarService: FuseProgressBarService\r\n )\r\n {\r\n // Set the defaults\r\n\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Subscribe to the progress bar service properties\r\n\r\n // Buffer value\r\n this._fuseProgressBarService.bufferValue\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((bufferValue) => {\r\n this.bufferValue = bufferValue;\r\n });\r\n\r\n // Mode\r\n this._fuseProgressBarService.mode\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((mode) => {\r\n this.mode = mode;\r\n });\r\n\r\n // Value\r\n this._fuseProgressBarService.value\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((value) => {\r\n this.value = value;\r\n });\r\n\r\n // Visible\r\n this._fuseProgressBarService.visible\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((visible) => {\r\n this.visible = visible;\r\n });\r\n\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\r\n\r\nimport { FuseProgressBarComponent } from './progress-bar.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseProgressBarComponent\r\n ],\r\n imports : [\r\n CommonModule,\r\n RouterModule,\r\n\r\n MatButtonModule,\r\n MatIconModule,\r\n MatProgressBarModule\r\n ],\r\n exports : [\r\n FuseProgressBarComponent\r\n ]\r\n})\r\nexport class FuseProgressBarModule\r\n{\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router } from '@angular/router';\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\nimport { filter } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class FuseProgressBarService\r\n{\r\n // Private\r\n private _bufferValue: BehaviorSubject;\r\n private _mode: BehaviorSubject;\r\n private _value: BehaviorSubject;\r\n private _visible: BehaviorSubject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {Router} _router\r\n */\r\n constructor(\r\n private _router: Router\r\n )\r\n {\r\n // Initialize the service\r\n this._init();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Buffer value\r\n */\r\n get bufferValue(): Observable\r\n {\r\n return this._bufferValue.asObservable();\r\n }\r\n\r\n setBufferValue(value: number): void\r\n {\r\n this._bufferValue.next(value);\r\n }\r\n\r\n /**\r\n * Mode\r\n */\r\n get mode(): Observable\r\n {\r\n return this._mode.asObservable();\r\n }\r\n\r\n setMode(value: 'determinate' | 'indeterminate' | 'buffer' | 'query'): void\r\n {\r\n this._mode.next(value);\r\n }\r\n\r\n /**\r\n * Value\r\n */\r\n get value(): Observable\r\n {\r\n return this._value.asObservable();\r\n }\r\n\r\n setValue(value: number): void\r\n {\r\n this._value.next(value);\r\n }\r\n\r\n /**\r\n * Visible\r\n */\r\n get visible(): Observable\r\n {\r\n return this._visible.asObservable();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Private methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Initialize\r\n *\r\n * @private\r\n */\r\n private _init(): void\r\n {\r\n // Initialize the behavior subjects\r\n this._bufferValue = new BehaviorSubject(0);\r\n this._mode = new BehaviorSubject('indeterminate');\r\n this._value = new BehaviorSubject(0);\r\n this._visible = new BehaviorSubject(false);\r\n\r\n // Subscribe to the router events to show/hide the loading bar\r\n this._router.events\r\n .pipe(filter((event) => event instanceof NavigationStart))\r\n .subscribe(() => {\r\n this.show();\r\n });\r\n\r\n this._router.events\r\n .pipe(filter((event) => event instanceof NavigationEnd || event instanceof NavigationError || event instanceof NavigationCancel))\r\n .subscribe(() => {\r\n this.hide();\r\n });\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Show the progress bar\r\n */\r\n show(): void\r\n {\r\n this._visible.next(true);\r\n }\r\n\r\n /**\r\n * Hide the progress bar\r\n */\r\n hide(): void\r\n {\r\n this._visible.next(false);\r\n }\r\n}\r\n\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\n:host .fuse-search-bar {\\n display: flex;\\n flex: 0 1 auto;\\n min-width: 64px;\\n height: 64px;\\n font-size: 13px;\\n}\\n@media screen and (max-width: 599px) {\\n :host .fuse-search-bar {\\n height: 56px;\\n }\\n}\\n:host .fuse-search-bar .fuse-search-bar-content {\\n display: flex;\\n flex: 1 1 auto;\\n align-items: center;\\n justify-content: flex-start;\\n}\\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-expander,\\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-collapser {\\n cursor: pointer;\\n padding: 0 20px;\\n margin: 0;\\n width: 64px !important;\\n height: 64px !important;\\n line-height: 64px !important;\\n}\\n@media screen and (max-width: 599px) {\\n :host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-expander,\\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-collapser {\\n height: 56px !important;\\n line-height: 56px !important;\\n }\\n}\\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-loader {\\n width: 64px !important;\\n height: 64px !important;\\n line-height: 64px !important;\\n}\\n@media screen and (max-width: 599px) {\\n :host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-loader {\\n height: 56px !important;\\n line-height: 56px !important;\\n }\\n}\\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-collapser {\\n display: none;\\n}\\n:host .fuse-search-bar .fuse-search-bar-content #fuse-search-bar-input {\\n display: none;\\n flex: 1 0 auto;\\n min-height: 64px;\\n font-size: 16px;\\n background-color: transparent;\\n color: currentColor;\\n}\\n:host .fuse-search-bar.expanded {\\n position: absolute;\\n top: 0;\\n right: 0;\\n bottom: 0;\\n left: 0;\\n z-index: 10;\\n}\\n:host .fuse-search-bar.expanded .fuse-search-bar-content #fuse-search-bar-input {\\n display: flex;\\n}\\n:host .fuse-search-bar.expanded .fuse-search-bar-content .fuse-search-bar-collapser {\\n display: flex;\\n}\\n:host body.fuse-search-bar-expanded #toolbar {\\n z-index: 999 !important;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/@fuse/components/search-bar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/@fuse/components/search-bar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\components\\search-bar\\search-bar.component.scss","src/@fuse/components/search-bar/search-bar.component.scss","src/@fuse/components/search-bar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC55FI;EACI,aAAA;EACA,cAAA;EACA,eAAA;EACA,YAAA;EACA,eAAA;ACAR;ACwBQ;EF7BJ;IAQQ,YAAA;ECCV;AACF;ADCQ;EACI,aAAA;EACA,cAAA;EACA,mBAAA;EACA,2BAAA;ACCZ;ADCY;;EAEI,eAAA;EACA,eAAA;EACA,SAAA;EACA,sBAAA;EACA,uBAAA;EACA,4BAAA;ACChB;ACIQ;EFZI;;IAUQ,uBAAA;IACA,4BAAA;ECGlB;AACF;ADAY;EACI,sBAAA;EACA,uBAAA;EACA,4BAAA;ACEhB;ACRQ;EFGI;IAMQ,uBAAA;IACA,4BAAA;ECGlB;AACF;ADAY;EACI,aAAA;ACEhB;ADCY;EACI,aAAA;EACA,cAAA;EACA,gBAAA;EACA,eAAA;EACA,6BAAA;EACA,mBAAA;ACChB;ADGQ;EACI,kBAAA;EACA,MAAA;EACA,QAAA;EACA,SAAA;EACA,OAAA;EACA,WAAA;ACDZ;ADKgB;EACI,aAAA;ACHpB;ADMgB;EACI,aAAA;ACJpB;ADcY;EACI,uBAAA;ACZhB","file":"src/@fuse/components/search-bar/search-bar.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\n\r\n:host {\r\n\r\n    .fuse-search-bar {\r\n        display: flex;\r\n        flex: 0 1 auto;\r\n        min-width: 64px;\r\n        height: 64px;\r\n        font-size: 13px;\r\n\r\n        @include media-breakpoint('xs') {\r\n            height: 56px;\r\n        }\r\n\r\n        .fuse-search-bar-content {\r\n            display: flex;\r\n            flex: 1 1 auto;\r\n            align-items: center;\r\n            justify-content: flex-start;\r\n\r\n            .fuse-search-bar-expander,\r\n            .fuse-search-bar-collapser {\r\n                cursor: pointer;\r\n                padding: 0 20px;\r\n                margin: 0;\r\n                width: 64px !important;\r\n                height: 64px !important;\r\n                line-height: 64px !important;\r\n\r\n                @include media-breakpoint('xs') {\r\n                    height: 56px !important;\r\n                    line-height: 56px !important;\r\n                }\r\n            }\r\n\r\n            .fuse-search-bar-loader {\r\n                width: 64px !important;\r\n                height: 64px !important;\r\n                line-height: 64px !important;\r\n\r\n                @include media-breakpoint('xs') {\r\n                    height: 56px !important;\r\n                    line-height: 56px !important;\r\n                }\r\n            }\r\n\r\n            .fuse-search-bar-collapser {\r\n                display: none;\r\n            }\r\n\r\n            #fuse-search-bar-input {\r\n                display: none;\r\n                flex: 1 0 auto;\r\n                min-height: 64px;\r\n                font-size: 16px;\r\n                background-color: transparent;\r\n                color: currentColor;\r\n            }\r\n        }\r\n\r\n        &.expanded {\r\n            position: absolute;\r\n            top: 0;\r\n            right: 0;\r\n            bottom: 0;\r\n            left: 0;\r\n            z-index: 10;\r\n\r\n            .fuse-search-bar-content {\r\n\r\n                #fuse-search-bar-input {\r\n                    display: flex;\r\n                }\r\n\r\n                .fuse-search-bar-collapser {\r\n                    display: flex;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    body {\r\n\r\n        &.fuse-search-bar-expanded {\r\n\r\n            #toolbar {\r\n                z-index: 999 !important;\r\n            }\r\n        }\r\n    }\r\n}\r\n","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\n:host .fuse-search-bar {\n  display: flex;\n  flex: 0 1 auto;\n  min-width: 64px;\n  height: 64px;\n  font-size: 13px;\n}\n@media screen and (max-width: 599px) {\n  :host .fuse-search-bar {\n    height: 56px;\n  }\n}\n:host .fuse-search-bar .fuse-search-bar-content {\n  display: flex;\n  flex: 1 1 auto;\n  align-items: center;\n  justify-content: flex-start;\n}\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-expander,\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-collapser {\n  cursor: pointer;\n  padding: 0 20px;\n  margin: 0;\n  width: 64px !important;\n  height: 64px !important;\n  line-height: 64px !important;\n}\n@media screen and (max-width: 599px) {\n  :host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-expander,\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-collapser {\n    height: 56px !important;\n    line-height: 56px !important;\n  }\n}\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-loader {\n  width: 64px !important;\n  height: 64px !important;\n  line-height: 64px !important;\n}\n@media screen and (max-width: 599px) {\n  :host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-loader {\n    height: 56px !important;\n    line-height: 56px !important;\n  }\n}\n:host .fuse-search-bar .fuse-search-bar-content .fuse-search-bar-collapser {\n  display: none;\n}\n:host .fuse-search-bar .fuse-search-bar-content #fuse-search-bar-input {\n  display: none;\n  flex: 1 0 auto;\n  min-height: 64px;\n  font-size: 16px;\n  background-color: transparent;\n  color: currentColor;\n}\n:host .fuse-search-bar.expanded {\n  position: absolute;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 10;\n}\n:host .fuse-search-bar.expanded .fuse-search-bar-content #fuse-search-bar-input {\n  display: flex;\n}\n:host .fuse-search-bar.expanded .fuse-search-bar-content .fuse-search-bar-collapser {\n  display: flex;\n}\n:host body.fuse-search-bar-expanded #toolbar {\n  z-index: 999 !important;\n}","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n"]} */\"","import { Component, EventEmitter, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseConfigService } from '@fuse/services/config.service';\r\n\r\n@Component({\r\n selector : 'fuse-search-bar',\r\n templateUrl: './search-bar.component.html',\r\n styleUrls : ['./search-bar.component.scss']\r\n})\r\nexport class FuseSearchBarComponent implements OnInit, OnDestroy\r\n{\r\n collapsed: boolean;\r\n fuseConfig: any;\r\n\r\n @Output()\r\n input: EventEmitter;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {FuseConfigService} _fuseConfigService\r\n */\r\n constructor(\r\n private _fuseConfigService: FuseConfigService\r\n )\r\n {\r\n // Set the defaults\r\n this.input = new EventEmitter();\r\n this.collapsed = true;\r\n\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Subscribe to config changes\r\n this._fuseConfigService.config\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(\r\n (config) => {\r\n this.fuseConfig = config;\r\n }\r\n );\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Collapse\r\n */\r\n collapse(): void\r\n {\r\n this.collapsed = true;\r\n }\r\n\r\n /**\r\n * Expand\r\n */\r\n expand(): void\r\n {\r\n this.collapsed = false;\r\n }\r\n\r\n /**\r\n * Search\r\n *\r\n * @param event\r\n */\r\n search(event): void\r\n {\r\n this.input.emit(event.target.value);\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\n\r\nimport { FuseSearchBarComponent } from './search-bar.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseSearchBarComponent\r\n ],\r\n imports : [\r\n CommonModule,\r\n RouterModule,\r\n\r\n MatButtonModule,\r\n MatIconModule\r\n ],\r\n exports : [\r\n FuseSearchBarComponent\r\n ]\r\n})\r\nexport class FuseSearchBarModule\r\n{\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\n@media screen and (max-width: 959px) {\\n :host #fuse-shortcuts.show-mobile-panel {\\n position: absolute;\\n top: 0;\\n right: 0;\\n bottom: 0;\\n left: 0;\\n z-index: 99;\\n padding: 0 8px;\\n }\\n :host #fuse-shortcuts.show-mobile-panel .shortcuts {\\n display: flex !important;\\n flex: 1;\\n height: 100%;\\n }\\n :host #fuse-shortcuts.show-mobile-panel .shortcuts > div {\\n flex: 1 1 auto !important;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/@fuse/components/shortcuts/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/@fuse/components/shortcuts/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss","src/@fuse/components/shortcuts/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\components\\shortcuts\\shortcuts.component.scss","src/@fuse/components/shortcuts/shortcuts.component.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC/3FQ;ECzBI;IACI,kBAAA;IACA,MAAA;IACA,QAAA;IACA,SAAA;IACA,OAAA;IACA,WAAA;IACA,cAAA;ECHd;EDKc;IACI,wBAAA;IACA,OAAA;IACA,YAAA;ECHlB;EDKkB;IACI,yBAAA;ECHtB;AACF","file":"src/@fuse/components/shortcuts/shortcuts.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n","@import 'src/@fuse/scss/fuse';\r\n\r\n:host {\r\n\r\n    @include media-breakpoint('lt-md') {\r\n\r\n        #fuse-shortcuts {\r\n\r\n            &.show-mobile-panel {\r\n                position: absolute;\r\n                top: 0;\r\n                right: 0;\r\n                bottom: 0;\r\n                left: 0;\r\n                z-index: 99;\r\n                padding: 0 8px;\r\n\r\n                .shortcuts {\r\n                    display: flex !important;\r\n                    flex: 1;\r\n                    height: 100%;\r\n\r\n                    > div {\r\n                        flex: 1 1 auto !important;\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\n@media screen and (max-width: 959px) {\n  :host #fuse-shortcuts.show-mobile-panel {\n    position: absolute;\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n    z-index: 99;\n    padding: 0 8px;\n  }\n  :host #fuse-shortcuts.show-mobile-panel .shortcuts {\n    display: flex !important;\n    flex: 1;\n    height: 100%;\n  }\n  :host #fuse-shortcuts.show-mobile-panel .shortcuts > div {\n    flex: 1 1 auto !important;\n  }\n}"]} */\"","import { AfterViewInit, Component, ElementRef, Input, OnDestroy, OnInit, Renderer2, ViewChild } from '@angular/core';\r\nimport { MediaObserver } from '@angular/flex-layout';\r\nimport { CookieService } from 'ngx-cookie-service';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseMatchMediaService } from '@fuse/services/match-media.service';\r\nimport { FuseNavigationService } from '@fuse/components/navigation/navigation.service';\r\n\r\n@Component({\r\n selector : 'fuse-shortcuts',\r\n templateUrl: './shortcuts.component.html',\r\n styleUrls : ['./shortcuts.component.scss']\r\n})\r\nexport class FuseShortcutsComponent implements OnInit, AfterViewInit, OnDestroy\r\n{\r\n shortcutItems: any[];\r\n navigationItems: any[];\r\n filteredNavigationItems: any[];\r\n searching: boolean;\r\n mobileShortcutsPanelActive: boolean;\r\n\r\n @Input()\r\n navigation: any;\r\n\r\n @ViewChild('searchInput', {static: false})\r\n searchInputField;\r\n\r\n @ViewChild('shortcuts', {static: false})\r\n shortcutsEl: ElementRef;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {CookieService} _cookieService\r\n * @param {FuseMatchMediaService} _fuseMatchMediaService\r\n * @param {FuseNavigationService} _fuseNavigationService\r\n * @param {MediaObserver} _mediaObserver\r\n * @param {Renderer2} _renderer\r\n */\r\n constructor(\r\n private _cookieService: CookieService,\r\n private _fuseMatchMediaService: FuseMatchMediaService,\r\n private _fuseNavigationService: FuseNavigationService,\r\n private _mediaObserver: MediaObserver,\r\n private _renderer: Renderer2\r\n )\r\n {\r\n // Set the defaults\r\n this.shortcutItems = [];\r\n this.searching = false;\r\n this.mobileShortcutsPanelActive = false;\r\n\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Get the navigation items and flatten them\r\n this.filteredNavigationItems = this.navigationItems = this._fuseNavigationService.getFlatNavigation(this.navigation);\r\n\r\n if ( this._cookieService.check('FUSE2.shortcuts') )\r\n {\r\n this.shortcutItems = JSON.parse(this._cookieService.get('FUSE2.shortcuts'));\r\n }\r\n else\r\n {\r\n // User's shortcut items\r\n this.shortcutItems = [\r\n {\r\n title: 'Calendar',\r\n type : 'item',\r\n icon : 'today',\r\n url : '/apps/calendar'\r\n },\r\n {\r\n title: 'Mail',\r\n type : 'item',\r\n icon : 'email',\r\n url : '/apps/mail'\r\n },\r\n {\r\n title: 'Contacts',\r\n type : 'item',\r\n icon : 'account_box',\r\n url : '/apps/contacts'\r\n },\r\n {\r\n title: 'To-Do',\r\n type : 'item',\r\n icon : 'check_box',\r\n url : '/apps/todo'\r\n }\r\n ];\r\n }\r\n\r\n }\r\n\r\n ngAfterViewInit(): void\r\n {\r\n // Subscribe to media changes\r\n this._fuseMatchMediaService.onMediaChange\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(() => {\r\n if ( this._mediaObserver.isActive('gt-sm') )\r\n {\r\n this.hideMobileShortcutsPanel();\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Search\r\n *\r\n * @param event\r\n */\r\n search(event): void\r\n {\r\n const value = event.target.value.toLowerCase();\r\n\r\n if ( value === '' )\r\n {\r\n this.searching = false;\r\n this.filteredNavigationItems = this.navigationItems;\r\n\r\n return;\r\n }\r\n\r\n this.searching = true;\r\n\r\n this.filteredNavigationItems = this.navigationItems.filter((navigationItem) => {\r\n return navigationItem.title.toLowerCase().includes(value);\r\n });\r\n }\r\n\r\n /**\r\n * Toggle shortcut\r\n *\r\n * @param event\r\n * @param itemToToggle\r\n */\r\n toggleShortcut(event, itemToToggle): void\r\n {\r\n event.stopPropagation();\r\n\r\n for ( let i = 0; i < this.shortcutItems.length; i++ )\r\n {\r\n if ( this.shortcutItems[i].url === itemToToggle.url )\r\n {\r\n this.shortcutItems.splice(i, 1);\r\n\r\n // Save to the cookies\r\n this._cookieService.set('FUSE2.shortcuts', JSON.stringify(this.shortcutItems));\r\n\r\n return;\r\n }\r\n }\r\n\r\n this.shortcutItems.push(itemToToggle);\r\n\r\n // Save to the cookies\r\n this._cookieService.set('FUSE2.shortcuts', JSON.stringify(this.shortcutItems));\r\n }\r\n\r\n /**\r\n * Is in shortcuts?\r\n *\r\n * @param navigationItem\r\n * @returns {any}\r\n */\r\n isInShortcuts(navigationItem): any\r\n {\r\n return this.shortcutItems.find(item => {\r\n return item.url === navigationItem.url;\r\n });\r\n }\r\n\r\n /**\r\n * On menu open\r\n */\r\n onMenuOpen(): void\r\n {\r\n setTimeout(() => {\r\n this.searchInputField.nativeElement.focus();\r\n });\r\n }\r\n\r\n /**\r\n * Show mobile shortcuts\r\n */\r\n showMobileShortcutsPanel(): void\r\n {\r\n this.mobileShortcutsPanelActive = true;\r\n this._renderer.addClass(this.shortcutsEl.nativeElement, 'show-mobile-panel');\r\n }\r\n\r\n /**\r\n * Hide mobile shortcuts\r\n */\r\n hideMobileShortcutsPanel(): void\r\n {\r\n this.mobileShortcutsPanelActive = false;\r\n this._renderer.removeClass(this.shortcutsEl.nativeElement, 'show-mobile-panel');\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { RouterModule } from '@angular/router';\r\nimport { FlexLayoutModule } from '@angular/flex-layout';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatDividerModule } from '@angular/material/divider';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatListModule } from '@angular/material/list';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { CookieService } from 'ngx-cookie-service';\r\n\r\nimport { FuseShortcutsComponent } from './shortcuts.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseShortcutsComponent\r\n ],\r\n imports : [\r\n CommonModule,\r\n RouterModule,\r\n\r\n FlexLayoutModule,\r\n\r\n MatButtonModule,\r\n MatDividerModule,\r\n MatFormFieldModule,\r\n MatIconModule,\r\n MatInputModule,\r\n MatMenuModule,\r\n MatListModule,\r\n MatTooltipModule\r\n ],\r\n exports : [\r\n FuseShortcutsComponent\r\n ],\r\n providers : [\r\n CookieService\r\n ]\r\n})\r\nexport class FuseShortcutsModule\r\n{\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\nfuse-sidebar {\\n display: flex;\\n flex-direction: column;\\n flex: 1 0 auto;\\n position: absolute;\\n top: 0;\\n bottom: 0;\\n overflow-x: hidden;\\n overflow-y: auto;\\n -webkit-overflow-scrolling: touch;\\n width: 280px;\\n min-width: 280px;\\n max-width: 280px;\\n z-index: 1000;\\n box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.35);\\n}\\n@media screen and (max-width: 599px) {\\n fuse-sidebar {\\n min-width: 0 !important;\\n max-width: 80vw !important;\\n width: 80vw !important;\\n }\\n}\\nfuse-sidebar.left-positioned {\\n left: 0;\\n transform: translateX(-100%);\\n}\\nfuse-sidebar.right-positioned {\\n right: 0;\\n transform: translateX(100%);\\n}\\nfuse-sidebar.open {\\n transform: translateX(0);\\n}\\nfuse-sidebar.locked-open {\\n position: relative !important;\\n transform: translateX(0) !important;\\n}\\nfuse-sidebar.folded {\\n position: absolute !important;\\n top: 0;\\n bottom: 0;\\n}\\nfuse-sidebar.animations-enabled {\\n transition-property: transform, width, min-width, max-width;\\n transition-duration: 150ms;\\n transition-timing-function: ease-in-out;\\n}\\n.fuse-sidebar-overlay {\\n position: absolute;\\n top: 0;\\n bottom: 0;\\n left: 0;\\n right: 0;\\n z-index: 999;\\n opacity: 0;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/@fuse/components/sidebar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/@fuse/components/sidebar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\components\\sidebar\\sidebar.component.scss","src/@fuse/components/sidebar/sidebar.component.scss","src/@fuse/components/sidebar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC95FA;EACI,aAAA;EACA,sBAAA;EACA,cAAA;EACA,kBAAA;EACA,MAAA;EACA,SAAA;EACA,kBAAA;EACA,gBAAA;EACA,iCAAA;EACA,YAAA;EACA,gBAAA;EACA,gBAAA;EACA,aAAA;EACA,2CAAA;ACEJ;ACeQ;EF/BR;IAiBQ,uBAAA;IACA,0BAAA;IACA,sBAAA;ECGN;AACF;ADDI;EACI,OAAA;EACA,4BAAA;ACGR;ADAI;EACI,QAAA;EACA,2BAAA;ACER;ADCI;EACI,wBAAA;ACCR;ADEI;EACI,6BAAA;EACA,mCAAA;ACAR;ADGI;EACI,6BAAA;EACA,MAAA;EACA,SAAA;ACDR;ADII;EACI,2DAAA;EACA,0BAAA;EACA,uCAAA;ACFR;ADMA;EACI,kBAAA;EACA,MAAA;EACA,SAAA;EACA,OAAA;EACA,QAAA;EACA,YAAA;EACA,UAAA;ACHJ","file":"src/@fuse/components/sidebar/sidebar.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\n\r\nfuse-sidebar {\r\n    display: flex;\r\n    flex-direction: column;\r\n    flex: 1 0 auto;\r\n    position: absolute;\r\n    top: 0;\r\n    bottom: 0;\r\n    overflow-x: hidden;\r\n    overflow-y: auto;\r\n    -webkit-overflow-scrolling: touch;\r\n    width: 280px;\r\n    min-width: 280px;\r\n    max-width: 280px;\r\n    z-index: 1000;\r\n    box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.35);\r\n\r\n    @include media-breakpoint('xs') {\r\n        min-width: 0 !important;\r\n        max-width: 80vw !important;\r\n        width: 80vw !important;\r\n    }\r\n\r\n    &.left-positioned {\r\n        left: 0;\r\n        transform: translateX(-100%);\r\n    }\r\n\r\n    &.right-positioned {\r\n        right: 0;\r\n        transform: translateX(100%);\r\n    }\r\n\r\n    &.open {\r\n        transform: translateX(0);\r\n    }\r\n\r\n    &.locked-open {\r\n        position: relative !important;\r\n        transform: translateX(0) !important;\r\n    }\r\n\r\n    &.folded {\r\n        position: absolute !important;\r\n        top: 0;\r\n        bottom: 0;\r\n    }\r\n\r\n    &.animations-enabled {\r\n        transition-property: transform, width, min-width, max-width;\r\n        transition-duration: 150ms;\r\n        transition-timing-function: ease-in-out;\r\n    }\r\n}\r\n\r\n.fuse-sidebar-overlay {\r\n    position: absolute;\r\n    top: 0;\r\n    bottom: 0;\r\n    left: 0;\r\n    right: 0;\r\n    z-index: 999;\r\n    opacity: 0;\r\n}","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\nfuse-sidebar {\n  display: flex;\n  flex-direction: column;\n  flex: 1 0 auto;\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  overflow-x: hidden;\n  overflow-y: auto;\n  -webkit-overflow-scrolling: touch;\n  width: 280px;\n  min-width: 280px;\n  max-width: 280px;\n  z-index: 1000;\n  box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.35);\n}\n@media screen and (max-width: 599px) {\n  fuse-sidebar {\n    min-width: 0 !important;\n    max-width: 80vw !important;\n    width: 80vw !important;\n  }\n}\nfuse-sidebar.left-positioned {\n  left: 0;\n  transform: translateX(-100%);\n}\nfuse-sidebar.right-positioned {\n  right: 0;\n  transform: translateX(100%);\n}\nfuse-sidebar.open {\n  transform: translateX(0);\n}\nfuse-sidebar.locked-open {\n  position: relative !important;\n  transform: translateX(0) !important;\n}\nfuse-sidebar.folded {\n  position: absolute !important;\n  top: 0;\n  bottom: 0;\n}\nfuse-sidebar.animations-enabled {\n  transition-property: transform, width, min-width, max-width;\n  transition-duration: 150ms;\n  transition-timing-function: ease-in-out;\n}\n\n.fuse-sidebar-overlay {\n  position: absolute;\n  top: 0;\n  bottom: 0;\n  left: 0;\n  right: 0;\n  z-index: 999;\n  opacity: 0;\n}","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n"]} */\"","import {\r\n ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, OnDestroy, OnInit, Output, Renderer2, ViewEncapsulation\r\n} from '@angular/core';\r\nimport { animate, AnimationBuilder, AnimationPlayer, style } from '@angular/animations';\r\nimport { MediaObserver } from '@angular/flex-layout';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseSidebarService } from './sidebar.service';\r\nimport { FuseMatchMediaService } from '@fuse/services/match-media.service';\r\nimport { FuseConfigService } from '@fuse/services/config.service';\r\n\r\n@Component({\r\n selector : 'fuse-sidebar',\r\n templateUrl : './sidebar.component.html',\r\n styleUrls : ['./sidebar.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\nexport class FuseSidebarComponent implements OnInit, OnDestroy\r\n{\r\n // Name\r\n @Input()\r\n name: string;\r\n\r\n // Key\r\n @Input()\r\n key: string;\r\n\r\n // Position\r\n @Input()\r\n position: 'left' | 'right';\r\n\r\n // Open\r\n @HostBinding('class.open')\r\n opened: boolean;\r\n\r\n // Locked Open\r\n @Input()\r\n lockedOpen: string;\r\n\r\n // isLockedOpen\r\n @HostBinding('class.locked-open')\r\n isLockedOpen: boolean;\r\n\r\n // Folded width\r\n @Input()\r\n foldedWidth: number;\r\n\r\n // Folded auto trigger on hover\r\n @Input()\r\n foldedAutoTriggerOnHover: boolean;\r\n\r\n // Folded unfolded\r\n @HostBinding('class.unfolded')\r\n unfolded: boolean;\r\n\r\n // Invisible overlay\r\n @Input()\r\n invisibleOverlay: boolean;\r\n\r\n // Folded changed\r\n @Output()\r\n foldedChanged: EventEmitter;\r\n\r\n // Opened changed\r\n @Output()\r\n openedChanged: EventEmitter;\r\n\r\n // Private\r\n private _folded: boolean;\r\n private _fuseConfig: any;\r\n private _wasActive: boolean;\r\n private _wasFolded: boolean;\r\n private _backdrop: HTMLElement | null = null;\r\n private _player: AnimationPlayer;\r\n private _unsubscribeAll: Subject;\r\n\r\n @HostBinding('class.animations-enabled')\r\n private _animationsEnabled: boolean;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {AnimationBuilder} _animationBuilder\r\n * @param {ChangeDetectorRef} _changeDetectorRef\r\n * @param {ElementRef} _elementRef\r\n * @param {FuseConfigService} _fuseConfigService\r\n * @param {FuseMatchMediaService} _fuseMatchMediaService\r\n * @param {FuseSidebarService} _fuseSidebarService\r\n * @param {MediaObserver} _mediaObserver\r\n * @param {Renderer2} _renderer\r\n */\r\n constructor(\r\n private _animationBuilder: AnimationBuilder,\r\n private _changeDetectorRef: ChangeDetectorRef,\r\n private _elementRef: ElementRef,\r\n private _fuseConfigService: FuseConfigService,\r\n private _fuseMatchMediaService: FuseMatchMediaService,\r\n private _fuseSidebarService: FuseSidebarService,\r\n private _mediaObserver: MediaObserver,\r\n private _renderer: Renderer2\r\n )\r\n {\r\n // Set the defaults\r\n this.foldedAutoTriggerOnHover = true;\r\n this.foldedWidth = 64;\r\n this.foldedChanged = new EventEmitter();\r\n this.openedChanged = new EventEmitter();\r\n this.opened = false;\r\n this.position = 'left';\r\n this.invisibleOverlay = false;\r\n\r\n // Set the private defaults\r\n this._animationsEnabled = false;\r\n this._folded = false;\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Folded\r\n *\r\n * @param {boolean} value\r\n */\r\n @Input()\r\n set folded(value: boolean)\r\n {\r\n // Set the folded\r\n this._folded = value;\r\n\r\n // Return if the sidebar is closed\r\n if ( !this.opened )\r\n {\r\n return;\r\n }\r\n\r\n // Programmatically add/remove padding to the element\r\n // that comes after or before based on the position\r\n let sibling,\r\n styleRule;\r\n\r\n const styleValue = this.foldedWidth + 'px';\r\n\r\n // Get the sibling and set the style rule\r\n if ( this.position === 'left' )\r\n {\r\n sibling = this._elementRef.nativeElement.nextElementSibling;\r\n styleRule = 'padding-left';\r\n }\r\n else\r\n {\r\n sibling = this._elementRef.nativeElement.previousElementSibling;\r\n styleRule = 'padding-right';\r\n }\r\n\r\n // If there is no sibling, return...\r\n if ( !sibling )\r\n {\r\n return;\r\n }\r\n\r\n // If folded...\r\n if ( value )\r\n {\r\n // Fold the sidebar\r\n this.fold();\r\n\r\n // Set the folded width\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'width', styleValue);\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'min-width', styleValue);\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'max-width', styleValue);\r\n\r\n // Set the style and class\r\n this._renderer.setStyle(sibling, styleRule, styleValue);\r\n this._renderer.addClass(this._elementRef.nativeElement, 'folded');\r\n }\r\n // If unfolded...\r\n else\r\n {\r\n // Unfold the sidebar\r\n this.unfold();\r\n\r\n // Remove the folded width\r\n this._renderer.removeStyle(this._elementRef.nativeElement, 'width');\r\n this._renderer.removeStyle(this._elementRef.nativeElement, 'min-width');\r\n this._renderer.removeStyle(this._elementRef.nativeElement, 'max-width');\r\n\r\n // Remove the style and class\r\n this._renderer.removeStyle(sibling, styleRule);\r\n this._renderer.removeClass(this._elementRef.nativeElement, 'folded');\r\n }\r\n\r\n // Emit the 'foldedChanged' event\r\n this.foldedChanged.emit(this.folded);\r\n }\r\n\r\n get folded(): boolean\r\n {\r\n return this._folded;\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Subscribe to config changes\r\n this._fuseConfigService.config\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((config) => {\r\n this._fuseConfig = config;\r\n });\r\n\r\n // Register the sidebar\r\n this._fuseSidebarService.register(this.name, this);\r\n\r\n // Setup visibility\r\n this._setupVisibility();\r\n\r\n // Setup position\r\n this._setupPosition();\r\n\r\n // Setup lockedOpen\r\n this._setupLockedOpen();\r\n\r\n // Setup folded\r\n this._setupFolded();\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // If the sidebar is folded, unfold it to revert modifications\r\n if ( this.folded )\r\n {\r\n this.unfold();\r\n }\r\n\r\n // Unregister the sidebar\r\n this._fuseSidebarService.unregister(this.name);\r\n\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Private methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Setup the visibility of the sidebar\r\n *\r\n * @private\r\n */\r\n private _setupVisibility(): void\r\n {\r\n // Remove the existing box-shadow\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'box-shadow', 'none');\r\n\r\n // Make the sidebar invisible\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'visibility', 'hidden');\r\n }\r\n\r\n /**\r\n * Setup the sidebar position\r\n *\r\n * @private\r\n */\r\n private _setupPosition(): void\r\n {\r\n // Add the correct class name to the sidebar\r\n // element depending on the position attribute\r\n if ( this.position === 'right' )\r\n {\r\n this._renderer.addClass(this._elementRef.nativeElement, 'right-positioned');\r\n }\r\n else\r\n {\r\n this._renderer.addClass(this._elementRef.nativeElement, 'left-positioned');\r\n }\r\n }\r\n\r\n /**\r\n * Setup the lockedOpen handler\r\n *\r\n * @private\r\n */\r\n private _setupLockedOpen(): void\r\n {\r\n // Return if the lockedOpen wasn't set\r\n if ( !this.lockedOpen )\r\n {\r\n // Return\r\n return;\r\n }\r\n\r\n // Set the wasActive for the first time\r\n this._wasActive = false;\r\n\r\n // Set the wasFolded\r\n this._wasFolded = this.folded;\r\n\r\n // Show the sidebar\r\n this._showSidebar();\r\n\r\n // Act on every media change\r\n this._fuseMatchMediaService.onMediaChange\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(() => {\r\n\r\n // Get the active status\r\n const isActive = this._mediaObserver.isActive(this.lockedOpen);\r\n\r\n // If the both status are the same, don't act\r\n if ( this._wasActive === isActive )\r\n {\r\n return;\r\n }\r\n\r\n // Activate the lockedOpen\r\n if ( isActive )\r\n {\r\n // Set the lockedOpen status\r\n this.isLockedOpen = true;\r\n\r\n // Show the sidebar\r\n this._showSidebar();\r\n\r\n // Force the the opened status to true\r\n this.opened = true;\r\n\r\n // Emit the 'openedChanged' event\r\n this.openedChanged.emit(this.opened);\r\n\r\n // If the sidebar was folded, forcefully fold it again\r\n if ( this._wasFolded )\r\n {\r\n // Enable the animations\r\n this._enableAnimations();\r\n\r\n // Fold\r\n this.folded = true;\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n // Hide the backdrop if any exists\r\n this._hideBackdrop();\r\n }\r\n // De-Activate the lockedOpen\r\n else\r\n {\r\n // Set the lockedOpen status\r\n this.isLockedOpen = false;\r\n\r\n // Unfold the sidebar in case if it was folded\r\n this.unfold();\r\n\r\n // Force the the opened status to close\r\n this.opened = false;\r\n\r\n // Emit the 'openedChanged' event\r\n this.openedChanged.emit(this.opened);\r\n\r\n // Hide the sidebar\r\n this._hideSidebar();\r\n }\r\n\r\n // Store the new active status\r\n this._wasActive = isActive;\r\n });\r\n }\r\n\r\n /**\r\n * Setup the initial folded status\r\n *\r\n * @private\r\n */\r\n private _setupFolded(): void\r\n {\r\n // Return, if sidebar is not folded\r\n if ( !this.folded )\r\n {\r\n return;\r\n }\r\n\r\n // Return if the sidebar is closed\r\n if ( !this.opened )\r\n {\r\n return;\r\n }\r\n\r\n // Programmatically add/remove padding to the element\r\n // that comes after or before based on the position\r\n let sibling,\r\n styleRule;\r\n\r\n const styleValue = this.foldedWidth + 'px';\r\n\r\n // Get the sibling and set the style rule\r\n if ( this.position === 'left' )\r\n {\r\n sibling = this._elementRef.nativeElement.nextElementSibling;\r\n styleRule = 'padding-left';\r\n }\r\n else\r\n {\r\n sibling = this._elementRef.nativeElement.previousElementSibling;\r\n styleRule = 'padding-right';\r\n }\r\n\r\n // If there is no sibling, return...\r\n if ( !sibling )\r\n {\r\n return;\r\n }\r\n\r\n // Fold the sidebar\r\n this.fold();\r\n\r\n // Set the folded width\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'width', styleValue);\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'min-width', styleValue);\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'max-width', styleValue);\r\n\r\n // Set the style and class\r\n this._renderer.setStyle(sibling, styleRule, styleValue);\r\n this._renderer.addClass(this._elementRef.nativeElement, 'folded');\r\n }\r\n\r\n /**\r\n * Show the backdrop\r\n *\r\n * @private\r\n */\r\n private _showBackdrop(): void\r\n {\r\n // Create the backdrop element\r\n this._backdrop = this._renderer.createElement('div');\r\n\r\n // Add a class to the backdrop element\r\n this._backdrop.classList.add('fuse-sidebar-overlay');\r\n\r\n // Add a class depending on the invisibleOverlay option\r\n if ( this.invisibleOverlay )\r\n {\r\n this._backdrop.classList.add('fuse-sidebar-overlay-invisible');\r\n }\r\n\r\n // Append the backdrop to the parent of the sidebar\r\n this._renderer.appendChild(this._elementRef.nativeElement.parentElement, this._backdrop);\r\n\r\n // Create the enter animation and attach it to the player\r\n this._player =\r\n this._animationBuilder\r\n .build([\r\n animate('300ms ease', style({opacity: 1}))\r\n ]).create(this._backdrop);\r\n\r\n // Play the animation\r\n this._player.play();\r\n\r\n // Add an event listener to the overlay\r\n this._backdrop.addEventListener('click', () => {\r\n this.close();\r\n }\r\n );\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Hide the backdrop\r\n *\r\n * @private\r\n */\r\n private _hideBackdrop(): void\r\n {\r\n if ( !this._backdrop )\r\n {\r\n return;\r\n }\r\n\r\n // Create the leave animation and attach it to the player\r\n this._player =\r\n this._animationBuilder\r\n .build([\r\n animate('300ms ease', style({opacity: 0}))\r\n ]).create(this._backdrop);\r\n\r\n // Play the animation\r\n this._player.play();\r\n\r\n // Once the animation is done...\r\n this._player.onDone(() => {\r\n\r\n // If the backdrop still exists...\r\n if ( this._backdrop )\r\n {\r\n // Remove the backdrop\r\n this._backdrop.parentNode.removeChild(this._backdrop);\r\n this._backdrop = null;\r\n }\r\n });\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Change some properties of the sidebar\r\n * and make it visible\r\n *\r\n * @private\r\n */\r\n private _showSidebar(): void\r\n {\r\n // Remove the box-shadow style\r\n this._renderer.removeStyle(this._elementRef.nativeElement, 'box-shadow');\r\n\r\n // Make the sidebar invisible\r\n this._renderer.removeStyle(this._elementRef.nativeElement, 'visibility');\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Change some properties of the sidebar\r\n * and make it invisible\r\n *\r\n * @private\r\n */\r\n private _hideSidebar(delay = true): void\r\n {\r\n const delayAmount = delay ? 300 : 0;\r\n\r\n // Add a delay so close animation can play\r\n setTimeout(() => {\r\n\r\n // Remove the box-shadow\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'box-shadow', 'none');\r\n\r\n // Make the sidebar invisible\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'visibility', 'hidden');\r\n }, delayAmount);\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Enable the animations\r\n *\r\n * @private\r\n */\r\n private _enableAnimations(): void\r\n {\r\n // Return if animations already enabled\r\n if ( this._animationsEnabled )\r\n {\r\n return;\r\n }\r\n\r\n // Enable the animations\r\n this._animationsEnabled = true;\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Open the sidebar\r\n */\r\n open(): void\r\n {\r\n if ( this.opened || this.isLockedOpen )\r\n {\r\n return;\r\n }\r\n\r\n // Enable the animations\r\n this._enableAnimations();\r\n\r\n // Show the sidebar\r\n this._showSidebar();\r\n\r\n // Show the backdrop\r\n this._showBackdrop();\r\n\r\n // Set the opened status\r\n this.opened = true;\r\n\r\n // Emit the 'openedChanged' event\r\n this.openedChanged.emit(this.opened);\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Close the sidebar\r\n */\r\n close(): void\r\n {\r\n if ( !this.opened || this.isLockedOpen )\r\n {\r\n return;\r\n }\r\n\r\n // Enable the animations\r\n this._enableAnimations();\r\n\r\n // Hide the backdrop\r\n this._hideBackdrop();\r\n\r\n // Set the opened status\r\n this.opened = false;\r\n\r\n // Emit the 'openedChanged' event\r\n this.openedChanged.emit(this.opened);\r\n\r\n // Hide the sidebar\r\n this._hideSidebar();\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Toggle open/close the sidebar\r\n */\r\n toggleOpen(): void\r\n {\r\n if ( this.opened )\r\n {\r\n this.close();\r\n }\r\n else\r\n {\r\n this.open();\r\n }\r\n }\r\n\r\n /**\r\n * Mouseenter\r\n */\r\n @HostListener('mouseenter')\r\n onMouseEnter(): void\r\n {\r\n // Only work if the auto trigger is enabled\r\n if ( !this.foldedAutoTriggerOnHover )\r\n {\r\n return;\r\n }\r\n\r\n this.unfoldTemporarily();\r\n }\r\n\r\n /**\r\n * Mouseleave\r\n */\r\n @HostListener('mouseleave')\r\n onMouseLeave(): void\r\n {\r\n // Only work if the auto trigger is enabled\r\n if ( !this.foldedAutoTriggerOnHover )\r\n {\r\n return;\r\n }\r\n\r\n this.foldTemporarily();\r\n }\r\n\r\n /**\r\n * Fold the sidebar permanently\r\n */\r\n fold(): void\r\n {\r\n // Only work if the sidebar is not folded\r\n if ( this.folded )\r\n {\r\n return;\r\n }\r\n\r\n // Enable the animations\r\n this._enableAnimations();\r\n\r\n // Fold\r\n this.folded = true;\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Unfold the sidebar permanently\r\n */\r\n unfold(): void\r\n {\r\n // Only work if the sidebar is folded\r\n if ( !this.folded )\r\n {\r\n return;\r\n }\r\n\r\n // Enable the animations\r\n this._enableAnimations();\r\n\r\n // Unfold\r\n this.folded = false;\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Toggle the sidebar fold/unfold permanently\r\n */\r\n toggleFold(): void\r\n {\r\n if ( this.folded )\r\n {\r\n this.unfold();\r\n }\r\n else\r\n {\r\n this.fold();\r\n }\r\n }\r\n\r\n /**\r\n * Fold the temporarily unfolded sidebar back\r\n */\r\n foldTemporarily(): void\r\n {\r\n // Only work if the sidebar is folded\r\n if ( !this.folded )\r\n {\r\n return;\r\n }\r\n\r\n // Enable the animations\r\n this._enableAnimations();\r\n\r\n // Fold the sidebar back\r\n this.unfolded = false;\r\n\r\n // Set the folded width\r\n const styleValue = this.foldedWidth + 'px';\r\n\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'width', styleValue);\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'min-width', styleValue);\r\n this._renderer.setStyle(this._elementRef.nativeElement, 'max-width', styleValue);\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n\r\n /**\r\n * Unfold the sidebar temporarily\r\n */\r\n unfoldTemporarily(): void\r\n {\r\n // Only work if the sidebar is folded\r\n if ( !this.folded )\r\n {\r\n return;\r\n }\r\n\r\n // Enable the animations\r\n this._enableAnimations();\r\n\r\n // Unfold the sidebar temporarily\r\n this.unfolded = true;\r\n\r\n // Remove the folded width\r\n this._renderer.removeStyle(this._elementRef.nativeElement, 'width');\r\n this._renderer.removeStyle(this._elementRef.nativeElement, 'min-width');\r\n this._renderer.removeStyle(this._elementRef.nativeElement, 'max-width');\r\n\r\n // Mark for check\r\n this._changeDetectorRef.markForCheck();\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { FuseSidebarComponent } from './sidebar.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseSidebarComponent\r\n ],\r\n exports : [\r\n FuseSidebarComponent\r\n ]\r\n})\r\nexport class FuseSidebarModule\r\n{\r\n}\r\n","import { Injectable } from '@angular/core';\r\n\r\nimport { FuseSidebarComponent } from './sidebar.component';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class FuseSidebarService\r\n{\r\n // Private\r\n private _registry: { [key: string]: FuseSidebarComponent } = {};\r\n\r\n /**\r\n * Constructor\r\n */\r\n constructor()\r\n {\r\n\r\n }\r\n\r\n /**\r\n * Add the sidebar to the registry\r\n *\r\n * @param key\r\n * @param sidebar\r\n */\r\n register(key, sidebar): void\r\n {\r\n // Check if the key already being used\r\n if ( this._registry[key] )\r\n {\r\n console.error(`The sidebar with the key '${key}' already exists. Either unregister it first or use a unique key.`);\r\n\r\n return;\r\n }\r\n\r\n // Add to the registry\r\n this._registry[key] = sidebar;\r\n }\r\n\r\n /**\r\n * Remove the sidebar from the registry\r\n *\r\n * @param key\r\n */\r\n unregister(key): void\r\n {\r\n // Check if the sidebar exists\r\n if ( !this._registry[key] )\r\n {\r\n console.warn(`The sidebar with the key '${key}' doesn't exist in the registry.`);\r\n }\r\n\r\n // Unregister the sidebar\r\n delete this._registry[key];\r\n }\r\n\r\n /**\r\n * Return the sidebar with the given key\r\n *\r\n * @param key\r\n * @returns {FuseSidebarComponent}\r\n */\r\n getSidebar(key): FuseSidebarComponent\r\n {\r\n // Check if the sidebar exists\r\n if ( !this._registry[key] )\r\n {\r\n console.warn(`The sidebar with the key '${key}' doesn't exist in the registry.`);\r\n\r\n return;\r\n }\r\n\r\n // Return the sidebar\r\n return this._registry[key];\r\n }\r\n}\r\n","import { Directive, ElementRef } from '@angular/core';\r\n\r\n@Directive({\r\n selector: '[fuseWidgetToggle]'\r\n})\r\nexport class FuseWidgetToggleDirective\r\n{\r\n /**\r\n * Constructor\r\n *\r\n * @param {ElementRef} elementRef\r\n */\r\n constructor(\r\n public elementRef: ElementRef\r\n )\r\n {\r\n }\r\n}\r\n","export default \"fuse-widget {\\n display: block;\\n position: relative;\\n perspective: 3000px;\\n padding: 12px;\\n}\\nfuse-widget > div {\\n position: relative;\\n transform-style: preserve-3d;\\n transition: transform 1s;\\n}\\nfuse-widget > .fuse-widget-front {\\n display: flex;\\n flex-direction: column;\\n flex: 1 1 auto;\\n position: relative;\\n overflow: hidden;\\n visibility: visible;\\n width: 100%;\\n opacity: 1;\\n z-index: 10;\\n border-radius: 8px;\\n transition: transform 0.5s ease-out 0s, visibility 0s ease-in 0.2s, opacity 0s ease-in 0.2s;\\n transform: rotateY(0deg);\\n -webkit-backface-visibility: hidden;\\n backface-visibility: hidden;\\n border: 1px solid;\\n}\\nfuse-widget > .fuse-widget-back {\\n display: block;\\n position: absolute;\\n top: 12px;\\n right: 12px;\\n bottom: 12px;\\n left: 12px;\\n overflow: hidden;\\n visibility: hidden;\\n opacity: 0;\\n z-index: 10;\\n border-radius: 8px;\\n transition: transform 0.5s ease-out 0s, visibility 0s ease-in 0.2s, opacity 0s ease-in 0.2s;\\n transform: rotateY(180deg);\\n -webkit-backface-visibility: hidden;\\n backface-visibility: hidden;\\n border: 1px solid;\\n}\\nfuse-widget > .fuse-widget-back [fuseWidgetToggle] {\\n position: absolute;\\n top: 0;\\n right: 0;\\n}\\nfuse-widget.flipped > .fuse-widget-front {\\n visibility: hidden;\\n opacity: 0;\\n transform: rotateY(180deg);\\n}\\nfuse-widget.flipped > .fuse-widget-back {\\n display: block;\\n visibility: visible;\\n opacity: 1;\\n transform: rotateY(360deg);\\n}\\nfuse-widget .mat-form-field.mat-form-field-type-mat-select .mat-form-field-wrapper {\\n padding: 16px 0;\\n}\\nfuse-widget .mat-form-field.mat-form-field-type-mat-select .mat-form-field-wrapper .mat-form-field-infix {\\n border: none;\\n padding: 0;\\n}\\nfuse-widget .mat-form-field.mat-form-field-type-mat-select .mat-form-field-underline {\\n display: none;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9AZnVzZS9jb21wb25lbnRzL3dpZGdldC9DOlxcUHJvZ3JhbURhdGFcXEplbmtpbnNcXC5qZW5raW5zXFx3b3Jrc3BhY2VcXFJQTVNcXFVJXFxMaXZlIChVSSBydW5uaW5nIG9uIFBheW1lbnR1cmUgQVdTKVxccGF5bWVudHVyZS5jb20vc3JjXFxAZnVzZVxcY29tcG9uZW50c1xcd2lkZ2V0XFx3aWRnZXQuY29tcG9uZW50LnNjc3MiLCJzcmMvQGZ1c2UvY29tcG9uZW50cy93aWRnZXQvd2lkZ2V0LmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0ksY0FBQTtFQUNBLGtCQUFBO0VBQ0EsbUJBQUE7RUFDQSxhQUFBO0FDQ0o7QURDSTtFQUNJLGtCQUFBO0VBQ0EsNEJBQUE7RUFDQSx3QkFBQTtBQ0NSO0FERUk7RUFDSSxhQUFBO0VBQ0Esc0JBQUE7RUFDQSxjQUFBO0VBQ0Esa0JBQUE7RUFDQSxnQkFBQTtFQUNBLG1CQUFBO0VBQ0EsV0FBQTtFQUNBLFVBQUE7RUFDQSxXQUFBO0VBQ0Esa0JBQUE7RUFDQSwyRkFBQTtFQUNBLHdCQUFBO0VBQ0EsbUNBQUE7VUFBQSwyQkFBQTtFQUNBLGlCQUFBO0FDQVI7QURHSTtFQUNJLGNBQUE7RUFDQSxrQkFBQTtFQUNBLFNBQUE7RUFDQSxXQUFBO0VBQ0EsWUFBQTtFQUNBLFVBQUE7RUFDQSxnQkFBQTtFQUNBLGtCQUFBO0VBQ0EsVUFBQTtFQUNBLFdBQUE7RUFDQSxrQkFBQTtFQUNBLDJGQUFBO0VBQ0EsMEJBQUE7RUFDQSxtQ0FBQTtVQUFBLDJCQUFBO0VBQ0EsaUJBQUE7QUNEUjtBREdRO0VBQ0ksa0JBQUE7RUFDQSxNQUFBO0VBQ0EsUUFBQTtBQ0RaO0FET1E7RUFDSSxrQkFBQTtFQUNBLFVBQUE7RUFDQSwwQkFBQTtBQ0xaO0FEUVE7RUFDSSxjQUFBO0VBQ0EsbUJBQUE7RUFDQSxVQUFBO0VBQ0EsMEJBQUE7QUNOWjtBRGNZO0VBQ0ksZUFBQTtBQ1poQjtBRGNnQjtFQUNJLFlBQUE7RUFDQSxVQUFBO0FDWnBCO0FEZ0JZO0VBQ0ksYUFBQTtBQ2RoQiIsImZpbGUiOiJzcmMvQGZ1c2UvY29tcG9uZW50cy93aWRnZXQvd2lkZ2V0LmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiZnVzZS13aWRnZXQge1xyXG4gICAgZGlzcGxheTogYmxvY2s7XHJcbiAgICBwb3NpdGlvbjogcmVsYXRpdmU7XHJcbiAgICBwZXJzcGVjdGl2ZTogMzAwMHB4O1xyXG4gICAgcGFkZGluZzogMTJweDtcclxuXHJcbiAgICA+IGRpdiB7XHJcbiAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xyXG4gICAgICAgIHRyYW5zZm9ybS1zdHlsZTogcHJlc2VydmUtM2Q7XHJcbiAgICAgICAgdHJhbnNpdGlvbjogdHJhbnNmb3JtIDFzO1xyXG4gICAgfVxyXG5cclxuICAgID4gLmZ1c2Utd2lkZ2V0LWZyb250IHtcclxuICAgICAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XHJcbiAgICAgICAgZmxleDogMSAxIGF1dG87XHJcbiAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xyXG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XHJcbiAgICAgICAgdmlzaWJpbGl0eTogdmlzaWJsZTtcclxuICAgICAgICB3aWR0aDogMTAwJTtcclxuICAgICAgICBvcGFjaXR5OiAxO1xyXG4gICAgICAgIHotaW5kZXg6IDEwO1xyXG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDhweDtcclxuICAgICAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC41cyBlYXNlLW91dCAwcywgdmlzaWJpbGl0eSAwcyBlYXNlLWluIDAuMnMsIG9wYWNpdHkgMHMgZWFzZS1pbiAwLjJzO1xyXG4gICAgICAgIHRyYW5zZm9ybTogcm90YXRlWSgwZGVnKTtcclxuICAgICAgICBiYWNrZmFjZS12aXNpYmlsaXR5OiBoaWRkZW47XHJcbiAgICAgICAgYm9yZGVyOiAxcHggc29saWQ7XHJcbiAgICB9XHJcblxyXG4gICAgPiAuZnVzZS13aWRnZXQtYmFjayB7XHJcbiAgICAgICAgZGlzcGxheTogYmxvY2s7XHJcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xyXG4gICAgICAgIHRvcDogMTJweDtcclxuICAgICAgICByaWdodDogMTJweDtcclxuICAgICAgICBib3R0b206IDEycHg7XHJcbiAgICAgICAgbGVmdDogMTJweDtcclxuICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xyXG4gICAgICAgIHZpc2liaWxpdHk6IGhpZGRlbjtcclxuICAgICAgICBvcGFjaXR5OiAwO1xyXG4gICAgICAgIHotaW5kZXg6IDEwO1xyXG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDhweDtcclxuICAgICAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC41cyBlYXNlLW91dCAwcywgdmlzaWJpbGl0eSAwcyBlYXNlLWluIDAuMnMsIG9wYWNpdHkgMHMgZWFzZS1pbiAwLjJzO1xyXG4gICAgICAgIHRyYW5zZm9ybTogcm90YXRlWSgxODBkZWcpO1xyXG4gICAgICAgIGJhY2tmYWNlLXZpc2liaWxpdHk6IGhpZGRlbjtcclxuICAgICAgICBib3JkZXI6IDFweCBzb2xpZDtcclxuXHJcbiAgICAgICAgW2Z1c2VXaWRnZXRUb2dnbGVdIHtcclxuICAgICAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xyXG4gICAgICAgICAgICB0b3A6IDA7XHJcbiAgICAgICAgICAgIHJpZ2h0OiAwO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICAmLmZsaXBwZWQge1xyXG5cclxuICAgICAgICA+IC5mdXNlLXdpZGdldC1mcm9udCB7XHJcbiAgICAgICAgICAgIHZpc2liaWxpdHk6IGhpZGRlbjtcclxuICAgICAgICAgICAgb3BhY2l0eTogMDtcclxuICAgICAgICAgICAgdHJhbnNmb3JtOiByb3RhdGVZKDE4MGRlZyk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICA+IC5mdXNlLXdpZGdldC1iYWNrIHtcclxuICAgICAgICAgICAgZGlzcGxheTogYmxvY2s7XHJcbiAgICAgICAgICAgIHZpc2liaWxpdHk6IHZpc2libGU7XHJcbiAgICAgICAgICAgIG9wYWNpdHk6IDE7XHJcbiAgICAgICAgICAgIHRyYW5zZm9ybTogcm90YXRlWSgzNjBkZWcpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICAubWF0LWZvcm0tZmllbGQge1xyXG5cclxuICAgICAgICAmLm1hdC1mb3JtLWZpZWxkLXR5cGUtbWF0LXNlbGVjdCB7XHJcblxyXG4gICAgICAgICAgICAubWF0LWZvcm0tZmllbGQtd3JhcHBlciB7XHJcbiAgICAgICAgICAgICAgICBwYWRkaW5nOiAxNnB4IDA7XHJcblxyXG4gICAgICAgICAgICAgICAgLm1hdC1mb3JtLWZpZWxkLWluZml4IHtcclxuICAgICAgICAgICAgICAgICAgICBib3JkZXI6IG5vbmU7XHJcbiAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogMDtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfVxyXG5cclxuICAgICAgICAgICAgLm1hdC1mb3JtLWZpZWxkLXVuZGVybGluZSB7XHJcbiAgICAgICAgICAgICAgICBkaXNwbGF5OiBub25lO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59XHJcbiIsImZ1c2Utd2lkZ2V0IHtcbiAgZGlzcGxheTogYmxvY2s7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgcGVyc3BlY3RpdmU6IDMwMDBweDtcbiAgcGFkZGluZzogMTJweDtcbn1cbmZ1c2Utd2lkZ2V0ID4gZGl2IHtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB0cmFuc2Zvcm0tc3R5bGU6IHByZXNlcnZlLTNkO1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMXM7XG59XG5mdXNlLXdpZGdldCA+IC5mdXNlLXdpZGdldC1mcm9udCB7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGZsZXg6IDEgMSBhdXRvO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHZpc2liaWxpdHk6IHZpc2libGU7XG4gIHdpZHRoOiAxMDAlO1xuICBvcGFjaXR5OiAxO1xuICB6LWluZGV4OiAxMDtcbiAgYm9yZGVyLXJhZGl1czogOHB4O1xuICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC41cyBlYXNlLW91dCAwcywgdmlzaWJpbGl0eSAwcyBlYXNlLWluIDAuMnMsIG9wYWNpdHkgMHMgZWFzZS1pbiAwLjJzO1xuICB0cmFuc2Zvcm06IHJvdGF0ZVkoMGRlZyk7XG4gIGJhY2tmYWNlLXZpc2liaWxpdHk6IGhpZGRlbjtcbiAgYm9yZGVyOiAxcHggc29saWQ7XG59XG5mdXNlLXdpZGdldCA+IC5mdXNlLXdpZGdldC1iYWNrIHtcbiAgZGlzcGxheTogYmxvY2s7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAxMnB4O1xuICByaWdodDogMTJweDtcbiAgYm90dG9tOiAxMnB4O1xuICBsZWZ0OiAxMnB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICB2aXNpYmlsaXR5OiBoaWRkZW47XG4gIG9wYWNpdHk6IDA7XG4gIHotaW5kZXg6IDEwO1xuICBib3JkZXItcmFkaXVzOiA4cHg7XG4gIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjVzIGVhc2Utb3V0IDBzLCB2aXNpYmlsaXR5IDBzIGVhc2UtaW4gMC4ycywgb3BhY2l0eSAwcyBlYXNlLWluIDAuMnM7XG4gIHRyYW5zZm9ybTogcm90YXRlWSgxODBkZWcpO1xuICBiYWNrZmFjZS12aXNpYmlsaXR5OiBoaWRkZW47XG4gIGJvcmRlcjogMXB4IHNvbGlkO1xufVxuZnVzZS13aWRnZXQgPiAuZnVzZS13aWRnZXQtYmFjayBbZnVzZVdpZGdldFRvZ2dsZV0ge1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRvcDogMDtcbiAgcmlnaHQ6IDA7XG59XG5mdXNlLXdpZGdldC5mbGlwcGVkID4gLmZ1c2Utd2lkZ2V0LWZyb250IHtcbiAgdmlzaWJpbGl0eTogaGlkZGVuO1xuICBvcGFjaXR5OiAwO1xuICB0cmFuc2Zvcm06IHJvdGF0ZVkoMTgwZGVnKTtcbn1cbmZ1c2Utd2lkZ2V0LmZsaXBwZWQgPiAuZnVzZS13aWRnZXQtYmFjayB7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICB2aXNpYmlsaXR5OiB2aXNpYmxlO1xuICBvcGFjaXR5OiAxO1xuICB0cmFuc2Zvcm06IHJvdGF0ZVkoMzYwZGVnKTtcbn1cbmZ1c2Utd2lkZ2V0IC5tYXQtZm9ybS1maWVsZC5tYXQtZm9ybS1maWVsZC10eXBlLW1hdC1zZWxlY3QgLm1hdC1mb3JtLWZpZWxkLXdyYXBwZXIge1xuICBwYWRkaW5nOiAxNnB4IDA7XG59XG5mdXNlLXdpZGdldCAubWF0LWZvcm0tZmllbGQubWF0LWZvcm0tZmllbGQtdHlwZS1tYXQtc2VsZWN0IC5tYXQtZm9ybS1maWVsZC13cmFwcGVyIC5tYXQtZm9ybS1maWVsZC1pbmZpeCB7XG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbn1cbmZ1c2Utd2lkZ2V0IC5tYXQtZm9ybS1maWVsZC5tYXQtZm9ybS1maWVsZC10eXBlLW1hdC1zZWxlY3QgLm1hdC1mb3JtLWZpZWxkLXVuZGVybGluZSB7XG4gIGRpc3BsYXk6IG5vbmU7XG59Il19 */\"","import { AfterContentInit, Component, ContentChildren, ElementRef, HostBinding, QueryList, Renderer2, ViewEncapsulation } from '@angular/core';\r\nimport { FuseWidgetToggleDirective } from './widget-toggle.directive';\r\n\r\n@Component({\r\n selector : 'fuse-widget',\r\n templateUrl : './widget.component.html',\r\n styleUrls : ['./widget.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\n\r\nexport class FuseWidgetComponent implements AfterContentInit\r\n{\r\n @HostBinding('class.flipped')\r\n flipped = false;\r\n\r\n @ContentChildren(FuseWidgetToggleDirective, {descendants: true})\r\n toggleButtons: QueryList;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {ElementRef} _elementRef\r\n * @param {Renderer2} _renderer\r\n */\r\n constructor(\r\n private _elementRef: ElementRef,\r\n private _renderer: Renderer2\r\n )\r\n {\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * After content init\r\n */\r\n ngAfterContentInit(): void\r\n {\r\n // Listen for the flip button click\r\n setTimeout(() => {\r\n this.toggleButtons.forEach(flipButton => {\r\n this._renderer.listen(flipButton.elementRef.nativeElement, 'click', (event) => {\r\n event.preventDefault();\r\n event.stopPropagation();\r\n this.toggle();\r\n });\r\n });\r\n });\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Toggle the flipped status\r\n */\r\n toggle(): void\r\n {\r\n this.flipped = !this.flipped;\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { FuseWidgetComponent } from './widget.component';\r\nimport { FuseWidgetToggleDirective } from './widget-toggle.directive';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseWidgetComponent,\r\n FuseWidgetToggleDirective\r\n ],\r\n exports : [\r\n FuseWidgetComponent,\r\n FuseWidgetToggleDirective\r\n ],\r\n})\r\nexport class FuseWidgetModule\r\n{\r\n}\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { FuseIfOnDomDirective } from '@fuse/directives/fuse-if-on-dom/fuse-if-on-dom.directive';\r\nimport { FuseInnerScrollDirective } from '@fuse/directives/fuse-inner-scroll/fuse-inner-scroll.directive';\r\nimport { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive';\r\nimport { FuseMatSidenavHelperDirective, FuseMatSidenavTogglerDirective } from '@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.directive';\r\n\r\n@NgModule({\r\n declarations: [\r\n FuseIfOnDomDirective,\r\n FuseInnerScrollDirective,\r\n FuseMatSidenavHelperDirective,\r\n FuseMatSidenavTogglerDirective,\r\n FusePerfectScrollbarDirective\r\n ],\r\n imports : [],\r\n exports : [\r\n FuseIfOnDomDirective,\r\n FuseInnerScrollDirective,\r\n FuseMatSidenavHelperDirective,\r\n FuseMatSidenavTogglerDirective,\r\n FusePerfectScrollbarDirective\r\n ]\r\n})\r\nexport class FuseDirectivesModule\r\n{\r\n}\r\n","import { AfterContentChecked, Directive, ElementRef, TemplateRef, ViewContainerRef } from '@angular/core';\r\n\r\n@Directive({\r\n selector: '[fuseIfOnDom]'\r\n})\r\nexport class FuseIfOnDomDirective implements AfterContentChecked\r\n{\r\n isCreated: boolean;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {ElementRef} _elementRef\r\n * @param {TemplateRef} _templateRef\r\n * @param {ViewContainerRef} _viewContainerRef\r\n */\r\n constructor(\r\n private _elementRef: ElementRef,\r\n private _templateRef: TemplateRef,\r\n private _viewContainerRef: ViewContainerRef\r\n )\r\n {\r\n // Set the defaults\r\n this.isCreated = false;\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * After content checked\r\n */\r\n ngAfterContentChecked(): void\r\n {\r\n if ( document.body.contains(this._elementRef.nativeElement) && !this.isCreated )\r\n {\r\n setTimeout(() => {\r\n this._viewContainerRef.createEmbeddedView(this._templateRef);\r\n }, 300);\r\n this.isCreated = true;\r\n }\r\n else if ( this.isCreated && !document.body.contains(this._elementRef.nativeElement) )\r\n {\r\n this._viewContainerRef.clear();\r\n this.isCreated = false;\r\n }\r\n }\r\n}\r\n","import { Directive, ElementRef, OnDestroy, OnInit, Renderer2 } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseMatchMediaService } from '@fuse/services/match-media.service';\r\n\r\n@Directive({\r\n selector: '.inner-scroll'\r\n})\r\nexport class FuseInnerScrollDirective implements OnInit, OnDestroy\r\n{\r\n // Private\r\n private _parent: any;\r\n private _grandParent: any;\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {ElementRef} _elementRef\r\n * @param {FuseMatchMediaService} _fuseMediaMatchService\r\n * @param {Renderer2} _renderer\r\n */\r\n constructor(\r\n private _elementRef: ElementRef,\r\n private _fuseMediaMatchService: FuseMatchMediaService,\r\n private _renderer: Renderer2\r\n )\r\n {\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Get the parent\r\n this._parent = this._renderer.parentNode(this._elementRef.nativeElement);\r\n\r\n // Return, if there is no parent\r\n if ( !this._parent )\r\n {\r\n return;\r\n }\r\n\r\n // Get the grand parent\r\n this._grandParent = this._renderer.parentNode(this._parent);\r\n\r\n // Register to the media query changes\r\n this._fuseMediaMatchService.onMediaChange\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((alias) => {\r\n\r\n if ( alias === 'xs' )\r\n {\r\n this._removeClass();\r\n }\r\n else\r\n {\r\n this._addClass();\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Return, if there is no parent\r\n if ( !this._parent )\r\n {\r\n return;\r\n }\r\n\r\n // Remove the class\r\n this._removeClass();\r\n\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Private methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Add the class name\r\n *\r\n * @private\r\n */\r\n private _addClass(): void\r\n {\r\n // Add the inner-scroll class\r\n this._renderer.addClass(this._grandParent, 'inner-scroll');\r\n }\r\n\r\n /**\r\n * Remove the class name\r\n * @private\r\n */\r\n private _removeClass(): void\r\n {\r\n\r\n // Remove the inner-scroll class\r\n this._renderer.removeClass(this._grandParent, 'inner-scroll');\r\n }\r\n}\r\n","import { Directive, Input, OnInit, HostListener, OnDestroy, HostBinding } from '@angular/core';\r\nimport { MatSidenav } from '@angular/material/sidenav';\r\nimport { MediaObserver } from '@angular/flex-layout';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseMatchMediaService } from '@fuse/services/match-media.service';\r\nimport { FuseMatSidenavHelperService } from '@fuse/directives/fuse-mat-sidenav/fuse-mat-sidenav.service';\r\n\r\n@Directive({\r\n selector: '[fuseMatSidenavHelper]'\r\n})\r\nexport class FuseMatSidenavHelperDirective implements OnInit, OnDestroy\r\n{\r\n @HostBinding('class.mat-is-locked-open')\r\n isLockedOpen: boolean;\r\n\r\n @Input()\r\n fuseMatSidenavHelper: string;\r\n\r\n @Input()\r\n matIsLockedOpen: string;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {FuseMatchMediaService} _fuseMatchMediaService\r\n * @param {FuseMatSidenavHelperService} _fuseMatSidenavHelperService\r\n * @param {MatSidenav} _matSidenav\r\n * @param {MediaObserver} _mediaObserver\r\n */\r\n constructor(\r\n private _fuseMatchMediaService: FuseMatchMediaService,\r\n private _fuseMatSidenavHelperService: FuseMatSidenavHelperService,\r\n private _matSidenav: MatSidenav,\r\n private _mediaObserver: MediaObserver\r\n )\r\n {\r\n // Set the defaults\r\n this.isLockedOpen = true;\r\n\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Register the sidenav to the service\r\n this._fuseMatSidenavHelperService.setSidenav(this.fuseMatSidenavHelper, this._matSidenav);\r\n\r\n if ( this.matIsLockedOpen && this._mediaObserver.isActive(this.matIsLockedOpen) )\r\n {\r\n this.isLockedOpen = true;\r\n this._matSidenav.mode = 'side';\r\n this._matSidenav.toggle(true);\r\n }\r\n else\r\n {\r\n this.isLockedOpen = false;\r\n this._matSidenav.mode = 'over';\r\n this._matSidenav.toggle(false);\r\n }\r\n\r\n this._fuseMatchMediaService.onMediaChange\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(() => {\r\n if ( this.matIsLockedOpen && this._mediaObserver.isActive(this.matIsLockedOpen) )\r\n {\r\n this.isLockedOpen = true;\r\n this._matSidenav.mode = 'side';\r\n this._matSidenav.toggle(true);\r\n }\r\n else\r\n {\r\n this.isLockedOpen = false;\r\n this._matSidenav.mode = 'over';\r\n this._matSidenav.toggle(false);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n}\r\n\r\n@Directive({\r\n selector: '[fuseMatSidenavToggler]'\r\n})\r\nexport class FuseMatSidenavTogglerDirective\r\n{\r\n @Input()\r\n fuseMatSidenavToggler: string;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {FuseMatSidenavHelperService} _fuseMatSidenavHelperService\r\n */\r\n constructor(\r\n private _fuseMatSidenavHelperService: FuseMatSidenavHelperService)\r\n {\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On click\r\n */\r\n @HostListener('click')\r\n onClick(): void\r\n {\r\n this._fuseMatSidenavHelperService.getSidenav(this.fuseMatSidenavToggler).toggle();\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { MatSidenav } from '@angular/material/sidenav';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class FuseMatSidenavHelperService\r\n{\r\n sidenavInstances: MatSidenav[];\r\n\r\n /**\r\n * Constructor\r\n */\r\n constructor()\r\n {\r\n this.sidenavInstances = [];\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Set sidenav\r\n *\r\n * @param id\r\n * @param instance\r\n */\r\n setSidenav(id, instance): void\r\n {\r\n this.sidenavInstances[id] = instance;\r\n }\r\n\r\n /**\r\n * Get sidenav\r\n *\r\n * @param id\r\n * @returns {any}\r\n */\r\n getSidenav(id): any\r\n {\r\n return this.sidenavInstances[id];\r\n }\r\n}\r\n","import { AfterViewInit, Directive, ElementRef, HostListener, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { Platform } from '@angular/cdk/platform';\r\nimport { fromEvent, Subject } from 'rxjs';\r\nimport { debounceTime, filter, takeUntil } from 'rxjs/operators';\r\nimport PerfectScrollbar from 'perfect-scrollbar';\r\nimport * as _ from 'lodash';\r\nimport { FusePerfectScrollbarGeometry, FusePerfectScrollbarPosition } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.interfaces';\r\nimport { FuseConfigService } from '@fuse/services/config.service';\r\n\r\n@Directive({\r\n selector: '[fusePerfectScrollbar]'\r\n})\r\nexport class FusePerfectScrollbarDirective implements OnInit, AfterViewInit, OnDestroy\r\n{\r\n isInitialized: boolean;\r\n isMobile: boolean;\r\n ps: PerfectScrollbar | any;\r\n\r\n // Private\r\n private _animation: number | null;\r\n private _enabled: boolean | '';\r\n private _debouncedUpdate: any;\r\n private _options: any;\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {ElementRef} elementRef\r\n * @param {FuseConfigService} _fuseConfigService\r\n * @param {Platform} _platform\r\n * @param {Router} _router\r\n */\r\n constructor(\r\n public elementRef: ElementRef,\r\n private _fuseConfigService: FuseConfigService,\r\n private _platform: Platform,\r\n private _router: Router\r\n )\r\n {\r\n // Set the defaults\r\n this.isInitialized = false;\r\n this.isMobile = false;\r\n\r\n // Set the private defaults\r\n this._animation = null;\r\n this._enabled = false;\r\n this._debouncedUpdate = _.debounce(this.update, 150);\r\n this._options = {\r\n updateOnRouteChange: false\r\n };\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Perfect Scrollbar options\r\n *\r\n * @param value\r\n */\r\n @Input()\r\n set fusePerfectScrollbarOptions(value)\r\n {\r\n // Merge the options\r\n this._options = _.merge({}, this._options, value);\r\n\r\n // Destroy and re-init the PerfectScrollbar to update its options\r\n setTimeout(() => {\r\n this._destroy();\r\n });\r\n\r\n setTimeout(() => {\r\n this._init();\r\n });\r\n }\r\n\r\n get fusePerfectScrollbarOptions(): any\r\n {\r\n // Return the options\r\n return this._options;\r\n }\r\n\r\n /**\r\n * Is enabled\r\n *\r\n * @param {boolean | \"\"} value\r\n */\r\n @Input('fusePerfectScrollbar')\r\n set enabled(value: boolean | '')\r\n {\r\n // If nothing is provided with the directive (empty string),\r\n // we will take that as a true\r\n if ( value === '' )\r\n {\r\n value = true;\r\n }\r\n\r\n // Return, if both values are the same\r\n if ( this.enabled === value )\r\n {\r\n return;\r\n }\r\n\r\n // Store the value\r\n this._enabled = value;\r\n\r\n // If enabled...\r\n if ( this.enabled )\r\n {\r\n // Init the directive\r\n this._init();\r\n }\r\n else\r\n {\r\n // Otherwise destroy it\r\n this._destroy();\r\n }\r\n }\r\n\r\n get enabled(): boolean | ''\r\n {\r\n // Return the enabled status\r\n return this._enabled;\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Subscribe to window resize event\r\n fromEvent(window, 'resize')\r\n .pipe(\r\n takeUntil(this._unsubscribeAll),\r\n debounceTime(150)\r\n )\r\n .subscribe(() => {\r\n\r\n // Update the PerfectScrollbar\r\n this.update();\r\n });\r\n }\r\n\r\n /**\r\n * After view init\r\n */\r\n ngAfterViewInit(): void\r\n {\r\n // Check if scrollbars enabled or not from the main config\r\n this._fuseConfigService.config\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe(\r\n (settings) => {\r\n this.enabled = settings.customScrollbars;\r\n }\r\n );\r\n\r\n // Scroll to the top on every route change\r\n if ( this.fusePerfectScrollbarOptions.updateOnRouteChange )\r\n {\r\n this._router.events\r\n .pipe(\r\n takeUntil(this._unsubscribeAll),\r\n filter(event => event instanceof NavigationEnd)\r\n )\r\n .subscribe(() => {\r\n setTimeout(() => {\r\n this.scrollToTop();\r\n this.update();\r\n }, 0);\r\n });\r\n }\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n this._destroy();\r\n\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Private methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Initialize\r\n *\r\n * @private\r\n */\r\n _init(): void\r\n {\r\n // Return, if already initialized\r\n if ( this.isInitialized )\r\n {\r\n return;\r\n }\r\n\r\n // Check if is mobile\r\n if ( this._platform.ANDROID || this._platform.IOS )\r\n {\r\n this.isMobile = true;\r\n }\r\n\r\n // Return if it's mobile\r\n if ( this.isMobile )\r\n {\r\n // Return...\r\n return;\r\n }\r\n\r\n // Set as initialized\r\n this.isInitialized = true;\r\n\r\n // Initialize the perfect-scrollbar\r\n this.ps = new PerfectScrollbar(this.elementRef.nativeElement, {\r\n ...this.fusePerfectScrollbarOptions\r\n });\r\n\r\n // Unbind 'keydown' events of PerfectScrollbar since it causes an extremely\r\n // high CPU usage on Angular Material inputs.\r\n // Loop through all the event elements of this PerfectScrollbar instance\r\n this.ps.event.eventElements.forEach((eventElement) => {\r\n\r\n // If we hit to the element with a 'keydown' event...\r\n if ( typeof eventElement.handlers['keydown'] !== 'undefined' )\r\n {\r\n // Unbind it\r\n eventElement.element.removeEventListener('keydown', eventElement.handlers['keydown'][0]);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * Destroy\r\n *\r\n * @private\r\n */\r\n _destroy(): void\r\n {\r\n if ( !this.isInitialized || !this.ps )\r\n {\r\n return;\r\n }\r\n\r\n // Destroy the perfect-scrollbar\r\n this.ps.destroy();\r\n\r\n // Clean up\r\n this.ps = null;\r\n this.isInitialized = false;\r\n }\r\n\r\n /**\r\n * Update scrollbars on window resize\r\n *\r\n * @private\r\n */\r\n @HostListener('window:resize')\r\n _updateOnResize(): void\r\n {\r\n this._debouncedUpdate();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Document click\r\n *\r\n * @param {Event} event\r\n */\r\n @HostListener('document:click', ['$event'])\r\n documentClick(event: Event): void\r\n {\r\n if ( !this.isInitialized || !this.ps )\r\n {\r\n return;\r\n }\r\n\r\n // Update the scrollbar on document click..\r\n // This isn't the most elegant solution but there is no other way\r\n // of knowing when the contents of the scrollable container changes.\r\n // Therefore, we update scrollbars on every document click.\r\n this.ps.update();\r\n }\r\n\r\n /**\r\n * Update the scrollbar\r\n */\r\n update(): void\r\n {\r\n if ( !this.isInitialized )\r\n {\r\n return;\r\n }\r\n\r\n // Update the perfect-scrollbar\r\n this.ps.update();\r\n }\r\n\r\n /**\r\n * Destroy the scrollbar\r\n */\r\n destroy(): void\r\n {\r\n this.ngOnDestroy();\r\n }\r\n\r\n /**\r\n * Returns the geometry of the scrollable element\r\n *\r\n * @param prefix\r\n */\r\n geometry(prefix: string = 'scroll'): FusePerfectScrollbarGeometry\r\n {\r\n return new FusePerfectScrollbarGeometry(\r\n this.elementRef.nativeElement[prefix + 'Left'],\r\n this.elementRef.nativeElement[prefix + 'Top'],\r\n this.elementRef.nativeElement[prefix + 'Width'],\r\n this.elementRef.nativeElement[prefix + 'Height']\r\n );\r\n }\r\n\r\n /**\r\n * Returns the position of the scrollable element\r\n *\r\n * @param absolute\r\n */\r\n position(absolute: boolean = false): FusePerfectScrollbarPosition\r\n {\r\n if ( !absolute && this.ps )\r\n {\r\n return new FusePerfectScrollbarPosition(\r\n this.ps.reach.x || 0,\r\n this.ps.reach.y || 0\r\n );\r\n }\r\n else\r\n {\r\n return new FusePerfectScrollbarPosition(\r\n this.elementRef.nativeElement.scrollLeft,\r\n this.elementRef.nativeElement.scrollTop\r\n );\r\n }\r\n }\r\n\r\n /**\r\n * Scroll to\r\n *\r\n * @param x\r\n * @param y\r\n * @param speed\r\n */\r\n scrollTo(x: number, y?: number, speed?: number): void\r\n {\r\n if ( y == null && speed == null )\r\n {\r\n this.animateScrolling('scrollTop', x, speed);\r\n }\r\n else\r\n {\r\n if ( x != null )\r\n {\r\n this.animateScrolling('scrollLeft', x, speed);\r\n }\r\n\r\n if ( y != null )\r\n {\r\n this.animateScrolling('scrollTop', y, speed);\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Scroll to X\r\n *\r\n * @param {number} x\r\n * @param {number} speed\r\n */\r\n scrollToX(x: number, speed?: number): void\r\n {\r\n this.animateScrolling('scrollLeft', x, speed);\r\n }\r\n\r\n /**\r\n * Scroll to Y\r\n *\r\n * @param {number} y\r\n * @param {number} speed\r\n */\r\n scrollToY(y: number, speed?: number): void\r\n {\r\n this.animateScrolling('scrollTop', y, speed);\r\n }\r\n\r\n /**\r\n * Scroll to top\r\n *\r\n * @param {number} offset\r\n * @param {number} speed\r\n */\r\n scrollToTop(offset?: number, speed?: number): void\r\n {\r\n this.animateScrolling('scrollTop', (offset || 0), speed);\r\n }\r\n\r\n /**\r\n * Scroll to left\r\n *\r\n * @param {number} offset\r\n * @param {number} speed\r\n */\r\n scrollToLeft(offset?: number, speed?: number): void\r\n {\r\n this.animateScrolling('scrollLeft', (offset || 0), speed);\r\n }\r\n\r\n /**\r\n * Scroll to right\r\n *\r\n * @param {number} offset\r\n * @param {number} speed\r\n */\r\n scrollToRight(offset?: number, speed?: number): void\r\n {\r\n const left = this.elementRef.nativeElement.scrollWidth - this.elementRef.nativeElement.clientWidth;\r\n this.animateScrolling('scrollLeft', left - (offset || 0), speed);\r\n }\r\n\r\n /**\r\n * Scroll to bottom\r\n *\r\n * @param {number} offset\r\n * @param {number} speed\r\n */\r\n scrollToBottom(offset?: number, speed?: number): void\r\n {\r\n const top = this.elementRef.nativeElement.scrollHeight - this.elementRef.nativeElement.clientHeight;\r\n this.animateScrolling('scrollTop', top - (offset || 0), speed);\r\n }\r\n\r\n /**\r\n * Scroll to element\r\n *\r\n * @param qs\r\n * @param offset\r\n * @param speed\r\n */\r\n scrollToElement(qs: string, offset?: number, speed?: number): void\r\n {\r\n const element = this.elementRef.nativeElement.querySelector(qs);\r\n\r\n if ( !element )\r\n {\r\n return;\r\n }\r\n\r\n const elementPos = element.getBoundingClientRect();\r\n const scrollerPos = this.elementRef.nativeElement.getBoundingClientRect();\r\n\r\n if ( this.elementRef.nativeElement.classList.contains('ps--active-x') )\r\n {\r\n const currentPos = this.elementRef.nativeElement['scrollLeft'];\r\n const position = elementPos.left - scrollerPos.left + currentPos;\r\n\r\n this.animateScrolling('scrollLeft', position + (offset || 0), speed);\r\n }\r\n\r\n if ( this.elementRef.nativeElement.classList.contains('ps--active-y') )\r\n {\r\n const currentPos = this.elementRef.nativeElement['scrollTop'];\r\n const position = elementPos.top - scrollerPos.top + currentPos;\r\n\r\n this.animateScrolling('scrollTop', position + (offset || 0), speed);\r\n }\r\n }\r\n\r\n /**\r\n * Animate scrolling\r\n *\r\n * @param target\r\n * @param value\r\n * @param speed\r\n */\r\n animateScrolling(target: string, value: number, speed?: number): void\r\n {\r\n if ( this._animation )\r\n {\r\n window.cancelAnimationFrame(this._animation);\r\n this._animation = null;\r\n }\r\n\r\n if ( !speed || typeof window === 'undefined' )\r\n {\r\n this.elementRef.nativeElement[target] = value;\r\n }\r\n else if ( value !== this.elementRef.nativeElement[target] )\r\n {\r\n let newValue = 0;\r\n let scrollCount = 0;\r\n\r\n let oldTimestamp = performance.now();\r\n let oldValue = this.elementRef.nativeElement[target];\r\n\r\n const cosParameter = (oldValue - value) / 2;\r\n\r\n const step = (newTimestamp: number) => {\r\n scrollCount += Math.PI / (speed / (newTimestamp - oldTimestamp));\r\n newValue = Math.round(value + cosParameter + cosParameter * Math.cos(scrollCount));\r\n\r\n // Only continue animation if scroll position has not changed\r\n if ( this.elementRef.nativeElement[target] === oldValue )\r\n {\r\n if ( scrollCount >= Math.PI )\r\n {\r\n this.animateScrolling(target, value, 0);\r\n }\r\n else\r\n {\r\n this.elementRef.nativeElement[target] = newValue;\r\n\r\n // On a zoomed out page the resulting offset may differ\r\n oldValue = this.elementRef.nativeElement[target];\r\n oldTimestamp = newTimestamp;\r\n\r\n this._animation = window.requestAnimationFrame(step);\r\n }\r\n }\r\n };\r\n\r\n window.requestAnimationFrame(step);\r\n }\r\n }\r\n}\r\n","export class FusePerfectScrollbarGeometry\r\n{\r\n public x: number;\r\n public y: number;\r\n\r\n public w: number;\r\n public h: number;\r\n\r\n constructor(x: number, y: number, w: number, h: number)\r\n {\r\n this.x = x;\r\n this.y = y;\r\n this.w = w;\r\n this.h = h;\r\n }\r\n}\r\n\r\nexport class FusePerfectScrollbarPosition\r\n{\r\n public x: number | 'start' | 'end';\r\n public y: number | 'start' | 'end';\r\n\r\n constructor(x: number | 'start' | 'end', y: number | 'start' | 'end')\r\n {\r\n this.x = x;\r\n this.y = y;\r\n }\r\n}\r\n","import { ModuleWithProviders, NgModule, Optional, SkipSelf } from '@angular/core';\r\n\r\nimport { FUSE_CONFIG } from '@fuse/services/config.service';\r\n\r\n@NgModule()\r\nexport class FuseModule\r\n{\r\n constructor(@Optional() @SkipSelf() parentModule: FuseModule)\r\n {\r\n if ( parentModule )\r\n {\r\n throw new Error('FuseModule is already loaded. Import it in the AppModule only!');\r\n }\r\n }\r\n\r\n static forRoot(config): ModuleWithProviders\r\n {\r\n return {\r\n ngModule : FuseModule,\r\n providers: [\r\n {\r\n provide : FUSE_CONFIG,\r\n useValue: config\r\n }\r\n ]\r\n };\r\n }\r\n}\r\n","const black87 = 'rgba(black, 0.87)';\r\nconst white87 = 'rgba(white, 0.87)';\r\nconst black12 = 'rgba(black, 0.12)';\r\nconst white12 = 'rgba(white, 0.12)';\r\nconst black6 = 'rgba(black, 0.06)';\r\nconst white6 = 'rgba(white, 0.06)';\r\n\r\nconst matColors = {\r\n 'red': {\r\n 50 : '#ffebee',\r\n 100 : '#ffcdd2',\r\n 200 : '#ef9a9a',\r\n 300 : '#e57373',\r\n 400 : '#ef5350',\r\n 500 : '#f44336',\r\n 600 : '#e53935',\r\n 700 : '#d32f2f',\r\n 800 : '#c62828',\r\n 900 : '#b71c1c',\r\n A100 : '#ff8a80',\r\n A200 : '#ff5252',\r\n A400 : '#ff1744',\r\n A700 : '#d50000',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : 'white',\r\n 600 : 'white',\r\n 700 : 'white',\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: 'white',\r\n A400: 'white',\r\n A700: 'white'\r\n }\r\n },\r\n\r\n 'pink': {\r\n 50 : '#fce4ec',\r\n 100 : '#f8bbd0',\r\n 200 : '#f48fb1',\r\n 300 : '#f06292',\r\n 400 : '#ec407a',\r\n 500 : '#e91e63',\r\n 600 : '#d81b60',\r\n 700 : '#c2185b',\r\n 800 : '#ad1457',\r\n 900 : '#880e4f',\r\n A100 : '#ff80ab',\r\n A200 : '#ff4081',\r\n A400 : '#f50057',\r\n A700 : '#c51162',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : 'white',\r\n 600 : 'white',\r\n 700 : white87,\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: 'white',\r\n A400: 'white',\r\n A700: 'white'\r\n }\r\n },\r\n\r\n 'purple': {\r\n 50 : '#f3e5f5',\r\n 100 : '#e1bee7',\r\n 200 : '#ce93d8',\r\n 300 : '#ba68c8',\r\n 400 : '#ab47bc',\r\n 500 : '#9c27b0',\r\n 600 : '#8e24aa',\r\n 700 : '#7b1fa2',\r\n 800 : '#6a1b9a',\r\n 900 : '#4a148c',\r\n A100 : '#ea80fc',\r\n A200 : '#e040fb',\r\n A400 : '#d500f9',\r\n A700 : '#aa00ff',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : 'white',\r\n 400 : 'white',\r\n 500 : white87,\r\n 600 : white87,\r\n 700 : white87,\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: 'white',\r\n A400: 'white',\r\n A700: 'white'\r\n }\r\n },\r\n\r\n 'deep-purple': {\r\n 50 : '#ede7f6',\r\n 100 : '#d1c4e9',\r\n 200 : '#b39ddb',\r\n 300 : '#9575cd',\r\n 400 : '#7e57c2',\r\n 500 : '#673ab7',\r\n 600 : '#5e35b1',\r\n 700 : '#512da8',\r\n 800 : '#4527a0',\r\n 900 : '#311b92',\r\n A100 : '#b388ff',\r\n A200 : '#7c4dff',\r\n A400 : '#651fff',\r\n A700 : '#6200ea',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : 'white',\r\n 400 : 'white',\r\n 500 : white87,\r\n 600 : white87,\r\n 700 : white87,\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: 'white',\r\n A400: white87,\r\n A700: white87\r\n }\r\n },\r\n\r\n 'indigo': {\r\n 50 : '#e8eaf6',\r\n 100 : '#c5cae9',\r\n 200 : '#9fa8da',\r\n 300 : '#7986cb',\r\n 400 : '#5c6bc0',\r\n 500 : '#3f51b5',\r\n 600 : '#3949ab',\r\n 700 : '#303f9f',\r\n 800 : '#283593',\r\n 900 : '#1a237e',\r\n A100 : '#8c9eff',\r\n A200 : '#536dfe',\r\n A400 : '#3d5afe',\r\n A700 : '#304ffe',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : 'white',\r\n 400 : 'white',\r\n 500 : white87,\r\n 600 : white87,\r\n 700 : white87,\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: 'white',\r\n A400: 'white',\r\n A700: white87\r\n }\r\n },\r\n\r\n 'blue': {\r\n 50 : '#e3f2fd',\r\n 100 : '#bbdefb',\r\n 200 : '#90caf9',\r\n 300 : '#64b5f6',\r\n 400 : '#42a5f5',\r\n 500 : '#2196f3',\r\n 600 : '#1e88e5',\r\n 700 : '#1976d2',\r\n 800 : '#1565c0',\r\n 900 : '#0d47a1',\r\n A100 : '#82b1ff',\r\n A200 : '#448aff',\r\n A400 : '#2979ff',\r\n A700 : '#2962ff',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : 'white',\r\n 600 : 'white',\r\n 700 : 'white',\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: 'white',\r\n A400: 'white',\r\n A700: 'white'\r\n }\r\n },\r\n\r\n 'light-blue': {\r\n 50 : '#e1f5fe',\r\n 100 : '#b3e5fc',\r\n 200 : '#81d4fa',\r\n 300 : '#4fc3f7',\r\n 400 : '#29b6f6',\r\n 500 : '#03a9f4',\r\n 600 : '#039be5',\r\n 700 : '#0288d1',\r\n 800 : '#0277bd',\r\n 900 : '#01579b',\r\n A100 : '#80d8ff',\r\n A200 : '#40c4ff',\r\n A400 : '#00b0ff',\r\n A700 : '#0091ea',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : 'white',\r\n 600 : 'white',\r\n 700 : 'white',\r\n 800 : 'white',\r\n 900 : white87,\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: 'white'\r\n }\r\n },\r\n\r\n 'cyan': {\r\n 50 : '#e0f7fa',\r\n 100 : '#b2ebf2',\r\n 200 : '#80deea',\r\n 300 : '#4dd0e1',\r\n 400 : '#26c6da',\r\n 500 : '#00bcd4',\r\n 600 : '#00acc1',\r\n 700 : '#0097a7',\r\n 800 : '#00838f',\r\n 900 : '#006064',\r\n A100 : '#84ffff',\r\n A200 : '#18ffff',\r\n A400 : '#00e5ff',\r\n A700 : '#00b8d4',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : 'white',\r\n 600 : 'white',\r\n 700 : 'white',\r\n 800 : 'white',\r\n 900 : white87,\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: black87\r\n }\r\n },\r\n\r\n 'teal': {\r\n 50 : '#e0f2f1',\r\n 100 : '#b2dfdb',\r\n 200 : '#80cbc4',\r\n 300 : '#4db6ac',\r\n 400 : '#26a69a',\r\n 500 : '#009688',\r\n 600 : '#00897b',\r\n 700 : '#00796b',\r\n 800 : '#00695c',\r\n 900 : '#004d40',\r\n A100 : '#a7ffeb',\r\n A200 : '#64ffda',\r\n A400 : '#1de9b6',\r\n A700 : '#00bfa5',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : 'white',\r\n 600 : 'white',\r\n 700 : 'white',\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: black87\r\n }\r\n },\r\n\r\n 'green': {\r\n 50 : '#e8f5e9',\r\n 100 : '#c8e6c9',\r\n 200 : '#a5d6a7',\r\n 300 : '#81c784',\r\n 400 : '#66bb6a',\r\n 500 : '#4caf50',\r\n 600 : '#43a047',\r\n 700 : '#388e3c',\r\n 800 : '#2e7d32',\r\n 900 : '#1b5e20',\r\n A100 : '#b9f6ca',\r\n A200 : '#69f0ae',\r\n A400 : '#00e676',\r\n A700 : '#00c853',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : 'white',\r\n 600 : 'white',\r\n 700 : 'white',\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: black87\r\n }\r\n },\r\n\r\n 'light-green': {\r\n 50 : '#f1f8e9',\r\n 100 : '#dcedc8',\r\n 200 : '#c5e1a5',\r\n 300 : '#aed581',\r\n 400 : '#9ccc65',\r\n 500 : '#8bc34a',\r\n 600 : '#7cb342',\r\n 700 : '#689f38',\r\n 800 : '#558b2f',\r\n 900 : '#33691e',\r\n A100 : '#ccff90',\r\n A200 : '#b2ff59',\r\n A400 : '#76ff03',\r\n A700 : '#64dd17',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : black87,\r\n 600 : black87,\r\n 700 : black87,\r\n 800 : 'white',\r\n 900 : 'white',\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: black87\r\n }\r\n },\r\n\r\n 'lime': {\r\n 50 : '#f9fbe7',\r\n 100 : '#f0f4c3',\r\n 200 : '#e6ee9c',\r\n 300 : '#dce775',\r\n 400 : '#d4e157',\r\n 500 : '#cddc39',\r\n 600 : '#c0ca33',\r\n 700 : '#afb42b',\r\n 800 : '#9e9d24',\r\n 900 : '#827717',\r\n A100 : '#f4ff81',\r\n A200 : '#eeff41',\r\n A400 : '#c6ff00',\r\n A700 : '#aeea00',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : black87,\r\n 600 : black87,\r\n 700 : black87,\r\n 800 : black87,\r\n 900 : 'white',\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: black87\r\n }\r\n },\r\n\r\n 'yellow': {\r\n 50 : '#fffde7',\r\n 100 : '#fff9c4',\r\n 200 : '#fff59d',\r\n 300 : '#fff176',\r\n 400 : '#ffee58',\r\n 500 : '#ffeb3b',\r\n 600 : '#fdd835',\r\n 700 : '#fbc02d',\r\n 800 : '#f9a825',\r\n 900 : '#f57f17',\r\n A100 : '#ffff8d',\r\n A200 : '#ffff00',\r\n A400 : '#ffea00',\r\n A700 : '#ffd600',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : black87,\r\n 600 : black87,\r\n 700 : black87,\r\n 800 : black87,\r\n 900 : black87,\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: black87\r\n }\r\n },\r\n\r\n 'amber': {\r\n 50 : '#fff8e1',\r\n 100 : '#ffecb3',\r\n 200 : '#ffe082',\r\n 300 : '#ffd54f',\r\n 400 : '#ffca28',\r\n 500 : '#ffc107',\r\n 600 : '#ffb300',\r\n 700 : '#ffa000',\r\n 800 : '#ff8f00',\r\n 900 : '#ff6f00',\r\n A100 : '#ffe57f',\r\n A200 : '#ffd740',\r\n A400 : '#ffc400',\r\n A700 : '#ffab00',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : black87,\r\n 600 : black87,\r\n 700 : black87,\r\n 800 : black87,\r\n 900 : black87,\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: black87\r\n }\r\n },\r\n\r\n 'orange': {\r\n 50 : '#fff3e0',\r\n 100 : '#ffe0b2',\r\n 200 : '#ffcc80',\r\n 300 : '#ffb74d',\r\n 400 : '#ffa726',\r\n 500 : '#ff9800',\r\n 600 : '#fb8c00',\r\n 700 : '#f57c00',\r\n 800 : '#ef6c00',\r\n 900 : '#e65100',\r\n A100 : '#ffd180',\r\n A200 : '#ffab40',\r\n A400 : '#ff9100',\r\n A700 : '#ff6d00',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : black87,\r\n 600 : black87,\r\n 700 : black87,\r\n 800 : 'white',\r\n 900 : 'white',\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: 'black'\r\n }\r\n },\r\n\r\n 'deep-orange': {\r\n 50 : '#fbe9e7',\r\n 100 : '#ffccbc',\r\n 200 : '#ffab91',\r\n 300 : '#ff8a65',\r\n 400 : '#ff7043',\r\n 500 : '#ff5722',\r\n 600 : '#f4511e',\r\n 700 : '#e64a19',\r\n 800 : '#d84315',\r\n 900 : '#bf360c',\r\n A100 : '#ff9e80',\r\n A200 : '#ff6e40',\r\n A400 : '#ff3d00',\r\n A700 : '#dd2c00',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : 'white',\r\n 600 : 'white',\r\n 700 : 'white',\r\n 800 : 'white',\r\n 900 : 'white',\r\n A100: black87,\r\n A200: black87,\r\n A400: 'white',\r\n A700: 'white'\r\n }\r\n },\r\n\r\n 'brown': {\r\n 50 : '#efebe9',\r\n 100 : '#d7ccc8',\r\n 200 : '#bcaaa4',\r\n 300 : '#a1887f',\r\n 400 : '#8d6e63',\r\n 500 : '#795548',\r\n 600 : '#6d4c41',\r\n 700 : '#5d4037',\r\n 800 : '#4e342e',\r\n 900 : '#3e2723',\r\n A100 : '#d7ccc8',\r\n A200 : '#bcaaa4',\r\n A400 : '#8d6e63',\r\n A700 : '#5d4037',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : 'white',\r\n 400 : 'white',\r\n 500 : white87,\r\n 600 : white87,\r\n 700 : white87,\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: black87,\r\n A400: 'white',\r\n A700: white87\r\n }\r\n },\r\n\r\n 'grey': {\r\n 0 : '#ffffff',\r\n 50 : '#fafafa',\r\n 100 : '#f5f5f5',\r\n 200 : '#eeeeee',\r\n 300 : '#e0e0e0',\r\n 400 : '#bdbdbd',\r\n 500 : '#9e9e9e',\r\n 600 : '#757575',\r\n 700 : '#616161',\r\n 800 : '#424242',\r\n 900 : '#212121',\r\n 1000 : '#000000',\r\n A100 : '#ffffff',\r\n A200 : '#eeeeee',\r\n A400 : '#bdbdbd',\r\n A700 : '#616161',\r\n contrast: {\r\n 0 : black87,\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : black87,\r\n 500 : black87,\r\n 600 : white87,\r\n 700 : white87,\r\n 800 : white87,\r\n 900 : white87,\r\n 1000: white87,\r\n A100: black87,\r\n A200: black87,\r\n A400: black87,\r\n A700: white87\r\n }\r\n },\r\n\r\n 'blue-grey': {\r\n 50 : '#eceff1',\r\n 100 : '#cfd8dc',\r\n 200 : '#b0bec5',\r\n 300 : '#90a4ae',\r\n 400 : '#78909c',\r\n 500 : '#607d8b',\r\n 600 : '#546e7a',\r\n 700 : '#455a64',\r\n 800 : '#37474f',\r\n 900 : '#263238',\r\n A100 : '#cfd8dc',\r\n A200 : '#b0bec5',\r\n A400 : '#78909c',\r\n A700 : '#455a64',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : black87,\r\n 400 : 'white',\r\n 500 : 'white',\r\n 600 : white87,\r\n 700 : white87,\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: black87,\r\n A400: 'white',\r\n A700: white87\r\n }\r\n },\r\n\r\n 'fuse-navy': {\r\n 50 : '#ECECEE',\r\n 100 : '#C5C6CB',\r\n 200 : '#9EA1A9',\r\n 300 : '#7D818C',\r\n 400 : '#5C616F',\r\n 500 : '#3C4252',\r\n 600 : '#353A48',\r\n 700 : '#2D323E',\r\n 800 : '#262933',\r\n 900 : '#1E2129',\r\n A100 : '#C5C6CB',\r\n A200 : '#9EA1A9',\r\n A400 : '#5C616F',\r\n A700 : '#2D323E',\r\n contrast: {\r\n 50 : black87,\r\n 100 : black87,\r\n 200 : black87,\r\n 300 : 'white',\r\n 400 : 'white',\r\n 500 : white87,\r\n 600 : white87,\r\n 700 : white87,\r\n 800 : white87,\r\n 900 : white87,\r\n A100: black87,\r\n A200: white87,\r\n A400: white87,\r\n A700: white87\r\n }\r\n },\r\n\r\n 'fuse-white': {\r\n 500 : 'white',\r\n contrast: {\r\n 500: black87\r\n }\r\n },\r\n\r\n 'fuse-black': {\r\n 500 : 'black',\r\n contrast: {\r\n 500: 'white'\r\n }\r\n }\r\n};\r\n\r\n// tslint:disable-next-line\r\nconst matPresetColors = [\r\n '#ffebee', '#ffcdd2', '#ef9a9a', '#e57373', '#ef5350', '#f44336', '#e53935', '#d32f2f', '#c62828', '#b71c1c', '#ff8a80', '#ff5252', '#ff1744', '#d50000', '#fce4ec', '#f8bbd0',\r\n '#f48fb1', '#f06292', '#ec407a', '#e91e63', '#d81b60', '#c2185b', '#ad1457', '#880e4f', '#ff80ab', '#ff4081', '#f50057', '#c51162', '#f3e5f5', '#e1bee7', '#ce93d8', '#ba68c8',\r\n '#ab47bc', '#9c27b0', '#8e24aa', '#7b1fa2', '#6a1b9a', '#4a148c', '#ea80fc', '#e040fb', '#d500f9', '#aa00ff', '#ede7f6', '#d1c4e9', '#b39ddb', '#9575cd', '#7e57c2', '#673ab7',\r\n '#5e35b1', '#512da8', '#4527a0', '#311b92', '#b388ff', '#7c4dff', '#651fff', '#6200ea', '#e8eaf6', '#c5cae9', '#9fa8da', '#7986cb', '#5c6bc0', '#3f51b5', '#3949ab', '#303f9f',\r\n '#283593', '#1a237e', '#8c9eff', '#536dfe', '#3d5afe', '#304ffe', '#e3f2fd', '#bbdefb', '#90caf9', '#64b5f6', '#42a5f5', '#2196f3', '#1e88e5', '#1976d2', '#1565c0', '#0d47a1',\r\n '#82b1ff', '#448aff', '#2979ff', '#2962ff', '#e1f5fe', '#b3e5fc', '#81d4fa', '#4fc3f7', '#29b6f6', '#03a9f4', '#039be5', '#0288d1', '#0277bd', '#01579b', '#80d8ff', '#40c4ff',\r\n '#00b0ff', '#0091ea', '#e0f7fa', '#b2ebf2', '#80deea', '#4dd0e1', '#26c6da', '#00bcd4', '#00acc1', '#0097a7', '#00838f', '#006064', '#84ffff', '#18ffff', '#00e5ff', '#00b8d4',\r\n '#e0f2f1', '#b2dfdb', '#80cbc4', '#4db6ac', '#26a69a', '#009688', '#00897b', '#00796b', '#00695c', '#004d40', '#a7ffeb', '#64ffda', '#1de9b6', '#00bfa5', '#e8f5e9', '#c8e6c9',\r\n '#a5d6a7', '#81c784', '#66bb6a', '#4caf50', '#43a047', '#388e3c', '#2e7d32', '#1b5e20', '#b9f6ca', '#69f0ae', '#00e676', '#00c853', '#f1f8e9', '#dcedc8', '#c5e1a5', '#aed581',\r\n '#9ccc65', '#8bc34a', '#7cb342', '#689f38', '#558b2f', '#33691e', '#ccff90', '#b2ff59', '#76ff03', '#64dd17', '#f9fbe7', '#f0f4c3', '#e6ee9c', '#dce775', '#d4e157', '#cddc39',\r\n '#c0ca33', '#afb42b', '#9e9d24', '#827717', '#f4ff81', '#eeff41', '#c6ff00', '#aeea00', '#fffde7', '#fff9c4', '#fff59d', '#fff176', '#ffee58', '#ffeb3b', '#fdd835', '#fbc02d',\r\n '#f9a825', '#f57f17', '#ffff8d', '#ffff00', '#ffea00', '#ffd600', '#fff8e1', '#ffecb3', '#ffe082', '#ffd54f', '#ffca28', '#ffc107', '#ffb300', '#ffa000', '#ff8f00', '#ff6f00',\r\n '#ffe57f', '#ffd740', '#ffc400', '#ffab00', '#fff3e0', '#ffe0b2', '#ffcc80', '#ffb74d', '#ffa726', '#ff9800', '#fb8c00', '#f57c00', '#ef6c00', '#e65100', '#ffd180', '#ffab40',\r\n '#ff9100', '#ff6d00', '#fbe9e7', '#ffccbc', '#ffab91', '#ff8a65', '#ff7043', '#ff5722', '#f4511e', '#e64a19', '#d84315', '#bf360c', '#ff9e80', '#ff6e40', '#ff3d00', '#dd2c00',\r\n '#efebe9', '#d7ccc8', '#bcaaa4', '#a1887f', '#8d6e63', '#795548', '#6d4c41', '#5d4037', '#4e342e', '#3e2723', '#d7ccc8', '#bcaaa4', '#8d6e63', '#5d4037', '#fafafa', '#f5f5f5',\r\n '#eeeeee', '#e0e0e0', '#bdbdbd', '#9e9e9e', '#757575', '#616161', '#424242', '#212121', '#ffffff', '#eeeeee', '#bdbdbd', '#616161', '#eceff1', '#cfd8dc', '#b0bec5', '#90a4ae',\r\n '#78909c', '#607d8b', '#546e7a', '#455a64', '#37474f', '#263238', '#cfd8dc', '#b0bec5', '#78909c', '#455a64'\r\n];\r\n\r\n/**\r\n // Color palettes from the Material Design spec.\r\n // See https://www.google.com/design/spec/style/color.html\r\n */\r\nexport class MatColors\r\n{\r\n public static all = matColors;\r\n public static presets = matPresetColors;\r\n\r\n public static getColor(colorName): any\r\n {\r\n if ( matColors[colorName] )\r\n {\r\n return matColors[colorName];\r\n }\r\n\r\n return false;\r\n }\r\n}\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\n\r\n@Pipe({name: 'camelCaseToDash'})\r\nexport class CamelCaseToDashPipe implements PipeTransform\r\n{\r\n /**\r\n * Transform\r\n *\r\n * @param {string} value\r\n * @param {any[]} args\r\n * @returns {string}\r\n */\r\n transform(value: string, args: any[] = []): string\r\n {\r\n return value ? String(value).replace(/([A-Z])/g, (g) => `-${g[0].toLowerCase()}`) : '';\r\n }\r\n}\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\n\r\n@Pipe({name: 'dateTime'})\r\nexport class DateTimePipe implements PipeTransform\r\n{\r\n /**\r\n * Transform\r\n *\r\n * @param {string} value\r\n * @returns {string}\r\n */\r\n transform(value: string): string\r\n {\r\n return value ? new Date(value).toLocaleTimeString() : '';\r\n }\r\n}","import { Pipe, PipeTransform } from '@angular/core';\r\nimport { FuseUtils } from '@fuse/utils';\r\n\r\n@Pipe({name: 'filter'})\r\nexport class FilterPipe implements PipeTransform\r\n{\r\n /**\r\n * Transform\r\n *\r\n * @param {any[]} mainArr\r\n * @param {string} searchText\r\n * @param {string} property\r\n * @returns {any}\r\n */\r\n transform(mainArr: any[], searchText: string, property: string): any\r\n {\r\n return FuseUtils.filterArrayByString(mainArr, searchText);\r\n }\r\n}\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\n\r\n@Pipe({\r\n name: 'getById',\r\n pure: false\r\n})\r\nexport class GetByIdPipe implements PipeTransform\r\n{\r\n /**\r\n * Transform\r\n *\r\n * @param {any[]} value\r\n * @param {number} id\r\n * @param {string} property\r\n * @returns {any}\r\n */\r\n transform(value: any[], id: number, property: string): any\r\n {\r\n const foundItem = value.find(item => {\r\n if ( item.id !== undefined )\r\n {\r\n return item.id === id;\r\n }\r\n\r\n return false;\r\n });\r\n\r\n if ( foundItem )\r\n {\r\n return foundItem[property];\r\n }\r\n }\r\n}\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\n\r\n@Pipe({name: 'htmlToPlaintext'})\r\nexport class HtmlToPlaintextPipe implements PipeTransform\r\n{\r\n /**\r\n * Transform\r\n *\r\n * @param {string} value\r\n * @param {any[]} args\r\n * @returns {string}\r\n */\r\n transform(value: string, args: any[] = []): string\r\n {\r\n return value ? String(value).replace(/<[^>]+>/gm, '') : '';\r\n }\r\n}\r\n","import { Pipe, PipeTransform } from '@angular/core';\r\n\r\n@Pipe({name: 'keys'})\r\nexport class KeysPipe implements PipeTransform\r\n{\r\n /**\r\n * Transform\r\n *\r\n * @param value\r\n * @param {string[]} args\r\n * @returns {any}\r\n */\r\n transform(value: any, args: string[]): any\r\n {\r\n const keys: any[] = [];\r\n\r\n for ( const key in value )\r\n {\r\n if ( value.hasOwnProperty(key) )\r\n {\r\n keys.push({\r\n key : key,\r\n value: value[key]\r\n });\r\n }\r\n }\r\n\r\n return keys;\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { KeysPipe } from './keys.pipe';\r\nimport { GetByIdPipe } from './getById.pipe';\r\nimport { HtmlToPlaintextPipe } from './htmlToPlaintext.pipe';\r\nimport { FilterPipe } from './filter.pipe';\r\nimport { CamelCaseToDashPipe } from './camelCaseToDash.pipe';\r\nimport { DateTimePipe } from './dateTime.pipe';\r\nimport { SanitizeHtmlPipe } from './sanitizeHtml.pipe';\r\n\r\n@NgModule({\r\n declarations: [\r\n KeysPipe,\r\n GetByIdPipe,\r\n HtmlToPlaintextPipe,\r\n FilterPipe,\r\n CamelCaseToDashPipe,\r\n DateTimePipe,\r\n SanitizeHtmlPipe\r\n ],\r\n imports : [],\r\n exports : [\r\n KeysPipe,\r\n GetByIdPipe,\r\n HtmlToPlaintextPipe,\r\n FilterPipe,\r\n CamelCaseToDashPipe,\r\n DateTimePipe,\r\n SanitizeHtmlPipe\r\n ]\r\n})\r\nexport class FusePipesModule\r\n{\r\n}\r\n","import { Pipe, PipeTransform } from \"@angular/core\";\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\n\r\n@Pipe({\r\n name: 'sanitizeHtml'\r\n})\r\nexport class SanitizeHtmlPipe implements PipeTransform {\r\n\r\n constructor(private _sanitizer:DomSanitizer) {\r\n }\r\n\r\n transform(v:string):SafeHtml {\r\n return this._sanitizer.bypassSecurityTrustHtml(v);\r\n }\r\n}","import { Inject, Injectable, InjectionToken } from '@angular/core';\r\nimport { ResolveEnd, Router } from '@angular/router';\r\nimport { Platform } from '@angular/cdk/platform';\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\nimport { filter } from 'rxjs/operators';\r\nimport * as _ from 'lodash';\r\n\r\n// Create the injection token for the custom settings\r\nexport const FUSE_CONFIG = new InjectionToken('fuseCustomConfig');\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class FuseConfigService\r\n{\r\n // Private\r\n private _configSubject: BehaviorSubject;\r\n private readonly _defaultConfig: any;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {Platform} _platform\r\n * @param {Router} _router\r\n * @param _config\r\n */\r\n constructor(\r\n private _platform: Platform,\r\n private _router: Router,\r\n @Inject(FUSE_CONFIG) private _config\r\n )\r\n {\r\n // Set the default config from the user provided config (from forRoot)\r\n this._defaultConfig = _config;\r\n\r\n // Initialize the service\r\n this._init();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Set and get the config\r\n */\r\n set config(value)\r\n {\r\n // Get the value from the behavior subject\r\n let config = this._configSubject.getValue();\r\n\r\n // Merge the new config\r\n config = _.merge({}, config, value);\r\n\r\n // Notify the observers\r\n this._configSubject.next(config);\r\n }\r\n\r\n get config(): any | Observable\r\n {\r\n return this._configSubject.asObservable();\r\n }\r\n\r\n /**\r\n * Get default config\r\n *\r\n * @returns {any}\r\n */\r\n get defaultConfig(): any\r\n {\r\n return this._defaultConfig;\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Private methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Initialize\r\n *\r\n * @private\r\n */\r\n private _init(): void\r\n {\r\n /**\r\n * Disable custom scrollbars if browser is mobile\r\n */\r\n if ( this._platform.ANDROID || this._platform.IOS )\r\n {\r\n this._defaultConfig.customScrollbars = false;\r\n }\r\n\r\n // Set the config from the default config\r\n this._configSubject = new BehaviorSubject(_.cloneDeep(this._defaultConfig));\r\n\r\n // Reload the default layout config on every RoutesRecognized event\r\n // if the current layout config is different from the default one\r\n this._router.events\r\n .pipe(filter(event => event instanceof ResolveEnd))\r\n .subscribe(() => {\r\n if ( !_.isEqual(this._configSubject.getValue().layout, this._defaultConfig.layout) )\r\n {\r\n // Clone the current config\r\n const config = _.cloneDeep(this._configSubject.getValue());\r\n\r\n // Reset the layout from the default config\r\n config.layout = _.cloneDeep(this._defaultConfig.layout);\r\n\r\n // Set the config\r\n this._configSubject.next(config);\r\n }\r\n });\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Set config\r\n *\r\n * @param value\r\n * @param {{emitEvent: boolean}} opts\r\n */\r\n setConfig(value, opts = {emitEvent: true}): void\r\n {\r\n // Get the value from the behavior subject\r\n let config = this._configSubject.getValue();\r\n\r\n // Merge the new config\r\n config = _.merge({}, config, value);\r\n\r\n // If emitEvent option is true...\r\n if ( opts.emitEvent === true )\r\n {\r\n // Notify the observers\r\n this._configSubject.next(config);\r\n }\r\n }\r\n\r\n /**\r\n * Get config\r\n *\r\n * @returns {Observable}\r\n */\r\n getConfig(): Observable\r\n {\r\n return this._configSubject.asObservable();\r\n }\r\n\r\n /**\r\n * Reset to the default config\r\n */\r\n resetToDefaults(): void\r\n {\r\n // Set the config from the default config\r\n this._configSubject.next(_.cloneDeep(this._defaultConfig));\r\n }\r\n}\r\n\r\n","import { MediaChange, MediaObserver } from '@angular/flex-layout';\r\nimport { Injectable } from '@angular/core';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class FuseMatchMediaService\r\n{\r\n activeMediaQuery: string;\r\n onMediaChange: BehaviorSubject = new BehaviorSubject('');\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {MediaObserver} _mediaObserver\r\n */\r\n constructor(\r\n private _mediaObserver: MediaObserver\r\n )\r\n {\r\n // Set the defaults\r\n this.activeMediaQuery = '';\r\n\r\n // Initialize\r\n this._init();\r\n\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Private methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Initialize\r\n *\r\n * @private\r\n */\r\n private _init(): void\r\n {\r\n this._mediaObserver.media$\r\n .pipe(\r\n debounceTime(500),\r\n distinctUntilChanged()\r\n )\r\n .subscribe((change: MediaChange) => {\r\n if ( this.activeMediaQuery !== change.mqAlias )\r\n {\r\n this.activeMediaQuery = change.mqAlias;\r\n this.onMediaChange.next(change.mqAlias);\r\n }\r\n });\r\n }\r\n\r\n}\r\n","import { Inject, Injectable } from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { animate, AnimationBuilder, AnimationPlayer, style } from '@angular/animations';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\n\r\nimport { filter, take } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class FuseSplashScreenService\r\n{\r\n splashScreenEl: any;\r\n player: AnimationPlayer;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {AnimationBuilder} _animationBuilder\r\n * @param _document\r\n * @param {Router} _router\r\n */\r\n constructor(\r\n private _animationBuilder: AnimationBuilder,\r\n @Inject(DOCUMENT) private _document: any,\r\n private _router: Router\r\n )\r\n {\r\n // Initialize\r\n this._init();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Private methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Initialize\r\n *\r\n * @private\r\n */\r\n private _init(): void\r\n {\r\n // Get the splash screen element\r\n this.splashScreenEl = this._document.body.querySelector('#fuse-splash-screen');\r\n\r\n // If the splash screen element exists...\r\n if ( this.splashScreenEl )\r\n {\r\n // Hide it on the first NavigationEnd event\r\n this._router.events\r\n .pipe(\r\n filter((event => event instanceof NavigationEnd)),\r\n take(1)\r\n )\r\n .subscribe(() => {\r\n setTimeout(() => {\r\n this.hide();\r\n });\r\n });\r\n }\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Show the splash screen\r\n */\r\n show(): void\r\n {\r\n this.player =\r\n this._animationBuilder\r\n .build([\r\n style({\r\n opacity: '0',\r\n zIndex : '99999'\r\n }),\r\n animate('400ms ease', style({opacity: '1'}))\r\n ]).create(this.splashScreenEl);\r\n\r\n setTimeout(() => {\r\n this.player.play();\r\n }, 0);\r\n }\r\n\r\n /**\r\n * Hide the splash screen\r\n */\r\n hide(): void\r\n {\r\n this.player =\r\n this._animationBuilder\r\n .build([\r\n style({opacity: '1'}),\r\n animate('400ms ease', style({\r\n opacity: '0',\r\n zIndex : '-10'\r\n }))\r\n ]).create(this.splashScreenEl);\r\n\r\n setTimeout(() => {\r\n this.player.play();\r\n }, 0);\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\nexport interface Locale\r\n{\r\n lang: string;\r\n data: Object;\r\n}\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class FuseTranslationLoaderService\r\n{\r\n /**\r\n * Constructor\r\n *\r\n * @param {TranslateService} _translateService\r\n */\r\n constructor(\r\n private _translateService: TranslateService\r\n )\r\n {\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Load translations\r\n *\r\n * @param {Locale} args\r\n */\r\n loadTranslations(...args: Locale[]): void\r\n {\r\n const locales = [...args];\r\n\r\n locales.forEach((locale) => {\r\n // use setTranslation() with the third argument set to true\r\n // to append translations instead of replacing them\r\n // this._translateService.setTranslation(locale.lang, locale.data, true);\r\n });\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FlexLayoutModule } from '@angular/flex-layout';\r\nimport { FuseConfirmDialogModule, FuseSidebarModule } from '@fuse/components';\r\nimport { FuseDirectivesModule } from '@fuse/directives/directives';\r\nimport { FusePipesModule } from '@fuse/pipes/pipes.module';\r\nimport {FuseWidgetModule} from '@fuse/components/widget/widget.module';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatRippleModule } from '@angular/material/core';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { MatTableModule } from '@angular/material/table';\r\nimport { MatSortModule } from '@angular/material/sort';\r\nimport {MatPaginatorModule } from '@angular/material/paginator';\r\nimport { MatToolbarModule } from '@angular/material/toolbar';\r\nimport { MatDividerModule } from '@angular/material/divider';\r\nimport { MatTabsModule } from '@angular/material/tabs';\r\nimport {MatSelectModule} from '@angular/material/select';\r\nimport { UiSwitchModule } from 'ngx-ui-switch';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport {NgxMaterialTimepickerModule} from 'ngx-material-timepicker'\r\nimport { differenceDialogModule } from './components/difference-dialog/difference-dialog.module';\r\n\r\nconst MaterialModules=[\r\n MatButtonModule,\r\n MatCheckboxModule,\r\n MatDatepickerModule,\r\n MatFormFieldModule,\r\n MatIconModule,\r\n MatInputModule,\r\n MatMenuModule,\r\n MatRippleModule,\r\n MatTableModule,\r\n MatToolbarModule,\r\n FlexLayoutModule,\r\n MatDividerModule,\r\n MatTabsModule,\r\n MatPaginatorModule,\r\n MatSortModule,\r\n MatSelectModule,\r\n UiSwitchModule,\r\n MatTooltipModule,\r\n NgxMaterialTimepickerModule\r\n];\r\nconst fuseModules=[\r\n FuseDirectivesModule,\r\n FusePipesModule,\r\n FuseWidgetModule,\r\n FuseConfirmDialogModule,\r\n FuseSidebarModule,\r\n differenceDialogModule\r\n]\r\n@NgModule({\r\n imports : [\r\n CommonModule,\r\n FormsModule,\r\n ReactiveFormsModule,\r\n ...MaterialModules,\r\n ...fuseModules\r\n ],\r\n exports : [\r\n CommonModule,\r\n FormsModule,\r\n ReactiveFormsModule,\r\n ...MaterialModules,\r\n ...fuseModules\r\n ]\r\n})\r\nexport class FuseSharedModule\r\n{\r\n}\r\n","export class FuseUtils\r\n{\r\n /**\r\n * Filter array by string\r\n *\r\n * @param mainArr\r\n * @param searchText\r\n * @returns {any}\r\n */\r\n public static filterArrayByString(mainArr, searchText): any\r\n {\r\n if ( searchText === '' )\r\n {\r\n return mainArr;\r\n }\r\n\r\n searchText = searchText.toLowerCase();\r\n\r\n return mainArr.filter(itemObj => {\r\n return this.searchInObj(itemObj, searchText);\r\n });\r\n }\r\n\r\n /**\r\n * Search in object\r\n *\r\n * @param itemObj\r\n * @param searchText\r\n * @returns {boolean}\r\n */\r\n public static searchInObj(itemObj, searchText): boolean\r\n {\r\n for ( const prop in itemObj )\r\n {\r\n if ( !itemObj.hasOwnProperty(prop) )\r\n {\r\n continue;\r\n }\r\n\r\n const value = itemObj[prop];\r\n\r\n if ( typeof value === 'string' )\r\n {\r\n if ( this.searchInString(value, searchText) )\r\n {\r\n return true;\r\n }\r\n }\r\n\r\n else if ( Array.isArray(value) )\r\n {\r\n if ( this.searchInArray(value, searchText) )\r\n {\r\n return true;\r\n }\r\n }\r\n\r\n if ( typeof value === 'object' )\r\n {\r\n if ( this.searchInObj(value, searchText) )\r\n {\r\n return true;\r\n }\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Search in array\r\n *\r\n * @param arr\r\n * @param searchText\r\n * @returns {boolean}\r\n */\r\n public static searchInArray(arr, searchText): boolean\r\n {\r\n for ( const value of arr )\r\n {\r\n if ( typeof value === 'string' )\r\n {\r\n if ( this.searchInString(value, searchText) )\r\n {\r\n return true;\r\n }\r\n }\r\n\r\n if ( typeof value === 'object' )\r\n {\r\n if ( this.searchInObj(value, searchText) )\r\n {\r\n return true;\r\n }\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * Search in string\r\n *\r\n * @param value\r\n * @param searchText\r\n * @returns {any}\r\n */\r\n public static searchInString(value, searchText): any\r\n {\r\n return value.toLowerCase().includes(searchText);\r\n }\r\n\r\n /**\r\n * Generate a unique GUID\r\n *\r\n * @returns {string}\r\n */\r\n public static generateGUID(): string\r\n {\r\n function S4(): string\r\n {\r\n return Math.floor((1 + Math.random()) * 0x10000)\r\n .toString(16)\r\n .substring(1);\r\n }\r\n\r\n return S4() + S4();\r\n }\r\n\r\n /**\r\n * Toggle in array\r\n *\r\n * @param item\r\n * @param array\r\n */\r\n public static toggleInArray(item, array): void\r\n {\r\n if ( array.indexOf(item) === -1 )\r\n {\r\n array.push(item);\r\n }\r\n else\r\n {\r\n array.splice(array.indexOf(item), 1);\r\n }\r\n }\r\n\r\n /**\r\n * Handleize\r\n *\r\n * @param text\r\n * @returns {string}\r\n */\r\n public static handleize(text): string\r\n {\r\n return text.toString().toLowerCase()\r\n .replace(/\\s+/g, '-') // Replace spaces with -\r\n .replace(/[^\\w\\-]+/g, '') // Remove all non-word chars\r\n .replace(/\\-\\-+/g, '-') // Replace multiple - with single -\r\n .replace(/^-+/, '') // Trim - from start of text\r\n .replace(/-+$/, ''); // Trim - from end of text\r\n }\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\n:host {\\n position: relative;\\n display: flex;\\n flex: 1 1 auto;\\n width: 100%;\\n height: 100%;\\n min-width: 0;\\n}\\n:host .theme-options-button {\\n position: absolute;\\n top: 160px;\\n right: 0;\\n width: 48px;\\n height: 48px;\\n line-height: 48px;\\n text-align: center;\\n cursor: pointer;\\n border-radius: 0;\\n margin: 0;\\n pointer-events: auto;\\n opacity: 0.9;\\n z-index: 998;\\n}\\n@media screen and (min-width: 1280px) {\\n :host .theme-options-button.right-side-panel {\\n right: 70px;\\n }\\n}\\n:host .theme-options-button.side-panel-hidden {\\n right: 0 !important;\\n}\\n:host .theme-options-button mat-icon {\\n -webkit-animation: rotating 3s linear infinite;\\n animation: rotating 3s linear infinite;\\n}\\n:host .theme-options-button:hover {\\n opacity: 1;\\n}\\n:host .theme-options-sidebar {\\n width: 360px;\\n min-width: 360px;\\n max-width: 360px;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/app/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\app\\app.component.scss","src/app/app.component.scss","src/app/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC95FA;EACI,kBAAA;EACA,aAAA;EACA,cAAA;EACA,WAAA;EACA,YAAA;EACA,YAAA;ACEJ;ADAI;EACI,kBAAA;EACA,UAAA;EACA,QAAA;EACA,WAAA;EACA,YAAA;EACA,iBAAA;EACA,kBAAA;EACA,eAAA;EACA,gBAAA;EACA,SAAA;EACA,oBAAA;EACA,YAAA;EACA,YAAA;ACER;ACQQ;EFRA;IAGQ,WAAA;ECCd;AACF;ADEQ;EACI,mBAAA;ACAZ;ADGQ;EACI,8CAAA;UAAA,sCAAA;ACDZ;ADIQ;EACI,UAAA;ACFZ;ADMI;EACI,YAAA;EACA,gBAAA;EACA,gBAAA;ACJR","file":"src/app/app.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\n\r\n:host {\r\n    position: relative;\r\n    display: flex;\r\n    flex: 1 1 auto;\r\n    width: 100%;\r\n    height: 100%;\r\n    min-width: 0;\r\n\r\n    .theme-options-button {\r\n        position: absolute;\r\n        top: 160px;\r\n        right: 0;\r\n        width: 48px;\r\n        height: 48px;\r\n        line-height: 48px;\r\n        text-align: center;\r\n        cursor: pointer;\r\n        border-radius: 0;\r\n        margin: 0;\r\n        pointer-events: auto;\r\n        opacity: .90;\r\n        z-index: 998;\r\n\r\n        &.right-side-panel {\r\n\r\n            @include media-breakpoint('gt-md') {\r\n                right: 70px;\r\n            }\r\n        }\r\n\r\n        &.side-panel-hidden {\r\n            right: 0 !important;\r\n        }\r\n\r\n        mat-icon {\r\n            animation: rotating 3s linear infinite;\r\n        }\r\n\r\n        &:hover {\r\n            opacity: 1;\r\n        }\r\n    }\r\n\r\n    .theme-options-sidebar {\r\n        width: 360px;\r\n        min-width: 360px;\r\n        max-width: 360px;\r\n    }\r\n}","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\n:host {\n  position: relative;\n  display: flex;\n  flex: 1 1 auto;\n  width: 100%;\n  height: 100%;\n  min-width: 0;\n}\n:host .theme-options-button {\n  position: absolute;\n  top: 160px;\n  right: 0;\n  width: 48px;\n  height: 48px;\n  line-height: 48px;\n  text-align: center;\n  cursor: pointer;\n  border-radius: 0;\n  margin: 0;\n  pointer-events: auto;\n  opacity: 0.9;\n  z-index: 998;\n}\n@media screen and (min-width: 1280px) {\n  :host .theme-options-button.right-side-panel {\n    right: 70px;\n  }\n}\n:host .theme-options-button.side-panel-hidden {\n  right: 0 !important;\n}\n:host .theme-options-button mat-icon {\n  animation: rotating 3s linear infinite;\n}\n:host .theme-options-button:hover {\n  opacity: 1;\n}\n:host .theme-options-sidebar {\n  width: 360px;\n  min-width: 360px;\n  max-width: 360px;\n}","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n"]} */\"","import { Component, Inject, OnDestroy, OnInit } from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { Platform } from '@angular/cdk/platform';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseConfigService } from '@fuse/services/config.service';\r\nimport { FuseNavigationService } from '@fuse/components/navigation/navigation.service';\r\nimport { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service';\r\nimport { FuseSplashScreenService } from '@fuse/services/splash-screen.service';\r\nimport { FuseTranslationLoaderService } from '@fuse/services/translation-loader.service';\r\n\r\nimport { navigation } from 'app/navigation/navigation';\r\nimport { locale as navigationEnglish } from 'app/navigation/i18n/en';\r\nimport { locale as navigationTurkish } from 'app/navigation/i18n/tr';\r\nimport { CustomTranslateService } from './shared/custom-translate.service';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { Title } from '@angular/platform-browser';\r\nimport { AuthService } from './shared/auth.service';\r\n\r\n@Component({\r\n selector: 'app',\r\n templateUrl: './app.component.html',\r\n styleUrls: ['./app.component.scss']\r\n})\r\nexport class AppComponent implements OnInit, OnDestroy {\r\n fuseConfig: any;\r\n navigation: any;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {DOCUMENT} document\r\n * @param {FuseConfigService} _fuseConfigService\r\n * @param {FuseNavigationService} _fuseNavigationService\r\n * @param {FuseSidebarService} _fuseSidebarService\r\n * @param {FuseSplashScreenService} _fuseSplashScreenService\r\n * @param {FuseTranslationLoaderService} _fuseTranslationLoaderService\r\n * @param {Platform} _platform\r\n * @param {TranslateService} _translateService\r\n */\r\n constructor(\r\n @Inject(DOCUMENT) private document: any,\r\n private _fuseConfigService: FuseConfigService,\r\n private _fuseNavigationService: FuseNavigationService,\r\n private _fuseSidebarService: FuseSidebarService,\r\n private _fuseSplashScreenService: FuseSplashScreenService,\r\n private _fuseTranslationLoaderService: FuseTranslationLoaderService,\r\n private _translateService: TranslateService,\r\n private _customTranslateService: CustomTranslateService,\r\n private _platform: Platform,\r\n public router: Router,\r\n private titleService: Title,\r\n private _authService: AuthService,\r\n ) {\r\n // Get default navigation\r\n this.navigation = navigation;\r\n\r\n // Register the navigation to the service\r\n this._fuseNavigationService.register('main', this.navigation);\r\n\r\n // Set the main navigation as our current navigation\r\n this._fuseNavigationService.setCurrentNavigation('main');\r\n\r\n // Add languages\r\n //this._translateService.addLangs(['en', 'tr']);\r\n\r\n // Set the default language\r\n //this._translateService.setDefaultLang('en');\r\n\r\n // Set the navigation translations\r\n // this._fuseTranslationLoaderService.loadTranslations(navigationEnglish, navigationTurkish);\r\n \r\n // Use a language\r\n //this._translateService.use('en'); \r\n this._translateService.setDefaultLang('EN-IN');\r\n // this._customTranslateService.SetTranslation('EN-IN');\r\n if (localStorage.getItem('DefaultCountryCode') !== null) {\r\n const self = this;\r\n var DefaultCountryCode = localStorage.getItem('DefaultCountryCode');\r\n self._customTranslateService.GetLanguageCodeCombination(DefaultCountryCode,function(list: any){ \r\n // var DefaultLanguageCountryCode = localStorage.getItem('DefaultLanguageCountryCode');\r\n // self._translateService.setDefaultLang(DefaultLanguageCountryCode);\r\n // self._customTranslateService.SetTranslation(DefaultLanguageCountryCode);\r\n })\r\n }\r\n\r\n /**\r\n * ----------------------------------------------------------------------------------------------------\r\n * ngxTranslate Fix Start\r\n * ----------------------------------------------------------------------------------------------------\r\n */\r\n\r\n /**\r\n * If you are using a language other than the default one, i.e. Turkish in this case,\r\n * you may encounter an issue where some of the components are not actually being\r\n * translated when your app first initialized.\r\n *\r\n * This is related to ngxTranslate module and below there is a temporary fix while we\r\n * are moving the multi language implementation over to the Angular's core language\r\n * service.\r\n **/\r\n\r\n // Set the default language to 'en' and then back to 'tr'.\r\n // '.use' cannot be used here as ngxTranslate won't switch to a language that's already\r\n // been selected and there is no way to force it, so we overcome the issue by switching\r\n // the default language back and forth.\r\n /**\r\n setTimeout(() => {\r\n this._translateService.setDefaultLang('en');\r\n this._translateService.setDefaultLang('tr');\r\n });\r\n */\r\n\r\n /**\r\n * ----------------------------------------------------------------------------------------------------\r\n * ngxTranslate Fix End\r\n * ----------------------------------------------------------------------------------------------------\r\n */\r\n\r\n // Add is-mobile class to the body if the platform is mobile\r\n if ( this._platform.ANDROID || this._platform.IOS )\r\n {\r\n this.document.body.classList.add('is-mobile');\r\n }\r\n\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n var branding = JSON.parse(localStorage.getItem('Branding'));\r\n if (branding && branding != null) {\r\n document.documentElement.style.setProperty('--primary-color',branding.primaryColor);\r\n }\r\n\r\n // Subscribe to config changes\r\n this._fuseConfigService.config\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((config) => {\r\n\r\n this.fuseConfig = config;\r\n\r\n // Boxed\r\n if ( this.fuseConfig.layout.width === 'boxed' )\r\n {\r\n this.document.body.classList.add('boxed');\r\n }\r\n else\r\n {\r\n this.document.body.classList.remove('boxed');\r\n }\r\n\r\n // Color theme - Use normal for loop for IE11 compatibility\r\n for ( let i = 0; i < this.document.body.classList.length; i++ )\r\n {\r\n const className = this.document.body.classList[i];\r\n\r\n if ( className.startsWith('theme-') )\r\n {\r\n this.document.body.classList.remove(className);\r\n }\r\n }\r\n\r\n this.document.body.classList.add(this.fuseConfig.colorTheme);\r\n });\r\n this.router.events.subscribe((evt) => {\r\n \r\n if (!(evt instanceof NavigationEnd)) {\r\n return;\r\n }\r\n try {\r\n if (localStorage.getItem('LoggedInUserData')) {\r\n var userDetails = JSON.parse(localStorage.getItem('LoggedInUserData'));\r\n this._authService.sendCompanyProfileLogo(userDetails.profileImage.toString());\r\n this.titleService.setTitle(userDetails.companyName || 'Admin');\r\n }else{\r\n // this.document.getElementById('appFavicon').setAttribute('href', 'assets/images/logos/crop-logo.png');\r\n }\r\n } catch (error) {\r\n }\r\n });\r\n \r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Toggle sidebar open\r\n *\r\n * @param key\r\n */\r\n toggleSidebarOpen(key): void\r\n {\r\n this._fuseSidebarService.getSidebar(key).toggleOpen();\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { BrowserModule } from '@angular/platform-browser';\r\nimport { HttpClientModule,HTTP_INTERCEPTORS } from '@angular/common/http';\r\nimport { BrowserAnimationsModule } from '@angular/platform-browser/animations';\r\nimport { RouterModule, Routes } from '@angular/router';\r\nimport { MatMomentDateModule } from '@angular/material-moment-adapter';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { InMemoryWebApiModule } from 'angular-in-memory-web-api';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport {BasicAuthInterceptor} from './basic-auth.interceptor';\r\nimport {ErrorInterceptor} from './http-error.interceptor';\r\nimport 'hammerjs';\r\n\r\nimport { FuseModule } from '@fuse/fuse.module';\r\nimport { FuseSharedModule } from '@fuse/shared.module';\r\nimport { FuseProgressBarModule, FuseSidebarModule } from '@fuse/components';\r\n\r\nimport { fuseConfig } from 'app/fuse-config';\r\n\r\nimport { FakeDbService } from 'app/fake-db/fake-db.service';\r\nimport { AppComponent } from 'app/app.component';\r\nimport { LayoutModule } from 'app/layout/layout.module';\r\n\r\nimport { ToastrModule } from 'ngx-toastr';\r\nimport { AuthGuard } from './auth.guard';\r\nimport { AuthService } from './shared/auth.service';\r\nimport { PreventLoggedInAccess } from './shared/preventAccess.guard';\r\nimport { MatExpansionModule } from '@angular/material/expansion';\r\nimport { NgJsonEditorModule } from 'ang-jsoneditor';\r\nimport { CustomerBalanceAdjustmentComponent } from './main/pages/customers/customer-balance-adjustment/customer-balance-adjustment.component';\r\nimport { CustomerMaxLimitComponent } from './main/pages/customers/customer-maxlimit/customer-maxlimit.component';\r\nimport { PayoutReceiptComponent } from './main/pages/reports/payout-receipt/payout-receipt.component';\r\n\r\nconst appRoutes: Routes = [\r\n {\r\n path : 'pages',\r\n loadChildren: './main/pages/pages.module#PagesModule',\r\n canActivate: [AuthGuard]\r\n },\r\n {\r\n path : 'login',\r\n loadChildren :() => import('./LogIn/login.module').then(a=>a.LoginModule),\r\n //canActivate: [PreventLoggedInAccess]\r\n },\r\n {\r\n path : 'ForgotPassword',\r\n loadChildren :() => import('./forget-password-link/forget-password-link.module').then(a=>a.ForgetPasswordLinkModule),\r\n canActivate: [PreventLoggedInAccess]\r\n },\r\n {\r\n path : '',\r\n redirectTo: '/pages/dashboards/project',\r\n pathMatch: 'full',\r\n },\r\n {\r\n path : '**',\r\n redirectTo: '/login',\r\n pathMatch: 'full',\r\n }\r\n];\r\n\r\n@NgModule({\r\n declarations: [\r\n AppComponent,CustomerBalanceAdjustmentComponent,CustomerMaxLimitComponent,PayoutReceiptComponent\r\n \r\n ],\r\n imports : [\r\n BrowserModule,\r\n BrowserAnimationsModule,\r\n HttpClientModule,\r\n RouterModule.forRoot(appRoutes),\r\n\r\n TranslateModule.forRoot(),\r\n InMemoryWebApiModule.forRoot(FakeDbService, {\r\n delay : 0,\r\n passThruUnknownUrl: true\r\n }),\r\n\r\n // Material moment date module\r\n MatMomentDateModule,\r\n\r\n // Material\r\n MatButtonModule,\r\n MatIconModule,\r\n MatExpansionModule,\r\n NgJsonEditorModule,\r\n // Fuse modules\r\n FuseModule.forRoot(fuseConfig),\r\n FuseProgressBarModule,\r\n FuseSharedModule,\r\n FuseSidebarModule,\r\n\r\n // App modules\r\n LayoutModule,\r\n\r\n // toaster\r\n ToastrModule.forRoot()\r\n ],\r\n bootstrap : [\r\n AppComponent\r\n ],\r\n providers:[\r\n {\r\n provide: HTTP_INTERCEPTORS,\r\n useClass: BasicAuthInterceptor,\r\n multi: true\r\n },\r\n {\r\n provide: HTTP_INTERCEPTORS,\r\n useClass: ErrorInterceptor,\r\n multi: true\r\n },\r\n AuthGuard,\r\n AuthService\r\n ],\r\n entryComponents :[\r\n CustomerBalanceAdjustmentComponent,\r\n CustomerMaxLimitComponent,\r\n PayoutReceiptComponent\r\n ]\r\n})\r\nexport class AppModule\r\n{\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot } from \r\n'@angular/router';\r\nimport { AuthService } from './shared/auth.service';\r\nimport {Router} from '@angular/router';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class AuthGuard implements CanActivate {\r\n\r\n constructor(\r\n private _auth: AuthService,\r\n private _route: Router)\r\n {}\r\n\r\n canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): boolean | import(\"@angular/router\").UrlTree | Observable | Promise {\r\n \r\n if(this._auth.isLoggedIn()){\r\n return true;\r\n }else{\r\n this._route.navigate([\"/login\"]);\r\n return false;\r\n }\r\n\r\n }\r\n \r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\r\nimport { Observable } from 'rxjs';\r\n\r\n@Injectable()\r\nexport class BasicAuthInterceptor implements HttpInterceptor {\r\n constructor() { }\r\n\r\n intercept(request: HttpRequest, next: HttpHandler): Observable> {\r\n // add authorization header with basic auth credentials if available\r\n if (localStorage.getItem('LoggedInUser')) {\r\n var currentUser=JSON.parse(localStorage.getItem('LoggedInUser'));\r\n request = request.clone({\r\n setHeaders: { \r\n Authorization: `bearer ${currentUser.access_token}`\r\n }\r\n });\r\n }\r\n\r\n return next.handle(request);\r\n }\r\n}","// export const BASE_URL=\"https://api.mypaylink.xyz\";\r\n// export const BASE_URL = (location.hostname.search(\"adminportal\")> -1) ? \"https://api.paymenture.com\" : (location.hostname.search(\"paymenture\")> -1) ? \"https://api.paymenture.com\" : (location.hostname.search(\"mypaylink\") > -1) ? \"https://api.paymenture.com\" : (location.hostname.search(\"rpmslive\") > -1 ? \"https://rpmsliveapi.wsicloud.net\" : \"https://rpmsapi.wsicloud.net\");\r\nexport const isLiveEnv = (location.hostname.search(\"admin.paymenture\")> -1 || location.hostname.search(\"mypaylink\") > -1 || location.hostname.search(\"rpmslive\") > -1) ? true : false;\r\nexport const BASE_URL = isLiveEnv ? \"https://api.paymenture.com\" : \"https://rpmsapi.wsicloud.net\";\r\nexport const BASE_URL_FOR_BRANDING = isLiveEnv ? 'https://zippyapi.paymenture.com' : 'https://zippyapistage.paymenture.com' ;\r\nexport const API_URL = `${BASE_URL}/api`;\r\nexport const API_URL_FOR_BRANDING = `${BASE_URL_FOR_BRANDING}/api`;\r\nexport const API_ENDPOINTS={\r\n ACCOUNT:{\r\n USERS:`${API_URL}/Account/users`,\r\n ROLES:`${API_URL}/Account/roles`,\r\n },\r\n AUTH:`${BASE_URL}/Token`,\r\n PERMISSIONS:{\r\n PAGES:`${API_URL}/api/Permissions/Pages`\r\n }\r\n}\r\n\r\nexport function objectToParams(object): string {\r\n // console.log(\"object\", object);\r\n function clean(obj) {\r\n for (let propName in obj) {\r\n if (obj[propName] === null || obj[propName] === undefined) {\r\n delete obj[propName];\r\n }\r\n }\r\n }\r\n clean(object);\r\n return Object.keys(object).map((key) => (typeof (object[key]) === \"object\") ?\r\n subObjectToParams(encodeURIComponent(key), object[key]) :\r\n `${encodeURIComponent(key)}=${encodeURIComponent(object[key])}`\r\n ).join('&');\r\n}\r\n\r\nfunction subObjectToParams(key, object): string {\r\n return Object.keys(object).map((childKey) => (typeof (object[childKey]) === \"object\") ?\r\n subObjectToParams(`${key}[${encodeURIComponent(childKey)}]`, object[childKey]) :\r\n `${key}[${encodeURIComponent(childKey)}]=${encodeURIComponent(object[childKey])}`\r\n ).join('&');\r\n}","export class AcademyFakeDb\r\n{\r\n public static courses = [\r\n {\r\n 'id' : '15459251a6d6b397565',\r\n 'title' : 'Basics of Angular',\r\n 'slug' : 'basics-of-angular',\r\n 'category': 'web',\r\n 'length' : 30,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '154588a0864d2881124',\r\n 'title' : 'Basics of TypeScript',\r\n 'slug' : 'basics-of-typeScript',\r\n 'category': 'web',\r\n 'length' : 60,\r\n 'updated' : 'Nov 01, 2017'\r\n },\r\n {\r\n 'id' : '15453ba60d3baa5daaf',\r\n 'title' : 'Android N: Quick Settings',\r\n 'slug' : 'android-n-quick-settings',\r\n 'category': 'android',\r\n 'length' : 120,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '15453a06c08fb021776',\r\n 'title' : 'Keep Sensitive Data Safe and Private',\r\n 'slug' : 'keep-sensitive-data-safe-and-private',\r\n 'category': 'android',\r\n 'length' : 45,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '15427f4c1b7f3953234',\r\n 'title' : 'Building a gRPC Service with Java',\r\n 'slug' : 'building-a-grpc-service-with-java',\r\n 'category': 'cloud',\r\n 'length' : 30,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '1542d75d929a603125',\r\n 'title' : 'Build a PWA Using Workbox',\r\n 'slug' : 'build-a-pwa-using-workbox',\r\n 'category': 'web',\r\n 'length' : 120,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '1543ee3a5b43e0f9f45',\r\n 'title' : 'Build an App for the Google Assistant with Firebase and Dialogflow',\r\n 'slug' : 'build-an-app-for-the-google-assistant-with-firebase-and-dialogflow',\r\n 'category': 'firebase',\r\n 'length' : 30,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '1543cc4515df3146112',\r\n 'title' : 'Cloud Functions for Firebase',\r\n 'slug' : 'cloud-functions-for-firebase',\r\n 'category': 'firebase',\r\n 'length' : 45,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '154398a4770d7aaf9a2',\r\n 'title' : 'Manage Your Pivotal Cloud Foundry App\\'s Using Apigee Edge',\r\n 'slug' : 'manage-your-pivotal-cloud-foundry-apps-using-apigee-Edge',\r\n 'category': 'cloud',\r\n 'length' : 90,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '15438351f87dcd68567',\r\n 'title' : 'Building Beautiful UIs with Flutter',\r\n 'your' : 'building-beautiful-uis-with-flutter',\r\n 'category': 'web',\r\n 'length' : 90,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '1544e43dcdae6ebf876',\r\n 'title' : 'Cloud Firestore',\r\n 'slug' : 'cloud-firestore',\r\n 'category': 'firebase',\r\n 'length' : 90,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '1541ca7af66da284177',\r\n 'title' : 'Customize Network Topology with Subnetworks',\r\n 'slug' : 'customize-network-topology-with-subnetworks',\r\n 'category': 'web',\r\n 'length' : 45,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '154297167e781781745',\r\n 'title' : 'Looking at Campaign Finance with BigQuery',\r\n 'slug' : 'looking-at-campaign-finance-with-bigquery',\r\n 'category': 'cloud',\r\n 'length' : 60,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '154537435d5b32bf11a',\r\n 'title' : 'Firebase Android',\r\n 'slug' : 'firebase-android',\r\n 'category': 'android',\r\n 'length' : 45,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '154204e45a59b168453',\r\n 'title' : 'Simulating a Thread Network Using OpenThread',\r\n 'slug' : 'simulating-a-thread-network-using-openthread',\r\n 'category': 'web',\r\n 'length' : 45,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '1541dd1e05dfc439216',\r\n 'title' : 'Your First Progressive Web App',\r\n 'slug' : 'your-first-progressive-web-app',\r\n 'category': 'web',\r\n 'length' : 30,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '1532dfc67e704e48515',\r\n 'title' : 'Launch Cloud Datalab',\r\n 'slug' : 'launch-cloud-datalab',\r\n 'category': 'cloud',\r\n 'length' : 60,\r\n 'updated' : 'Jun 28, 2017'\r\n },\r\n {\r\n 'id' : '1542e43dfaae6ebf226',\r\n 'title' : 'Personalize Your iOS App with Firebase User Management',\r\n 'slug' : 'personalize-your-ios-app-with-firebase-user-management',\r\n 'category': 'firebase',\r\n 'length' : 90,\r\n 'updated' : 'Jun 28, 2017'\r\n }\r\n ];\r\n\r\n public static categories = [\r\n {\r\n 'id' : 0,\r\n 'value': 'web',\r\n 'label': 'Web'\r\n },\r\n {\r\n 'id' : 1,\r\n 'value': 'firebase',\r\n 'label': 'Firebase'\r\n },\r\n {\r\n 'id' : 2,\r\n 'value': 'cloud',\r\n 'label': 'Cloud'\r\n },\r\n {\r\n 'id' : 3,\r\n 'value': 'android',\r\n 'label': 'Android'\r\n }\r\n ];\r\n\r\n private static demoSteps = [\r\n {\r\n 'title' : 'Introduction',\r\n 'content': '

Step 1 - Introduction

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'Get the sample code',\r\n 'content': '

Step 2 - Get the sample code

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'Create a Firebase project and Set up your app',\r\n 'content': '

Step 3 - Create a Firebase project and Set up your app

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'Install the Firebase Command Line Interface',\r\n 'content': '

Step 4 - Install the Firebase Command Line Interface

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'Deploy and run the web app',\r\n 'content': '

Step 5 - Deploy and run the web app

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'The Functions Directory',\r\n 'content': '

Step 6 - The Functions Directory

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'Import the Cloud Functions and Firebase Admin modules',\r\n 'content': '

Step 7 - Import the Cloud Functions and Firebase Admin modules

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'Welcome New Users',\r\n 'content': '

Step 8 - Welcome New Users

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'Images moderation',\r\n 'content': '

Step 9 - Images moderation

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'New Message Notifications',\r\n 'content': '

Step 10 - New Message Notifications

' +\r\n '
' +\r\n 'This is an example step of the course. You can put anything in here from example codes to videos.' +\r\n '

' +\r\n 'To install the CLI you need to have installed npm which typically comes with NodeJS.' +\r\n 'To install or upgrade the CLI run the following npm command:' +\r\n '

' +\r\n 'npm -g install @angular/cli' +\r\n '

' +\r\n 'To verify that the CLI has been installed correctly, open a console and run:' +\r\n '

' +\r\n 'ng version' +\r\n '

' +\r\n '

Install dependencies

' +\r\n '
' +\r\n 'To moderate the images we\\'ll need a few Node.js packages:' +\r\n '

' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Vision Client Library for Node.js: @google-cloud/vision to run the image through the Cloud Vision API to detect inappropriate images.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'The Google Cloud Storage Client Library for Node.js: @google-cloud/storage to download and upload the images from Cloud Storage.' +\r\n '
  • ' +\r\n '
    ' +\r\n '
  • ' +\r\n 'A Node.js library allowing us to run processes: child-process-promise to run ImageMagick since the ImageMagick command-line tool comes pre-installed on all Functions instances.' +\r\n '
  • ' +\r\n '
' +\r\n '
' +\r\n 'To install these three packages into your Cloud Functions app, run the following npm install --save command. Make sure that you do this from the functions directory.' +\r\n '

' +\r\n 'npm install --save @google-cloud/vision @google-cloud/storage child-process-promise' +\r\n '

' +\r\n 'This will install the three packages locally and add them as declared dependencies in your package.js file.'\r\n },\r\n {\r\n 'title' : 'Congratulations!',\r\n 'content': '

Step 11 - Congratulations!

' +\r\n '
' +\r\n 'You\\'ve built a full-fidelity, offline-capable progressive web app by leveraging the power of reusable Web Components and Firebase. Why bother with a native app when you know how to do all that?!'\r\n }\r\n ];\r\n\r\n public static course = [\r\n {\r\n 'id' : '15459251a6d6b397565',\r\n 'title' : 'Basics of Angular',\r\n 'slug' : 'basics-of-angular',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'web',\r\n 'length' : 30,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '154588a0864d2881124',\r\n 'title' : 'Basics of TypeScript',\r\n 'slug' : 'basics-of-typeScript',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'web',\r\n 'length' : 60,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Nov 01, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '15453ba60d3baa5daaf',\r\n 'title' : 'Android N: Quick Settings',\r\n 'slug' : 'android-n-quick-settings',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'android',\r\n 'length' : 120,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '15453a06c08fb021776',\r\n 'title' : 'Keep Sensitive Data Safe and Private',\r\n 'slug' : 'keep-sensitive-data-safe-and-private',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'android',\r\n 'length' : 45,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '15427f4c1b7f3953234',\r\n 'title' : 'Building a gRPC Service with Java',\r\n 'slug' : 'building-a-grpc-service-with-java',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'cloud',\r\n 'length' : 30,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '1542d75d929a603125',\r\n 'title' : 'Build a PWA Using Workbox',\r\n 'slug' : 'build-a-pwa-using-workbox',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'web',\r\n 'length' : 120,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '1543ee3a5b43e0f9f45',\r\n 'title' : 'Build an App for the Google Assistant with Firebase and Dialogflow',\r\n 'slug' : 'build-an-app-for-the-google-assistant-with-firebase-and-dialogflow',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'firebase',\r\n 'length' : 30,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '1543cc4515df3146112',\r\n 'title' : 'Cloud Functions for Firebase',\r\n 'slug' : 'cloud-functions-for-firebase',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'firebase',\r\n 'length' : 45,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '154398a4770d7aaf9a2',\r\n 'title' : 'Manage Your Pivotal Cloud Foundry App\\'s Using Apigee Edge',\r\n 'slug' : 'manage-your-pivotal-cloud-foundry-apps-using-apigee-Edge',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'cloud',\r\n 'length' : 90,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '15438351f87dcd68567',\r\n 'title' : 'Building Beautiful UIs with Flutter',\r\n 'your' : 'building-beautiful-uis-with-flutter',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'web',\r\n 'length' : 90,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '1544e43dcdae6ebf876',\r\n 'title' : 'Cloud Firestore',\r\n 'slug' : 'cloud-firestore',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'firebase',\r\n 'length' : 90,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '1541ca7af66da284177',\r\n 'title' : 'Customize Network Topology with Subnetworks',\r\n 'slug' : 'customize-network-topology-with-subnetworks',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'web',\r\n 'length' : 45,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '154297167e781781745',\r\n 'title' : 'Looking at Campaign Finance with BigQuery',\r\n 'slug' : 'looking-at-campaign-finance-with-bigquery',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'cloud',\r\n 'length' : 60,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '154537435d5b32bf11a',\r\n 'title' : 'Firebase Android',\r\n 'slug' : 'firebase-android',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'android',\r\n 'length' : 45,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '154204e45a59b168453',\r\n 'title' : 'Simulating a Thread Network Using OpenThread',\r\n 'slug' : 'simulating-a-thread-network-using-openthread',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'web',\r\n 'length' : 45,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '1541dd1e05dfc439216',\r\n 'title' : 'Your First Progressive Web App',\r\n 'slug' : 'your-first-progressive-web-app',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'web',\r\n 'length' : 30,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '1532dfc67e704e48515',\r\n 'title' : 'Launch Cloud Datalab',\r\n 'slug' : 'launch-cloud-datalab',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'cloud',\r\n 'length' : 60,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n },\r\n {\r\n 'id' : '1542e43dfaae6ebf226',\r\n 'title' : 'Personalize Your iOS App with Firebase User Management',\r\n 'slug' : 'personalize-your-ios-app-with-firebase-user-management',\r\n 'description': 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'category' : 'firebase',\r\n 'length' : 90,\r\n 'totalSteps' : 11,\r\n 'updated' : 'Jun 28, 2017',\r\n 'steps' : AcademyFakeDb.demoSteps\r\n }\r\n ];\r\n\r\n}\r\n","import {\r\n startOfDay,\r\n endOfDay,\r\n subDays,\r\n addDays,\r\n endOfMonth,\r\n isSameDay,\r\n isSameMonth,\r\n addHours\r\n} from 'date-fns';\r\n\r\nexport class CalendarFakeDb\r\n{\r\n\r\n public static data = [\r\n {\r\n id : 'events',\r\n data: [\r\n {\r\n start : subDays(startOfDay(new Date()), 1),\r\n end : addDays(new Date(), 1),\r\n title : 'A 3 day event',\r\n allDay : true,\r\n color : {\r\n primary : '#F44336',\r\n secondary: '#FFCDD2'\r\n },\r\n resizable: {\r\n beforeStart: true,\r\n afterEnd : true\r\n },\r\n draggable: true,\r\n meta : {\r\n location: 'Los Angeles',\r\n notes : 'Eos eu verear adipiscing, ex ornatus denique iracundia sed, quodsi oportere appellantur an pri.'\r\n }\r\n },\r\n {\r\n start : startOfDay(new Date()),\r\n title : 'An event with no end date',\r\n allDay : false,\r\n color : {\r\n primary : '#FF9800',\r\n secondary: '#FFE0B2'\r\n },\r\n resizable: {\r\n beforeStart: true,\r\n afterEnd : true\r\n },\r\n draggable: true,\r\n meta : {\r\n location: 'Los Angeles',\r\n notes : 'Eos eu verear adipiscing, ex ornatus denique iracundia sed, quodsi oportere appellantur an pri.'\r\n }\r\n },\r\n {\r\n start : subDays(endOfMonth(new Date()), 3),\r\n end : addDays(endOfMonth(new Date()), 3),\r\n title : 'A long event that spans 2 months',\r\n allDay : false,\r\n color : {\r\n primary : '#1E90FF',\r\n secondary: '#D1E8FF'\r\n },\r\n resizable: {\r\n beforeStart: true,\r\n afterEnd : true\r\n },\r\n draggable: true,\r\n meta : {\r\n location: 'Los Angeles',\r\n notes : 'Eos eu verear adipiscing, ex ornatus denique iracundia sed, quodsi oportere appellantur an pri.'\r\n }\r\n },\r\n {\r\n start : addHours(startOfDay(new Date()), 2),\r\n end : new Date(),\r\n title : 'A draggable and resizable event',\r\n allDay : false,\r\n color : {\r\n primary : '#673AB7',\r\n secondary: '#D1C4E9'\r\n },\r\n resizable: {\r\n beforeStart: true,\r\n afterEnd : true\r\n },\r\n draggable: true,\r\n meta : {\r\n location: 'Los Angeles',\r\n notes : 'Eos eu verear adipiscing, ex ornatus denique iracundia sed, quodsi oportere appellantur an pri.'\r\n }\r\n }\r\n ]\r\n }\r\n ];\r\n}\r\n","export class ChatPanelFakeDb\r\n{\r\n public static contacts = [\r\n {\r\n 'id' : '5725a680b3249760ea21de52',\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...',\r\n 'unread': '2'\r\n },\r\n {\r\n 'id' : '5725a680606588342058356d',\r\n 'name' : 'Arnold',\r\n 'avatar': 'assets/images/avatars/Arnold.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a68009e20d0a9e9acf2a',\r\n 'name' : 'Barrera',\r\n 'avatar': 'assets/images/avatars/Barrera.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a6809fdd915739187ed5',\r\n 'name' : 'Blair',\r\n 'avatar': 'assets/images/avatars/Blair.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...',\r\n 'unread': '3'\r\n },\r\n {\r\n 'id' : '5725a68007920cf75051da64',\r\n 'name' : 'Boyle',\r\n 'avatar': 'assets/images/avatars/Boyle.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...',\r\n 'unread': '1'\r\n },\r\n {\r\n 'id' : '5725a68031fdbb1db2c1af47',\r\n 'name' : 'Christy',\r\n 'avatar': 'assets/images/avatars/Christy.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680bc670af746c435e2',\r\n 'name' : 'Copeland',\r\n 'avatar': 'assets/images/avatars/Copeland.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680e7eb988a58ddf303',\r\n 'name' : 'Estes',\r\n 'avatar': 'assets/images/avatars/Estes.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680dcb077889f758961',\r\n 'name' : 'Harper',\r\n 'avatar': 'assets/images/avatars/Harper.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a6806acf030f9341e925',\r\n 'name' : 'Helen',\r\n 'avatar': 'assets/images/avatars/Helen.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680ae1ae9a3c960d487',\r\n 'name' : 'Henderson',\r\n 'avatar': 'assets/images/avatars/Henderson.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680b8d240c011dd224b',\r\n 'name' : 'Josefina',\r\n 'avatar': 'assets/images/avatars/Josefina.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a68034cb3968e1f79eac',\r\n 'name' : 'Katina',\r\n 'avatar': 'assets/images/avatars/Katina.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a6801146cce777df2a08',\r\n 'name' : 'Lily',\r\n 'avatar': 'assets/images/avatars/Lily.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...',\r\n 'unread': '10'\r\n },\r\n {\r\n 'id' : '5725a6808a178bfd034d6ecf',\r\n 'name' : 'Mai',\r\n 'avatar': 'assets/images/avatars/Mai.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680653c265f5c79b5a9',\r\n 'name' : 'Nancy',\r\n 'avatar': 'assets/images/avatars/Nancy.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680bbcec3cc32a8488a',\r\n 'name' : 'Nora',\r\n 'avatar': 'assets/images/avatars/Nora.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...',\r\n 'unread': '7'\r\n },\r\n {\r\n 'id' : '5725a6803d87f1b77e17b62b',\r\n 'name' : 'Odessa',\r\n 'avatar': 'assets/images/avatars/Odessa.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...',\r\n 'unread': '1'\r\n },\r\n {\r\n 'id' : '5725a680e87cb319bd9bd673',\r\n 'name' : 'Reyna',\r\n 'avatar': 'assets/images/avatars/Reyna.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a6802d10e277a0f35775',\r\n 'name' : 'Shauna',\r\n 'avatar': 'assets/images/avatars/Shauna.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680aef1e5cf26dd3d1f',\r\n 'name' : 'Shepard',\r\n 'avatar': 'assets/images/avatars/Shepard.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a680cd7efa56a45aea5d',\r\n 'name' : 'Tillman',\r\n 'avatar': 'assets/images/avatars/Tillman.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : '',\r\n 'unread': '99+'\r\n },\r\n {\r\n 'id' : '5725a680fb65c91a82cb35e2',\r\n 'name' : 'Trevino',\r\n 'avatar': 'assets/images/avatars/Trevino.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a68018c663044be49cbf',\r\n 'name' : 'Tyson',\r\n 'avatar': 'assets/images/avatars/Tyson.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n },\r\n {\r\n 'id' : '5725a6809413bf8a0a5272b1',\r\n 'name' : 'Velazquez',\r\n 'avatar': 'assets/images/avatars/Velazquez.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit...'\r\n }\r\n ];\r\n\r\n public static chats = [\r\n {\r\n 'id' : '1725a680b3249760ea21de52',\r\n 'dialog': [\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'Quickly come to the meeting room 1B, we have a big server issue',\r\n 'time' : '2017-03-22T08:54:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'I’m having breakfast right now, can’t you wait for 10 minutes?',\r\n 'time' : '2017-03-22T08:55:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'I’m having breakfast right now, can’t you wait for 10 minutes?',\r\n 'time' : '2017-03-22T08:55:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:00:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'It’s not my money, you know. I will eat my breakfast and then I will come to the meeting room.',\r\n 'time' : '2017-03-22T09:02:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T09:05:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:15:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T09:05:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:15:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'It’s not my money, you know. I will eat my breakfast and then I will come to the meeting room.',\r\n 'time' : '2017-03-22T09:20:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T09:22:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:25:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'It’s not my money, you know. I will eat my breakfast and then I will come to the meeting room.',\r\n 'time' : '2017-03-22T09:27:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T09:33:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T09:33:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:35:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'It’s not my money, you know. I will eat my breakfast and then I will come to the meeting room.',\r\n 'time' : '2017-03-22T09:45:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T10:00:28.299Z'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : '2725a680b8d240c011dd2243',\r\n 'dialog': [\r\n {\r\n 'who' : '5725a680606588342058356d',\r\n 'message': 'Quickly come to the meeting room 1B, we have a big server issue',\r\n 'time' : '2017-04-22T01:00:00.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'I’m having breakfast right now, can’t you wait for 10 minutes?',\r\n 'time' : '2017-04-22T01:05:00.299Z'\r\n },\r\n {\r\n 'who' : '5725a680606588342058356d',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-04-22T01:10:00.299Z'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : '3725a6809413bf8a0a5272b4',\r\n 'dialog': [\r\n {\r\n 'who' : '5725a68009e20d0a9e9acf2a',\r\n 'message': 'Quickly come to the meeting room 1B, we have a big server issue',\r\n 'time' : '2017-04-22T02:10:00.299Z'\r\n }\r\n ]\r\n }\r\n ];\r\n\r\n public static user = [\r\n {\r\n 'id' : '5725a6802d10e277a0f35724',\r\n 'name' : 'John Doe',\r\n 'avatar' : 'assets/images/avatars/profile.jpg',\r\n 'status' : 'online',\r\n 'mood' : '',\r\n 'chatList': [\r\n {\r\n 'chatId' : '1725a680b3249760ea21de52',\r\n 'contactId' : '5725a680b3249760ea21de52',\r\n 'lastMessageTime': '2017-06-12T02:10:18.931Z'\r\n },\r\n {\r\n 'chatId' : '2725a680b8d240c011dd2243',\r\n 'contactId' : '5725a680606588342058356d',\r\n 'lastMessageTime': '2017-02-18T10:30:18.931Z'\r\n },\r\n {\r\n 'chatId' : '3725a6809413bf8a0a5272b4',\r\n 'contactId' : '5725a68009e20d0a9e9acf2a',\r\n 'lastMessageTime': '2017-03-18T12:30:18.931Z'\r\n }\r\n ]\r\n }\r\n ];\r\n\r\n}\r\n","export class ChatFakeDb\r\n{\r\n public static contacts = [\r\n {\r\n 'id' : '5725a680b3249760ea21de52',\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680606588342058356d',\r\n 'name' : 'Arnold',\r\n 'avatar': 'assets/images/avatars/Arnold.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a68009e20d0a9e9acf2a',\r\n 'name' : 'Barrera',\r\n 'avatar': 'assets/images/avatars/Barrera.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'unread': null\r\n },\r\n {\r\n 'id' : '5725a6809fdd915739187ed5',\r\n 'name' : 'Blair',\r\n 'avatar': 'assets/images/avatars/Blair.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'unread': 3\r\n },\r\n {\r\n 'id' : '5725a68007920cf75051da64',\r\n 'name' : 'Boyle',\r\n 'avatar': 'assets/images/avatars/Boyle.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a68031fdbb1db2c1af47',\r\n 'name' : 'Christy',\r\n 'avatar': 'assets/images/avatars/Christy.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680bc670af746c435e2',\r\n 'name' : 'Copeland',\r\n 'avatar': 'assets/images/avatars/Copeland.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680e7eb988a58ddf303',\r\n 'name' : 'Estes',\r\n 'avatar': 'assets/images/avatars/Estes.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680dcb077889f758961',\r\n 'name' : 'Harper',\r\n 'avatar': 'assets/images/avatars/Harper.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a6806acf030f9341e925',\r\n 'name' : 'Helen',\r\n 'avatar': 'assets/images/avatars/Helen.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680ae1ae9a3c960d487',\r\n 'name' : 'Henderson',\r\n 'avatar': 'assets/images/avatars/Henderson.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680b8d240c011dd224b',\r\n 'name' : 'Josefina',\r\n 'avatar': 'assets/images/avatars/Josefina.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a68034cb3968e1f79eac',\r\n 'name' : 'Katina',\r\n 'avatar': 'assets/images/avatars/Katina.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a6801146cce777df2a08',\r\n 'name' : 'Lily',\r\n 'avatar': 'assets/images/avatars/Lily.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a6808a178bfd034d6ecf',\r\n 'name' : 'Mai',\r\n 'avatar': 'assets/images/avatars/Mai.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680653c265f5c79b5a9',\r\n 'name' : 'Nancy',\r\n 'avatar': 'assets/images/avatars/Nancy.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680bbcec3cc32a8488a',\r\n 'name' : 'Nora',\r\n 'avatar': 'assets/images/avatars/Nora.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a6803d87f1b77e17b62b',\r\n 'name' : 'Odessa',\r\n 'avatar': 'assets/images/avatars/Odessa.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680e87cb319bd9bd673',\r\n 'name' : 'Reyna',\r\n 'avatar': 'assets/images/avatars/Reyna.jpg',\r\n 'status': 'offline',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a6802d10e277a0f35775',\r\n 'name' : 'Shauna',\r\n 'avatar': 'assets/images/avatars/Shauna.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'unread': null\r\n },\r\n {\r\n 'id' : '5725a680aef1e5cf26dd3d1f',\r\n 'name' : 'Shepard',\r\n 'avatar': 'assets/images/avatars/Shepard.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a680cd7efa56a45aea5d',\r\n 'name' : 'Tillman',\r\n 'avatar': 'assets/images/avatars/Tillman.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : ''\r\n },\r\n {\r\n 'id' : '5725a680fb65c91a82cb35e2',\r\n 'name' : 'Trevino',\r\n 'avatar': 'assets/images/avatars/Trevino.jpg',\r\n 'status': 'away',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a68018c663044be49cbf',\r\n 'name' : 'Tyson',\r\n 'avatar': 'assets/images/avatars/Tyson.jpg',\r\n 'status': 'do-not-disturb',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n },\r\n {\r\n 'id' : '5725a6809413bf8a0a5272b1',\r\n 'name' : 'Velazquez',\r\n 'avatar': 'assets/images/avatars/Velazquez.jpg',\r\n 'status': 'online',\r\n 'mood' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\r\n }\r\n ];\r\n\r\n public static chats = [\r\n {\r\n 'id' : '1725a680b3249760ea21de52',\r\n 'dialog': [\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'Quickly come to the meeting room 1B, we have a big server issue',\r\n 'time' : '2017-03-22T08:54:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'I’m having breakfast right now, can’t you wait for 10 minutes?',\r\n 'time' : '2017-03-22T08:55:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:00:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'It’s not my money, you know. I will eat my breakfast and then I will come to the meeting room.',\r\n 'time' : '2017-03-22T09:02:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T09:05:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:15:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'It’s not my money, you know. I will eat my breakfast and then I will come to the meeting room.',\r\n 'time' : '2017-03-22T09:20:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T09:22:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:25:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'It’s not my money, you know. I will eat my breakfast and then I will come to the meeting room.',\r\n 'time' : '2017-03-22T09:27:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T09:33:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-03-22T09:35:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'It’s not my money, you know. I will eat my breakfast and then I will come to the meeting room.',\r\n 'time' : '2017-03-22T09:45:28.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b3249760ea21de52',\r\n 'message': 'You are the worst!',\r\n 'time' : '2017-03-22T10:00:28.299Z'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : '2725a680b8d240c011dd2243',\r\n 'dialog': [\r\n {\r\n 'who' : '5725a680b8d240c011dd224b',\r\n 'message': 'Quickly come to the meeting room 1B, we have a big server issue',\r\n 'time' : '2017-04-22T01:00:00.299Z'\r\n },\r\n {\r\n 'who' : '5725a6802d10e277a0f35724',\r\n 'message': 'I’m having breakfast right now, can’t you wait for 10 minutes?',\r\n 'time' : '2017-04-22T01:05:00.299Z'\r\n },\r\n {\r\n 'who' : '5725a680b8d240c011dd224b',\r\n 'message': 'We are losing money! Quick!',\r\n 'time' : '2017-04-22T01:10:00.299Z'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : '3725a6809413bf8a0a5272b4',\r\n 'dialog': [\r\n {\r\n 'who' : '5725a6809413bf8a0a5272b1',\r\n 'message': 'Quickly come to the meeting room 1B, we have a big server issue',\r\n 'time' : '2017-04-22T02:10:00.299Z'\r\n }\r\n ]\r\n }\r\n ];\r\n\r\n public static user = [\r\n {\r\n 'id' : '5725a6802d10e277a0f35724',\r\n 'name' : 'John Doe',\r\n 'avatar' : 'assets/images/avatars/profile.jpg',\r\n 'status' : 'online',\r\n 'mood' : 'it\\'s a status....not your diary...',\r\n 'chatList': [\r\n {\r\n 'id' : '1725a680b3249760ea21de52',\r\n 'contactId' : '5725a680b3249760ea21de52',\r\n 'name' : 'Alice Freeman',\r\n 'unread' : 4,\r\n 'lastMessage' : 'You are the worst!',\r\n 'lastMessageTime': '2017-06-12T02:10:18.931Z'\r\n },\r\n {\r\n 'id' : '2725a680b8d240c011dd2243',\r\n 'contactId' : '5725a680b8d240c011dd224b',\r\n 'name' : 'Josefina',\r\n 'unread' : null,\r\n 'lastMessage' : 'We are losing money! Quick!',\r\n 'lastMessageTime': '2017-02-18T10:30:18.931Z'\r\n },\r\n {\r\n 'id' : '3725a6809413bf8a0a5272b4',\r\n 'contactId' : '5725a6809413bf8a0a5272b1',\r\n 'name' : 'Velazquez',\r\n 'unread' : 2,\r\n 'lastMessage' : 'Quickly come to the meeting room 1B, we have a big server issue',\r\n 'lastMessageTime': '2017-03-18T12:30:18.931Z'\r\n }\r\n ]\r\n }\r\n ];\r\n\r\n}\r\n","export class ContactsFakeDb\r\n{\r\n public static contacts = [\r\n {\r\n 'id' : '5725a680b3249760ea21de52',\r\n 'name' : 'Abbott',\r\n 'lastName': 'Keitch',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'nickname': 'Royalguard',\r\n 'company' : 'Saois',\r\n 'jobTitle': 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'address' : '933 8th Street Stamford, CT 06902',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680606588342058356d',\r\n 'name' : 'Arnold',\r\n 'lastName': 'Matlock',\r\n 'avatar' : 'assets/images/avatars/Arnold.jpg',\r\n 'nickname': 'Wanderer',\r\n 'company' : 'Laotcone',\r\n 'jobTitle': 'Graphic Artist',\r\n 'email' : 'arnold@withinpixels.com',\r\n 'phone' : '+1-202-555-0141',\r\n 'address' : '906 Valley Road Michigan City, IN 46360',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a68009e20d0a9e9acf2a',\r\n 'name' : 'Barrera',\r\n 'lastName': 'Bradbury',\r\n 'avatar' : 'assets/images/avatars/Barrera.jpg',\r\n 'nickname': 'Jackal',\r\n 'company' : 'Unizim',\r\n 'jobTitle': 'Graphic Designer',\r\n 'email' : 'barrera@withinpixels.com',\r\n 'phone' : '+1-202-555-0196',\r\n 'address' : '183 River Street Passaic, NJ 07055',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a6809fdd915739187ed5',\r\n 'name' : 'Blair',\r\n 'lastName': 'Strangeway',\r\n 'avatar' : 'assets/images/avatars/Blair.jpg',\r\n 'nickname': 'Knight',\r\n 'company' : 'Conedubdax',\r\n 'jobTitle': 'Visual Designer',\r\n 'email' : 'blair@withinpixels.com',\r\n 'phone' : '+1-202-555-0118',\r\n 'address' : '143 Jones Street Eau Claire, WI 54701',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a68007920cf75051da64',\r\n 'name' : 'Boyle',\r\n 'lastName': 'Winters',\r\n 'avatar' : 'assets/images/avatars/Boyle.jpg',\r\n 'nickname': 'Jester',\r\n 'company' : 'Newo',\r\n 'jobTitle': 'Catalogue Illustrator',\r\n 'email' : 'boyle@withinpixels.com',\r\n 'phone' : '+1-202-555-0177',\r\n 'address' : '218 Pearl Street Brandon, FL 33510',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a68031fdbb1db2c1af47',\r\n 'name' : 'Christy',\r\n 'lastName': 'Camacho',\r\n 'avatar' : 'assets/images/avatars/Christy.jpg',\r\n 'nickname': 'Mist',\r\n 'company' : 'uniway',\r\n 'jobTitle': '3D Animator',\r\n 'email' : 'christy@withinpixels.com',\r\n 'phone' : '+1-202-555-0136',\r\n 'address' : '329 Bridge Street Desoto, TX 75115',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680bc670af746c435e2',\r\n 'name' : 'Copeland',\r\n 'lastName': 'Redcliff',\r\n 'avatar' : 'assets/images/avatars/Copeland.jpg',\r\n 'nickname': 'Cloudlaw',\r\n 'company' : 'Tempron',\r\n 'jobTitle': 'Multimedia Artist',\r\n 'email' : 'copeland@withinpixels.com',\r\n 'phone' : '+1-202-555-0107',\r\n 'address' : '956 6th Avenue North Bergen, NJ 0704',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680e7eb988a58ddf303',\r\n 'name' : 'Estes',\r\n 'lastName': 'Stevens',\r\n 'avatar' : 'assets/images/avatars/Estes.jpg',\r\n 'nickname': 'Roamer',\r\n 'company' : 'nam-dex',\r\n 'jobTitle': 'Special Effects Artist',\r\n 'email' : 'estes@withinpixels.com',\r\n 'phone' : '+1-202-555-0113',\r\n 'address' : '664 York Street Cambridge, MA 02138',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680dcb077889f758961',\r\n 'name' : 'Harper',\r\n 'lastName': 'MacGuffin',\r\n 'avatar' : 'assets/images/avatars/Harper.jpg',\r\n 'nickname': 'Tempest',\r\n 'company' : 'runcane',\r\n 'jobTitle': 'Application Developer',\r\n 'email' : 'harper@withinpixels.com',\r\n 'phone' : '+1-202-555-0173',\r\n 'address' : '738 Route 11 Cornelius, NC 28031',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a6806acf030f9341e925',\r\n 'name' : 'Helen',\r\n 'lastName': 'Sheridan',\r\n 'avatar' : 'assets/images/avatars/Helen.jpg',\r\n 'nickname': 'Magicbattler',\r\n 'company' : 'Subhow',\r\n 'jobTitle': 'Content Developer',\r\n 'email' : 'helen@withinpixels.com',\r\n 'phone' : '+1-202-555-0163',\r\n 'address' : '194 Washington Avenue Saint Petersburg, FL 33702',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680ae1ae9a3c960d487',\r\n 'name' : 'Henderson',\r\n 'lastName': 'Cambias',\r\n 'avatar' : 'assets/images/avatars/Henderson.jpg',\r\n 'nickname': 'Blizzard',\r\n 'company' : 'Howcom',\r\n 'jobTitle': 'Web Designer',\r\n 'email' : 'henderson@withinpixels.com',\r\n 'phone' : '+1-202-555-0151',\r\n 'address' : '686 Roosevelt Avenue Oviedo, FL 32765',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680b8d240c011dd224b',\r\n 'name' : 'Josefina',\r\n 'lastName': 'Lakefield',\r\n 'avatar' : 'assets/images/avatars/Josefina.jpg',\r\n 'nickname': 'Violet',\r\n 'company' : 'Gecko',\r\n 'jobTitle': 'Web Developer',\r\n 'email' : 'josefina@withinpixels.com',\r\n 'phone' : '+1-202-555-0160',\r\n 'address' : '202 Hartford Road Lynchburg, VA 24502',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a68034cb3968e1f79eac',\r\n 'name' : 'Katina',\r\n 'lastName': 'Bletchley',\r\n 'avatar' : 'assets/images/avatars/Katina.jpg',\r\n 'nickname': 'Rose',\r\n 'company' : 'Lexicom',\r\n 'jobTitle': 'Software Designer',\r\n 'email' : 'katina@withinpixels.com',\r\n 'phone' : '+1-202-555-0186',\r\n 'address' : '219 Woodland Road Valrico, FL 33594',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a6801146cce777df2a08',\r\n 'name' : 'Lily',\r\n 'lastName': 'Peasegood',\r\n 'avatar' : 'assets/images/avatars/Lily.jpg',\r\n 'nickname': 'Star',\r\n 'company' : 'zooflex',\r\n 'jobTitle': 'Software Specialist',\r\n 'email' : 'lily@withinpixels.com',\r\n 'phone' : '+1-202-555-0115',\r\n 'address' : '305 Willow Drive Superior, WI 54880',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a6808a178bfd034d6ecf',\r\n 'name' : 'Mai',\r\n 'lastName': 'Nox',\r\n 'avatar' : 'assets/images/avatars/Mai.jpg',\r\n 'nickname': 'Violetmage',\r\n 'company' : 'quadzone',\r\n 'jobTitle': 'Software Engineer',\r\n 'email' : 'mai@withinpixels.com',\r\n 'phone' : '+1-202-555-0199',\r\n 'address' : '148 Heather Lane Mcminnville, TN 37110',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680653c265f5c79b5a9',\r\n 'name' : 'Nancy',\r\n 'lastName': 'Jaggers',\r\n 'avatar' : 'assets/images/avatars/Nancy.jpg',\r\n 'nickname': 'Silverwarden',\r\n 'company' : 'Opetamnix',\r\n 'jobTitle': 'Software Architect',\r\n 'email' : 'nancy@withinpixels.com',\r\n 'phone' : '+1-202-555-0120',\r\n 'address' : '345 Laurel Lane Union City, NJ 07087',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680bbcec3cc32a8488a',\r\n 'name' : 'Nora',\r\n 'lastName': 'Franklin',\r\n 'avatar' : 'assets/images/avatars/Nora.jpg',\r\n 'nickname': 'Katanachanter',\r\n 'company' : 'Saoway',\r\n 'jobTitle': 'Database Coordinator',\r\n 'email' : 'nora@withinpixels.com',\r\n 'phone' : '+1-202-555-0172',\r\n 'address' : '572 Rose Street Summerfield, FL 34491',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a6803d87f1b77e17b62b',\r\n 'name' : 'Odessa',\r\n 'lastName': 'Goodman',\r\n 'avatar' : 'assets/images/avatars/Odessa.jpg',\r\n 'nickname': 'Rose',\r\n 'company' : 'transace',\r\n 'jobTitle': 'Database Administration Manager',\r\n 'email' : 'odessa@withinpixels.com',\r\n 'phone' : '+1-202-555-0190',\r\n 'address' : '527 Jefferson Court Conyers, GA 30012',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680e87cb319bd9bd673',\r\n 'name' : 'Reyna',\r\n 'lastName': 'Preece',\r\n 'avatar' : 'assets/images/avatars/Reyna.jpg',\r\n 'nickname': 'Holydawn',\r\n 'company' : 'Dingex',\r\n 'jobTitle': 'Data Processing Planner',\r\n 'email' : 'reyna@withinpixels.com',\r\n 'phone' : '+1-202-555-0116',\r\n 'address' : '297 Strawberry Lane Faribault, MN 55021',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a6802d10e277a0f35775',\r\n 'name' : 'Shauna',\r\n 'lastName': 'Atherton',\r\n 'avatar' : 'assets/images/avatars/Shauna.jpg',\r\n 'nickname': 'Faunasoul',\r\n 'company' : 'Vivaflex',\r\n 'jobTitle': 'Art Director',\r\n 'email' : 'shauna@withinpixels.com',\r\n 'phone' : '+1-202-555-0159',\r\n 'address' : '928 Canterbury Court Pittsburgh, PA 15206',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680aef1e5cf26dd3d1f',\r\n 'name' : 'Shepard',\r\n 'lastName': 'Rosco',\r\n 'avatar' : 'assets/images/avatars/Shepard.jpg',\r\n 'nickname': 'Fireking',\r\n 'company' : 'Goldenla',\r\n 'jobTitle': 'Magazine Designer',\r\n 'email' : 'shepard@withinpixels.com',\r\n 'phone' : '+1-202-555-0173',\r\n 'address' : '904 Ridge Road Pickerington, OH 43147',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680cd7efa56a45aea5d',\r\n 'name' : 'Tillman',\r\n 'lastName': 'Lee',\r\n 'avatar' : 'assets/images/avatars/Tillman.jpg',\r\n 'nickname': 'Gust',\r\n 'company' : 'K-techno',\r\n 'jobTitle': 'News Photographer',\r\n 'email' : 'tillman@withinpixels.com',\r\n 'phone' : '+1-202-555-0183',\r\n 'address' : '447 Charles Street Dorchester, MA 02125',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a680fb65c91a82cb35e2',\r\n 'name' : 'Trevino',\r\n 'lastName': 'Bush',\r\n 'avatar' : 'assets/images/avatars/Trevino.jpg',\r\n 'nickname': 'Wolf',\r\n 'company' : 'Dalthex',\r\n 'jobTitle': 'Photojournalist',\r\n 'email' : 'trevino@withinpixels.com',\r\n 'phone' : '+1-202-555-0138',\r\n 'address' : '84 Valley View Road Norman, OK 73072',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a68018c663044be49cbf',\r\n 'name' : 'Tyson',\r\n 'lastName': 'Marshall',\r\n 'avatar' : 'assets/images/avatars/Tyson.jpg',\r\n 'nickname': 'Honordread',\r\n 'company' : 'Geocon',\r\n 'jobTitle': 'Manuscript Editor',\r\n 'email' : 'tyson@withinpixels.com',\r\n 'phone' : '+1-202-555-0146',\r\n 'address' : '204 Clark Street Monsey, NY 10952',\r\n 'birthday': '',\r\n 'notes' : ''\r\n },\r\n {\r\n 'id' : '5725a6809413bf8a0a5272b1',\r\n 'name' : 'Velazquez',\r\n 'lastName': 'Smethley',\r\n 'avatar' : 'assets/images/avatars/Velazquez.jpg',\r\n 'nickname': 'Strifedream',\r\n 'company' : 'ranex',\r\n 'jobTitle': 'Publications Editor',\r\n 'email' : 'velezquez@withinpixels.com',\r\n 'phone' : '+1-202-555-0146',\r\n 'address' : '261 Cleveland Street Riverside, NJ 08075',\r\n 'birthday': '',\r\n 'notes' : ''\r\n }\r\n ];\r\n\r\n public static user = [\r\n {\r\n 'id' : '5725a6802d10e277a0f35724',\r\n 'name' : 'John Doe',\r\n 'avatar' : 'assets/images/avatars/profile.jpg',\r\n 'starred' : [\r\n '5725a680ae1ae9a3c960d487',\r\n '5725a6801146cce777df2a08',\r\n '5725a680bbcec3cc32a8488a',\r\n '5725a680bc670af746c435e2',\r\n '5725a68009e20d0a9e9acf2a'\r\n ],\r\n 'frequentContacts': [\r\n '5725a6809fdd915739187ed5',\r\n '5725a68031fdbb1db2c1af47',\r\n '5725a680606588342058356d',\r\n '5725a680e7eb988a58ddf303',\r\n '5725a6806acf030f9341e925',\r\n '5725a68034cb3968e1f79eac',\r\n '5725a6801146cce777df2a08',\r\n '5725a680653c265f5c79b5a9'\r\n ],\r\n 'groups' : [\r\n {\r\n 'id' : '5725a6802d10e277a0f35739',\r\n 'name' : 'Friends',\r\n 'contactIds': [\r\n '5725a680bbcec3cc32a8488a',\r\n '5725a680e87cb319bd9bd673',\r\n '5725a6802d10e277a0f35775'\r\n ]\r\n },\r\n {\r\n 'id' : '5725a6802d10e277a0f35749',\r\n 'name' : 'Clients',\r\n 'contactIds': [\r\n '5725a680cd7efa56a45aea5d',\r\n '5725a68018c663044be49cbf',\r\n '5725a6809413bf8a0a5272b1',\r\n '5725a6803d87f1b77e17b62b'\r\n ]\r\n },\r\n {\r\n 'id' : '5725a6802d10e277a0f35329',\r\n 'name' : 'Recent Workers',\r\n 'contactIds': [\r\n '5725a680bbcec3cc32a8488a',\r\n '5725a680653c265f5c79b5a9',\r\n '5725a6808a178bfd034d6ecf',\r\n '5725a6801146cce777df2a08'\r\n ]\r\n }\r\n ]\r\n }\r\n ];\r\n}\r\n","export class AnalyticsDashboardDb\r\n{\r\n public static widgets = {\r\n widget1: {\r\n chartType: 'line',\r\n datasets : {\r\n '2016': [\r\n {\r\n label: 'Sales',\r\n data : [1.9, 3, 3.4, 2.2, 2.9, 3.9, 2.5, 3.8, 4.1, 3.8, 3.2, 2.9],\r\n fill : 'start'\r\n\r\n }\r\n ],\r\n '2017': [\r\n {\r\n label: 'Sales',\r\n data : [2.2, 2.9, 3.9, 2.5, 3.8, 3.2, 2.9, 1.9, 3, 3.4, 4.1, 3.8],\r\n fill : 'start'\r\n\r\n }\r\n ],\r\n '2018': [\r\n {\r\n label: 'Sales',\r\n data : [3.9, 2.5, 3.8, 4.1, 1.9, 3, 3.8, 3.2, 2.9, 3.4, 2.2, 2.9],\r\n fill : 'start'\r\n\r\n }\r\n ]\r\n\r\n },\r\n labels : ['JAN', 'FEB', 'MAR', 'APR', 'MAY', 'JUN', 'JUL', 'AUG', 'SEP', 'OCT', 'NOV', 'DEC'],\r\n colors : [\r\n {\r\n borderColor : '#42a5f5',\r\n backgroundColor : '#42a5f5',\r\n pointBackgroundColor : '#1e88e5',\r\n pointHoverBackgroundColor: '#1e88e5',\r\n pointBorderColor : '#ffffff',\r\n pointHoverBorderColor : '#ffffff'\r\n }\r\n ],\r\n options : {\r\n spanGaps : false,\r\n legend : {\r\n display: false\r\n },\r\n maintainAspectRatio: false,\r\n layout : {\r\n padding: {\r\n top : 32,\r\n left : 32,\r\n right: 32\r\n }\r\n },\r\n elements : {\r\n point: {\r\n radius : 4,\r\n borderWidth : 2,\r\n hoverRadius : 4,\r\n hoverBorderWidth: 2\r\n },\r\n line : {\r\n tension: 0\r\n }\r\n },\r\n scales : {\r\n xAxes: [\r\n {\r\n gridLines: {\r\n display : false,\r\n drawBorder : false,\r\n tickMarkLength: 18\r\n },\r\n ticks : {\r\n fontColor: '#ffffff'\r\n }\r\n }\r\n ],\r\n yAxes: [\r\n {\r\n display: false,\r\n ticks : {\r\n min : 1.5,\r\n max : 5,\r\n stepSize: 0.5\r\n }\r\n }\r\n ]\r\n },\r\n plugins : {\r\n filler : {\r\n propagate: false\r\n },\r\n xLabelsOnTop: {\r\n active: true\r\n }\r\n }\r\n }\r\n },\r\n widget2: {\r\n conversion: {\r\n value : 492,\r\n ofTarget: 13\r\n },\r\n chartType : 'bar',\r\n datasets : [\r\n {\r\n label: 'Conversion',\r\n data : [221, 428, 492, 471, 413, 344, 294]\r\n }\r\n ],\r\n labels : ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday'],\r\n colors : [\r\n {\r\n borderColor : '#42a5f5',\r\n backgroundColor: '#42a5f5'\r\n }\r\n ],\r\n options : {\r\n spanGaps : false,\r\n legend : {\r\n display: false\r\n },\r\n maintainAspectRatio: false,\r\n layout : {\r\n padding: {\r\n top : 24,\r\n left : 16,\r\n right : 16,\r\n bottom: 16\r\n }\r\n },\r\n scales : {\r\n xAxes: [\r\n {\r\n display: false\r\n }\r\n ],\r\n yAxes: [\r\n {\r\n display: false,\r\n ticks : {\r\n min: 100,\r\n max: 500\r\n }\r\n }\r\n ]\r\n }\r\n }\r\n },\r\n widget3: {\r\n impressions: {\r\n value : '87k',\r\n ofTarget: 12\r\n },\r\n chartType : 'line',\r\n datasets : [\r\n {\r\n label: 'Impression',\r\n data : [67000, 54000, 82000, 57000, 72000, 57000, 87000, 72000, 89000, 98700, 112000, 136000, 110000, 149000, 98000],\r\n fill : false\r\n }\r\n ],\r\n labels : ['Jan 1', 'Jan 2', 'Jan 3', 'Jan 4', 'Jan 5', 'Jan 6', 'Jan 7', 'Jan 8', 'Jan 9', 'Jan 10', 'Jan 11', 'Jan 12', 'Jan 13', 'Jan 14', 'Jan 15'],\r\n colors : [\r\n {\r\n borderColor: '#5c84f1'\r\n }\r\n ],\r\n options : {\r\n spanGaps : false,\r\n legend : {\r\n display: false\r\n },\r\n maintainAspectRatio: false,\r\n elements : {\r\n point: {\r\n radius : 2,\r\n borderWidth : 1,\r\n hoverRadius : 2,\r\n hoverBorderWidth: 1\r\n },\r\n line : {\r\n tension: 0\r\n }\r\n },\r\n layout : {\r\n padding: {\r\n top : 24,\r\n left : 16,\r\n right : 16,\r\n bottom: 16\r\n }\r\n },\r\n scales : {\r\n xAxes: [\r\n {\r\n display: false\r\n }\r\n ],\r\n yAxes: [\r\n {\r\n display: false,\r\n ticks : {\r\n // min: 100,\r\n // max: 500\r\n }\r\n }\r\n ]\r\n }\r\n }\r\n },\r\n widget4: {\r\n visits : {\r\n value : 882,\r\n ofTarget: -9\r\n },\r\n chartType: 'bar',\r\n datasets : [\r\n {\r\n label: 'Visits',\r\n data : [432, 428, 327, 363, 456, 267, 231]\r\n }\r\n ],\r\n labels : ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday'],\r\n colors : [\r\n {\r\n borderColor : '#f44336',\r\n backgroundColor: '#f44336'\r\n }\r\n ],\r\n options : {\r\n spanGaps : false,\r\n legend : {\r\n display: false\r\n },\r\n maintainAspectRatio: false,\r\n layout : {\r\n padding: {\r\n top : 24,\r\n left : 16,\r\n right : 16,\r\n bottom: 16\r\n }\r\n },\r\n scales : {\r\n xAxes: [\r\n {\r\n display: false\r\n }\r\n ],\r\n yAxes: [\r\n {\r\n display: false,\r\n ticks : {\r\n min: 150,\r\n max: 500\r\n }\r\n }\r\n ]\r\n }\r\n }\r\n },\r\n widget5: {\r\n chartType: 'line',\r\n datasets : {\r\n 'yesterday': [\r\n {\r\n label: 'Visitors',\r\n data : [190, 300, 340, 220, 290, 390, 250, 380, 410, 380, 320, 290],\r\n fill : 'start'\r\n\r\n },\r\n {\r\n label: 'Page views',\r\n data : [2200, 2900, 3900, 2500, 3800, 3200, 2900, 1900, 3000, 3400, 4100, 3800],\r\n fill : 'start'\r\n }\r\n ],\r\n 'today' : [\r\n {\r\n label: 'Visitors',\r\n data : [410, 380, 320, 290, 190, 390, 250, 380, 300, 340, 220, 290],\r\n fill : 'start'\r\n },\r\n {\r\n label: 'Page Views',\r\n data : [3000, 3400, 4100, 3800, 2200, 3200, 2900, 1900, 2900, 3900, 2500, 3800],\r\n fill : 'start'\r\n\r\n }\r\n ]\r\n },\r\n labels : ['12am', '2am', '4am', '6am', '8am', '10am', '12pm', '2pm', '4pm', '6pm', '8pm', '10pm'],\r\n colors : [\r\n {\r\n borderColor : '#3949ab',\r\n backgroundColor : '#3949ab',\r\n pointBackgroundColor : '#3949ab',\r\n pointHoverBackgroundColor: '#3949ab',\r\n pointBorderColor : '#ffffff',\r\n pointHoverBorderColor : '#ffffff'\r\n },\r\n {\r\n borderColor : 'rgba(30, 136, 229, 0.87)',\r\n backgroundColor : 'rgba(30, 136, 229, 0.87)',\r\n pointBackgroundColor : 'rgba(30, 136, 229, 0.87)',\r\n pointHoverBackgroundColor: 'rgba(30, 136, 229, 0.87)',\r\n pointBorderColor : '#ffffff',\r\n pointHoverBorderColor : '#ffffff'\r\n }\r\n ],\r\n options : {\r\n spanGaps : false,\r\n legend : {\r\n display: false\r\n },\r\n maintainAspectRatio: false,\r\n tooltips : {\r\n position : 'nearest',\r\n mode : 'index',\r\n intersect: false\r\n },\r\n layout : {\r\n padding: {\r\n left : 24,\r\n right: 32\r\n }\r\n },\r\n elements : {\r\n point: {\r\n radius : 4,\r\n borderWidth : 2,\r\n hoverRadius : 4,\r\n hoverBorderWidth: 2\r\n }\r\n },\r\n scales : {\r\n xAxes: [\r\n {\r\n gridLines: {\r\n display: false\r\n },\r\n ticks : {\r\n fontColor: 'rgba(0,0,0,0.54)'\r\n }\r\n }\r\n ],\r\n yAxes: [\r\n {\r\n gridLines: {\r\n tickMarkLength: 16\r\n },\r\n ticks : {\r\n stepSize: 1000\r\n }\r\n }\r\n ]\r\n },\r\n plugins : {\r\n filler: {\r\n propagate: false\r\n }\r\n }\r\n }\r\n },\r\n widget6: {\r\n markers: [\r\n {\r\n lat : 52,\r\n lng : -73,\r\n label: '120'\r\n },\r\n {\r\n lat : 37,\r\n lng : -104,\r\n label: '498'\r\n },\r\n {\r\n lat : 21,\r\n lng : -7,\r\n label: '443'\r\n },\r\n {\r\n lat : 55,\r\n lng : 75,\r\n label: '332'\r\n },\r\n {\r\n lat : 51,\r\n lng : 7,\r\n label: '50'\r\n },\r\n {\r\n lat : 31,\r\n lng : 12,\r\n label: '221'\r\n },\r\n {\r\n lat : 45,\r\n lng : 44,\r\n label: '455'\r\n },\r\n {\r\n lat : -26,\r\n lng : 134,\r\n label: '231'\r\n },\r\n {\r\n lat : -9,\r\n lng : -60,\r\n label: '67'\r\n },\r\n {\r\n lat : 33,\r\n lng : 104,\r\n label: '665'\r\n }\r\n ],\r\n styles : [\r\n {\r\n 'featureType': 'administrative',\r\n 'elementType': 'labels.text.fill',\r\n 'stylers' : [\r\n {\r\n 'color': '#444444'\r\n }\r\n ]\r\n },\r\n {\r\n 'featureType': 'landscape',\r\n 'elementType': 'all',\r\n 'stylers' : [\r\n {\r\n 'color': '#f2f2f2'\r\n }\r\n ]\r\n },\r\n {\r\n 'featureType': 'poi',\r\n 'elementType': 'all',\r\n 'stylers' : [\r\n {\r\n 'visibility': 'off'\r\n }\r\n ]\r\n },\r\n {\r\n 'featureType': 'road',\r\n 'elementType': 'all',\r\n 'stylers' : [\r\n {\r\n 'saturation': -100\r\n },\r\n {\r\n 'lightness': 45\r\n }\r\n ]\r\n },\r\n {\r\n 'featureType': 'road.highway',\r\n 'elementType': 'all',\r\n 'stylers' : [\r\n {\r\n 'visibility': 'simplified'\r\n }\r\n ]\r\n },\r\n {\r\n 'featureType': 'road.arterial',\r\n 'elementType': 'labels.icon',\r\n 'stylers' : [\r\n {\r\n 'visibility': 'off'\r\n }\r\n ]\r\n },\r\n {\r\n 'featureType': 'transit',\r\n 'elementType': 'all',\r\n 'stylers' : [\r\n {\r\n 'visibility': 'off'\r\n }\r\n ]\r\n },\r\n {\r\n 'featureType': 'water',\r\n 'elementType': 'all',\r\n 'stylers' : [\r\n {\r\n 'color': '#039be5'\r\n },\r\n {\r\n 'visibility': 'on'\r\n }\r\n ]\r\n }\r\n ]\r\n },\r\n widget7: {\r\n scheme : {\r\n domain: ['#4867d2', '#5c84f1', '#89a9f4']\r\n },\r\n devices: [\r\n {\r\n name : 'Desktop',\r\n value : 92.8,\r\n change: -0.6\r\n },\r\n {\r\n name : 'Mobile',\r\n value : 6.1,\r\n change: 0.7\r\n },\r\n {\r\n name : 'Tablet',\r\n value : 1.1,\r\n change: 0.1\r\n }\r\n ]\r\n },\r\n widget8: {\r\n scheme : {\r\n domain: ['#5c84f1']\r\n },\r\n today : '12,540',\r\n change : {\r\n value : 321,\r\n percentage: 2.05\r\n },\r\n data : [\r\n {\r\n name : 'Sales',\r\n series: [\r\n {\r\n name : 'Jan 1',\r\n value: 540\r\n },\r\n {\r\n name : 'Jan 2',\r\n value: 539\r\n },\r\n {\r\n name : 'Jan 3',\r\n value: 538\r\n },\r\n {\r\n name : 'Jan 4',\r\n value: 539\r\n },\r\n {\r\n name : 'Jan 5',\r\n value: 540\r\n },\r\n {\r\n name : 'Jan 6',\r\n value: 539\r\n },\r\n {\r\n name : 'Jan 7',\r\n value: 540\r\n }\r\n ]\r\n }\r\n ],\r\n dataMin: 538,\r\n dataMax: 541\r\n },\r\n widget9: {\r\n rows: [\r\n {\r\n title : 'Holiday Travel',\r\n clicks : 3621,\r\n conversion: 90\r\n },\r\n {\r\n title : 'Get Away Deals',\r\n clicks : 703,\r\n conversion: 7\r\n },\r\n {\r\n title : 'Airfare',\r\n clicks : 532,\r\n conversion: 0\r\n },\r\n {\r\n title : 'Vacation',\r\n clicks : 201,\r\n conversion: 8\r\n },\r\n {\r\n title : 'Hotels',\r\n clicks : 94,\r\n conversion: 4\r\n }\r\n ]\r\n }\r\n };\r\n}\r\n","export class ProjectDashboardDb\r\n{\r\n public static projects = [\r\n {\r\n 'name': 'ACME Corp. Backend App'\r\n },\r\n {\r\n 'name': 'ACME Corp. Frontend App'\r\n },\r\n {\r\n 'name': 'Creapond'\r\n },\r\n {\r\n 'name': 'Withinpixels'\r\n }\r\n ];\r\n\r\n public static widgets = {\r\n 'widget1' : {\r\n 'ranges' : {\r\n 'DY' : 'Yesterday',\r\n 'DT' : 'Today',\r\n 'DTM': 'Tomorrow'\r\n },\r\n 'currentRange': 'DT',\r\n 'data' : {\r\n 'label': 'DUE TASKS',\r\n 'count': {\r\n 'DY' : 21,\r\n 'DT' : 25,\r\n 'DTM': 19\r\n },\r\n 'extra': {\r\n 'label': 'Completed',\r\n 'count': {\r\n 'DY' : 6,\r\n 'DT' : 7,\r\n 'DTM': '-'\r\n }\r\n\r\n }\r\n },\r\n 'detail' : 'You can show some detailed information about this widget in here.'\r\n },\r\n 'widget2' : {\r\n 'title' : 'Overdue',\r\n 'data' : {\r\n 'label': 'TASKS',\r\n 'count': 4,\r\n 'extra': {\r\n 'label': 'Yesterday\\'s overdue',\r\n 'count': 2\r\n }\r\n },\r\n 'detail': 'You can show some detailed information about this widget in here.'\r\n },\r\n 'widget3' : {\r\n 'title' : 'Issues',\r\n 'data' : {\r\n 'label': 'OPEN',\r\n 'count': 32,\r\n 'extra': {\r\n 'label': 'Closed today',\r\n 'count': 0\r\n }\r\n },\r\n 'detail': 'You can show some detailed information about this widget in here.'\r\n },\r\n 'widget4' : {\r\n 'title' : 'Features',\r\n 'data' : {\r\n 'label': 'PROPOSALS',\r\n 'count': 42,\r\n 'extra': {\r\n 'label': 'Implemented',\r\n 'count': 8\r\n }\r\n },\r\n 'detail': 'You can show some detailed information about this widget in here.'\r\n },\r\n 'widget5' : {\r\n 'title' : 'Github Issues',\r\n 'ranges' : {\r\n 'TW': 'This Week',\r\n 'LW': 'Last Week',\r\n '2W': '2 Weeks Ago'\r\n },\r\n 'mainChart' : {\r\n '2W': [\r\n {\r\n 'name' : 'Mon',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 37\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 9\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 32\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 12\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 39\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 9\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 27\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 12\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 18\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 7\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 24\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 8\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 20\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 16\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'Mon',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 37\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 12\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 24\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 8\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 51\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 7\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 31\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 13\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 29\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 7\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 17\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 6\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 31\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 10\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'Mon',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 42\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 11\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 28\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 10\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 43\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 8\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 34\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 11\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 20\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 8\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 25\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 10\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'series': [\r\n {\r\n 'name' : 'issues',\r\n 'value': 22\r\n },\r\n {\r\n 'name' : 'closed issues',\r\n 'value': 17\r\n }\r\n ]\r\n }\r\n ]\r\n },\r\n 'supporting': {\r\n 'created' : {\r\n 'label': 'CREATED',\r\n 'count': {\r\n '2W': 48,\r\n 'LW': 46,\r\n 'TW': 54\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'CREATED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'Created',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'Created',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 1\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 4\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n },\r\n 'closed' : {\r\n 'label': 'CLOSED',\r\n 'count': {\r\n '2W': 27,\r\n 'LW': 31,\r\n 'TW': 26\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'CLOSED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 1\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 4\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'CLOSED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'CLOSED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n },\r\n 'reOpened' : {\r\n 'label': 'RE-OPENED',\r\n 'count': {\r\n '2W': 4,\r\n 'LW': 5,\r\n 'TW': 2\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'RE-OPENED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'RE-OPENED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 1\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'RE-OPENED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 1\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 4\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n },\r\n 'wontFix' : {\r\n 'label': 'WON\\'T FIX',\r\n 'count': {\r\n '2W': 6,\r\n 'LW': 3,\r\n 'TW': 4\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'WON\\'T FIX',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 2\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'WON\\'T FIX',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'WON\\'T FIX',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n },\r\n 'needsTest': {\r\n 'label': 'NEEDS TEST',\r\n 'count': {\r\n '2W': 10,\r\n 'LW': 7,\r\n 'TW': 8\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'NEEDS TEST',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'NEEDS TEST',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 1\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'NEEDS TEST',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n },\r\n 'fixed' : {\r\n 'label': 'FIXED',\r\n 'count': {\r\n '2W': 21,\r\n 'LW': 17,\r\n 'TW': 14\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'FIXED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 1\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'FIXED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'FIXED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 2\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n }\r\n }\r\n },\r\n 'widget6' : {\r\n 'title' : 'Task Distribution',\r\n 'ranges' : {\r\n 'TW': 'This Week',\r\n 'LW': 'Last Week',\r\n '2W': '2 Weeks Ago'\r\n },\r\n 'mainChart' : {\r\n 'TW': [\r\n {\r\n 'name' : 'Frontend',\r\n 'value': 15\r\n },\r\n {\r\n 'name' : 'Backend',\r\n 'value': 20\r\n },\r\n {\r\n 'name' : 'API',\r\n 'value': 38\r\n },\r\n {\r\n 'name' : 'Issues',\r\n 'value': 27\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'Frontend',\r\n 'value': 19\r\n },\r\n {\r\n 'name' : 'Backend',\r\n 'value': 16\r\n },\r\n {\r\n 'name' : 'API',\r\n 'value': 42\r\n },\r\n {\r\n 'name' : 'Issues',\r\n 'value': 23\r\n }\r\n ],\r\n '2W': [\r\n {\r\n 'name' : 'Frontend',\r\n 'value': 18\r\n },\r\n {\r\n 'name' : 'Backend',\r\n 'value': 17\r\n },\r\n {\r\n 'name' : 'API',\r\n 'value': 40\r\n },\r\n {\r\n 'name' : 'Issues',\r\n 'value': 25\r\n }\r\n ]\r\n },\r\n 'footerLeft' : {\r\n 'title': 'Tasks Added',\r\n 'count': {\r\n '2W': 487,\r\n 'LW': 526,\r\n 'TW': 594\r\n }\r\n },\r\n 'footerRight': {\r\n 'title': 'Tasks Completed',\r\n 'count': {\r\n '2W': 193,\r\n 'LW': 260,\r\n 'TW': 287\r\n }\r\n }\r\n },\r\n 'widget7' : {\r\n 'title' : 'Schedule',\r\n 'ranges' : {\r\n 'T' : 'Today',\r\n 'TM': 'Tomorrow'\r\n },\r\n 'schedule': {\r\n 'T' : [\r\n {\r\n 'title' : 'Group Meeting',\r\n 'time' : 'In 32 minutes',\r\n 'location': 'Room 1B'\r\n },\r\n {\r\n 'title': 'Coffee Break',\r\n 'time' : '10:30 AM'\r\n },\r\n {\r\n 'title': 'Public Beta Release',\r\n 'time' : '11:00 AM'\r\n },\r\n {\r\n 'title': 'Lunch',\r\n 'time' : '12:10 PM'\r\n },\r\n {\r\n 'title': 'Dinner with David',\r\n 'time' : '17:30 PM'\r\n },\r\n {\r\n 'title': 'Jane\\'s Birthday Party',\r\n 'time' : '19:30 PM'\r\n },\r\n {\r\n 'title': 'Overseer\\'s Retirement Party',\r\n 'time' : '21:30 PM'\r\n }\r\n ],\r\n 'TM': [\r\n {\r\n 'title': 'Marketing Meeting',\r\n 'time' : '09:00 AM'\r\n },\r\n {\r\n 'title': 'Public Announcement',\r\n 'time' : '11:00 AM'\r\n },\r\n {\r\n 'title': 'Lunch',\r\n 'time' : '12:10 PM'\r\n },\r\n {\r\n 'title': 'Meeting with Beta Testers',\r\n 'time' : '15:00 AM'\r\n },\r\n {\r\n 'title': 'Live Stream',\r\n 'time' : '17:30 PM'\r\n },\r\n {\r\n 'title': 'Release Party',\r\n 'time' : '19:30 PM'\r\n },\r\n {\r\n 'title': 'CEO\\'s Party',\r\n 'time' : '22:30 PM'\r\n }\r\n ]\r\n }\r\n },\r\n 'widget8' : {\r\n 'title' : 'Budget Distribution',\r\n 'mainChart': [\r\n {\r\n 'name' : 'Wireframing',\r\n 'value': 12\r\n },\r\n {\r\n 'name' : 'Design',\r\n 'value': 17\r\n },\r\n {\r\n 'name' : 'Coding',\r\n 'value': 28\r\n },\r\n {\r\n 'name' : 'Marketing',\r\n 'value': 25\r\n },\r\n {\r\n 'name' : 'Extra',\r\n 'value': 15\r\n }\r\n ]\r\n },\r\n 'widget9' : {\r\n 'title' : 'Spent',\r\n 'ranges' : {\r\n 'TW': 'This Week',\r\n 'LW': 'Last Week',\r\n '2W': '2 Weeks Ago'\r\n },\r\n 'weeklySpent' : {\r\n 'title': 'WEEKLY SPENT',\r\n 'count': {\r\n '2W': '2,682.85',\r\n 'LW': '1,445.34',\r\n 'TW': '3,630.15'\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'CREATED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 1\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 2\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'Created',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 1\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 4\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'Created',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 6\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n },\r\n 'totalSpent' : {\r\n 'title': 'TOTAL SPENT',\r\n 'count': {\r\n '2W': '29,682.85',\r\n 'LW': '31,128.19',\r\n 'TW': '34,758.34'\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'CREATED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 4\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'Created',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 1\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'Created',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 7\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n },\r\n 'remaining' : {\r\n 'title': 'REMAINING',\r\n 'count': {\r\n '2W': '94.317,15',\r\n 'LW': '92.871,81',\r\n 'TW': '89.241,66'\r\n },\r\n 'chart': {\r\n '2W': [\r\n {\r\n 'name' : 'CREATED',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 1\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 7\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 4\r\n }\r\n ]\r\n }\r\n ],\r\n 'LW': [\r\n {\r\n 'name' : 'Created',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 3\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 1\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 4\r\n }\r\n ]\r\n }\r\n ],\r\n 'TW': [\r\n {\r\n 'name' : 'Created',\r\n 'series': [\r\n {\r\n 'name' : 'Mon',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Tue',\r\n 'value': 4\r\n },\r\n {\r\n 'name' : 'Wed',\r\n 'value': 8\r\n },\r\n {\r\n 'name' : 'Thu',\r\n 'value': 6\r\n },\r\n {\r\n 'name' : 'Fri',\r\n 'value': 2\r\n },\r\n {\r\n 'name' : 'Sat',\r\n 'value': 5\r\n },\r\n {\r\n 'name' : 'Sun',\r\n 'value': 1\r\n }\r\n ]\r\n }\r\n ]\r\n }\r\n },\r\n 'totalRemaining': {\r\n 'title': 'TOTAL BUDGET',\r\n 'count': '124.000,00'\r\n },\r\n 'totalBudget' : {\r\n 'title': 'TOTAL BUDGET',\r\n 'count': '124.000,00'\r\n }\r\n },\r\n 'widget10' : {\r\n 'title': 'Budget Details',\r\n 'table': {\r\n 'columns': [\r\n {\r\n 'title': 'Budget Type'\r\n },\r\n {\r\n 'title': 'Total Budget'\r\n },\r\n {\r\n 'title': 'Spent ($)'\r\n },\r\n {\r\n 'title': 'Spent (%)'\r\n },\r\n {\r\n 'title': 'Remaining ($)'\r\n },\r\n {\r\n 'title': 'Remaining (%)'\r\n }\r\n ],\r\n 'rows' : [\r\n [\r\n {\r\n 'value' : 'Wireframing',\r\n 'classes': 'primary',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$14,880.00',\r\n 'classes': 'text-bold',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$14,000.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%94.08',\r\n 'classes': 'text-success',\r\n 'icon' : 'trending_up'\r\n },\r\n {\r\n 'value' : '$880.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%5.92',\r\n 'classes': '',\r\n 'icon' : ''\r\n }\r\n ],\r\n [\r\n {\r\n 'value' : 'Design',\r\n 'classes': 'green',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$21,080.00',\r\n 'classes': 'text-bold',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$17,240.34',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%81.78',\r\n 'classes': 'text-success',\r\n 'icon' : 'trending_up'\r\n },\r\n {\r\n 'value' : '$3,839.66',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%18.22',\r\n 'classes': '',\r\n 'icon' : ''\r\n }\r\n ],\r\n [\r\n {\r\n 'value' : 'Coding',\r\n 'classes': 'red',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$34,720.00',\r\n 'classes': 'text-bold',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$3,518.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%10.13',\r\n 'classes': 'text-danger',\r\n 'icon' : 'trending_down'\r\n },\r\n {\r\n 'value' : '$31,202.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%89.87',\r\n 'classes': '',\r\n 'icon' : ''\r\n }\r\n ],\r\n [\r\n {\r\n 'value' : 'Marketing',\r\n 'classes': 'accent',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$34,720.00',\r\n 'classes': 'text-bold',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$0.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%0.00',\r\n 'classes': 'text-info',\r\n 'icon' : 'trending_flat'\r\n },\r\n {\r\n 'value' : '$34,720.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%100.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n }\r\n ],\r\n [\r\n {\r\n 'value' : 'Extra',\r\n 'classes': 'orange',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$18,600.00',\r\n 'classes': 'text-bold',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '$0.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%0.00',\r\n 'classes': 'text-info',\r\n 'icon' : 'trending_flat'\r\n },\r\n {\r\n 'value' : '$34,720.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n },\r\n {\r\n 'value' : '%100.00',\r\n 'classes': '',\r\n 'icon' : ''\r\n }\r\n ]\r\n ]\r\n }\r\n },\r\n 'widget11' : {\r\n 'title': 'Team Members',\r\n 'table': {\r\n 'columns': ['avatar', 'name', 'position', 'office', 'email', 'phone'],\r\n 'rows' : [\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Jack Gilbert',\r\n position: 'Design Manager',\r\n office : 'Johor Bahru',\r\n email : 'jgilbert48@mail.com',\r\n phone : '+16 298 032 7774'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Kathy Anderson',\r\n position: 'Recruiting Manager',\r\n office : 'Solţānābād',\r\n email : 'kanderson49@mail.com.br',\r\n phone : '+23 572 311 1136'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Mark Turner',\r\n position: 'Recruiting Manager',\r\n office : 'Neftegorsk',\r\n email : 'mturner4a@mail.com',\r\n phone : '+01 139 803 9263'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Kathryn Martinez',\r\n position: 'Director of Sales',\r\n office : 'Palekastro',\r\n email : 'kmartinez4b@mail.com',\r\n phone : '+25 467 022 5393'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Annie Gonzales',\r\n position: 'Actuary',\r\n office : 'Candon',\r\n email : 'agonzales4c@mail.edu',\r\n phone : '+99 891 619 7138'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Howard King',\r\n position: 'Human Resources',\r\n office : 'Bergen op Zoom',\r\n email : 'hking4d@mail.gov',\r\n phone : '+46 984 348 1409'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Elizabeth Dixon',\r\n position: 'Electrical Engineer',\r\n office : 'Písečná',\r\n email : 'edixon4e@mail.gov',\r\n phone : '+33 332 067 9063'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Dorothy Morris',\r\n position: 'Office Assistant',\r\n office : 'Magsaysay',\r\n email : 'dmorris4f@mail.com',\r\n phone : '+05 490 958 6120'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Mark Gonzales',\r\n position: 'Quality Control',\r\n office : 'Matsue-shi',\r\n email : 'mgonzales4g@mail.com',\r\n phone : '+03 168 394 9935'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Catherine Rogers',\r\n position: 'Programmer Analyst',\r\n office : 'Kangar',\r\n email : 'crogers4h@mail.com',\r\n phone : '+86 235 407 5373'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Ruth Grant',\r\n position: 'Community Outreach',\r\n office : 'Beaune',\r\n email : 'rgrant4i@mail.pl',\r\n phone : '+36 288 083 8460'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Phyllis Gutierrez',\r\n position: 'Administrative Assistant',\r\n office : 'Shlissel’burg',\r\n email : 'pgutierrez4j@mail.net',\r\n phone : '+52 749 861 9304'\r\n }, {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Lillian Morris',\r\n position: 'Media Planner',\r\n office : 'Berlin',\r\n email : 'lmorris4k@mail.de',\r\n phone : '+59 695 110 3856'\r\n }, {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Jeremy Anderson',\r\n position: 'Systems Engineer',\r\n office : 'Lũng Hồ',\r\n email : 'janderson4l@mail.uk',\r\n phone : '+40 384 115 1448'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Arthur Lawrence',\r\n position: 'Nurse Practicioner',\r\n office : 'Sarkanjut',\r\n email : 'alawrence4m@mail.com',\r\n phone : '+36 631 599 7867'\r\n }, {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'David Simmons',\r\n position: 'Social Worker',\r\n office : 'Ushumun',\r\n email : 'dsimmons4n@mail.com',\r\n phone : '+01 189 681 4417'\r\n }, {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Daniel Johnston',\r\n position: 'Help Desk',\r\n office : 'São Carlos',\r\n email : 'djohnston4o@mail.gov',\r\n phone : '+60 028 943 7919'\r\n },\r\n\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Ann King',\r\n position: 'Internal Auditor',\r\n office : 'Liren',\r\n email : 'aking4p@mail.com',\r\n phone : '+91 103 932 6545'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Phillip Franklin',\r\n position: 'VP Accounting',\r\n office : 'Soba',\r\n email : 'pfranklin4q@mail.com',\r\n phone : '+25 820 986 7626'\r\n },\r\n {\r\n avatar : 'assets/images/avatars/profile.jpg',\r\n name : 'Gary Gonzalez',\r\n position: 'Speech Pathologist',\r\n office : 'Gangkou',\r\n email : 'ggonzalez4r@mail.cc',\r\n phone : '+10 862 046 7916'\r\n }\r\n ]\r\n }\r\n },\r\n 'weatherWidget': {\r\n 'locations' : {\r\n 'NewYork': {\r\n 'name' : 'New York',\r\n 'icon' : 'icon-rainy2',\r\n 'temp' : {\r\n 'C': '22',\r\n 'F': '72'\r\n },\r\n 'windSpeed' : {\r\n 'KMH': 12,\r\n 'MPH': 7.5\r\n },\r\n 'windDirection' : 'NW',\r\n 'rainProbability': '98%',\r\n 'next3Days' : [\r\n {\r\n 'name': 'Sunday',\r\n 'icon': 'icon-rainy',\r\n 'temp': {\r\n 'C': '21',\r\n 'F': '70'\r\n }\r\n },\r\n {\r\n 'name': 'Sunday',\r\n 'icon': 'icon-cloudy',\r\n 'temp': {\r\n 'C': '19',\r\n 'F': '66'\r\n }\r\n },\r\n {\r\n 'name': 'Tuesday',\r\n 'icon': 'icon-windy3',\r\n 'temp': {\r\n 'C': '24',\r\n 'F': '75'\r\n }\r\n }\r\n ]\r\n }\r\n },\r\n 'currentLocation': 'NewYork',\r\n 'tempUnit' : 'C',\r\n 'speedUnit' : 'KMH'\r\n }\r\n };\r\n}\r\n","export class ECommerceFakeDb\r\n{\r\n public static products = [\r\n {\r\n 'id' : '1',\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'handle' : 'a-walk-amongst-friends-canvas-print',\r\n 'description' : 'Officia amet eiusmod eu sunt tempor voluptate laboris velit nisi amet enim proident et. Consequat laborum non eiusmod cillum eu exercitation. Qui adipisicing est fugiat eiusmod esse. Sint aliqua cupidatat pariatur mollit ad est proident reprehenderit. Eiusmod adipisicing laborum incididunt sit aliqua ullamco.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 1,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 9.309,\r\n 'priceTaxIncl' : 10.24,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 19.90,\r\n 'quantity' : 3,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '2',\r\n 'name' : 'Braies Lake - Canvas Print',\r\n 'handle' : 'braies-lake-canvas-print',\r\n 'description' : 'Duis anim est non exercitation consequat. Ullamco ut ipsum dolore est elit est ea elit ad fugiat exercitation. Adipisicing eu ad sit culpa sint. Minim irure Lorem eiusmod minim nisi sit est consectetur.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 2,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 22.381,\r\n 'priceTaxIncl' : 24.62,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 29.90,\r\n 'quantity' : 92,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '3',\r\n 'name' : 'Fall Glow - Canvas Print',\r\n 'handle' : 'fall-glow-canvas-print',\r\n 'description' : 'Sit ipsum esse eu consequat veniam sit consectetur consectetur anim. Ut Lorem dolor ullamco do. Laboris excepteur consectetur tempor nisi commodo amet deserunt duis.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 3,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 44.809,\r\n 'priceTaxIncl' : 49.29,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 59.90,\r\n 'quantity' : 60,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '4',\r\n 'name' : 'First Snow - Canvas Print',\r\n 'handle' : 'first-snow-canvas-print',\r\n 'description' : 'Incididunt nostrud culpa labore nostrud veniam nostrud dolore velit sunt laborum ad reprehenderit. Excepteur enim irure ut labore elit ut deserunt qui qui consequat quis do nostrud ad. Aliqua dolor labore ut occaecat laborum irure. Aute in deserunt do aute laborum sit et reprehenderit minim voluptate proident do est.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 4,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 62.827,\r\n 'priceTaxIncl' : 69.11,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 79.90,\r\n 'quantity' : 101,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : false\r\n },\r\n {\r\n 'id' : '5',\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'handle' : 'lago-di-braies-canvas-print',\r\n 'description' : 'Laboris laborum minim qui reprehenderit duis fugiat ea anim labore incididunt duis. Officia adipisicing anim amet in sit aliqua fugiat quis do sint non velit eu. Labore occaecat labore elit voluptate Lorem adipisicing et ipsum id et reprehenderit ullamco. Elit in nulla laborum nulla quis dolor deserunt magna dolor ad anim magna. Esse aute reprehenderit anim sit est et quis est. Ex reprehenderit culpa deserunt qui sint eiusmod reprehenderit ipsum consequat ut.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 5,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 9.309,\r\n 'priceTaxIncl' : 10.24,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 19.90,\r\n 'quantity' : 19,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '6',\r\n 'name' : 'Lago di Sorapis - Canvas Print',\r\n 'handle' : 'lago-di-sorapis-canvas-print',\r\n 'description' : 'Tempor sunt tempor veniam non culpa excepteur. Ea irure elit non cupidatat cillum dolore. Sit incididunt qui dolore ipsum commodo aliqua amet cupidatat incididunt nisi qui consectetur. Cillum eu aute qui irure aute adipisicing cupidatat magna.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 6,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 53.963,\r\n 'priceTaxIncl' : 59.36,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 69.90,\r\n 'quantity' : 101,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '7',\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'handle' : 'never-stop-changing-canvas-print',\r\n 'description' : 'Excepteur commodo ipsum in ex esse elit ea id voluptate id occaecat. Sunt Lorem ipsum ut proident eu aliquip velit non minim. Sunt velit deserunt veniam eu non veniam. Eiusmod sit ex et id incididunt labore aliqua eu aute dolor cillum ex mollit mollit. Incididunt voluptate adipisicing eiusmod non ipsum cupidatat excepteur enim in pariatur eu. Labore dolor qui exercitation amet labore laboris Lorem do adipisicing. Minim non consectetur adipisicing esse ut occaecat incididunt eiusmod commodo et cillum pariatur.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 7,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 58.372,\r\n 'priceTaxIncl' : 64.21,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 69.90,\r\n 'quantity' : 34,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '8',\r\n 'name' : 'Reaching - Canvas Print',\r\n 'handle' : 'reaching-canvas-print',\r\n 'description' : 'Velit cillum cupidatat eiusmod ea quis sit. Consequat dolore elit sunt sunt voluptate irure incididunt consectetur non. Dolore veniam ipsum anim commodo ex. Proident ipsum nostrud ullamco sit. Ad dolore nulla qui mollit laborum ex ipsum.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 8,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 63.390,\r\n 'priceTaxIncl' : 69.73,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 79.90,\r\n 'quantity' : 4,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : false\r\n },\r\n {\r\n 'id' : '9',\r\n 'name' : 'Morain Lake - Canvas Print',\r\n 'handle' : 'morain-lake-canvas-print',\r\n 'description' : 'Consequat minim velit commodo Lorem ipsum velit elit amet ut. In deserunt id duis nisi labore. Proident cillum et reprehenderit excepteur ex nulla enim.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 9,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 52.154,\r\n 'priceTaxIncl' : 57.37,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 59.90,\r\n 'quantity' : 58,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '10',\r\n 'name' : 'Yosemite - Canvas Print',\r\n 'handle' : 'yosemite-canvas-print',\r\n 'description' : 'Proident do sunt dolor tempor aliquip adipisicing dolor reprehenderit officia proident. Culpa non reprehenderit velit anim consequat velit elit eu culpa quis incididunt id. Eu incididunt exercitation nostrud est mollit officia. Laboris deserunt dolore sit occaecat exercitation quis sunt sunt nisi commodo.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 9,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 62.18,\r\n 'priceTaxIncl' : 68.40,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 69.90,\r\n 'quantity' : 125,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '11',\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'handle' : 'a-walk-amongst-friends-canvas-print',\r\n 'description' : 'Officia amet eiusmod eu sunt tempor voluptate laboris velit nisi amet enim proident et. Consequat laborum non eiusmod cillum eu exercitation. Qui adipisicing est fugiat eiusmod esse. Sint aliqua cupidatat pariatur mollit ad est proident reprehenderit. Eiusmod adipisicing laborum incididunt sit aliqua ullamco.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 1,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 9.309,\r\n 'priceTaxIncl' : 10.24,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 19.90,\r\n 'quantity' : 3,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '12',\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'handle' : 'never-stop-changing-canvas-print',\r\n 'description' : 'Excepteur commodo ipsum in ex esse elit ea id voluptate id occaecat. Sunt Lorem ipsum ut proident eu aliquip velit non minim. Sunt velit deserunt veniam eu non veniam. Eiusmod sit ex et id incididunt labore aliqua eu aute dolor cillum ex mollit mollit. Incididunt voluptate adipisicing eiusmod non ipsum cupidatat excepteur enim in pariatur eu. Labore dolor qui exercitation amet labore laboris Lorem do adipisicing. Minim non consectetur adipisicing esse ut occaecat incididunt eiusmod commodo et cillum pariatur.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 7,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 58.372,\r\n 'priceTaxIncl' : 64.21,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 69.90,\r\n 'quantity' : 34,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '13',\r\n 'name' : 'Morain Lake - Canvas Print',\r\n 'handle' : 'morain-lake-canvas-print',\r\n 'description' : 'Consequat minim velit commodo Lorem ipsum velit elit amet ut. In deserunt id duis nisi labore. Proident cillum et reprehenderit excepteur ex nulla enim.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 9,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 52.154,\r\n 'priceTaxIncl' : 57.37,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 59.90,\r\n 'quantity' : 58,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '14',\r\n 'name' : 'Braies Lake - Canvas Print',\r\n 'handle' : 'braies-lake-canvas-print',\r\n 'description' : 'Duis anim est non exercitation consequat. Ullamco ut ipsum dolore est elit est ea elit ad fugiat exercitation. Adipisicing eu ad sit culpa sint. Minim irure Lorem eiusmod minim nisi sit est consectetur.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 2,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 22.381,\r\n 'priceTaxIncl' : 24.62,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 29.90,\r\n 'quantity' : 92,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '15',\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'handle' : 'lago-di-braies-canvas-print',\r\n 'description' : 'Laboris laborum minim qui reprehenderit duis fugiat ea anim labore incididunt duis. Officia adipisicing anim amet in sit aliqua fugiat quis do sint non velit eu. Labore occaecat labore elit voluptate Lorem adipisicing et ipsum id et reprehenderit ullamco. Elit in nulla laborum nulla quis dolor deserunt magna dolor ad anim magna. Esse aute reprehenderit anim sit est et quis est. Ex reprehenderit culpa deserunt qui sint eiusmod reprehenderit ipsum consequat ut.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 5,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 9.309,\r\n 'priceTaxIncl' : 10.24,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 19.90,\r\n 'quantity' : 19,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '16',\r\n 'name' : 'Fall Glow - Canvas Print',\r\n 'handle' : 'fall-glow-canvas-print',\r\n 'description' : 'Sit ipsum esse eu consequat veniam sit consectetur consectetur anim. Ut Lorem dolor ullamco do. Laboris excepteur consectetur tempor nisi commodo amet deserunt duis.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 3,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 44.809,\r\n 'priceTaxIncl' : 49.29,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 59.90,\r\n 'quantity' : 60,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '17',\r\n 'name' : 'Lago di Sorapis - Canvas Print',\r\n 'handle' : 'lago-di-sorapis-canvas-print',\r\n 'description' : 'Tempor sunt tempor veniam non culpa excepteur. Ea irure elit non cupidatat cillum dolore. Sit incididunt qui dolore ipsum commodo aliqua amet cupidatat incididunt nisi qui consectetur. Cillum eu aute qui irure aute adipisicing cupidatat magna.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 6,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 53.963,\r\n 'priceTaxIncl' : 59.36,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 69.90,\r\n 'quantity' : 101,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n },\r\n {\r\n 'id' : '18',\r\n 'name' : 'Reaching - Canvas Print',\r\n 'handle' : 'reaching-canvas-print',\r\n 'description' : 'Velit cillum cupidatat eiusmod ea quis sit. Consequat dolore elit sunt sunt voluptate irure incididunt consectetur non. Dolore veniam ipsum anim commodo ex. Proident ipsum nostrud ullamco sit. Ad dolore nulla qui mollit laborum ex ipsum.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 8,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 63.390,\r\n 'priceTaxIncl' : 69.73,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 79.90,\r\n 'quantity' : 4,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : false\r\n },\r\n {\r\n 'id' : '19',\r\n 'name' : 'First Snow - Canvas Print',\r\n 'handle' : 'first-snow-canvas-print',\r\n 'description' : 'Incididunt nostrud culpa labore nostrud veniam nostrud dolore velit sunt laborum ad reprehenderit. Excepteur enim irure ut labore elit ut deserunt qui qui consequat quis do nostrud ad. Aliqua dolor labore ut occaecat laborum irure. Aute in deserunt do aute laborum sit et reprehenderit minim voluptate proident do est.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 4,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 62.827,\r\n 'priceTaxIncl' : 69.11,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 79.90,\r\n 'quantity' : 101,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : false\r\n },\r\n {\r\n 'id' : '20',\r\n 'name' : 'Yosemite - Canvas Print',\r\n 'handle' : 'yosemite-canvas-print',\r\n 'description' : 'Proident do sunt dolor tempor aliquip adipisicing dolor reprehenderit officia proident. Culpa non reprehenderit velit anim consequat velit elit eu culpa quis incididunt id. Eu incididunt exercitation nostrud est mollit officia. Laboris deserunt dolore sit occaecat exercitation quis sunt sunt nisi commodo.',\r\n 'categories' : [\r\n 'Canvas Print',\r\n 'Nature'\r\n ],\r\n 'tags' : [\r\n 'canvas-print',\r\n 'nature'\r\n ],\r\n 'featuredImageId' : 9,\r\n 'images' : [\r\n {\r\n 'id' : 0,\r\n 'url' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 1,\r\n 'url' : 'assets/images/ecommerce/braies-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 2,\r\n 'url' : 'assets/images/ecommerce/fall-glow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 3,\r\n 'url' : 'assets/images/ecommerce/first-snow.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 4,\r\n 'url' : 'assets/images/ecommerce/lago-di-braies.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 5,\r\n 'url' : 'assets/images/ecommerce/lago-di-sorapis.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 6,\r\n 'url' : 'assets/images/ecommerce/never-stop-changing.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 7,\r\n 'url' : 'assets/images/ecommerce/reaching.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 8,\r\n 'url' : 'assets/images/ecommerce/morain-lake.jpg',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : 9,\r\n 'url' : 'assets/images/ecommerce/yosemite.jpg',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'priceTaxExcl' : 62.18,\r\n 'priceTaxIncl' : 68.40,\r\n 'taxRate' : 10,\r\n 'comparedPrice' : 69.90,\r\n 'quantity' : 125,\r\n 'sku' : 'A445BV',\r\n 'width' : '22',\r\n 'height' : '24',\r\n 'depth' : '15',\r\n 'weight' : '3',\r\n 'extraShippingFee': 3.00,\r\n 'active' : true\r\n }\r\n ];\r\n\r\n public static orders = [\r\n {\r\n 'id' : 1,\r\n 'reference' : '70d4d7d0',\r\n 'subtotal' : '39.97',\r\n 'tax' : '77.44',\r\n 'discount' : '-10.17',\r\n 'total' : '73.31',\r\n 'date' : '2018/04/25 02:07:59',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Dollie',\r\n 'lastName' : 'Bullock',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 13,\r\n 'name' : 'On pre-order (not paid)',\r\n 'color': 'purple-300',\r\n 'date' : '2018/04/03 10:06:18'\r\n },\r\n {\r\n 'id' : 1,\r\n 'name' : 'Awaiting check payment',\r\n 'color': 'blue-500',\r\n 'date' : '2018/03/17 18:28:37'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '2a894b9e',\r\n 'amount' : '73.31',\r\n 'method' : 'Credit Card',\r\n 'date' : '2018/02/23 15:50:23'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'TNT',\r\n 'weight' : '10.44',\r\n 'fee' : '7.00',\r\n 'date' : '2018/04/10 07:03:52'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 2,\r\n 'reference' : '2003479c',\r\n 'subtotal' : '98.68',\r\n 'tax' : '45.55',\r\n 'discount' : '-10.25',\r\n 'total' : '24.51',\r\n 'date' : '2018/11/07 15:47:31',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Holmes',\r\n 'lastName' : 'Hines',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 2,\r\n 'name' : 'Payment accepted',\r\n 'color': 'green-500',\r\n 'date' : '2018/10/04 08:54:33'\r\n },\r\n {\r\n 'id' : 1,\r\n 'name' : 'Awaiting check payment',\r\n 'color': 'blue-500',\r\n 'date' : '2018/05/03 03:43:04'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '79c640c8',\r\n 'amount' : '24.51',\r\n 'method' : 'Check',\r\n 'date' : '2018/04/22 04:49:49'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '2.92',\r\n 'fee' : '4.00',\r\n 'date' : '2018/07/11 14:57:12'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 3,\r\n 'reference' : '09f5443b',\r\n 'subtotal' : '23.03',\r\n 'tax' : '16.36',\r\n 'discount' : '-19.46',\r\n 'total' : '87.17',\r\n 'date' : '2018/11/26 16:04:40',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Serena',\r\n 'lastName' : 'Glover',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 8,\r\n 'name' : 'Payment error',\r\n 'color': 'red-900',\r\n 'date' : '2018/07/02 20:44:34'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Preparing the order',\r\n 'color': 'orange-500',\r\n 'date' : '2018/03/23 04:59:45'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '5ff44b0c',\r\n 'amount' : '87.17',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/01/25 11:46:28'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '7.53',\r\n 'fee' : '7.00',\r\n 'date' : '2018/11/25 00:40:54'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 4,\r\n 'reference' : '960898d0',\r\n 'subtotal' : '13.47',\r\n 'tax' : '53.45',\r\n 'discount' : '-15.55',\r\n 'total' : '26.98',\r\n 'date' : '2018/11/23 05:35:18',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Dianne',\r\n 'lastName' : 'Prince',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 5,\r\n 'name' : 'Delivered',\r\n 'color': 'green-800',\r\n 'date' : '2018/10/26 16:12:47'\r\n },\r\n {\r\n 'id' : 4,\r\n 'name' : 'Shipped',\r\n 'color': 'purple-500',\r\n 'date' : '2018/02/06 06:42:37'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '787d49b1',\r\n 'amount' : '26.98',\r\n 'method' : 'Check',\r\n 'date' : '2018/03/07 05:50:57'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'FedEx',\r\n 'weight' : '11.93',\r\n 'fee' : '5.00',\r\n 'date' : '2018/03/21 07:08:26'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 5,\r\n 'reference' : '2d7f68de',\r\n 'subtotal' : '46.93',\r\n 'tax' : '12.14',\r\n 'discount' : '-19.16',\r\n 'total' : '12.97',\r\n 'date' : '2018/01/13 06:21:21',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Frankie',\r\n 'lastName' : 'Hewitt',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 8,\r\n 'name' : 'Payment error',\r\n 'color': 'red-900',\r\n 'date' : '2018/02/01 09:21:46'\r\n },\r\n {\r\n 'id' : 6,\r\n 'name' : 'Canceled',\r\n 'color': 'pink-500',\r\n 'date' : '2018/11/16 04:48:32'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': 'cd8c4727',\r\n 'amount' : '12.97',\r\n 'method' : 'Bank-wire',\r\n 'date' : '2018/05/15 21:15:32'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '5.43',\r\n 'fee' : '3.00',\r\n 'date' : '2018/01/06 00:51:59'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 6,\r\n 'reference' : '9c991708',\r\n 'subtotal' : '32.55',\r\n 'tax' : '11.81',\r\n 'discount' : '-12.33',\r\n 'total' : '30.96',\r\n 'date' : '2018/01/17 04:21:08',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Cole',\r\n 'lastName' : 'Holcomb',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 3,\r\n 'name' : 'Preparing the order',\r\n 'color': 'orange-500',\r\n 'date' : '2018/11/30 01:04:32'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Payment accepted',\r\n 'color': 'green-500',\r\n 'date' : '2018/11/12 21:27:18'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': 'a41f4b7c',\r\n 'amount' : '30.96',\r\n 'method' : 'Check',\r\n 'date' : '2018/04/27 03:59:22'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'FedEx',\r\n 'weight' : '6.05',\r\n 'fee' : '4.00',\r\n 'date' : '2018/09/10 11:28:47'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 7,\r\n 'reference' : '7683b54d',\r\n 'subtotal' : '14.08',\r\n 'tax' : '74.96',\r\n 'discount' : '-16.60',\r\n 'total' : '63.36',\r\n 'date' : '2018/06/14 14:49:47',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Merrill',\r\n 'lastName' : 'Richardson',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 11,\r\n 'name' : 'Awaiting PayPal payment',\r\n 'color': 'blue-500',\r\n 'date' : '2018/09/03 18:53:02'\r\n },\r\n {\r\n 'id' : 13,\r\n 'name' : 'On pre-order (not paid)',\r\n 'color': 'purple-300',\r\n 'date' : '2018/12/13 18:14:40'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': 1974588,\r\n 'amount' : '63.36',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/11/28 22:24:58'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'FedEx',\r\n 'weight' : '2.89',\r\n 'fee' : '3.00',\r\n 'date' : '2018/02/10 09:03:44'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 8,\r\n 'reference' : 'c1de0f75',\r\n 'subtotal' : '13.77',\r\n 'tax' : '55.78',\r\n 'discount' : '-17.20',\r\n 'total' : '45.74',\r\n 'date' : '2018/01/18 01:31:47',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Morgan',\r\n 'lastName' : 'Pitts',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 4,\r\n 'name' : 'Shipped',\r\n 'color': 'purple-500',\r\n 'date' : '2018/04/29 07:57:43'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Preparing the order',\r\n 'color': 'orange-500',\r\n 'date' : '2018/04/23 11:14:38'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '1e704aaf',\r\n 'amount' : '45.74',\r\n 'method' : 'Credit Card',\r\n 'date' : '2018/06/08 03:50:41'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '6.35',\r\n 'fee' : '2.00',\r\n 'date' : '2018/06/01 09:18:26'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 9,\r\n 'reference' : '35a4dbc6',\r\n 'subtotal' : '56.49',\r\n 'tax' : '11.44',\r\n 'discount' : '-17.45',\r\n 'total' : '15.31',\r\n 'date' : '2018/02/14 14:22:58',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Krista',\r\n 'lastName' : 'Mathis',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 12,\r\n 'name' : 'Remote payment accepted',\r\n 'color': 'green-500',\r\n 'date' : '2018/07/15 15:48:00'\r\n },\r\n {\r\n 'id' : 14,\r\n 'name' : 'Awaiting Cash-on-delivery payment',\r\n 'color': 'blue-500',\r\n 'date' : '2018/11/08 18:30:15'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '762c4e1a',\r\n 'amount' : '15.31',\r\n 'method' : 'Bank-wire',\r\n 'date' : '2018/06/19 14:52:53'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '7.93',\r\n 'fee' : '8.00',\r\n 'date' : '2018/08/25 15:18:55'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 10,\r\n 'reference' : 'a8bc5b17',\r\n 'subtotal' : '29.34',\r\n 'tax' : '87.50',\r\n 'discount' : '-18.11',\r\n 'total' : '20.97',\r\n 'date' : '2018/10/23 03:02:55',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Hayden',\r\n 'lastName' : 'Fitzgerald',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 5,\r\n 'name' : 'Delivered',\r\n 'color': 'green-800',\r\n 'date' : '2018/05/02 09:53:55'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Payment accepted',\r\n 'color': 'green-500',\r\n 'date' : '2018/07/11 05:33:31'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '3dce47a3',\r\n 'amount' : '20.97',\r\n 'method' : 'Credit Card',\r\n 'date' : '2018/07/28 23:53:49'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'TNT',\r\n 'weight' : '9.20',\r\n 'fee' : '2.00',\r\n 'date' : '2018/08/05 08:45:55'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 11,\r\n 'reference' : '54ab8191',\r\n 'subtotal' : '50.35',\r\n 'tax' : '71.75',\r\n 'discount' : '-10.46',\r\n 'total' : '72.30',\r\n 'date' : '2018/07/28 13:22:49',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Cotton',\r\n 'lastName' : 'Carlson',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 9,\r\n 'name' : 'On pre-order (paid)',\r\n 'color': 'purple-300',\r\n 'date' : '2018/02/26 14:15:38'\r\n },\r\n {\r\n 'id' : 4,\r\n 'name' : 'Shipped',\r\n 'color': 'purple-500',\r\n 'date' : '2018/10/17 03:32:39'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': 'f4154419',\r\n 'amount' : '72.30',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/03/07 15:10:12'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '2.81',\r\n 'fee' : '7.00',\r\n 'date' : '2018/05/01 11:15:22'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 12,\r\n 'reference' : '6919050',\r\n 'subtotal' : '81.95',\r\n 'tax' : '22.44',\r\n 'discount' : '-10.89',\r\n 'total' : '42.54',\r\n 'date' : '2018/06/07 17:54:36',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Kaye',\r\n 'lastName' : 'Baldwin',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 10,\r\n 'name' : 'Awaiting bank wire payment',\r\n 'color': 'blue-500',\r\n 'date' : '2018/09/01 20:50:07'\r\n },\r\n {\r\n 'id' : 12,\r\n 'name' : 'Remote payment accepted',\r\n 'color': 'green-500',\r\n 'date' : '2018/02/13 21:19:04'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': 44464979,\r\n 'amount' : '42.54',\r\n 'method' : 'Credit Card',\r\n 'date' : '2018/06/30 11:59:49'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'FedEx',\r\n 'weight' : '5.52',\r\n 'fee' : '2.00',\r\n 'date' : '2018/03/15 07:08:37'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 13,\r\n 'reference' : '1d4e89f0',\r\n 'subtotal' : '67.10',\r\n 'tax' : '46.96',\r\n 'discount' : '-11.64',\r\n 'total' : '97.49',\r\n 'date' : '2018/02/06 13:26:55',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Iva',\r\n 'lastName' : 'Clark',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 6,\r\n 'name' : 'Canceled',\r\n 'color': 'pink-500',\r\n 'date' : '2018/03/31 03:01:12'\r\n },\r\n {\r\n 'id' : 8,\r\n 'name' : 'Payment error',\r\n 'color': 'red-900',\r\n 'date' : '2018/03/11 18:53:35'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '2aef4aa3',\r\n 'amount' : '97.49',\r\n 'method' : 'Check',\r\n 'date' : '2018/05/13 13:28:52'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'TNT',\r\n 'weight' : '5.37',\r\n 'fee' : '6.00',\r\n 'date' : '2018/04/22 01:48:15'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 14,\r\n 'reference' : 'd897564e',\r\n 'subtotal' : '55.50',\r\n 'tax' : '48.92',\r\n 'discount' : '-18.45',\r\n 'total' : '16.95',\r\n 'date' : '2018/01/17 04:23:11',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Shauna',\r\n 'lastName' : 'Rosales',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 7,\r\n 'name' : 'Refunded',\r\n 'color': 'red-500',\r\n 'date' : '2018/12/29 15:34:46'\r\n },\r\n {\r\n 'id' : 11,\r\n 'name' : 'Awaiting PayPal payment',\r\n 'color': 'blue-500',\r\n 'date' : '2018/07/14 19:10:43'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': 'b7ea43c9',\r\n 'amount' : '16.95',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/07/11 07:18:06'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'TNT',\r\n 'weight' : '6.49',\r\n 'fee' : '6.00',\r\n 'date' : '2018/01/05 13:42:13'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 15,\r\n 'reference' : '1a803de2',\r\n 'subtotal' : '13.73',\r\n 'tax' : '64.42',\r\n 'discount' : '-19.64',\r\n 'total' : '20.34',\r\n 'date' : '2018/09/26 14:26:33',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Carroll',\r\n 'lastName' : 'Dotson',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'Awaiting check payment',\r\n 'color': 'blue-500',\r\n 'date' : '2018/12/21 10:42:21'\r\n },\r\n {\r\n 'id' : 6,\r\n 'name' : 'Canceled',\r\n 'color': 'pink-500',\r\n 'date' : '2018/02/11 05:58:55'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '0633458c',\r\n 'amount' : '20.34',\r\n 'method' : 'Check',\r\n 'date' : '2018/07/17 20:54:14'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'TNT',\r\n 'weight' : '3.30',\r\n 'fee' : '2.00',\r\n 'date' : '2018/11/04 14:08:16'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 16,\r\n 'reference' : '7d90eaa6',\r\n 'subtotal' : '99.07',\r\n 'tax' : '31.36',\r\n 'discount' : '-18.23',\r\n 'total' : '10.64',\r\n 'date' : '2018/08/10 14:28:10',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Jeannie',\r\n 'lastName' : 'Reese',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 9,\r\n 'name' : 'On pre-order (paid)',\r\n 'color': 'purple-300',\r\n 'date' : '2018/06/20 08:37:46'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Payment accepted',\r\n 'color': 'green-500',\r\n 'date' : '2018/01/01 01:42:21'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '45f7440a',\r\n 'amount' : '10.64',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/11/23 11:14:47'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '9.94',\r\n 'fee' : '6.00',\r\n 'date' : '2018/04/30 19:17:39'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 17,\r\n 'reference' : 'cf9b4bfc',\r\n 'subtotal' : '96.93',\r\n 'tax' : '74.32',\r\n 'discount' : '-12.63',\r\n 'total' : '27.06',\r\n 'date' : '2018/11/10 16:54:11',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Dena',\r\n 'lastName' : 'Rowe',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 5,\r\n 'name' : 'Delivered',\r\n 'color': 'green-800',\r\n 'date' : '2018/03/23 00:18:52'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Preparing the order',\r\n 'color': 'orange-500',\r\n 'date' : '2018/03/22 04:48:12'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '966f4c8e',\r\n 'amount' : '27.06',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/07/10 17:22:44'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'FedEx',\r\n 'weight' : '6.81',\r\n 'fee' : '3.00',\r\n 'date' : '2018/01/23 07:31:46'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 18,\r\n 'reference' : '07a938c4',\r\n 'subtotal' : '67.73',\r\n 'tax' : '33.33',\r\n 'discount' : '-12.33',\r\n 'total' : '91.50',\r\n 'date' : '2018/08/26 16:24:38',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Blankenship',\r\n 'lastName' : 'Lynch',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 6,\r\n 'name' : 'Canceled',\r\n 'color': 'pink-500',\r\n 'date' : '2018/03/24 22:56:35'\r\n },\r\n {\r\n 'id' : 4,\r\n 'name' : 'Shipped',\r\n 'color': 'purple-500',\r\n 'date' : '2018/04/09 13:33:26'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '411a4e97',\r\n 'amount' : '91.50',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/02/05 05:35:52'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '6.11',\r\n 'fee' : '7.00',\r\n 'date' : '2018/10/20 10:46:31'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 19,\r\n 'reference' : 'd460f4ff',\r\n 'subtotal' : '15.83',\r\n 'tax' : '41.90',\r\n 'discount' : '-16.54',\r\n 'total' : '47.99',\r\n 'date' : '2018/01/04 21:13:53',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Whitley',\r\n 'lastName' : 'Mcgee',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 7,\r\n 'name' : 'Refunded',\r\n 'color': 'red-500',\r\n 'date' : '2018/08/10 17:14:57'\r\n },\r\n {\r\n 'id' : 5,\r\n 'name' : 'Delivered',\r\n 'color': 'green-800',\r\n 'date' : '2018/03/30 01:38:14'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '761943c2',\r\n 'amount' : '47.99',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/10/11 20:10:46'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '5.51',\r\n 'fee' : '5.00',\r\n 'date' : '2018/08/28 21:24:36'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : 20,\r\n 'reference' : 'ba6a946d',\r\n 'subtotal' : '36.84',\r\n 'tax' : '20.12',\r\n 'discount' : '-14.57',\r\n 'total' : '44.40',\r\n 'date' : '2018/02/24 00:57:18',\r\n 'customer' : {\r\n 'id' : 1,\r\n 'firstName' : 'Hood',\r\n 'lastName' : 'Hodges',\r\n 'avatar' : 'assets/images/avatars/Abbott.jpg',\r\n 'company' : 'Saois',\r\n 'jobTitle' : 'Digital Archivist',\r\n 'email' : 'abbott@withinpixels.com',\r\n 'phone' : '+1-202-555-0175',\r\n 'invoiceAddress' : {\r\n 'address': '704 6th Ave, New York, NY 10010, USA',\r\n 'lat' : 40.7424739,\r\n 'lng' : -73.99283919999999\r\n },\r\n 'shippingAddress': {\r\n 'address': '377 E South Omaha Bridge Rd, Council Bluffs, IA 51501, USA',\r\n 'lat' : 41.2183223,\r\n 'lng' : -95.8420876\r\n }\r\n },\r\n 'products' : [\r\n {\r\n 'id' : 1,\r\n 'name' : 'A Walk Amongst Friends - Canvas Print',\r\n 'price' : '10.24',\r\n 'quantity': 1,\r\n 'total' : '10.24',\r\n 'image' : 'assets/images/ecommerce/a-walk-amongst-friends.jpg'\r\n },\r\n {\r\n 'id' : 2,\r\n 'name' : 'Lago di Braies - Canvas Print',\r\n 'price' : '24.62',\r\n 'quantity': 1,\r\n 'total' : '24.62',\r\n 'image' : 'assets/images/ecommerce/lago-di-braies.jpg'\r\n },\r\n {\r\n 'id' : 3,\r\n 'name' : 'Never Stop Changing - Canvas Print',\r\n 'price' : '49.29',\r\n 'quantity': 1,\r\n 'total' : '49.29',\r\n 'image' : 'assets/images/ecommerce/never-stop-changing.jpg'\r\n }\r\n ],\r\n 'status' : [\r\n {\r\n 'id' : 10,\r\n 'name' : 'Awaiting bank wire payment',\r\n 'color': 'blue-500',\r\n 'date' : '2018/05/19 11:09:56'\r\n },\r\n {\r\n 'id' : 12,\r\n 'name' : 'Remote payment accepted',\r\n 'color': 'green-500',\r\n 'date' : '2018/03/27 05:02:33'\r\n }\r\n ],\r\n 'payment' : {\r\n 'transactionId': '4af94368',\r\n 'amount' : '44.40',\r\n 'method' : 'PayPal',\r\n 'date' : '2018/11/11 14:25:39'\r\n },\r\n 'shippingDetails': [\r\n {\r\n 'tracking': '',\r\n 'carrier' : 'USPS',\r\n 'weight' : '3.63',\r\n 'fee' : '5.00',\r\n 'date' : '2018/03/01 09:07:49'\r\n }\r\n ]\r\n }\r\n ];\r\n}\r\n","import { InMemoryDbService } from 'angular-in-memory-web-api';\r\n\r\nimport { ProjectDashboardDb } from 'app/fake-db/dashboard-project';\r\nimport { AnalyticsDashboardDb } from 'app/fake-db/dashboard-analytics';\r\nimport { CalendarFakeDb } from 'app/fake-db/calendar';\r\nimport { ECommerceFakeDb } from 'app/fake-db/e-commerce';\r\nimport { AcademyFakeDb } from 'app/fake-db/academy';\r\nimport { MailFakeDb } from 'app/fake-db/mail';\r\nimport { ChatFakeDb } from 'app/fake-db/chat';\r\nimport { FileManagerFakeDb } from 'app/fake-db/file-manager';\r\nimport { ContactsFakeDb } from 'app/fake-db/contacts';\r\nimport { TodoFakeDb } from 'app/fake-db/todo';\r\nimport { ScrumboardFakeDb } from 'app/fake-db/scrumboard';\r\nimport { InvoiceFakeDb } from 'app/fake-db/invoice';\r\nimport { ProfileFakeDb } from 'app/fake-db/profile';\r\nimport { SearchFakeDb } from 'app/fake-db/search';\r\nimport { FaqFakeDb } from 'app/fake-db/faq';\r\nimport { KnowledgeBaseFakeDb } from 'app/fake-db/knowledge-base';\r\nimport { IconsFakeDb } from 'app/fake-db/icons';\r\nimport { ChatPanelFakeDb } from 'app/fake-db/chat-panel';\r\nimport { QuickPanelFakeDb } from 'app/fake-db/quick-panel';\r\n\r\nexport class FakeDbService implements InMemoryDbService\r\n{\r\n createDb(): any\r\n {\r\n return {\r\n // Dashboards\r\n 'project-dashboard-projects' : ProjectDashboardDb.projects,\r\n 'project-dashboard-widgets' : ProjectDashboardDb.widgets,\r\n 'analytics-dashboard-widgets': AnalyticsDashboardDb.widgets,\r\n\r\n // Calendar\r\n 'calendar': CalendarFakeDb.data,\r\n\r\n // E-Commerce\r\n 'e-commerce-products' : ECommerceFakeDb.products,\r\n 'e-commerce-orders' : ECommerceFakeDb.orders,\r\n\r\n // Academy\r\n 'academy-categories': AcademyFakeDb.categories,\r\n 'academy-courses' : AcademyFakeDb.courses,\r\n 'academy-course' : AcademyFakeDb.course,\r\n\r\n // Mail\r\n 'mail-mails' : MailFakeDb.mails,\r\n 'mail-folders': MailFakeDb.folders,\r\n 'mail-filters': MailFakeDb.filters,\r\n 'mail-labels' : MailFakeDb.labels,\r\n\r\n // Chat\r\n 'chat-contacts': ChatFakeDb.contacts,\r\n 'chat-chats' : ChatFakeDb.chats,\r\n 'chat-user' : ChatFakeDb.user,\r\n\r\n // File Manager\r\n 'file-manager': FileManagerFakeDb.files,\r\n\r\n // Contacts\r\n 'contacts-contacts': ContactsFakeDb.contacts,\r\n 'contacts-user' : ContactsFakeDb.user,\r\n\r\n // Todo\r\n 'todo-todos' : TodoFakeDb.todos,\r\n 'todo-filters': TodoFakeDb.filters,\r\n 'todo-tags' : TodoFakeDb.tags,\r\n\r\n // Scrumboard\r\n 'scrumboard-boards': ScrumboardFakeDb.boards,\r\n\r\n // Invoice\r\n 'invoice': InvoiceFakeDb.invoice,\r\n\r\n // Profile\r\n 'profile-timeline' : ProfileFakeDb.timeline,\r\n 'profile-photos-videos': ProfileFakeDb.photosVideos,\r\n 'profile-about' : ProfileFakeDb.about,\r\n\r\n // Search\r\n 'search': SearchFakeDb.search,\r\n\r\n // FAQ\r\n 'faq': FaqFakeDb.data,\r\n\r\n // Knowledge base\r\n 'knowledge-base': KnowledgeBaseFakeDb.data,\r\n\r\n // Icons\r\n 'icons': IconsFakeDb.icons,\r\n\r\n // Chat Panel\r\n 'chat-panel-contacts' : ChatPanelFakeDb.contacts,\r\n 'chat-panel-chats': ChatPanelFakeDb.chats,\r\n 'chat-panel-user': ChatPanelFakeDb.user,\r\n\r\n // Quick Panel\r\n 'quick-panel-notes' : QuickPanelFakeDb.notes,\r\n 'quick-panel-events': QuickPanelFakeDb.events\r\n };\r\n }\r\n}\r\n","export class FaqFakeDb\r\n{\r\n public static data = [\r\n {\r\n 'question': 'Proident tempor est nulla irure ad est?',\r\n 'answer': 'Id nulla nulla proident deserunt deserunt proident in quis. Cillum reprehenderit labore id anim laborum.'\r\n },\r\n {\r\n 'question': 'Ullamco duis commodo sint ad aliqua aute?',\r\n 'answer': 'Sunt laborum enim nostrud ea fugiat cillum mollit aliqua exercitation ad elit.'\r\n },\r\n {\r\n 'question': 'Eiusmod non occaecat pariatur Lorem in ex?',\r\n 'answer': 'Nostrud anim mollit incididunt qui qui sit commodo duis. Anim amet irure aliquip duis nostrud sit quis fugiat ullamco non dolor labore. Lorem sunt voluptate laboris culpa proident. Aute eiusmod aliqua exercitation irure exercitation qui laboris mollit occaecat eu occaecat fugiat.'\r\n },\r\n {\r\n 'question': 'Lorem magna cillum consequat consequat mollit?',\r\n 'answer': 'Velit ipsum proident ea incididunt et. Consectetur eiusmod laborum voluptate duis occaecat ullamco sint enim proident.'\r\n },\r\n {\r\n 'question': 'Quis irure cupidatat ad consequat reprehenderit excepteur?',\r\n 'answer': 'Esse nisi mollit aliquip mollit aute consequat adipisicing. Do excepteur dolore proident cupidatat pariatur irure consequat incididunt.'\r\n },\r\n {\r\n 'question': 'Officia voluptate tempor ut mollit ea cillum?',\r\n 'answer': 'Deserunt veniam reprehenderit do elit magna ut.'\r\n },\r\n {\r\n 'question': 'Sunt fugiat officia nisi minim sunt duis?',\r\n 'answer': 'Eiusmod eiusmod sint aliquip exercitation cillum. Magna nulla officia ex consectetur ea ad excepteur in qui.'\r\n },\r\n {\r\n 'question': 'Non cupidatat enim quis aliquip minim laborum?',\r\n 'answer': 'Qui cillum eiusmod nostrud sunt dolore velit nostrud labore voluptate ad dolore. Eu Lorem anim pariatur aliqua. Ullamco ut dolor velit esse occaecat dolore eu cillum commodo qui. Nulla dolor consequat voluptate magna ut commodo magna consectetur non aute proident.'\r\n },\r\n {\r\n 'question': 'Dolor ex occaecat magna labore laboris qui?',\r\n 'answer': 'Incididunt qui excepteur eiusmod elit cillum occaecat voluptate cillum nostrud. Dolor ullamco ullamco eiusmod do sunt adipisicing pariatur. In esse esse labore id reprehenderit sint do. Pariatur culpa dolor tempor qui excepteur duis do anim minim ipsum.'\r\n },\r\n {\r\n 'question': 'Nisi et ullamco minim ea proident tempor?',\r\n 'answer': 'Dolor veniam dolor cillum Lorem magna nisi in occaecat nulla dolor ea eiusmod.'\r\n },\r\n {\r\n 'question': 'Amet sunt et quis amet commodo quis?',\r\n 'answer': 'Nulla dolore consequat aliqua sint consequat elit qui occaecat et.'\r\n },\r\n {\r\n 'question': 'Ut eiusmod ex ea eiusmod culpa incididunt?',\r\n 'answer': 'Fugiat non incididunt officia ex incididunt occaecat. Voluptate nostrud culpa aliquip mollit incididunt non dolore.'\r\n },\r\n {\r\n 'question': 'Proident reprehenderit laboris pariatur ut et nisi?',\r\n 'answer': 'Reprehenderit proident ut ad cillum quis velit quis aliqua ut aliquip tempor ullamco.'\r\n },\r\n {\r\n 'question': 'Aliqua aliquip aliquip aliquip et exercitation aute?',\r\n 'answer': 'Adipisicing Lorem tempor ex anim. Labore tempor laboris nostrud dolore voluptate ullamco. Fugiat ex deserunt anim minim esse velit laboris aute ea duis incididunt. Elit irure id Lorem incididunt laborum aliquip consectetur est irure sunt. Ut labore anim nisi aliqua tempor laborum nulla cillum. Duis irure consequat cillum magna cillum eiusmod ut. Et exercitation voluptate quis deserunt elit quis dolor deserunt ex ex esse ex.'\r\n }\r\n ];\r\n}\r\n","export class FileManagerFakeDb\r\n{\r\n public static files = [\r\n {\r\n 'name' : 'Work Documents',\r\n 'type' : 'folder',\r\n 'owner' : 'me',\r\n 'size' : '',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true\r\n },\r\n {\r\n 'name' : 'Public Documents',\r\n 'type' : 'folder',\r\n 'owner' : 'public',\r\n 'size' : '',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true\r\n },\r\n {\r\n 'name' : 'Private Documents',\r\n 'type' : 'folder',\r\n 'owner' : 'me',\r\n 'size' : '',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true\r\n },\r\n {\r\n 'name' : 'Ongoing projects',\r\n 'type' : 'document',\r\n 'owner' : 'Emily Bennett',\r\n 'size' : '1.2 Mb',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true,\r\n 'preview' : 'assets/images/file-manager/sample-file-preview.jpg'\r\n },\r\n {\r\n 'name' : 'Shopping list',\r\n 'type' : 'document',\r\n 'owner' : 'Emily Bennett',\r\n 'size' : '980 Kb',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true,\r\n 'preview' : 'assets/images/file-manager/sample-file-preview.jpg'\r\n },\r\n {\r\n 'name' : 'Invoices',\r\n 'type' : 'spreadsheet',\r\n 'owner' : 'Emily Bennett',\r\n 'size' : '750 Kb',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true,\r\n 'preview' : 'assets/images/file-manager/sample-file-preview.jpg'\r\n },\r\n {\r\n 'name' : 'Crash logs',\r\n 'type' : 'document',\r\n 'owner' : 'Emily Bennett',\r\n 'size' : '980 Mb',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true,\r\n 'preview' : 'assets/images/file-manager/sample-file-preview.jpg'\r\n },\r\n {\r\n 'name' : 'System logs',\r\n 'type' : 'document',\r\n 'owner' : 'Emily Bennett',\r\n 'size' : '52 Kb',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true,\r\n 'preview' : 'assets/images/file-manager/sample-file-preview.jpg'\r\n },\r\n {\r\n 'name' : 'Prices',\r\n 'type' : 'spreadsheet',\r\n 'owner' : 'Emily Bennett',\r\n 'size' : '27 Mb',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true,\r\n 'preview' : 'assets/images/file-manager/sample-file-preview.jpg'\r\n },\r\n {\r\n 'name' : 'Anabelle Manual',\r\n 'type' : 'document',\r\n 'owner' : 'Emily Bennett',\r\n 'size' : '1.1 Kb',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true,\r\n 'preview' : 'assets/images/file-manager/sample-file-preview.jpg'\r\n },\r\n {\r\n 'name' : 'Steam summer sale budget',\r\n 'type' : 'spreadsheet',\r\n 'owner' : 'Emily Bennett',\r\n 'size' : '505 Kb',\r\n 'modified' : 'July 8, 2017',\r\n 'opened' : 'July 8, 2017',\r\n 'created' : 'July 8, 2017',\r\n 'extention': '',\r\n 'location' : 'My Files > Documents',\r\n 'offline' : true,\r\n 'preview' : 'assets/images/file-manager/sample-file-preview.jpg'\r\n }\r\n ];\r\n\r\n}\r\n","export class IconsFakeDb\r\n{\r\n public static icons = [\r\n {\r\n 'name' : '3d_rotation',\r\n 'ligature': '3d_rotation',\r\n 'tags' : ['3d_rotation']\r\n },\r\n {\r\n 'name' : '4k',\r\n 'ligature': '4k',\r\n 'tags' : ['4k']\r\n },\r\n {\r\n 'name' : '360',\r\n 'ligature': '360',\r\n 'tags' : ['360']\r\n },\r\n {\r\n 'name' : 'ac_unit',\r\n 'ligature': 'ac_unit',\r\n 'tags' : ['ac_unit']\r\n },\r\n {\r\n 'name' : 'access_alarm',\r\n 'ligature': 'access_alarm',\r\n 'tags' : ['access_alarm']\r\n },\r\n {\r\n 'name' : 'access_alarms',\r\n 'ligature': 'access_alarms',\r\n 'tags' : ['access_alarms']\r\n },\r\n {\r\n 'name' : 'access_time',\r\n 'ligature': 'access_time',\r\n 'tags' : ['access_time']\r\n },\r\n {\r\n 'name' : 'accessibility_new',\r\n 'ligature': 'accessibility_new',\r\n 'tags' : ['accessibility_new']\r\n },\r\n {\r\n 'name' : 'accessibility',\r\n 'ligature': 'accessibility',\r\n 'tags' : ['accessibility']\r\n },\r\n {\r\n 'name' : 'accessible_forward',\r\n 'ligature': 'accessible_forward',\r\n 'tags' : ['accessible_forward']\r\n },\r\n {\r\n 'name' : 'accessible',\r\n 'ligature': 'accessible',\r\n 'tags' : ['accessible']\r\n },\r\n {\r\n 'name' : 'account_balance_wallet',\r\n 'ligature': 'account_balance_wallet',\r\n 'tags' : ['account_balance_wallet']\r\n },\r\n {\r\n 'name' : 'account_balance',\r\n 'ligature': 'account_balance',\r\n 'tags' : ['account_balance']\r\n },\r\n {\r\n 'name' : 'account_box',\r\n 'ligature': 'account_box',\r\n 'tags' : ['account_box']\r\n },\r\n {\r\n 'name' : 'account_circle',\r\n 'ligature': 'account_circle',\r\n 'tags' : ['account_circle']\r\n },\r\n {\r\n 'name' : 'adb',\r\n 'ligature': 'adb',\r\n 'tags' : ['adb']\r\n },\r\n {\r\n 'name' : 'add_a_photo',\r\n 'ligature': 'add_a_photo',\r\n 'tags' : ['add_a_photo']\r\n },\r\n {\r\n 'name' : 'add_alarm',\r\n 'ligature': 'add_alarm',\r\n 'tags' : ['add_alarm']\r\n },\r\n {\r\n 'name' : 'add_alert',\r\n 'ligature': 'add_alert',\r\n 'tags' : ['add_alert']\r\n },\r\n {\r\n 'name' : 'add_box',\r\n 'ligature': 'add_box',\r\n 'tags' : ['add_box']\r\n },\r\n {\r\n 'name' : 'add_circle_outline',\r\n 'ligature': 'add_circle_outline',\r\n 'tags' : ['add_circle_outline']\r\n },\r\n {\r\n 'name' : 'add_circle',\r\n 'ligature': 'add_circle',\r\n 'tags' : ['add_circle']\r\n },\r\n {\r\n 'name' : 'add_comment',\r\n 'ligature': 'add_comment',\r\n 'tags' : ['add_comment']\r\n },\r\n {\r\n 'name' : 'add_location',\r\n 'ligature': 'add_location',\r\n 'tags' : ['add_location']\r\n },\r\n {\r\n 'name' : 'add_photo_alternate',\r\n 'ligature': 'add_photo_alternate',\r\n 'tags' : ['add_photo_alternate']\r\n },\r\n {\r\n 'name' : 'add_shopping_cart',\r\n 'ligature': 'add_shopping_cart',\r\n 'tags' : ['add_shopping_cart']\r\n },\r\n {\r\n 'name' : 'add_to_home_screen',\r\n 'ligature': 'add_to_home_screen',\r\n 'tags' : ['add_to_home_screen']\r\n },\r\n {\r\n 'name' : 'add_to_photos',\r\n 'ligature': 'add_to_photos',\r\n 'tags' : ['add_to_photos']\r\n },\r\n {\r\n 'name' : 'add_to_queue',\r\n 'ligature': 'add_to_queue',\r\n 'tags' : ['add_to_queue']\r\n },\r\n {\r\n 'name' : 'add',\r\n 'ligature': 'add',\r\n 'tags' : ['add']\r\n },\r\n {\r\n 'name' : 'adjust',\r\n 'ligature': 'adjust',\r\n 'tags' : ['adjust']\r\n },\r\n {\r\n 'name' : 'airline_seat_flat_angled',\r\n 'ligature': 'airline_seat_flat_angled',\r\n 'tags' : ['airline_seat_flat_angled']\r\n },\r\n {\r\n 'name' : 'airline_seat_flat',\r\n 'ligature': 'airline_seat_flat',\r\n 'tags' : ['airline_seat_flat']\r\n },\r\n {\r\n 'name' : 'airline_seat_individual_suite',\r\n 'ligature': 'airline_seat_individual_suite',\r\n 'tags' : ['airline_seat_individual_suite']\r\n },\r\n {\r\n 'name' : 'airline_seat_legroom_extra',\r\n 'ligature': 'airline_seat_legroom_extra',\r\n 'tags' : ['airline_seat_legroom_extra']\r\n },\r\n {\r\n 'name' : 'airline_seat_legroom_normal',\r\n 'ligature': 'airline_seat_legroom_normal',\r\n 'tags' : ['airline_seat_legroom_normal']\r\n },\r\n {\r\n 'name' : 'airline_seat_legroom_reduced',\r\n 'ligature': 'airline_seat_legroom_reduced',\r\n 'tags' : ['airline_seat_legroom_reduced']\r\n },\r\n {\r\n 'name' : 'airline_seat_recline_extra',\r\n 'ligature': 'airline_seat_recline_extra',\r\n 'tags' : ['airline_seat_recline_extra']\r\n },\r\n {\r\n 'name' : 'airline_seat_recline_normal',\r\n 'ligature': 'airline_seat_recline_normal',\r\n 'tags' : ['airline_seat_recline_normal']\r\n },\r\n {\r\n 'name' : 'airplanemode_active',\r\n 'ligature': 'airplanemode_active',\r\n 'tags' : ['airplanemode_active']\r\n },\r\n {\r\n 'name' : 'airplanemode_inactive',\r\n 'ligature': 'airplanemode_inactive',\r\n 'tags' : ['airplanemode_inactive']\r\n },\r\n {\r\n 'name' : 'airplay',\r\n 'ligature': 'airplay',\r\n 'tags' : ['airplay']\r\n },\r\n {\r\n 'name' : 'airport_shuttle',\r\n 'ligature': 'airport_shuttle',\r\n 'tags' : ['airport_shuttle']\r\n },\r\n {\r\n 'name' : 'alarm_add',\r\n 'ligature': 'alarm_add',\r\n 'tags' : ['alarm_add']\r\n },\r\n {\r\n 'name' : 'alarm_off',\r\n 'ligature': 'alarm_off',\r\n 'tags' : ['alarm_off']\r\n },\r\n {\r\n 'name' : 'alarm_on',\r\n 'ligature': 'alarm_on',\r\n 'tags' : ['alarm_on']\r\n },\r\n {\r\n 'name' : 'alarm',\r\n 'ligature': 'alarm',\r\n 'tags' : ['alarm']\r\n },\r\n {\r\n 'name' : 'album',\r\n 'ligature': 'album',\r\n 'tags' : ['album']\r\n },\r\n {\r\n 'name' : 'all_inbox',\r\n 'ligature': 'all_inbox',\r\n 'tags' : ['all_inbox']\r\n },\r\n {\r\n 'name' : 'all_inclusive',\r\n 'ligature': 'all_inclusive',\r\n 'tags' : ['all_inclusive']\r\n },\r\n {\r\n 'name' : 'all_out',\r\n 'ligature': 'all_out',\r\n 'tags' : ['all_out']\r\n },\r\n {\r\n 'name' : 'alternate_email',\r\n 'ligature': 'alternate_email',\r\n 'tags' : ['alternate_email']\r\n },\r\n {\r\n 'name' : 'android',\r\n 'ligature': 'android',\r\n 'tags' : ['android']\r\n },\r\n {\r\n 'name' : 'announcement',\r\n 'ligature': 'announcement',\r\n 'tags' : ['announcement']\r\n },\r\n {\r\n 'name' : 'apps',\r\n 'ligature': 'apps',\r\n 'tags' : ['apps']\r\n },\r\n {\r\n 'name' : 'archive',\r\n 'ligature': 'archive',\r\n 'tags' : ['archive']\r\n },\r\n {\r\n 'name' : 'arrow_back_ios',\r\n 'ligature': 'arrow_back_ios',\r\n 'tags' : ['arrow_back_ios']\r\n },\r\n {\r\n 'name' : 'arrow_back',\r\n 'ligature': 'arrow_back',\r\n 'tags' : ['arrow_back']\r\n },\r\n {\r\n 'name' : 'arrow_downward',\r\n 'ligature': 'arrow_downward',\r\n 'tags' : ['arrow_downward']\r\n },\r\n {\r\n 'name' : 'arrow_drop_down_circle',\r\n 'ligature': 'arrow_drop_down_circle',\r\n 'tags' : ['arrow_drop_down_circle']\r\n },\r\n {\r\n 'name' : 'arrow_drop_down',\r\n 'ligature': 'arrow_drop_down',\r\n 'tags' : ['arrow_drop_down']\r\n },\r\n {\r\n 'name' : 'arrow_drop_up',\r\n 'ligature': 'arrow_drop_up',\r\n 'tags' : ['arrow_drop_up']\r\n },\r\n {\r\n 'name' : 'arrow_forward_ios',\r\n 'ligature': 'arrow_forward_ios',\r\n 'tags' : ['arrow_forward_ios']\r\n },\r\n {\r\n 'name' : 'arrow_forward',\r\n 'ligature': 'arrow_forward',\r\n 'tags' : ['arrow_forward']\r\n },\r\n {\r\n 'name' : 'arrow_left',\r\n 'ligature': 'arrow_left',\r\n 'tags' : ['arrow_left']\r\n },\r\n {\r\n 'name' : 'arrow_right_alt',\r\n 'ligature': 'arrow_right_alt',\r\n 'tags' : ['arrow_right_alt']\r\n },\r\n {\r\n 'name' : 'arrow_right',\r\n 'ligature': 'arrow_right',\r\n 'tags' : ['arrow_right']\r\n },\r\n {\r\n 'name' : 'arrow_upward',\r\n 'ligature': 'arrow_upward',\r\n 'tags' : ['arrow_upward']\r\n },\r\n {\r\n 'name' : 'art_track',\r\n 'ligature': 'art_track',\r\n 'tags' : ['art_track']\r\n },\r\n {\r\n 'name' : 'aspect_ratio',\r\n 'ligature': 'aspect_ratio',\r\n 'tags' : ['aspect_ratio']\r\n },\r\n {\r\n 'name' : 'assessment',\r\n 'ligature': 'assessment',\r\n 'tags' : ['assessment']\r\n },\r\n {\r\n 'name' : 'assignment_ind',\r\n 'ligature': 'assignment_ind',\r\n 'tags' : ['assignment_ind']\r\n },\r\n {\r\n 'name' : 'assignment_late',\r\n 'ligature': 'assignment_late',\r\n 'tags' : ['assignment_late']\r\n },\r\n {\r\n 'name' : 'assignment_return',\r\n 'ligature': 'assignment_return',\r\n 'tags' : ['assignment_return']\r\n },\r\n {\r\n 'name' : 'assignment_returned',\r\n 'ligature': 'assignment_returned',\r\n 'tags' : ['assignment_returned']\r\n },\r\n {\r\n 'name' : 'assignment_turned_in',\r\n 'ligature': 'assignment_turned_in',\r\n 'tags' : ['assignment_turned_in']\r\n },\r\n {\r\n 'name' : 'assignment',\r\n 'ligature': 'assignment',\r\n 'tags' : ['assignment']\r\n },\r\n {\r\n 'name' : 'assistant_photo',\r\n 'ligature': 'assistant_photo',\r\n 'tags' : ['assistant_photo']\r\n },\r\n {\r\n 'name' : 'assistant',\r\n 'ligature': 'assistant',\r\n 'tags' : ['assistant']\r\n },\r\n {\r\n 'name' : 'atm',\r\n 'ligature': 'atm',\r\n 'tags' : ['atm']\r\n },\r\n {\r\n 'name' : 'attach_file',\r\n 'ligature': 'attach_file',\r\n 'tags' : ['attach_file']\r\n },\r\n {\r\n 'name' : 'attach_money',\r\n 'ligature': 'attach_money',\r\n 'tags' : ['attach_money']\r\n },\r\n {\r\n 'name' : 'attachment',\r\n 'ligature': 'attachment',\r\n 'tags' : ['attachment']\r\n },\r\n {\r\n 'name' : 'audiotrack',\r\n 'ligature': 'audiotrack',\r\n 'tags' : ['audiotrack']\r\n },\r\n {\r\n 'name' : 'autorenew',\r\n 'ligature': 'autorenew',\r\n 'tags' : ['autorenew']\r\n },\r\n {\r\n 'name' : 'av_timer',\r\n 'ligature': 'av_timer',\r\n 'tags' : ['av_timer']\r\n },\r\n {\r\n 'name' : 'backspace',\r\n 'ligature': 'backspace',\r\n 'tags' : ['backspace']\r\n },\r\n {\r\n 'name' : 'backup',\r\n 'ligature': 'backup',\r\n 'tags' : ['backup']\r\n },\r\n {\r\n 'name' : 'ballot',\r\n 'ligature': 'ballot',\r\n 'tags' : ['ballot']\r\n },\r\n {\r\n 'name' : 'bar_chart',\r\n 'ligature': 'bar_chart',\r\n 'tags' : ['bar_chart']\r\n },\r\n {\r\n 'name' : 'battery_alert',\r\n 'ligature': 'battery_alert',\r\n 'tags' : ['battery_alert']\r\n },\r\n {\r\n 'name' : 'battery_charging_full',\r\n 'ligature': 'battery_charging_full',\r\n 'tags' : ['battery_charging_full']\r\n },\r\n {\r\n 'name' : 'battery_full',\r\n 'ligature': 'battery_full',\r\n 'tags' : ['battery_full']\r\n },\r\n {\r\n 'name' : 'battery_std',\r\n 'ligature': 'battery_std',\r\n 'tags' : ['battery_std']\r\n },\r\n {\r\n 'name' : 'battery_unknown',\r\n 'ligature': 'battery_unknown',\r\n 'tags' : ['battery_unknown']\r\n },\r\n {\r\n 'name' : 'beach_access',\r\n 'ligature': 'beach_access',\r\n 'tags' : ['beach_access']\r\n },\r\n {\r\n 'name' : 'beenhere',\r\n 'ligature': 'beenhere',\r\n 'tags' : ['beenhere']\r\n },\r\n {\r\n 'name' : 'block',\r\n 'ligature': 'block',\r\n 'tags' : ['block']\r\n },\r\n {\r\n 'name' : 'bluetooth_audio',\r\n 'ligature': 'bluetooth_audio',\r\n 'tags' : ['bluetooth_audio']\r\n },\r\n {\r\n 'name' : 'bluetooth_connected',\r\n 'ligature': 'bluetooth_connected',\r\n 'tags' : ['bluetooth_connected']\r\n },\r\n {\r\n 'name' : 'bluetooth_disabled',\r\n 'ligature': 'bluetooth_disabled',\r\n 'tags' : ['bluetooth_disabled']\r\n },\r\n {\r\n 'name' : 'bluetooth_searching',\r\n 'ligature': 'bluetooth_searching',\r\n 'tags' : ['bluetooth_searching']\r\n },\r\n {\r\n 'name' : 'bluetooth',\r\n 'ligature': 'bluetooth',\r\n 'tags' : ['bluetooth']\r\n },\r\n {\r\n 'name' : 'blur_circular',\r\n 'ligature': 'blur_circular',\r\n 'tags' : ['blur_circular']\r\n },\r\n {\r\n 'name' : 'blur_linear',\r\n 'ligature': 'blur_linear',\r\n 'tags' : ['blur_linear']\r\n },\r\n {\r\n 'name' : 'blur_off',\r\n 'ligature': 'blur_off',\r\n 'tags' : ['blur_off']\r\n },\r\n {\r\n 'name' : 'blur_on',\r\n 'ligature': 'blur_on',\r\n 'tags' : ['blur_on']\r\n },\r\n {\r\n 'name' : 'book',\r\n 'ligature': 'book',\r\n 'tags' : ['book']\r\n },\r\n {\r\n 'name' : 'bookmark_border',\r\n 'ligature': 'bookmark_border',\r\n 'tags' : ['bookmark_border']\r\n },\r\n {\r\n 'name' : 'bookmark',\r\n 'ligature': 'bookmark',\r\n 'tags' : ['bookmark']\r\n },\r\n {\r\n 'name' : 'bookmarks',\r\n 'ligature': 'bookmarks',\r\n 'tags' : ['bookmarks']\r\n },\r\n {\r\n 'name' : 'border_all',\r\n 'ligature': 'border_all',\r\n 'tags' : ['border_all']\r\n },\r\n {\r\n 'name' : 'border_bottom',\r\n 'ligature': 'border_bottom',\r\n 'tags' : ['border_bottom']\r\n },\r\n {\r\n 'name' : 'border_clear',\r\n 'ligature': 'border_clear',\r\n 'tags' : ['border_clear']\r\n },\r\n {\r\n 'name' : 'border_horizontal',\r\n 'ligature': 'border_horizontal',\r\n 'tags' : ['border_horizontal']\r\n },\r\n {\r\n 'name' : 'border_inner',\r\n 'ligature': 'border_inner',\r\n 'tags' : ['border_inner']\r\n },\r\n {\r\n 'name' : 'border_left',\r\n 'ligature': 'border_left',\r\n 'tags' : ['border_left']\r\n },\r\n {\r\n 'name' : 'border_outer',\r\n 'ligature': 'border_outer',\r\n 'tags' : ['border_outer']\r\n },\r\n {\r\n 'name' : 'border_right',\r\n 'ligature': 'border_right',\r\n 'tags' : ['border_right']\r\n },\r\n {\r\n 'name' : 'border_style',\r\n 'ligature': 'border_style',\r\n 'tags' : ['border_style']\r\n },\r\n {\r\n 'name' : 'border_top',\r\n 'ligature': 'border_top',\r\n 'tags' : ['border_top']\r\n },\r\n {\r\n 'name' : 'border_vertical',\r\n 'ligature': 'border_vertical',\r\n 'tags' : ['border_vertical']\r\n },\r\n {\r\n 'name' : 'branding_watermark',\r\n 'ligature': 'branding_watermark',\r\n 'tags' : ['branding_watermark']\r\n },\r\n {\r\n 'name' : 'brightness_1',\r\n 'ligature': 'brightness_1',\r\n 'tags' : ['brightness_1']\r\n },\r\n {\r\n 'name' : 'brightness_2',\r\n 'ligature': 'brightness_2',\r\n 'tags' : ['brightness_2']\r\n },\r\n {\r\n 'name' : 'brightness_3',\r\n 'ligature': 'brightness_3',\r\n 'tags' : ['brightness_3']\r\n },\r\n {\r\n 'name' : 'brightness_4',\r\n 'ligature': 'brightness_4',\r\n 'tags' : ['brightness_4']\r\n },\r\n {\r\n 'name' : 'brightness_5',\r\n 'ligature': 'brightness_5',\r\n 'tags' : ['brightness_5']\r\n },\r\n {\r\n 'name' : 'brightness_6',\r\n 'ligature': 'brightness_6',\r\n 'tags' : ['brightness_6']\r\n },\r\n {\r\n 'name' : 'brightness_7',\r\n 'ligature': 'brightness_7',\r\n 'tags' : ['brightness_7']\r\n },\r\n {\r\n 'name' : 'brightness_auto',\r\n 'ligature': 'brightness_auto',\r\n 'tags' : ['brightness_auto']\r\n },\r\n {\r\n 'name' : 'brightness_high',\r\n 'ligature': 'brightness_high',\r\n 'tags' : ['brightness_high']\r\n },\r\n {\r\n 'name' : 'brightness_low',\r\n 'ligature': 'brightness_low',\r\n 'tags' : ['brightness_low']\r\n },\r\n {\r\n 'name' : 'brightness_medium',\r\n 'ligature': 'brightness_medium',\r\n 'tags' : ['brightness_medium']\r\n },\r\n {\r\n 'name' : 'broken_image',\r\n 'ligature': 'broken_image',\r\n 'tags' : ['broken_image']\r\n },\r\n {\r\n 'name' : 'brush',\r\n 'ligature': 'brush',\r\n 'tags' : ['brush']\r\n },\r\n {\r\n 'name' : 'bubble_chart',\r\n 'ligature': 'bubble_chart',\r\n 'tags' : ['bubble_chart']\r\n },\r\n {\r\n 'name' : 'bug_report',\r\n 'ligature': 'bug_report',\r\n 'tags' : ['bug_report']\r\n },\r\n {\r\n 'name' : 'build',\r\n 'ligature': 'build',\r\n 'tags' : ['build']\r\n },\r\n {\r\n 'name' : 'burst_mode',\r\n 'ligature': 'burst_mode',\r\n 'tags' : ['burst_mode']\r\n },\r\n {\r\n 'name' : 'business_center',\r\n 'ligature': 'business_center',\r\n 'tags' : ['business_center']\r\n },\r\n {\r\n 'name' : 'business',\r\n 'ligature': 'business',\r\n 'tags' : ['business']\r\n },\r\n {\r\n 'name' : 'cached',\r\n 'ligature': 'cached',\r\n 'tags' : ['cached']\r\n },\r\n {\r\n 'name' : 'cake',\r\n 'ligature': 'cake',\r\n 'tags' : ['cake']\r\n },\r\n {\r\n 'name' : 'calendar_today',\r\n 'ligature': 'calendar_today',\r\n 'tags' : ['calendar_today']\r\n },\r\n {\r\n 'name' : 'calendar_view_day',\r\n 'ligature': 'calendar_view_day',\r\n 'tags' : ['calendar_view_day']\r\n },\r\n {\r\n 'name' : 'call_end',\r\n 'ligature': 'call_end',\r\n 'tags' : ['call_end']\r\n },\r\n {\r\n 'name' : 'call_made',\r\n 'ligature': 'call_made',\r\n 'tags' : ['call_made']\r\n },\r\n {\r\n 'name' : 'call_merge',\r\n 'ligature': 'call_merge',\r\n 'tags' : ['call_merge']\r\n },\r\n {\r\n 'name' : 'call_missed_outgoing',\r\n 'ligature': 'call_missed_outgoing',\r\n 'tags' : ['call_missed_outgoing']\r\n },\r\n {\r\n 'name' : 'call_missed',\r\n 'ligature': 'call_missed',\r\n 'tags' : ['call_missed']\r\n },\r\n {\r\n 'name' : 'call_received',\r\n 'ligature': 'call_received',\r\n 'tags' : ['call_received']\r\n },\r\n {\r\n 'name' : 'call_split',\r\n 'ligature': 'call_split',\r\n 'tags' : ['call_split']\r\n },\r\n {\r\n 'name' : 'call_to_action',\r\n 'ligature': 'call_to_action',\r\n 'tags' : ['call_to_action']\r\n },\r\n {\r\n 'name' : 'call',\r\n 'ligature': 'call',\r\n 'tags' : ['call']\r\n },\r\n {\r\n 'name' : 'camera_alt',\r\n 'ligature': 'camera_alt',\r\n 'tags' : ['camera_alt']\r\n },\r\n {\r\n 'name' : 'camera_enhance',\r\n 'ligature': 'camera_enhance',\r\n 'tags' : ['camera_enhance']\r\n },\r\n {\r\n 'name' : 'camera_front',\r\n 'ligature': 'camera_front',\r\n 'tags' : ['camera_front']\r\n },\r\n {\r\n 'name' : 'camera_rear',\r\n 'ligature': 'camera_rear',\r\n 'tags' : ['camera_rear']\r\n },\r\n {\r\n 'name' : 'camera_roll',\r\n 'ligature': 'camera_roll',\r\n 'tags' : ['camera_roll']\r\n },\r\n {\r\n 'name' : 'camera',\r\n 'ligature': 'camera',\r\n 'tags' : ['camera']\r\n },\r\n {\r\n 'name' : 'cancel_presentation',\r\n 'ligature': 'cancel_presentation',\r\n 'tags' : ['cancel_presentation']\r\n },\r\n {\r\n 'name' : 'cancel',\r\n 'ligature': 'cancel',\r\n 'tags' : ['cancel']\r\n },\r\n {\r\n 'name' : 'card_giftcard',\r\n 'ligature': 'card_giftcard',\r\n 'tags' : ['card_giftcard']\r\n },\r\n {\r\n 'name' : 'card_membership',\r\n 'ligature': 'card_membership',\r\n 'tags' : ['card_membership']\r\n },\r\n {\r\n 'name' : 'card_travel',\r\n 'ligature': 'card_travel',\r\n 'tags' : ['card_travel']\r\n },\r\n {\r\n 'name' : 'casino',\r\n 'ligature': 'casino',\r\n 'tags' : ['casino']\r\n },\r\n {\r\n 'name' : 'cast_connected',\r\n 'ligature': 'cast_connected',\r\n 'tags' : ['cast_connected']\r\n },\r\n {\r\n 'name' : 'cast_for_education',\r\n 'ligature': 'cast_for_education',\r\n 'tags' : ['cast_for_education']\r\n },\r\n {\r\n 'name' : 'cast',\r\n 'ligature': 'cast',\r\n 'tags' : ['cast']\r\n },\r\n {\r\n 'name' : 'category',\r\n 'ligature': 'category',\r\n 'tags' : ['category']\r\n },\r\n {\r\n 'name' : 'center_focus_strong',\r\n 'ligature': 'center_focus_strong',\r\n 'tags' : ['center_focus_strong']\r\n },\r\n {\r\n 'name' : 'center_focus_weak',\r\n 'ligature': 'center_focus_weak',\r\n 'tags' : ['center_focus_weak']\r\n },\r\n {\r\n 'name' : 'change_history',\r\n 'ligature': 'change_history',\r\n 'tags' : ['change_history']\r\n },\r\n {\r\n 'name' : 'chat_bubble_outline',\r\n 'ligature': 'chat_bubble_outline',\r\n 'tags' : ['chat_bubble_outline']\r\n },\r\n {\r\n 'name' : 'chat_bubble',\r\n 'ligature': 'chat_bubble',\r\n 'tags' : ['chat_bubble']\r\n },\r\n {\r\n 'name' : 'chat',\r\n 'ligature': 'chat',\r\n 'tags' : ['chat']\r\n },\r\n {\r\n 'name' : 'check_box_outline_blank',\r\n 'ligature': 'check_box_outline_blank',\r\n 'tags' : ['check_box_outline_blank']\r\n },\r\n {\r\n 'name' : 'check_box',\r\n 'ligature': 'check_box',\r\n 'tags' : ['check_box']\r\n },\r\n {\r\n 'name' : 'check_circle_outline',\r\n 'ligature': 'check_circle_outline',\r\n 'tags' : ['check_circle_outline']\r\n },\r\n {\r\n 'name' : 'check_circle',\r\n 'ligature': 'check_circle',\r\n 'tags' : ['check_circle']\r\n },\r\n {\r\n 'name' : 'check',\r\n 'ligature': 'check',\r\n 'tags' : ['check']\r\n },\r\n {\r\n 'name' : 'chevron_left',\r\n 'ligature': 'chevron_left',\r\n 'tags' : ['chevron_left']\r\n },\r\n {\r\n 'name' : 'chevron_right',\r\n 'ligature': 'chevron_right',\r\n 'tags' : ['chevron_right']\r\n },\r\n {\r\n 'name' : 'child_care',\r\n 'ligature': 'child_care',\r\n 'tags' : ['child_care']\r\n },\r\n {\r\n 'name' : 'child_friendly',\r\n 'ligature': 'child_friendly',\r\n 'tags' : ['child_friendly']\r\n },\r\n {\r\n 'name' : 'chrome_reader_mode',\r\n 'ligature': 'chrome_reader_mode',\r\n 'tags' : ['chrome_reader_mode']\r\n },\r\n {\r\n 'name' : 'class',\r\n 'ligature': 'class',\r\n 'tags' : ['class']\r\n },\r\n {\r\n 'name' : 'clear_all',\r\n 'ligature': 'clear_all',\r\n 'tags' : ['clear_all']\r\n },\r\n {\r\n 'name' : 'clear',\r\n 'ligature': 'clear',\r\n 'tags' : ['clear']\r\n },\r\n {\r\n 'name' : 'close',\r\n 'ligature': 'close',\r\n 'tags' : ['close']\r\n },\r\n {\r\n 'name' : 'closed_caption',\r\n 'ligature': 'closed_caption',\r\n 'tags' : ['closed_caption']\r\n },\r\n {\r\n 'name' : 'cloud_circle',\r\n 'ligature': 'cloud_circle',\r\n 'tags' : ['cloud_circle']\r\n },\r\n {\r\n 'name' : 'cloud_done',\r\n 'ligature': 'cloud_done',\r\n 'tags' : ['cloud_done']\r\n },\r\n {\r\n 'name' : 'cloud_download',\r\n 'ligature': 'cloud_download',\r\n 'tags' : ['cloud_download']\r\n },\r\n {\r\n 'name' : 'cloud_off',\r\n 'ligature': 'cloud_off',\r\n 'tags' : ['cloud_off']\r\n },\r\n {\r\n 'name' : 'cloud_queue',\r\n 'ligature': 'cloud_queue',\r\n 'tags' : ['cloud_queue']\r\n },\r\n {\r\n 'name' : 'cloud_upload',\r\n 'ligature': 'cloud_upload',\r\n 'tags' : ['cloud_upload']\r\n },\r\n {\r\n 'name' : 'cloud',\r\n 'ligature': 'cloud',\r\n 'tags' : ['cloud']\r\n },\r\n {\r\n 'name' : 'code',\r\n 'ligature': 'code',\r\n 'tags' : ['code']\r\n },\r\n {\r\n 'name' : 'collections_bookmark',\r\n 'ligature': 'collections_bookmark',\r\n 'tags' : ['collections_bookmark']\r\n },\r\n {\r\n 'name' : 'collections',\r\n 'ligature': 'collections',\r\n 'tags' : ['collections']\r\n },\r\n {\r\n 'name' : 'color_lens',\r\n 'ligature': 'color_lens',\r\n 'tags' : ['color_lens']\r\n },\r\n {\r\n 'name' : 'colorize',\r\n 'ligature': 'colorize',\r\n 'tags' : ['colorize']\r\n },\r\n {\r\n 'name' : 'comment',\r\n 'ligature': 'comment',\r\n 'tags' : ['comment']\r\n },\r\n {\r\n 'name' : 'commute',\r\n 'ligature': 'commute',\r\n 'tags' : ['commute']\r\n },\r\n {\r\n 'name' : 'compare_arrows',\r\n 'ligature': 'compare_arrows',\r\n 'tags' : ['compare_arrows']\r\n },\r\n {\r\n 'name' : 'compare',\r\n 'ligature': 'compare',\r\n 'tags' : ['compare']\r\n },\r\n {\r\n 'name' : 'compass_calibration',\r\n 'ligature': 'compass_calibration',\r\n 'tags' : ['compass_calibration']\r\n },\r\n {\r\n 'name' : 'computer',\r\n 'ligature': 'computer',\r\n 'tags' : ['computer']\r\n },\r\n {\r\n 'name' : 'confirmation_number',\r\n 'ligature': 'confirmation_number',\r\n 'tags' : ['confirmation_number']\r\n },\r\n {\r\n 'name' : 'contact_mail',\r\n 'ligature': 'contact_mail',\r\n 'tags' : ['contact_mail']\r\n },\r\n {\r\n 'name' : 'contact_phone',\r\n 'ligature': 'contact_phone',\r\n 'tags' : ['contact_phone']\r\n },\r\n {\r\n 'name' : 'contact_support',\r\n 'ligature': 'contact_support',\r\n 'tags' : ['contact_support']\r\n },\r\n {\r\n 'name' : 'contacts',\r\n 'ligature': 'contacts',\r\n 'tags' : ['contacts']\r\n },\r\n {\r\n 'name' : 'control_camera',\r\n 'ligature': 'control_camera',\r\n 'tags' : ['control_camera']\r\n },\r\n {\r\n 'name' : 'control_point_duplicate',\r\n 'ligature': 'control_point_duplicate',\r\n 'tags' : ['control_point_duplicate']\r\n },\r\n {\r\n 'name' : 'control_point',\r\n 'ligature': 'control_point',\r\n 'tags' : ['control_point']\r\n },\r\n {\r\n 'name' : 'copyright',\r\n 'ligature': 'copyright',\r\n 'tags' : ['copyright']\r\n },\r\n {\r\n 'name' : 'create_new_folder',\r\n 'ligature': 'create_new_folder',\r\n 'tags' : ['create_new_folder']\r\n },\r\n {\r\n 'name' : 'create',\r\n 'ligature': 'create',\r\n 'tags' : ['create']\r\n },\r\n {\r\n 'name' : 'credit_card',\r\n 'ligature': 'credit_card',\r\n 'tags' : ['credit_card']\r\n },\r\n {\r\n 'name' : 'crop_3_2',\r\n 'ligature': 'crop_3_2',\r\n 'tags' : ['crop_3_2']\r\n },\r\n {\r\n 'name' : 'crop_5_4',\r\n 'ligature': 'crop_5_4',\r\n 'tags' : ['crop_5_4']\r\n },\r\n {\r\n 'name' : 'crop_7_5',\r\n 'ligature': 'crop_7_5',\r\n 'tags' : ['crop_7_5']\r\n },\r\n {\r\n 'name' : 'crop_16_9',\r\n 'ligature': 'crop_16_9',\r\n 'tags' : ['crop_16_9']\r\n },\r\n {\r\n 'name' : 'crop_din',\r\n 'ligature': 'crop_din',\r\n 'tags' : ['crop_din']\r\n },\r\n {\r\n 'name' : 'crop_free',\r\n 'ligature': 'crop_free',\r\n 'tags' : ['crop_free']\r\n },\r\n {\r\n 'name' : 'crop_landscape',\r\n 'ligature': 'crop_landscape',\r\n 'tags' : ['crop_landscape']\r\n },\r\n {\r\n 'name' : 'crop_original',\r\n 'ligature': 'crop_original',\r\n 'tags' : ['crop_original']\r\n },\r\n {\r\n 'name' : 'crop_portrait',\r\n 'ligature': 'crop_portrait',\r\n 'tags' : ['crop_portrait']\r\n },\r\n {\r\n 'name' : 'crop_rotate',\r\n 'ligature': 'crop_rotate',\r\n 'tags' : ['crop_rotate']\r\n },\r\n {\r\n 'name' : 'crop_square',\r\n 'ligature': 'crop_square',\r\n 'tags' : ['crop_square']\r\n },\r\n {\r\n 'name' : 'crop',\r\n 'ligature': 'crop',\r\n 'tags' : ['crop']\r\n },\r\n {\r\n 'name' : 'dashboard',\r\n 'ligature': 'dashboard',\r\n 'tags' : ['dashboard']\r\n },\r\n {\r\n 'name' : 'data_usage',\r\n 'ligature': 'data_usage',\r\n 'tags' : ['data_usage']\r\n },\r\n {\r\n 'name' : 'date_range',\r\n 'ligature': 'date_range',\r\n 'tags' : ['date_range']\r\n },\r\n {\r\n 'name' : 'dehaze',\r\n 'ligature': 'dehaze',\r\n 'tags' : ['dehaze']\r\n },\r\n {\r\n 'name' : 'delete_forever',\r\n 'ligature': 'delete_forever',\r\n 'tags' : ['delete_forever']\r\n },\r\n {\r\n 'name' : 'delete_outline',\r\n 'ligature': 'delete_outline',\r\n 'tags' : ['delete_outline']\r\n },\r\n {\r\n 'name' : 'delete_sweep',\r\n 'ligature': 'delete_sweep',\r\n 'tags' : ['delete_sweep']\r\n },\r\n {\r\n 'name' : 'delete',\r\n 'ligature': 'delete',\r\n 'tags' : ['delete']\r\n },\r\n {\r\n 'name' : 'departure_board',\r\n 'ligature': 'departure_board',\r\n 'tags' : ['departure_board']\r\n },\r\n {\r\n 'name' : 'description',\r\n 'ligature': 'description',\r\n 'tags' : ['description']\r\n },\r\n {\r\n 'name' : 'desktop_access_disabled',\r\n 'ligature': 'desktop_access_disabled',\r\n 'tags' : ['desktop_access_disabled']\r\n },\r\n {\r\n 'name' : 'desktop_mac',\r\n 'ligature': 'desktop_mac',\r\n 'tags' : ['desktop_mac']\r\n },\r\n {\r\n 'name' : 'desktop_windows',\r\n 'ligature': 'desktop_windows',\r\n 'tags' : ['desktop_windows']\r\n },\r\n {\r\n 'name' : 'details',\r\n 'ligature': 'details',\r\n 'tags' : ['details']\r\n },\r\n {\r\n 'name' : 'developer_board',\r\n 'ligature': 'developer_board',\r\n 'tags' : ['developer_board']\r\n },\r\n {\r\n 'name' : 'developer_mode',\r\n 'ligature': 'developer_mode',\r\n 'tags' : ['developer_mode']\r\n },\r\n {\r\n 'name' : 'device_hub',\r\n 'ligature': 'device_hub',\r\n 'tags' : ['device_hub']\r\n },\r\n {\r\n 'name' : 'device_unknown',\r\n 'ligature': 'device_unknown',\r\n 'tags' : ['device_unknown']\r\n },\r\n {\r\n 'name' : 'devices_other',\r\n 'ligature': 'devices_other',\r\n 'tags' : ['devices_other']\r\n },\r\n {\r\n 'name' : 'devices',\r\n 'ligature': 'devices',\r\n 'tags' : ['devices']\r\n },\r\n {\r\n 'name' : 'dialer_sip',\r\n 'ligature': 'dialer_sip',\r\n 'tags' : ['dialer_sip']\r\n },\r\n {\r\n 'name' : 'dialpad',\r\n 'ligature': 'dialpad',\r\n 'tags' : ['dialpad']\r\n },\r\n {\r\n 'name' : 'directions_bike',\r\n 'ligature': 'directions_bike',\r\n 'tags' : ['directions_bike']\r\n },\r\n {\r\n 'name' : 'directions_boat',\r\n 'ligature': 'directions_boat',\r\n 'tags' : ['directions_boat']\r\n },\r\n {\r\n 'name' : 'directions_bus',\r\n 'ligature': 'directions_bus',\r\n 'tags' : ['directions_bus']\r\n },\r\n {\r\n 'name' : 'directions_car',\r\n 'ligature': 'directions_car',\r\n 'tags' : ['directions_car']\r\n },\r\n {\r\n 'name' : 'directions_railway',\r\n 'ligature': 'directions_railway',\r\n 'tags' : ['directions_railway']\r\n },\r\n {\r\n 'name' : 'directions_run',\r\n 'ligature': 'directions_run',\r\n 'tags' : ['directions_run']\r\n },\r\n {\r\n 'name' : 'directions_subway',\r\n 'ligature': 'directions_subway',\r\n 'tags' : ['directions_subway']\r\n },\r\n {\r\n 'name' : 'directions_transit',\r\n 'ligature': 'directions_transit',\r\n 'tags' : ['directions_transit']\r\n },\r\n {\r\n 'name' : 'directions_walk',\r\n 'ligature': 'directions_walk',\r\n 'tags' : ['directions_walk']\r\n },\r\n {\r\n 'name' : 'directions',\r\n 'ligature': 'directions',\r\n 'tags' : ['directions']\r\n },\r\n {\r\n 'name' : 'disc_full',\r\n 'ligature': 'disc_full',\r\n 'tags' : ['disc_full']\r\n },\r\n {\r\n 'name' : 'dns',\r\n 'ligature': 'dns',\r\n 'tags' : ['dns']\r\n },\r\n {\r\n 'name' : 'dock',\r\n 'ligature': 'dock',\r\n 'tags' : ['dock']\r\n },\r\n {\r\n 'name' : 'domain_disabled',\r\n 'ligature': 'domain_disabled',\r\n 'tags' : ['domain_disabled']\r\n },\r\n {\r\n 'name' : 'domain',\r\n 'ligature': 'domain',\r\n 'tags' : ['domain']\r\n },\r\n {\r\n 'name' : 'done_all',\r\n 'ligature': 'done_all',\r\n 'tags' : ['done_all']\r\n },\r\n {\r\n 'name' : 'done_outline',\r\n 'ligature': 'done_outline',\r\n 'tags' : ['done_outline']\r\n },\r\n {\r\n 'name' : 'done',\r\n 'ligature': 'done',\r\n 'tags' : ['done']\r\n },\r\n {\r\n 'name' : 'donut_large',\r\n 'ligature': 'donut_large',\r\n 'tags' : ['donut_large']\r\n },\r\n {\r\n 'name' : 'donut_small',\r\n 'ligature': 'donut_small',\r\n 'tags' : ['donut_small']\r\n },\r\n {\r\n 'name' : 'drafts',\r\n 'ligature': 'drafts',\r\n 'tags' : ['drafts']\r\n },\r\n {\r\n 'name' : 'drag_handle',\r\n 'ligature': 'drag_handle',\r\n 'tags' : ['drag_handle']\r\n },\r\n {\r\n 'name' : 'drag_indicator',\r\n 'ligature': 'drag_indicator',\r\n 'tags' : ['drag_indicator']\r\n },\r\n {\r\n 'name' : 'drive_eta',\r\n 'ligature': 'drive_eta',\r\n 'tags' : ['drive_eta']\r\n },\r\n {\r\n 'name' : 'duo',\r\n 'ligature': 'duo',\r\n 'tags' : ['duo']\r\n },\r\n {\r\n 'name' : 'dvr',\r\n 'ligature': 'dvr',\r\n 'tags' : ['dvr']\r\n },\r\n {\r\n 'name' : 'edit_attributes',\r\n 'ligature': 'edit_attributes',\r\n 'tags' : ['edit_attributes']\r\n },\r\n {\r\n 'name' : 'edit_location',\r\n 'ligature': 'edit_location',\r\n 'tags' : ['edit_location']\r\n },\r\n {\r\n 'name' : 'edit',\r\n 'ligature': 'edit',\r\n 'tags' : ['edit']\r\n },\r\n {\r\n 'name' : 'eject',\r\n 'ligature': 'eject',\r\n 'tags' : ['eject']\r\n },\r\n {\r\n 'name' : 'email',\r\n 'ligature': 'email',\r\n 'tags' : ['email']\r\n },\r\n {\r\n 'name' : 'enhanced_encryption',\r\n 'ligature': 'enhanced_encryption',\r\n 'tags' : ['enhanced_encryption']\r\n },\r\n {\r\n 'name' : 'equalizer',\r\n 'ligature': 'equalizer',\r\n 'tags' : ['equalizer']\r\n },\r\n {\r\n 'name' : 'error_outline',\r\n 'ligature': 'error_outline',\r\n 'tags' : ['error_outline']\r\n },\r\n {\r\n 'name' : 'error',\r\n 'ligature': 'error',\r\n 'tags' : ['error']\r\n },\r\n {\r\n 'name' : 'euro_symbol',\r\n 'ligature': 'euro_symbol',\r\n 'tags' : ['euro_symbol']\r\n },\r\n {\r\n 'name' : 'ev_station',\r\n 'ligature': 'ev_station',\r\n 'tags' : ['ev_station']\r\n },\r\n {\r\n 'name' : 'event_available',\r\n 'ligature': 'event_available',\r\n 'tags' : ['event_available']\r\n },\r\n {\r\n 'name' : 'event_busy',\r\n 'ligature': 'event_busy',\r\n 'tags' : ['event_busy']\r\n },\r\n {\r\n 'name' : 'event_note',\r\n 'ligature': 'event_note',\r\n 'tags' : ['event_note']\r\n },\r\n {\r\n 'name' : 'event_seat',\r\n 'ligature': 'event_seat',\r\n 'tags' : ['event_seat']\r\n },\r\n {\r\n 'name' : 'event',\r\n 'ligature': 'event',\r\n 'tags' : ['event']\r\n },\r\n {\r\n 'name' : 'exit_to_app',\r\n 'ligature': 'exit_to_app',\r\n 'tags' : ['exit_to_app']\r\n },\r\n {\r\n 'name' : 'expand_less',\r\n 'ligature': 'expand_less',\r\n 'tags' : ['expand_less']\r\n },\r\n {\r\n 'name' : 'expand_more',\r\n 'ligature': 'expand_more',\r\n 'tags' : ['expand_more']\r\n },\r\n {\r\n 'name' : 'explicit',\r\n 'ligature': 'explicit',\r\n 'tags' : ['explicit']\r\n },\r\n {\r\n 'name' : 'explore_off',\r\n 'ligature': 'explore_off',\r\n 'tags' : ['explore_off']\r\n },\r\n {\r\n 'name' : 'explore',\r\n 'ligature': 'explore',\r\n 'tags' : ['explore']\r\n },\r\n {\r\n 'name' : 'exposure_neg_1',\r\n 'ligature': 'exposure_neg_1',\r\n 'tags' : ['exposure_neg_1']\r\n },\r\n {\r\n 'name' : 'exposure_neg_2',\r\n 'ligature': 'exposure_neg_2',\r\n 'tags' : ['exposure_neg_2']\r\n },\r\n {\r\n 'name' : 'exposure_plus_1',\r\n 'ligature': 'exposure_plus_1',\r\n 'tags' : ['exposure_plus_1']\r\n },\r\n {\r\n 'name' : 'exposure_plus_2',\r\n 'ligature': 'exposure_plus_2',\r\n 'tags' : ['exposure_plus_2']\r\n },\r\n {\r\n 'name' : 'exposure_zero',\r\n 'ligature': 'exposure_zero',\r\n 'tags' : ['exposure_zero']\r\n },\r\n {\r\n 'name' : 'exposure',\r\n 'ligature': 'exposure',\r\n 'tags' : ['exposure']\r\n },\r\n {\r\n 'name' : 'extension',\r\n 'ligature': 'extension',\r\n 'tags' : ['extension']\r\n },\r\n {\r\n 'name' : 'face',\r\n 'ligature': 'face',\r\n 'tags' : ['face']\r\n },\r\n {\r\n 'name' : 'fast_forward',\r\n 'ligature': 'fast_forward',\r\n 'tags' : ['fast_forward']\r\n },\r\n {\r\n 'name' : 'fast_rewind',\r\n 'ligature': 'fast_rewind',\r\n 'tags' : ['fast_rewind']\r\n },\r\n {\r\n 'name' : 'fastfood',\r\n 'ligature': 'fastfood',\r\n 'tags' : ['fastfood']\r\n },\r\n {\r\n 'name' : 'favorite_border',\r\n 'ligature': 'favorite_border',\r\n 'tags' : ['favorite_border']\r\n },\r\n {\r\n 'name' : 'favorite',\r\n 'ligature': 'favorite',\r\n 'tags' : ['favorite']\r\n },\r\n {\r\n 'name' : 'featured_play_list',\r\n 'ligature': 'featured_play_list',\r\n 'tags' : ['featured_play_list']\r\n },\r\n {\r\n 'name' : 'featured_video',\r\n 'ligature': 'featured_video',\r\n 'tags' : ['featured_video']\r\n },\r\n {\r\n 'name' : 'feedback',\r\n 'ligature': 'feedback',\r\n 'tags' : ['feedback']\r\n },\r\n {\r\n 'name' : 'fiber_dvr',\r\n 'ligature': 'fiber_dvr',\r\n 'tags' : ['fiber_dvr']\r\n },\r\n {\r\n 'name' : 'fiber_manual_record',\r\n 'ligature': 'fiber_manual_record',\r\n 'tags' : ['fiber_manual_record']\r\n },\r\n {\r\n 'name' : 'fiber_new',\r\n 'ligature': 'fiber_new',\r\n 'tags' : ['fiber_new']\r\n },\r\n {\r\n 'name' : 'fiber_pin',\r\n 'ligature': 'fiber_pin',\r\n 'tags' : ['fiber_pin']\r\n },\r\n {\r\n 'name' : 'fiber_smart_record',\r\n 'ligature': 'fiber_smart_record',\r\n 'tags' : ['fiber_smart_record']\r\n },\r\n {\r\n 'name' : 'file_copy',\r\n 'ligature': 'file_copy',\r\n 'tags' : ['file_copy']\r\n },\r\n {\r\n 'name' : 'filter_1',\r\n 'ligature': 'filter_1',\r\n 'tags' : ['filter_1']\r\n },\r\n {\r\n 'name' : 'filter_2',\r\n 'ligature': 'filter_2',\r\n 'tags' : ['filter_2']\r\n },\r\n {\r\n 'name' : 'filter_3',\r\n 'ligature': 'filter_3',\r\n 'tags' : ['filter_3']\r\n },\r\n {\r\n 'name' : 'filter_4',\r\n 'ligature': 'filter_4',\r\n 'tags' : ['filter_4']\r\n },\r\n {\r\n 'name' : 'filter_5',\r\n 'ligature': 'filter_5',\r\n 'tags' : ['filter_5']\r\n },\r\n {\r\n 'name' : 'filter_6',\r\n 'ligature': 'filter_6',\r\n 'tags' : ['filter_6']\r\n },\r\n {\r\n 'name' : 'filter_7',\r\n 'ligature': 'filter_7',\r\n 'tags' : ['filter_7']\r\n },\r\n {\r\n 'name' : 'filter_8',\r\n 'ligature': 'filter_8',\r\n 'tags' : ['filter_8']\r\n },\r\n {\r\n 'name' : 'filter_9_plus',\r\n 'ligature': 'filter_9_plus',\r\n 'tags' : ['filter_9_plus']\r\n },\r\n {\r\n 'name' : 'filter_9',\r\n 'ligature': 'filter_9',\r\n 'tags' : ['filter_9']\r\n },\r\n {\r\n 'name' : 'filter_b_and_w',\r\n 'ligature': 'filter_b_and_w',\r\n 'tags' : ['filter_b_and_w']\r\n },\r\n {\r\n 'name' : 'filter_center_focus',\r\n 'ligature': 'filter_center_focus',\r\n 'tags' : ['filter_center_focus']\r\n },\r\n {\r\n 'name' : 'filter_drama',\r\n 'ligature': 'filter_drama',\r\n 'tags' : ['filter_drama']\r\n },\r\n {\r\n 'name' : 'filter_frames',\r\n 'ligature': 'filter_frames',\r\n 'tags' : ['filter_frames']\r\n },\r\n {\r\n 'name' : 'filter_hdr',\r\n 'ligature': 'filter_hdr',\r\n 'tags' : ['filter_hdr']\r\n },\r\n {\r\n 'name' : 'filter_list',\r\n 'ligature': 'filter_list',\r\n 'tags' : ['filter_list']\r\n },\r\n {\r\n 'name' : 'filter_none',\r\n 'ligature': 'filter_none',\r\n 'tags' : ['filter_none']\r\n },\r\n {\r\n 'name' : 'filter_tilt_shift',\r\n 'ligature': 'filter_tilt_shift',\r\n 'tags' : ['filter_tilt_shift']\r\n },\r\n {\r\n 'name' : 'filter_vintage',\r\n 'ligature': 'filter_vintage',\r\n 'tags' : ['filter_vintage']\r\n },\r\n {\r\n 'name' : 'filter',\r\n 'ligature': 'filter',\r\n 'tags' : ['filter']\r\n },\r\n {\r\n 'name' : 'find_in_page',\r\n 'ligature': 'find_in_page',\r\n 'tags' : ['find_in_page']\r\n },\r\n {\r\n 'name' : 'find_replace',\r\n 'ligature': 'find_replace',\r\n 'tags' : ['find_replace']\r\n },\r\n {\r\n 'name' : 'fingerprint',\r\n 'ligature': 'fingerprint',\r\n 'tags' : ['fingerprint']\r\n },\r\n {\r\n 'name' : 'first_page',\r\n 'ligature': 'first_page',\r\n 'tags' : ['first_page']\r\n },\r\n {\r\n 'name' : 'fitness_center',\r\n 'ligature': 'fitness_center',\r\n 'tags' : ['fitness_center']\r\n },\r\n {\r\n 'name' : 'flag',\r\n 'ligature': 'flag',\r\n 'tags' : ['flag']\r\n },\r\n {\r\n 'name' : 'flare',\r\n 'ligature': 'flare',\r\n 'tags' : ['flare']\r\n },\r\n {\r\n 'name' : 'flash_auto',\r\n 'ligature': 'flash_auto',\r\n 'tags' : ['flash_auto']\r\n },\r\n {\r\n 'name' : 'flash_off',\r\n 'ligature': 'flash_off',\r\n 'tags' : ['flash_off']\r\n },\r\n {\r\n 'name' : 'flash_on',\r\n 'ligature': 'flash_on',\r\n 'tags' : ['flash_on']\r\n },\r\n {\r\n 'name' : 'flight_land',\r\n 'ligature': 'flight_land',\r\n 'tags' : ['flight_land']\r\n },\r\n {\r\n 'name' : 'flight_takeoff',\r\n 'ligature': 'flight_takeoff',\r\n 'tags' : ['flight_takeoff']\r\n },\r\n {\r\n 'name' : 'flight',\r\n 'ligature': 'flight',\r\n 'tags' : ['flight']\r\n },\r\n {\r\n 'name' : 'flip_to_back',\r\n 'ligature': 'flip_to_back',\r\n 'tags' : ['flip_to_back']\r\n },\r\n {\r\n 'name' : 'flip_to_front',\r\n 'ligature': 'flip_to_front',\r\n 'tags' : ['flip_to_front']\r\n },\r\n {\r\n 'name' : 'flip',\r\n 'ligature': 'flip',\r\n 'tags' : ['flip']\r\n },\r\n {\r\n 'name' : 'folder_open',\r\n 'ligature': 'folder_open',\r\n 'tags' : ['folder_open']\r\n },\r\n {\r\n 'name' : 'folder_shared',\r\n 'ligature': 'folder_shared',\r\n 'tags' : ['folder_shared']\r\n },\r\n {\r\n 'name' : 'folder_special',\r\n 'ligature': 'folder_special',\r\n 'tags' : ['folder_special']\r\n },\r\n {\r\n 'name' : 'folder',\r\n 'ligature': 'folder',\r\n 'tags' : ['folder']\r\n },\r\n {\r\n 'name' : 'font_download',\r\n 'ligature': 'font_download',\r\n 'tags' : ['font_download']\r\n },\r\n {\r\n 'name' : 'format_align_center',\r\n 'ligature': 'format_align_center',\r\n 'tags' : ['format_align_center']\r\n },\r\n {\r\n 'name' : 'format_align_justify',\r\n 'ligature': 'format_align_justify',\r\n 'tags' : ['format_align_justify']\r\n },\r\n {\r\n 'name' : 'format_align_left',\r\n 'ligature': 'format_align_left',\r\n 'tags' : ['format_align_left']\r\n },\r\n {\r\n 'name' : 'format_align_right',\r\n 'ligature': 'format_align_right',\r\n 'tags' : ['format_align_right']\r\n },\r\n {\r\n 'name' : 'format_bold',\r\n 'ligature': 'format_bold',\r\n 'tags' : ['format_bold']\r\n },\r\n {\r\n 'name' : 'format_clear',\r\n 'ligature': 'format_clear',\r\n 'tags' : ['format_clear']\r\n },\r\n {\r\n 'name' : 'format_color_reset',\r\n 'ligature': 'format_color_reset',\r\n 'tags' : ['format_color_reset']\r\n },\r\n {\r\n 'name' : 'format_indent_decrease',\r\n 'ligature': 'format_indent_decrease',\r\n 'tags' : ['format_indent_decrease']\r\n },\r\n {\r\n 'name' : 'format_indent_increase',\r\n 'ligature': 'format_indent_increase',\r\n 'tags' : ['format_indent_increase']\r\n },\r\n {\r\n 'name' : 'format_italic',\r\n 'ligature': 'format_italic',\r\n 'tags' : ['format_italic']\r\n },\r\n {\r\n 'name' : 'format_line_spacing',\r\n 'ligature': 'format_line_spacing',\r\n 'tags' : ['format_line_spacing']\r\n },\r\n {\r\n 'name' : 'format_list_bulleted',\r\n 'ligature': 'format_list_bulleted',\r\n 'tags' : ['format_list_bulleted']\r\n },\r\n {\r\n 'name' : 'format_list_numbered_rtl',\r\n 'ligature': 'format_list_numbered_rtl',\r\n 'tags' : ['format_list_numbered_rtl']\r\n },\r\n {\r\n 'name' : 'format_list_numbered',\r\n 'ligature': 'format_list_numbered',\r\n 'tags' : ['format_list_numbered']\r\n },\r\n {\r\n 'name' : 'format_paint',\r\n 'ligature': 'format_paint',\r\n 'tags' : ['format_paint']\r\n },\r\n {\r\n 'name' : 'format_quote',\r\n 'ligature': 'format_quote',\r\n 'tags' : ['format_quote']\r\n },\r\n {\r\n 'name' : 'format_shapes',\r\n 'ligature': 'format_shapes',\r\n 'tags' : ['format_shapes']\r\n },\r\n {\r\n 'name' : 'format_size',\r\n 'ligature': 'format_size',\r\n 'tags' : ['format_size']\r\n },\r\n {\r\n 'name' : 'format_strikethrough',\r\n 'ligature': 'format_strikethrough',\r\n 'tags' : ['format_strikethrough']\r\n },\r\n {\r\n 'name' : 'format_textdirection_l_to_r',\r\n 'ligature': 'format_textdirection_l_to_r',\r\n 'tags' : ['format_textdirection_l_to_r']\r\n },\r\n {\r\n 'name' : 'format_textdirection_r_to_l',\r\n 'ligature': 'format_textdirection_r_to_l',\r\n 'tags' : ['format_textdirection_r_to_l']\r\n },\r\n {\r\n 'name' : 'format_underlined',\r\n 'ligature': 'format_underlined',\r\n 'tags' : ['format_underlined']\r\n },\r\n {\r\n 'name' : 'forum',\r\n 'ligature': 'forum',\r\n 'tags' : ['forum']\r\n },\r\n {\r\n 'name' : 'forward_5',\r\n 'ligature': 'forward_5',\r\n 'tags' : ['forward_5']\r\n },\r\n {\r\n 'name' : 'forward_10',\r\n 'ligature': 'forward_10',\r\n 'tags' : ['forward_10']\r\n },\r\n {\r\n 'name' : 'forward_30',\r\n 'ligature': 'forward_30',\r\n 'tags' : ['forward_30']\r\n },\r\n {\r\n 'name' : 'forward',\r\n 'ligature': 'forward',\r\n 'tags' : ['forward']\r\n },\r\n {\r\n 'name' : 'free_breakfast',\r\n 'ligature': 'free_breakfast',\r\n 'tags' : ['free_breakfast']\r\n },\r\n {\r\n 'name' : 'fullscreen_exit',\r\n 'ligature': 'fullscreen_exit',\r\n 'tags' : ['fullscreen_exit']\r\n },\r\n {\r\n 'name' : 'fullscreen',\r\n 'ligature': 'fullscreen',\r\n 'tags' : ['fullscreen']\r\n },\r\n {\r\n 'name' : 'functions',\r\n 'ligature': 'functions',\r\n 'tags' : ['functions']\r\n },\r\n {\r\n 'name' : 'g_translate',\r\n 'ligature': 'g_translate',\r\n 'tags' : ['g_translate']\r\n },\r\n {\r\n 'name' : 'gamepad',\r\n 'ligature': 'gamepad',\r\n 'tags' : ['gamepad']\r\n },\r\n {\r\n 'name' : 'games',\r\n 'ligature': 'games',\r\n 'tags' : ['games']\r\n },\r\n {\r\n 'name' : 'gavel',\r\n 'ligature': 'gavel',\r\n 'tags' : ['gavel']\r\n },\r\n {\r\n 'name' : 'gesture',\r\n 'ligature': 'gesture',\r\n 'tags' : ['gesture']\r\n },\r\n {\r\n 'name' : 'get_app',\r\n 'ligature': 'get_app',\r\n 'tags' : ['get_app']\r\n },\r\n {\r\n 'name' : 'gif',\r\n 'ligature': 'gif',\r\n 'tags' : ['gif']\r\n },\r\n {\r\n 'name' : 'golf_course',\r\n 'ligature': 'golf_course',\r\n 'tags' : ['golf_course']\r\n },\r\n {\r\n 'name' : 'gps_fixed',\r\n 'ligature': 'gps_fixed',\r\n 'tags' : ['gps_fixed']\r\n },\r\n {\r\n 'name' : 'gps_not_fixed',\r\n 'ligature': 'gps_not_fixed',\r\n 'tags' : ['gps_not_fixed']\r\n },\r\n {\r\n 'name' : 'gps_off',\r\n 'ligature': 'gps_off',\r\n 'tags' : ['gps_off']\r\n },\r\n {\r\n 'name' : 'grade',\r\n 'ligature': 'grade',\r\n 'tags' : ['grade']\r\n },\r\n {\r\n 'name' : 'gradient',\r\n 'ligature': 'gradient',\r\n 'tags' : ['gradient']\r\n },\r\n {\r\n 'name' : 'grain',\r\n 'ligature': 'grain',\r\n 'tags' : ['grain']\r\n },\r\n {\r\n 'name' : 'graphic_eq',\r\n 'ligature': 'graphic_eq',\r\n 'tags' : ['graphic_eq']\r\n },\r\n {\r\n 'name' : 'grid_off',\r\n 'ligature': 'grid_off',\r\n 'tags' : ['grid_off']\r\n },\r\n {\r\n 'name' : 'grid_on',\r\n 'ligature': 'grid_on',\r\n 'tags' : ['grid_on']\r\n },\r\n {\r\n 'name' : 'group_add',\r\n 'ligature': 'group_add',\r\n 'tags' : ['group_add']\r\n },\r\n {\r\n 'name' : 'group_work',\r\n 'ligature': 'group_work',\r\n 'tags' : ['group_work']\r\n },\r\n {\r\n 'name' : 'group',\r\n 'ligature': 'group',\r\n 'tags' : ['group']\r\n },\r\n {\r\n 'name' : 'hd',\r\n 'ligature': 'hd',\r\n 'tags' : ['hd']\r\n },\r\n {\r\n 'name' : 'hdr_off',\r\n 'ligature': 'hdr_off',\r\n 'tags' : ['hdr_off']\r\n },\r\n {\r\n 'name' : 'hdr_on',\r\n 'ligature': 'hdr_on',\r\n 'tags' : ['hdr_on']\r\n },\r\n {\r\n 'name' : 'hdr_strong',\r\n 'ligature': 'hdr_strong',\r\n 'tags' : ['hdr_strong']\r\n },\r\n {\r\n 'name' : 'hdr_weak',\r\n 'ligature': 'hdr_weak',\r\n 'tags' : ['hdr_weak']\r\n },\r\n {\r\n 'name' : 'headset_mic',\r\n 'ligature': 'headset_mic',\r\n 'tags' : ['headset_mic']\r\n },\r\n {\r\n 'name' : 'headset',\r\n 'ligature': 'headset',\r\n 'tags' : ['headset']\r\n },\r\n {\r\n 'name' : 'healing',\r\n 'ligature': 'healing',\r\n 'tags' : ['healing']\r\n },\r\n {\r\n 'name' : 'hearing',\r\n 'ligature': 'hearing',\r\n 'tags' : ['hearing']\r\n },\r\n {\r\n 'name' : 'help_outline',\r\n 'ligature': 'help_outline',\r\n 'tags' : ['help_outline']\r\n },\r\n {\r\n 'name' : 'help',\r\n 'ligature': 'help',\r\n 'tags' : ['help']\r\n },\r\n {\r\n 'name' : 'high_quality',\r\n 'ligature': 'high_quality',\r\n 'tags' : ['high_quality']\r\n },\r\n {\r\n 'name' : 'highlight_off',\r\n 'ligature': 'highlight_off',\r\n 'tags' : ['highlight_off']\r\n },\r\n {\r\n 'name' : 'highlight',\r\n 'ligature': 'highlight',\r\n 'tags' : ['highlight']\r\n },\r\n {\r\n 'name' : 'history',\r\n 'ligature': 'history',\r\n 'tags' : ['history']\r\n },\r\n {\r\n 'name' : 'home',\r\n 'ligature': 'home',\r\n 'tags' : ['home']\r\n },\r\n {\r\n 'name' : 'horizontal_split',\r\n 'ligature': 'horizontal_split',\r\n 'tags' : ['horizontal_split']\r\n },\r\n {\r\n 'name' : 'hot_tub',\r\n 'ligature': 'hot_tub',\r\n 'tags' : ['hot_tub']\r\n },\r\n {\r\n 'name' : 'hotel',\r\n 'ligature': 'hotel',\r\n 'tags' : ['hotel']\r\n },\r\n {\r\n 'name' : 'hourglass_empty',\r\n 'ligature': 'hourglass_empty',\r\n 'tags' : ['hourglass_empty']\r\n },\r\n {\r\n 'name' : 'hourglass_full',\r\n 'ligature': 'hourglass_full',\r\n 'tags' : ['hourglass_full']\r\n },\r\n {\r\n 'name' : 'how_to_reg',\r\n 'ligature': 'how_to_reg',\r\n 'tags' : ['how_to_reg']\r\n },\r\n {\r\n 'name' : 'how_to_vote',\r\n 'ligature': 'how_to_vote',\r\n 'tags' : ['how_to_vote']\r\n },\r\n {\r\n 'name' : 'http',\r\n 'ligature': 'http',\r\n 'tags' : ['http']\r\n },\r\n {\r\n 'name' : 'https',\r\n 'ligature': 'https',\r\n 'tags' : ['https']\r\n },\r\n {\r\n 'name' : 'image_aspect_ratio',\r\n 'ligature': 'image_aspect_ratio',\r\n 'tags' : ['image_aspect_ratio']\r\n },\r\n {\r\n 'name' : 'image_search',\r\n 'ligature': 'image_search',\r\n 'tags' : ['image_search']\r\n },\r\n {\r\n 'name' : 'image',\r\n 'ligature': 'image',\r\n 'tags' : ['image']\r\n },\r\n {\r\n 'name' : 'import_contacts',\r\n 'ligature': 'import_contacts',\r\n 'tags' : ['import_contacts']\r\n },\r\n {\r\n 'name' : 'import_export',\r\n 'ligature': 'import_export',\r\n 'tags' : ['import_export']\r\n },\r\n {\r\n 'name' : 'important_devices',\r\n 'ligature': 'important_devices',\r\n 'tags' : ['important_devices']\r\n },\r\n {\r\n 'name' : 'inbox',\r\n 'ligature': 'inbox',\r\n 'tags' : ['inbox']\r\n },\r\n {\r\n 'name' : 'indeterminate_check_box',\r\n 'ligature': 'indeterminate_check_box',\r\n 'tags' : ['indeterminate_check_box']\r\n },\r\n {\r\n 'name' : 'info',\r\n 'ligature': 'info',\r\n 'tags' : ['info']\r\n },\r\n {\r\n 'name' : 'input',\r\n 'ligature': 'input',\r\n 'tags' : ['input']\r\n },\r\n {\r\n 'name' : 'insert_chart_outlined',\r\n 'ligature': 'insert_chart_outlined',\r\n 'tags' : ['insert_chart_outlined']\r\n },\r\n {\r\n 'name' : 'insert_chart',\r\n 'ligature': 'insert_chart',\r\n 'tags' : ['insert_chart']\r\n },\r\n {\r\n 'name' : 'insert_comment',\r\n 'ligature': 'insert_comment',\r\n 'tags' : ['insert_comment']\r\n },\r\n {\r\n 'name' : 'insert_drive_file',\r\n 'ligature': 'insert_drive_file',\r\n 'tags' : ['insert_drive_file']\r\n },\r\n {\r\n 'name' : 'insert_emoticon',\r\n 'ligature': 'insert_emoticon',\r\n 'tags' : ['insert_emoticon']\r\n },\r\n {\r\n 'name' : 'insert_invitation',\r\n 'ligature': 'insert_invitation',\r\n 'tags' : ['insert_invitation']\r\n },\r\n {\r\n 'name' : 'insert_link',\r\n 'ligature': 'insert_link',\r\n 'tags' : ['insert_link']\r\n },\r\n {\r\n 'name' : 'insert_photo',\r\n 'ligature': 'insert_photo',\r\n 'tags' : ['insert_photo']\r\n },\r\n {\r\n 'name' : 'invert_colors_off',\r\n 'ligature': 'invert_colors_off',\r\n 'tags' : ['invert_colors_off']\r\n },\r\n {\r\n 'name' : 'invert_colors',\r\n 'ligature': 'invert_colors',\r\n 'tags' : ['invert_colors']\r\n },\r\n {\r\n 'name' : 'iso',\r\n 'ligature': 'iso',\r\n 'tags' : ['iso']\r\n },\r\n {\r\n 'name' : 'keyboard_arrow_down',\r\n 'ligature': 'keyboard_arrow_down',\r\n 'tags' : ['keyboard_arrow_down']\r\n },\r\n {\r\n 'name' : 'keyboard_arrow_left',\r\n 'ligature': 'keyboard_arrow_left',\r\n 'tags' : ['keyboard_arrow_left']\r\n },\r\n {\r\n 'name' : 'keyboard_arrow_right',\r\n 'ligature': 'keyboard_arrow_right',\r\n 'tags' : ['keyboard_arrow_right']\r\n },\r\n {\r\n 'name' : 'keyboard_arrow_up',\r\n 'ligature': 'keyboard_arrow_up',\r\n 'tags' : ['keyboard_arrow_up']\r\n },\r\n {\r\n 'name' : 'keyboard_backspace',\r\n 'ligature': 'keyboard_backspace',\r\n 'tags' : ['keyboard_backspace']\r\n },\r\n {\r\n 'name' : 'keyboard_capslock',\r\n 'ligature': 'keyboard_capslock',\r\n 'tags' : ['keyboard_capslock']\r\n },\r\n {\r\n 'name' : 'keyboard_hide',\r\n 'ligature': 'keyboard_hide',\r\n 'tags' : ['keyboard_hide']\r\n },\r\n {\r\n 'name' : 'keyboard_return',\r\n 'ligature': 'keyboard_return',\r\n 'tags' : ['keyboard_return']\r\n },\r\n {\r\n 'name' : 'keyboard_tab',\r\n 'ligature': 'keyboard_tab',\r\n 'tags' : ['keyboard_tab']\r\n },\r\n {\r\n 'name' : 'keyboard_voice',\r\n 'ligature': 'keyboard_voice',\r\n 'tags' : ['keyboard_voice']\r\n },\r\n {\r\n 'name' : 'keyboard',\r\n 'ligature': 'keyboard',\r\n 'tags' : ['keyboard']\r\n },\r\n {\r\n 'name' : 'kitchen',\r\n 'ligature': 'kitchen',\r\n 'tags' : ['kitchen']\r\n },\r\n {\r\n 'name' : 'label_important',\r\n 'ligature': 'label_important',\r\n 'tags' : ['label_important']\r\n },\r\n {\r\n 'name' : 'label_off',\r\n 'ligature': 'label_off',\r\n 'tags' : ['label_off']\r\n },\r\n {\r\n 'name' : 'label',\r\n 'ligature': 'label',\r\n 'tags' : ['label']\r\n },\r\n {\r\n 'name' : 'landscape',\r\n 'ligature': 'landscape',\r\n 'tags' : ['landscape']\r\n },\r\n {\r\n 'name' : 'language',\r\n 'ligature': 'language',\r\n 'tags' : ['language']\r\n },\r\n {\r\n 'name' : 'laptop_chromebook',\r\n 'ligature': 'laptop_chromebook',\r\n 'tags' : ['laptop_chromebook']\r\n },\r\n {\r\n 'name' : 'laptop_mac',\r\n 'ligature': 'laptop_mac',\r\n 'tags' : ['laptop_mac']\r\n },\r\n {\r\n 'name' : 'laptop_windows',\r\n 'ligature': 'laptop_windows',\r\n 'tags' : ['laptop_windows']\r\n },\r\n {\r\n 'name' : 'laptop',\r\n 'ligature': 'laptop',\r\n 'tags' : ['laptop']\r\n },\r\n {\r\n 'name' : 'last_page',\r\n 'ligature': 'last_page',\r\n 'tags' : ['last_page']\r\n },\r\n {\r\n 'name' : 'launch',\r\n 'ligature': 'launch',\r\n 'tags' : ['launch']\r\n },\r\n {\r\n 'name' : 'layers_clear',\r\n 'ligature': 'layers_clear',\r\n 'tags' : ['layers_clear']\r\n },\r\n {\r\n 'name' : 'layers',\r\n 'ligature': 'layers',\r\n 'tags' : ['layers']\r\n },\r\n {\r\n 'name' : 'leak_add',\r\n 'ligature': 'leak_add',\r\n 'tags' : ['leak_add']\r\n },\r\n {\r\n 'name' : 'leak_remove',\r\n 'ligature': 'leak_remove',\r\n 'tags' : ['leak_remove']\r\n },\r\n {\r\n 'name' : 'lens',\r\n 'ligature': 'lens',\r\n 'tags' : ['lens']\r\n },\r\n {\r\n 'name' : 'library_add',\r\n 'ligature': 'library_add',\r\n 'tags' : ['library_add']\r\n },\r\n {\r\n 'name' : 'library_books',\r\n 'ligature': 'library_books',\r\n 'tags' : ['library_books']\r\n },\r\n {\r\n 'name' : 'library_music',\r\n 'ligature': 'library_music',\r\n 'tags' : ['library_music']\r\n },\r\n {\r\n 'name' : 'line_style',\r\n 'ligature': 'line_style',\r\n 'tags' : ['line_style']\r\n },\r\n {\r\n 'name' : 'line_weight',\r\n 'ligature': 'line_weight',\r\n 'tags' : ['line_weight']\r\n },\r\n {\r\n 'name' : 'linear_scale',\r\n 'ligature': 'linear_scale',\r\n 'tags' : ['linear_scale']\r\n },\r\n {\r\n 'name' : 'link_off',\r\n 'ligature': 'link_off',\r\n 'tags' : ['link_off']\r\n },\r\n {\r\n 'name' : 'link',\r\n 'ligature': 'link',\r\n 'tags' : ['link']\r\n },\r\n {\r\n 'name' : 'linked_camera',\r\n 'ligature': 'linked_camera',\r\n 'tags' : ['linked_camera']\r\n },\r\n {\r\n 'name' : 'list_alt',\r\n 'ligature': 'list_alt',\r\n 'tags' : ['list_alt']\r\n },\r\n {\r\n 'name' : 'list',\r\n 'ligature': 'list',\r\n 'tags' : ['list']\r\n },\r\n {\r\n 'name' : 'live_help',\r\n 'ligature': 'live_help',\r\n 'tags' : ['live_help']\r\n },\r\n {\r\n 'name' : 'live_tv',\r\n 'ligature': 'live_tv',\r\n 'tags' : ['live_tv']\r\n },\r\n {\r\n 'name' : 'local_activity',\r\n 'ligature': 'local_activity',\r\n 'tags' : ['local_activity']\r\n },\r\n {\r\n 'name' : 'local_airport',\r\n 'ligature': 'local_airport',\r\n 'tags' : ['local_airport']\r\n },\r\n {\r\n 'name' : 'local_atm',\r\n 'ligature': 'local_atm',\r\n 'tags' : ['local_atm']\r\n },\r\n {\r\n 'name' : 'local_bar',\r\n 'ligature': 'local_bar',\r\n 'tags' : ['local_bar']\r\n },\r\n {\r\n 'name' : 'local_cafe',\r\n 'ligature': 'local_cafe',\r\n 'tags' : ['local_cafe']\r\n },\r\n {\r\n 'name' : 'local_car_wash',\r\n 'ligature': 'local_car_wash',\r\n 'tags' : ['local_car_wash']\r\n },\r\n {\r\n 'name' : 'local_convenience_store',\r\n 'ligature': 'local_convenience_store',\r\n 'tags' : ['local_convenience_store']\r\n },\r\n {\r\n 'name' : 'local_dining',\r\n 'ligature': 'local_dining',\r\n 'tags' : ['local_dining']\r\n },\r\n {\r\n 'name' : 'local_drink',\r\n 'ligature': 'local_drink',\r\n 'tags' : ['local_drink']\r\n },\r\n {\r\n 'name' : 'local_florist',\r\n 'ligature': 'local_florist',\r\n 'tags' : ['local_florist']\r\n },\r\n {\r\n 'name' : 'local_gas_station',\r\n 'ligature': 'local_gas_station',\r\n 'tags' : ['local_gas_station']\r\n },\r\n {\r\n 'name' : 'local_grocery_store',\r\n 'ligature': 'local_grocery_store',\r\n 'tags' : ['local_grocery_store']\r\n },\r\n {\r\n 'name' : 'local_hospital',\r\n 'ligature': 'local_hospital',\r\n 'tags' : ['local_hospital']\r\n },\r\n {\r\n 'name' : 'local_hotel',\r\n 'ligature': 'local_hotel',\r\n 'tags' : ['local_hotel']\r\n },\r\n {\r\n 'name' : 'local_laundry_service',\r\n 'ligature': 'local_laundry_service',\r\n 'tags' : ['local_laundry_service']\r\n },\r\n {\r\n 'name' : 'local_library',\r\n 'ligature': 'local_library',\r\n 'tags' : ['local_library']\r\n },\r\n {\r\n 'name' : 'local_mall',\r\n 'ligature': 'local_mall',\r\n 'tags' : ['local_mall']\r\n },\r\n {\r\n 'name' : 'local_movies',\r\n 'ligature': 'local_movies',\r\n 'tags' : ['local_movies']\r\n },\r\n {\r\n 'name' : 'local_offer',\r\n 'ligature': 'local_offer',\r\n 'tags' : ['local_offer']\r\n },\r\n {\r\n 'name' : 'local_parking',\r\n 'ligature': 'local_parking',\r\n 'tags' : ['local_parking']\r\n },\r\n {\r\n 'name' : 'local_pharmacy',\r\n 'ligature': 'local_pharmacy',\r\n 'tags' : ['local_pharmacy']\r\n },\r\n {\r\n 'name' : 'local_phone',\r\n 'ligature': 'local_phone',\r\n 'tags' : ['local_phone']\r\n },\r\n {\r\n 'name' : 'local_pizza',\r\n 'ligature': 'local_pizza',\r\n 'tags' : ['local_pizza']\r\n },\r\n {\r\n 'name' : 'local_play',\r\n 'ligature': 'local_play',\r\n 'tags' : ['local_play']\r\n },\r\n {\r\n 'name' : 'local_post_office',\r\n 'ligature': 'local_post_office',\r\n 'tags' : ['local_post_office']\r\n },\r\n {\r\n 'name' : 'local_printshop',\r\n 'ligature': 'local_printshop',\r\n 'tags' : ['local_printshop']\r\n },\r\n {\r\n 'name' : 'local_see',\r\n 'ligature': 'local_see',\r\n 'tags' : ['local_see']\r\n },\r\n {\r\n 'name' : 'local_shipping',\r\n 'ligature': 'local_shipping',\r\n 'tags' : ['local_shipping']\r\n },\r\n {\r\n 'name' : 'local_taxi',\r\n 'ligature': 'local_taxi',\r\n 'tags' : ['local_taxi']\r\n },\r\n {\r\n 'name' : 'location_city',\r\n 'ligature': 'location_city',\r\n 'tags' : ['location_city']\r\n },\r\n {\r\n 'name' : 'location_disabled',\r\n 'ligature': 'location_disabled',\r\n 'tags' : ['location_disabled']\r\n },\r\n {\r\n 'name' : 'location_off',\r\n 'ligature': 'location_off',\r\n 'tags' : ['location_off']\r\n },\r\n {\r\n 'name' : 'location_on',\r\n 'ligature': 'location_on',\r\n 'tags' : ['location_on']\r\n },\r\n {\r\n 'name' : 'location_searching',\r\n 'ligature': 'location_searching',\r\n 'tags' : ['location_searching']\r\n },\r\n {\r\n 'name' : 'lock_open',\r\n 'ligature': 'lock_open',\r\n 'tags' : ['lock_open']\r\n },\r\n {\r\n 'name' : 'lock',\r\n 'ligature': 'lock',\r\n 'tags' : ['lock']\r\n },\r\n {\r\n 'name' : 'looks_3',\r\n 'ligature': 'looks_3',\r\n 'tags' : ['looks_3']\r\n },\r\n {\r\n 'name' : 'looks_4',\r\n 'ligature': 'looks_4',\r\n 'tags' : ['looks_4']\r\n },\r\n {\r\n 'name' : 'looks_5',\r\n 'ligature': 'looks_5',\r\n 'tags' : ['looks_5']\r\n },\r\n {\r\n 'name' : 'looks_6',\r\n 'ligature': 'looks_6',\r\n 'tags' : ['looks_6']\r\n },\r\n {\r\n 'name' : 'looks_one',\r\n 'ligature': 'looks_one',\r\n 'tags' : ['looks_one']\r\n },\r\n {\r\n 'name' : 'looks_two',\r\n 'ligature': 'looks_two',\r\n 'tags' : ['looks_two']\r\n },\r\n {\r\n 'name' : 'looks',\r\n 'ligature': 'looks',\r\n 'tags' : ['looks']\r\n },\r\n {\r\n 'name' : 'loop',\r\n 'ligature': 'loop',\r\n 'tags' : ['loop']\r\n },\r\n {\r\n 'name' : 'loupe',\r\n 'ligature': 'loupe',\r\n 'tags' : ['loupe']\r\n },\r\n {\r\n 'name' : 'low_priority',\r\n 'ligature': 'low_priority',\r\n 'tags' : ['low_priority']\r\n },\r\n {\r\n 'name' : 'loyalty',\r\n 'ligature': 'loyalty',\r\n 'tags' : ['loyalty']\r\n },\r\n {\r\n 'name' : 'mail_outline',\r\n 'ligature': 'mail_outline',\r\n 'tags' : ['mail_outline']\r\n },\r\n {\r\n 'name' : 'mail',\r\n 'ligature': 'mail',\r\n 'tags' : ['mail']\r\n },\r\n {\r\n 'name' : 'map',\r\n 'ligature': 'map',\r\n 'tags' : ['map']\r\n },\r\n {\r\n 'name' : 'markunread_mailbox',\r\n 'ligature': 'markunread_mailbox',\r\n 'tags' : ['markunread_mailbox']\r\n },\r\n {\r\n 'name' : 'markunread',\r\n 'ligature': 'markunread',\r\n 'tags' : ['markunread']\r\n },\r\n {\r\n 'name' : 'maximize',\r\n 'ligature': 'maximize',\r\n 'tags' : ['maximize']\r\n },\r\n {\r\n 'name' : 'meeting_room',\r\n 'ligature': 'meeting_room',\r\n 'tags' : ['meeting_room']\r\n },\r\n {\r\n 'name' : 'memory',\r\n 'ligature': 'memory',\r\n 'tags' : ['memory']\r\n },\r\n {\r\n 'name' : 'menu',\r\n 'ligature': 'menu',\r\n 'tags' : ['menu']\r\n },\r\n {\r\n 'name' : 'merge_type',\r\n 'ligature': 'merge_type',\r\n 'tags' : ['merge_type']\r\n },\r\n {\r\n 'name' : 'message',\r\n 'ligature': 'message',\r\n 'tags' : ['message']\r\n },\r\n {\r\n 'name' : 'mic_none',\r\n 'ligature': 'mic_none',\r\n 'tags' : ['mic_none']\r\n },\r\n {\r\n 'name' : 'mic_off',\r\n 'ligature': 'mic_off',\r\n 'tags' : ['mic_off']\r\n },\r\n {\r\n 'name' : 'mic',\r\n 'ligature': 'mic',\r\n 'tags' : ['mic']\r\n },\r\n {\r\n 'name' : 'minimize',\r\n 'ligature': 'minimize',\r\n 'tags' : ['minimize']\r\n },\r\n {\r\n 'name' : 'missed_video_call',\r\n 'ligature': 'missed_video_call',\r\n 'tags' : ['missed_video_call']\r\n },\r\n {\r\n 'name' : 'mms',\r\n 'ligature': 'mms',\r\n 'tags' : ['mms']\r\n },\r\n {\r\n 'name' : 'mobile_friendly',\r\n 'ligature': 'mobile_friendly',\r\n 'tags' : ['mobile_friendly']\r\n },\r\n {\r\n 'name' : 'mobile_off',\r\n 'ligature': 'mobile_off',\r\n 'tags' : ['mobile_off']\r\n },\r\n {\r\n 'name' : 'mobile_screen_share',\r\n 'ligature': 'mobile_screen_share',\r\n 'tags' : ['mobile_screen_share']\r\n },\r\n {\r\n 'name' : 'mode_comment',\r\n 'ligature': 'mode_comment',\r\n 'tags' : ['mode_comment']\r\n },\r\n {\r\n 'name' : 'monetization_on',\r\n 'ligature': 'monetization_on',\r\n 'tags' : ['monetization_on']\r\n },\r\n {\r\n 'name' : 'money_off',\r\n 'ligature': 'money_off',\r\n 'tags' : ['money_off']\r\n },\r\n {\r\n 'name' : 'money',\r\n 'ligature': 'money',\r\n 'tags' : ['money']\r\n },\r\n {\r\n 'name' : 'monochrome_photos',\r\n 'ligature': 'monochrome_photos',\r\n 'tags' : ['monochrome_photos']\r\n },\r\n {\r\n 'name' : 'mood_bad',\r\n 'ligature': 'mood_bad',\r\n 'tags' : ['mood_bad']\r\n },\r\n {\r\n 'name' : 'mood',\r\n 'ligature': 'mood',\r\n 'tags' : ['mood']\r\n },\r\n {\r\n 'name' : 'more_horiz',\r\n 'ligature': 'more_horiz',\r\n 'tags' : ['more_horiz']\r\n },\r\n {\r\n 'name' : 'more_vert',\r\n 'ligature': 'more_vert',\r\n 'tags' : ['more_vert']\r\n },\r\n {\r\n 'name' : 'more',\r\n 'ligature': 'more',\r\n 'tags' : ['more']\r\n },\r\n {\r\n 'name' : 'motorcycle',\r\n 'ligature': 'motorcycle',\r\n 'tags' : ['motorcycle']\r\n },\r\n {\r\n 'name' : 'mouse',\r\n 'ligature': 'mouse',\r\n 'tags' : ['mouse']\r\n },\r\n {\r\n 'name' : 'move_to_inbox',\r\n 'ligature': 'move_to_inbox',\r\n 'tags' : ['move_to_inbox']\r\n },\r\n {\r\n 'name' : 'movie_creation',\r\n 'ligature': 'movie_creation',\r\n 'tags' : ['movie_creation']\r\n },\r\n {\r\n 'name' : 'movie_filter',\r\n 'ligature': 'movie_filter',\r\n 'tags' : ['movie_filter']\r\n },\r\n {\r\n 'name' : 'movie',\r\n 'ligature': 'movie',\r\n 'tags' : ['movie']\r\n },\r\n {\r\n 'name' : 'multiline_chart',\r\n 'ligature': 'multiline_chart',\r\n 'tags' : ['multiline_chart']\r\n },\r\n {\r\n 'name' : 'music_note',\r\n 'ligature': 'music_note',\r\n 'tags' : ['music_note']\r\n },\r\n {\r\n 'name' : 'music_off',\r\n 'ligature': 'music_off',\r\n 'tags' : ['music_off']\r\n },\r\n {\r\n 'name' : 'music_video',\r\n 'ligature': 'music_video',\r\n 'tags' : ['music_video']\r\n },\r\n {\r\n 'name' : 'my_location',\r\n 'ligature': 'my_location',\r\n 'tags' : ['my_location']\r\n },\r\n {\r\n 'name' : 'nature_people',\r\n 'ligature': 'nature_people',\r\n 'tags' : ['nature_people']\r\n },\r\n {\r\n 'name' : 'nature',\r\n 'ligature': 'nature',\r\n 'tags' : ['nature']\r\n },\r\n {\r\n 'name' : 'navigate_before',\r\n 'ligature': 'navigate_before',\r\n 'tags' : ['navigate_before']\r\n },\r\n {\r\n 'name' : 'navigate_next',\r\n 'ligature': 'navigate_next',\r\n 'tags' : ['navigate_next']\r\n },\r\n {\r\n 'name' : 'navigation',\r\n 'ligature': 'navigation',\r\n 'tags' : ['navigation']\r\n },\r\n {\r\n 'name' : 'near_me',\r\n 'ligature': 'near_me',\r\n 'tags' : ['near_me']\r\n },\r\n {\r\n 'name' : 'network_check',\r\n 'ligature': 'network_check',\r\n 'tags' : ['network_check']\r\n },\r\n {\r\n 'name' : 'network_locked',\r\n 'ligature': 'network_locked',\r\n 'tags' : ['network_locked']\r\n },\r\n {\r\n 'name' : 'new_releases',\r\n 'ligature': 'new_releases',\r\n 'tags' : ['new_releases']\r\n },\r\n {\r\n 'name' : 'next_week',\r\n 'ligature': 'next_week',\r\n 'tags' : ['next_week']\r\n },\r\n {\r\n 'name' : 'nfc',\r\n 'ligature': 'nfc',\r\n 'tags' : ['nfc']\r\n },\r\n {\r\n 'name' : 'no_encryption',\r\n 'ligature': 'no_encryption',\r\n 'tags' : ['no_encryption']\r\n },\r\n {\r\n 'name' : 'no_meeting_room',\r\n 'ligature': 'no_meeting_room',\r\n 'tags' : ['no_meeting_room']\r\n },\r\n {\r\n 'name' : 'no_sim',\r\n 'ligature': 'no_sim',\r\n 'tags' : ['no_sim']\r\n },\r\n {\r\n 'name' : 'not_interested',\r\n 'ligature': 'not_interested',\r\n 'tags' : ['not_interested']\r\n },\r\n {\r\n 'name' : 'not_listed_location',\r\n 'ligature': 'not_listed_location',\r\n 'tags' : ['not_listed_location']\r\n },\r\n {\r\n 'name' : 'note_add',\r\n 'ligature': 'note_add',\r\n 'tags' : ['note_add']\r\n },\r\n {\r\n 'name' : 'note',\r\n 'ligature': 'note',\r\n 'tags' : ['note']\r\n },\r\n {\r\n 'name' : 'notes',\r\n 'ligature': 'notes',\r\n 'tags' : ['notes']\r\n },\r\n {\r\n 'name' : 'notification_important',\r\n 'ligature': 'notification_important',\r\n 'tags' : ['notification_important']\r\n },\r\n {\r\n 'name' : 'notifications_active',\r\n 'ligature': 'notifications_active',\r\n 'tags' : ['notifications_active']\r\n },\r\n {\r\n 'name' : 'notifications_none',\r\n 'ligature': 'notifications_none',\r\n 'tags' : ['notifications_none']\r\n },\r\n {\r\n 'name' : 'notifications_off',\r\n 'ligature': 'notifications_off',\r\n 'tags' : ['notifications_off']\r\n },\r\n {\r\n 'name' : 'notifications_paused',\r\n 'ligature': 'notifications_paused',\r\n 'tags' : ['notifications_paused']\r\n },\r\n {\r\n 'name' : 'notifications',\r\n 'ligature': 'notifications',\r\n 'tags' : ['notifications']\r\n },\r\n {\r\n 'name' : 'offline_bolt',\r\n 'ligature': 'offline_bolt',\r\n 'tags' : ['offline_bolt']\r\n },\r\n {\r\n 'name' : 'offline_pin',\r\n 'ligature': 'offline_pin',\r\n 'tags' : ['offline_pin']\r\n },\r\n {\r\n 'name' : 'ondemand_video',\r\n 'ligature': 'ondemand_video',\r\n 'tags' : ['ondemand_video']\r\n },\r\n {\r\n 'name' : 'opacity',\r\n 'ligature': 'opacity',\r\n 'tags' : ['opacity']\r\n },\r\n {\r\n 'name' : 'open_in_browser',\r\n 'ligature': 'open_in_browser',\r\n 'tags' : ['open_in_browser']\r\n },\r\n {\r\n 'name' : 'open_in_new',\r\n 'ligature': 'open_in_new',\r\n 'tags' : ['open_in_new']\r\n },\r\n {\r\n 'name' : 'open_with',\r\n 'ligature': 'open_with',\r\n 'tags' : ['open_with']\r\n },\r\n {\r\n 'name' : 'outlined_flag',\r\n 'ligature': 'outlined_flag',\r\n 'tags' : ['outlined_flag']\r\n },\r\n {\r\n 'name' : 'pages',\r\n 'ligature': 'pages',\r\n 'tags' : ['pages']\r\n },\r\n {\r\n 'name' : 'pageview',\r\n 'ligature': 'pageview',\r\n 'tags' : ['pageview']\r\n },\r\n {\r\n 'name' : 'palette',\r\n 'ligature': 'palette',\r\n 'tags' : ['palette']\r\n },\r\n {\r\n 'name' : 'pan_tool',\r\n 'ligature': 'pan_tool',\r\n 'tags' : ['pan_tool']\r\n },\r\n {\r\n 'name' : 'panorama_fish_eye',\r\n 'ligature': 'panorama_fish_eye',\r\n 'tags' : ['panorama_fish_eye']\r\n },\r\n {\r\n 'name' : 'panorama_horizontal',\r\n 'ligature': 'panorama_horizontal',\r\n 'tags' : ['panorama_horizontal']\r\n },\r\n {\r\n 'name' : 'panorama_vertical',\r\n 'ligature': 'panorama_vertical',\r\n 'tags' : ['panorama_vertical']\r\n },\r\n {\r\n 'name' : 'panorama_wide_angle',\r\n 'ligature': 'panorama_wide_angle',\r\n 'tags' : ['panorama_wide_angle']\r\n },\r\n {\r\n 'name' : 'panorama',\r\n 'ligature': 'panorama',\r\n 'tags' : ['panorama']\r\n },\r\n {\r\n 'name' : 'party_mode',\r\n 'ligature': 'party_mode',\r\n 'tags' : ['party_mode']\r\n },\r\n {\r\n 'name' : 'pause_circle_filled',\r\n 'ligature': 'pause_circle_filled',\r\n 'tags' : ['pause_circle_filled']\r\n },\r\n {\r\n 'name' : 'pause_circle_outline',\r\n 'ligature': 'pause_circle_outline',\r\n 'tags' : ['pause_circle_outline']\r\n },\r\n {\r\n 'name' : 'pause_presentation',\r\n 'ligature': 'pause_presentation',\r\n 'tags' : ['pause_presentation']\r\n },\r\n {\r\n 'name' : 'pause',\r\n 'ligature': 'pause',\r\n 'tags' : ['pause']\r\n },\r\n {\r\n 'name' : 'payment',\r\n 'ligature': 'payment',\r\n 'tags' : ['payment']\r\n },\r\n {\r\n 'name' : 'people_outline',\r\n 'ligature': 'people_outline',\r\n 'tags' : ['people_outline']\r\n },\r\n {\r\n 'name' : 'people',\r\n 'ligature': 'people',\r\n 'tags' : ['people']\r\n },\r\n {\r\n 'name' : 'perm_camera_mic',\r\n 'ligature': 'perm_camera_mic',\r\n 'tags' : ['perm_camera_mic']\r\n },\r\n {\r\n 'name' : 'perm_contact_calendar',\r\n 'ligature': 'perm_contact_calendar',\r\n 'tags' : ['perm_contact_calendar']\r\n },\r\n {\r\n 'name' : 'perm_data_setting',\r\n 'ligature': 'perm_data_setting',\r\n 'tags' : ['perm_data_setting']\r\n },\r\n {\r\n 'name' : 'perm_device_information',\r\n 'ligature': 'perm_device_information',\r\n 'tags' : ['perm_device_information']\r\n },\r\n {\r\n 'name' : 'perm_identity',\r\n 'ligature': 'perm_identity',\r\n 'tags' : ['perm_identity']\r\n },\r\n {\r\n 'name' : 'perm_media',\r\n 'ligature': 'perm_media',\r\n 'tags' : ['perm_media']\r\n },\r\n {\r\n 'name' : 'perm_phone_msg',\r\n 'ligature': 'perm_phone_msg',\r\n 'tags' : ['perm_phone_msg']\r\n },\r\n {\r\n 'name' : 'perm_scan_wifi',\r\n 'ligature': 'perm_scan_wifi',\r\n 'tags' : ['perm_scan_wifi']\r\n },\r\n {\r\n 'name' : 'person_add_disabled',\r\n 'ligature': 'person_add_disabled',\r\n 'tags' : ['person_add_disabled']\r\n },\r\n {\r\n 'name' : 'person_add',\r\n 'ligature': 'person_add',\r\n 'tags' : ['person_add']\r\n },\r\n {\r\n 'name' : 'person_outline',\r\n 'ligature': 'person_outline',\r\n 'tags' : ['person_outline']\r\n },\r\n {\r\n 'name' : 'person_pin_circle',\r\n 'ligature': 'person_pin_circle',\r\n 'tags' : ['person_pin_circle']\r\n },\r\n {\r\n 'name' : 'person_pin',\r\n 'ligature': 'person_pin',\r\n 'tags' : ['person_pin']\r\n },\r\n {\r\n 'name' : 'person',\r\n 'ligature': 'person',\r\n 'tags' : ['person']\r\n },\r\n {\r\n 'name' : 'personal_video',\r\n 'ligature': 'personal_video',\r\n 'tags' : ['personal_video']\r\n },\r\n {\r\n 'name' : 'pets',\r\n 'ligature': 'pets',\r\n 'tags' : ['pets']\r\n },\r\n {\r\n 'name' : 'phone_android',\r\n 'ligature': 'phone_android',\r\n 'tags' : ['phone_android']\r\n },\r\n {\r\n 'name' : 'phone_bluetooth_speaker',\r\n 'ligature': 'phone_bluetooth_speaker',\r\n 'tags' : ['phone_bluetooth_speaker']\r\n },\r\n {\r\n 'name' : 'phone_callback',\r\n 'ligature': 'phone_callback',\r\n 'tags' : ['phone_callback']\r\n },\r\n {\r\n 'name' : 'phone_forwarded',\r\n 'ligature': 'phone_forwarded',\r\n 'tags' : ['phone_forwarded']\r\n },\r\n {\r\n 'name' : 'phone_in_talk',\r\n 'ligature': 'phone_in_talk',\r\n 'tags' : ['phone_in_talk']\r\n },\r\n {\r\n 'name' : 'phone_iphone',\r\n 'ligature': 'phone_iphone',\r\n 'tags' : ['phone_iphone']\r\n },\r\n {\r\n 'name' : 'phone_locked',\r\n 'ligature': 'phone_locked',\r\n 'tags' : ['phone_locked']\r\n },\r\n {\r\n 'name' : 'phone_missed',\r\n 'ligature': 'phone_missed',\r\n 'tags' : ['phone_missed']\r\n },\r\n {\r\n 'name' : 'phone_paused',\r\n 'ligature': 'phone_paused',\r\n 'tags' : ['phone_paused']\r\n },\r\n {\r\n 'name' : 'phone',\r\n 'ligature': 'phone',\r\n 'tags' : ['phone']\r\n },\r\n {\r\n 'name' : 'phonelink_erase',\r\n 'ligature': 'phonelink_erase',\r\n 'tags' : ['phonelink_erase']\r\n },\r\n {\r\n 'name' : 'phonelink_lock',\r\n 'ligature': 'phonelink_lock',\r\n 'tags' : ['phonelink_lock']\r\n },\r\n {\r\n 'name' : 'phonelink_off',\r\n 'ligature': 'phonelink_off',\r\n 'tags' : ['phonelink_off']\r\n },\r\n {\r\n 'name' : 'phonelink_ring',\r\n 'ligature': 'phonelink_ring',\r\n 'tags' : ['phonelink_ring']\r\n },\r\n {\r\n 'name' : 'phonelink_setup',\r\n 'ligature': 'phonelink_setup',\r\n 'tags' : ['phonelink_setup']\r\n },\r\n {\r\n 'name' : 'phonelink',\r\n 'ligature': 'phonelink',\r\n 'tags' : ['phonelink']\r\n },\r\n {\r\n 'name' : 'photo_album',\r\n 'ligature': 'photo_album',\r\n 'tags' : ['photo_album']\r\n },\r\n {\r\n 'name' : 'photo_camera',\r\n 'ligature': 'photo_camera',\r\n 'tags' : ['photo_camera']\r\n },\r\n {\r\n 'name' : 'photo_filter',\r\n 'ligature': 'photo_filter',\r\n 'tags' : ['photo_filter']\r\n },\r\n {\r\n 'name' : 'photo_library',\r\n 'ligature': 'photo_library',\r\n 'tags' : ['photo_library']\r\n },\r\n {\r\n 'name' : 'photo_size_select_actual',\r\n 'ligature': 'photo_size_select_actual',\r\n 'tags' : ['photo_size_select_actual']\r\n },\r\n {\r\n 'name' : 'photo_size_select_large',\r\n 'ligature': 'photo_size_select_large',\r\n 'tags' : ['photo_size_select_large']\r\n },\r\n {\r\n 'name' : 'photo_size_select_small',\r\n 'ligature': 'photo_size_select_small',\r\n 'tags' : ['photo_size_select_small']\r\n },\r\n {\r\n 'name' : 'photo',\r\n 'ligature': 'photo',\r\n 'tags' : ['photo']\r\n },\r\n {\r\n 'name' : 'picture_as_pdf',\r\n 'ligature': 'picture_as_pdf',\r\n 'tags' : ['picture_as_pdf']\r\n },\r\n {\r\n 'name' : 'picture_in_picture_alt',\r\n 'ligature': 'picture_in_picture_alt',\r\n 'tags' : ['picture_in_picture_alt']\r\n },\r\n {\r\n 'name' : 'picture_in_picture',\r\n 'ligature': 'picture_in_picture',\r\n 'tags' : ['picture_in_picture']\r\n },\r\n {\r\n 'name' : 'pie_chart',\r\n 'ligature': 'pie_chart',\r\n 'tags' : ['pie_chart']\r\n },\r\n {\r\n 'name' : 'pin_drop',\r\n 'ligature': 'pin_drop',\r\n 'tags' : ['pin_drop']\r\n },\r\n {\r\n 'name' : 'place',\r\n 'ligature': 'place',\r\n 'tags' : ['place']\r\n },\r\n {\r\n 'name' : 'play_arrow',\r\n 'ligature': 'play_arrow',\r\n 'tags' : ['play_arrow']\r\n },\r\n {\r\n 'name' : 'play_circle_filled_white',\r\n 'ligature': 'play_circle_filled_white',\r\n 'tags' : ['play_circle_filled_white']\r\n },\r\n {\r\n 'name' : 'play_circle_filled',\r\n 'ligature': 'play_circle_filled',\r\n 'tags' : ['play_circle_filled']\r\n },\r\n {\r\n 'name' : 'play_circle_outline',\r\n 'ligature': 'play_circle_outline',\r\n 'tags' : ['play_circle_outline']\r\n },\r\n {\r\n 'name' : 'play_for_work',\r\n 'ligature': 'play_for_work',\r\n 'tags' : ['play_for_work']\r\n },\r\n {\r\n 'name' : 'playlist_add_check',\r\n 'ligature': 'playlist_add_check',\r\n 'tags' : ['playlist_add_check']\r\n },\r\n {\r\n 'name' : 'playlist_add',\r\n 'ligature': 'playlist_add',\r\n 'tags' : ['playlist_add']\r\n },\r\n {\r\n 'name' : 'playlist_play',\r\n 'ligature': 'playlist_play',\r\n 'tags' : ['playlist_play']\r\n },\r\n {\r\n 'name' : 'plus_one',\r\n 'ligature': 'plus_one',\r\n 'tags' : ['plus_one']\r\n },\r\n {\r\n 'name' : 'poll',\r\n 'ligature': 'poll',\r\n 'tags' : ['poll']\r\n },\r\n {\r\n 'name' : 'polymer',\r\n 'ligature': 'polymer',\r\n 'tags' : ['polymer']\r\n },\r\n {\r\n 'name' : 'pool',\r\n 'ligature': 'pool',\r\n 'tags' : ['pool']\r\n },\r\n {\r\n 'name' : 'portable_wifi_off',\r\n 'ligature': 'portable_wifi_off',\r\n 'tags' : ['portable_wifi_off']\r\n },\r\n {\r\n 'name' : 'portrait',\r\n 'ligature': 'portrait',\r\n 'tags' : ['portrait']\r\n },\r\n {\r\n 'name' : 'power_input',\r\n 'ligature': 'power_input',\r\n 'tags' : ['power_input']\r\n },\r\n {\r\n 'name' : 'power_off',\r\n 'ligature': 'power_off',\r\n 'tags' : ['power_off']\r\n },\r\n {\r\n 'name' : 'power_settings_new',\r\n 'ligature': 'power_settings_new',\r\n 'tags' : ['power_settings_new']\r\n },\r\n {\r\n 'name' : 'power',\r\n 'ligature': 'power',\r\n 'tags' : ['power']\r\n },\r\n {\r\n 'name' : 'pregnant_woman',\r\n 'ligature': 'pregnant_woman',\r\n 'tags' : ['pregnant_woman']\r\n },\r\n {\r\n 'name' : 'present_to_all',\r\n 'ligature': 'present_to_all',\r\n 'tags' : ['present_to_all']\r\n },\r\n {\r\n 'name' : 'print_disabled',\r\n 'ligature': 'print_disabled',\r\n 'tags' : ['print_disabled']\r\n },\r\n {\r\n 'name' : 'print',\r\n 'ligature': 'print',\r\n 'tags' : ['print']\r\n },\r\n {\r\n 'name' : 'priority_high',\r\n 'ligature': 'priority_high',\r\n 'tags' : ['priority_high']\r\n },\r\n {\r\n 'name' : 'public',\r\n 'ligature': 'public',\r\n 'tags' : ['public']\r\n },\r\n {\r\n 'name' : 'publish',\r\n 'ligature': 'publish',\r\n 'tags' : ['publish']\r\n },\r\n {\r\n 'name' : 'query_builder',\r\n 'ligature': 'query_builder',\r\n 'tags' : ['query_builder']\r\n },\r\n {\r\n 'name' : 'question_answer',\r\n 'ligature': 'question_answer',\r\n 'tags' : ['question_answer']\r\n },\r\n {\r\n 'name' : 'queue_music',\r\n 'ligature': 'queue_music',\r\n 'tags' : ['queue_music']\r\n },\r\n {\r\n 'name' : 'queue_play_next',\r\n 'ligature': 'queue_play_next',\r\n 'tags' : ['queue_play_next']\r\n },\r\n {\r\n 'name' : 'queue',\r\n 'ligature': 'queue',\r\n 'tags' : ['queue']\r\n },\r\n {\r\n 'name' : 'radio_button_checked',\r\n 'ligature': 'radio_button_checked',\r\n 'tags' : ['radio_button_checked']\r\n },\r\n {\r\n 'name' : 'radio_button_unchecked',\r\n 'ligature': 'radio_button_unchecked',\r\n 'tags' : ['radio_button_unchecked']\r\n },\r\n {\r\n 'name' : 'radio',\r\n 'ligature': 'radio',\r\n 'tags' : ['radio']\r\n },\r\n {\r\n 'name' : 'rate_review',\r\n 'ligature': 'rate_review',\r\n 'tags' : ['rate_review']\r\n },\r\n {\r\n 'name' : 'receipt',\r\n 'ligature': 'receipt',\r\n 'tags' : ['receipt']\r\n },\r\n {\r\n 'name' : 'recent_actors',\r\n 'ligature': 'recent_actors',\r\n 'tags' : ['recent_actors']\r\n },\r\n {\r\n 'name' : 'record_voice_over',\r\n 'ligature': 'record_voice_over',\r\n 'tags' : ['record_voice_over']\r\n },\r\n {\r\n 'name' : 'redeem',\r\n 'ligature': 'redeem',\r\n 'tags' : ['redeem']\r\n },\r\n {\r\n 'name' : 'redo',\r\n 'ligature': 'redo',\r\n 'tags' : ['redo']\r\n },\r\n {\r\n 'name' : 'refresh',\r\n 'ligature': 'refresh',\r\n 'tags' : ['refresh']\r\n },\r\n {\r\n 'name' : 'remove_circle_outline',\r\n 'ligature': 'remove_circle_outline',\r\n 'tags' : ['remove_circle_outline']\r\n },\r\n {\r\n 'name' : 'remove_circle',\r\n 'ligature': 'remove_circle',\r\n 'tags' : ['remove_circle']\r\n },\r\n {\r\n 'name' : 'remove_from_queue',\r\n 'ligature': 'remove_from_queue',\r\n 'tags' : ['remove_from_queue']\r\n },\r\n {\r\n 'name' : 'remove_red_eye',\r\n 'ligature': 'remove_red_eye',\r\n 'tags' : ['remove_red_eye']\r\n },\r\n {\r\n 'name' : 'remove_shopping_cart',\r\n 'ligature': 'remove_shopping_cart',\r\n 'tags' : ['remove_shopping_cart']\r\n },\r\n {\r\n 'name' : 'remove',\r\n 'ligature': 'remove',\r\n 'tags' : ['remove']\r\n },\r\n {\r\n 'name' : 'reorder',\r\n 'ligature': 'reorder',\r\n 'tags' : ['reorder']\r\n },\r\n {\r\n 'name' : 'repeat_one',\r\n 'ligature': 'repeat_one',\r\n 'tags' : ['repeat_one']\r\n },\r\n {\r\n 'name' : 'repeat',\r\n 'ligature': 'repeat',\r\n 'tags' : ['repeat']\r\n },\r\n {\r\n 'name' : 'replay_5',\r\n 'ligature': 'replay_5',\r\n 'tags' : ['replay_5']\r\n },\r\n {\r\n 'name' : 'replay_10',\r\n 'ligature': 'replay_10',\r\n 'tags' : ['replay_10']\r\n },\r\n {\r\n 'name' : 'replay_30',\r\n 'ligature': 'replay_30',\r\n 'tags' : ['replay_30']\r\n },\r\n {\r\n 'name' : 'replay',\r\n 'ligature': 'replay',\r\n 'tags' : ['replay']\r\n },\r\n {\r\n 'name' : 'reply_all',\r\n 'ligature': 'reply_all',\r\n 'tags' : ['reply_all']\r\n },\r\n {\r\n 'name' : 'reply',\r\n 'ligature': 'reply',\r\n 'tags' : ['reply']\r\n },\r\n {\r\n 'name' : 'report_off',\r\n 'ligature': 'report_off',\r\n 'tags' : ['report_off']\r\n },\r\n {\r\n 'name' : 'report_problem',\r\n 'ligature': 'report_problem',\r\n 'tags' : ['report_problem']\r\n },\r\n {\r\n 'name' : 'report',\r\n 'ligature': 'report',\r\n 'tags' : ['report']\r\n },\r\n {\r\n 'name' : 'restaurant_menu',\r\n 'ligature': 'restaurant_menu',\r\n 'tags' : ['restaurant_menu']\r\n },\r\n {\r\n 'name' : 'restaurant',\r\n 'ligature': 'restaurant',\r\n 'tags' : ['restaurant']\r\n },\r\n {\r\n 'name' : 'restore_from_trash',\r\n 'ligature': 'restore_from_trash',\r\n 'tags' : ['restore_from_trash']\r\n },\r\n {\r\n 'name' : 'restore_page',\r\n 'ligature': 'restore_page',\r\n 'tags' : ['restore_page']\r\n },\r\n {\r\n 'name' : 'restore',\r\n 'ligature': 'restore',\r\n 'tags' : ['restore']\r\n },\r\n {\r\n 'name' : 'ring_volume',\r\n 'ligature': 'ring_volume',\r\n 'tags' : ['ring_volume']\r\n },\r\n {\r\n 'name' : 'room_service',\r\n 'ligature': 'room_service',\r\n 'tags' : ['room_service']\r\n },\r\n {\r\n 'name' : 'room',\r\n 'ligature': 'room',\r\n 'tags' : ['room']\r\n },\r\n {\r\n 'name' : 'rotate_90_degrees_ccw',\r\n 'ligature': 'rotate_90_degrees_ccw',\r\n 'tags' : ['rotate_90_degrees_ccw']\r\n },\r\n {\r\n 'name' : 'rotate_left',\r\n 'ligature': 'rotate_left',\r\n 'tags' : ['rotate_left']\r\n },\r\n {\r\n 'name' : 'rotate_right',\r\n 'ligature': 'rotate_right',\r\n 'tags' : ['rotate_right']\r\n },\r\n {\r\n 'name' : 'rounded_corner',\r\n 'ligature': 'rounded_corner',\r\n 'tags' : ['rounded_corner']\r\n },\r\n {\r\n 'name' : 'router',\r\n 'ligature': 'router',\r\n 'tags' : ['router']\r\n },\r\n {\r\n 'name' : 'rowing',\r\n 'ligature': 'rowing',\r\n 'tags' : ['rowing']\r\n },\r\n {\r\n 'name' : 'rss_feed',\r\n 'ligature': 'rss_feed',\r\n 'tags' : ['rss_feed']\r\n },\r\n {\r\n 'name' : 'rv_hookup',\r\n 'ligature': 'rv_hookup',\r\n 'tags' : ['rv_hookup']\r\n },\r\n {\r\n 'name' : 'satellite',\r\n 'ligature': 'satellite',\r\n 'tags' : ['satellite']\r\n },\r\n {\r\n 'name' : 'save_alt',\r\n 'ligature': 'save_alt',\r\n 'tags' : ['save_alt']\r\n },\r\n {\r\n 'name' : 'save',\r\n 'ligature': 'save',\r\n 'tags' : ['save']\r\n },\r\n {\r\n 'name' : 'scanner',\r\n 'ligature': 'scanner',\r\n 'tags' : ['scanner']\r\n },\r\n {\r\n 'name' : 'scatter_plot',\r\n 'ligature': 'scatter_plot',\r\n 'tags' : ['scatter_plot']\r\n },\r\n {\r\n 'name' : 'schedule',\r\n 'ligature': 'schedule',\r\n 'tags' : ['schedule']\r\n },\r\n {\r\n 'name' : 'school',\r\n 'ligature': 'school',\r\n 'tags' : ['school']\r\n },\r\n {\r\n 'name' : 'score',\r\n 'ligature': 'score',\r\n 'tags' : ['score']\r\n },\r\n {\r\n 'name' : 'screen_lock_landscape',\r\n 'ligature': 'screen_lock_landscape',\r\n 'tags' : ['screen_lock_landscape']\r\n },\r\n {\r\n 'name' : 'screen_lock_portrait',\r\n 'ligature': 'screen_lock_portrait',\r\n 'tags' : ['screen_lock_portrait']\r\n },\r\n {\r\n 'name' : 'screen_lock_rotation',\r\n 'ligature': 'screen_lock_rotation',\r\n 'tags' : ['screen_lock_rotation']\r\n },\r\n {\r\n 'name' : 'screen_rotation',\r\n 'ligature': 'screen_rotation',\r\n 'tags' : ['screen_rotation']\r\n },\r\n {\r\n 'name' : 'screen_share',\r\n 'ligature': 'screen_share',\r\n 'tags' : ['screen_share']\r\n },\r\n {\r\n 'name' : 'sd_card',\r\n 'ligature': 'sd_card',\r\n 'tags' : ['sd_card']\r\n },\r\n {\r\n 'name' : 'sd_storage',\r\n 'ligature': 'sd_storage',\r\n 'tags' : ['sd_storage']\r\n },\r\n {\r\n 'name' : 'search',\r\n 'ligature': 'search',\r\n 'tags' : ['search']\r\n },\r\n {\r\n 'name' : 'security',\r\n 'ligature': 'security',\r\n 'tags' : ['security']\r\n },\r\n {\r\n 'name' : 'select_all',\r\n 'ligature': 'select_all',\r\n 'tags' : ['select_all']\r\n },\r\n {\r\n 'name' : 'send',\r\n 'ligature': 'send',\r\n 'tags' : ['send']\r\n },\r\n {\r\n 'name' : 'sentiment_dissatisfied',\r\n 'ligature': 'sentiment_dissatisfied',\r\n 'tags' : ['sentiment_dissatisfied']\r\n },\r\n {\r\n 'name' : 'sentiment_satisfied_alt',\r\n 'ligature': 'sentiment_satisfied_alt',\r\n 'tags' : ['sentiment_satisfied_alt']\r\n },\r\n {\r\n 'name' : 'sentiment_satisfied',\r\n 'ligature': 'sentiment_satisfied',\r\n 'tags' : ['sentiment_satisfied']\r\n },\r\n {\r\n 'name' : 'sentiment_very_dissatisfied',\r\n 'ligature': 'sentiment_very_dissatisfied',\r\n 'tags' : ['sentiment_very_dissatisfied']\r\n },\r\n {\r\n 'name' : 'sentiment_very_satisfied',\r\n 'ligature': 'sentiment_very_satisfied',\r\n 'tags' : ['sentiment_very_satisfied']\r\n },\r\n {\r\n 'name' : 'settings_applications',\r\n 'ligature': 'settings_applications',\r\n 'tags' : ['settings_applications']\r\n },\r\n {\r\n 'name' : 'settings_backup_restore',\r\n 'ligature': 'settings_backup_restore',\r\n 'tags' : ['settings_backup_restore']\r\n },\r\n {\r\n 'name' : 'settings_bluetooth',\r\n 'ligature': 'settings_bluetooth',\r\n 'tags' : ['settings_bluetooth']\r\n },\r\n {\r\n 'name' : 'settings_brightness',\r\n 'ligature': 'settings_brightness',\r\n 'tags' : ['settings_brightness']\r\n },\r\n {\r\n 'name' : 'settings_cell',\r\n 'ligature': 'settings_cell',\r\n 'tags' : ['settings_cell']\r\n },\r\n {\r\n 'name' : 'settings_ethernet',\r\n 'ligature': 'settings_ethernet',\r\n 'tags' : ['settings_ethernet']\r\n },\r\n {\r\n 'name' : 'settings_input_antenna',\r\n 'ligature': 'settings_input_antenna',\r\n 'tags' : ['settings_input_antenna']\r\n },\r\n {\r\n 'name' : 'settings_input_component',\r\n 'ligature': 'settings_input_component',\r\n 'tags' : ['settings_input_component']\r\n },\r\n {\r\n 'name' : 'settings_input_composite',\r\n 'ligature': 'settings_input_composite',\r\n 'tags' : ['settings_input_composite']\r\n },\r\n {\r\n 'name' : 'settings_input_hdmi',\r\n 'ligature': 'settings_input_hdmi',\r\n 'tags' : ['settings_input_hdmi']\r\n },\r\n {\r\n 'name' : 'settings_input_svideo',\r\n 'ligature': 'settings_input_svideo',\r\n 'tags' : ['settings_input_svideo']\r\n },\r\n {\r\n 'name' : 'settings_overscan',\r\n 'ligature': 'settings_overscan',\r\n 'tags' : ['settings_overscan']\r\n },\r\n {\r\n 'name' : 'settings_phone',\r\n 'ligature': 'settings_phone',\r\n 'tags' : ['settings_phone']\r\n },\r\n {\r\n 'name' : 'settings_power',\r\n 'ligature': 'settings_power',\r\n 'tags' : ['settings_power']\r\n },\r\n {\r\n 'name' : 'settings_remote',\r\n 'ligature': 'settings_remote',\r\n 'tags' : ['settings_remote']\r\n },\r\n {\r\n 'name' : 'settings_system_daydream',\r\n 'ligature': 'settings_system_daydream',\r\n 'tags' : ['settings_system_daydream']\r\n },\r\n {\r\n 'name' : 'settings_voice',\r\n 'ligature': 'settings_voice',\r\n 'tags' : ['settings_voice']\r\n },\r\n {\r\n 'name' : 'settings',\r\n 'ligature': 'settings',\r\n 'tags' : ['settings']\r\n },\r\n {\r\n 'name' : 'share',\r\n 'ligature': 'share',\r\n 'tags' : ['share']\r\n },\r\n {\r\n 'name' : 'shop_two',\r\n 'ligature': 'shop_two',\r\n 'tags' : ['shop_two']\r\n },\r\n {\r\n 'name' : 'shop',\r\n 'ligature': 'shop',\r\n 'tags' : ['shop']\r\n },\r\n {\r\n 'name' : 'shopping_basket',\r\n 'ligature': 'shopping_basket',\r\n 'tags' : ['shopping_basket']\r\n },\r\n {\r\n 'name' : 'shopping_cart',\r\n 'ligature': 'shopping_cart',\r\n 'tags' : ['shopping_cart']\r\n },\r\n {\r\n 'name' : 'short_text',\r\n 'ligature': 'short_text',\r\n 'tags' : ['short_text']\r\n },\r\n {\r\n 'name' : 'show_chart',\r\n 'ligature': 'show_chart',\r\n 'tags' : ['show_chart']\r\n },\r\n {\r\n 'name' : 'shuffle',\r\n 'ligature': 'shuffle',\r\n 'tags' : ['shuffle']\r\n },\r\n {\r\n 'name' : 'shutter_speed',\r\n 'ligature': 'shutter_speed',\r\n 'tags' : ['shutter_speed']\r\n },\r\n {\r\n 'name' : 'signal_cellular_0_bar',\r\n 'ligature': 'signal_cellular_0_bar',\r\n 'tags' : ['signal_cellular_0_bar']\r\n },\r\n {\r\n 'name' : 'signal_cellular_4_bar',\r\n 'ligature': 'signal_cellular_4_bar',\r\n 'tags' : ['signal_cellular_4_bar']\r\n },\r\n {\r\n 'name' : 'signal_cellular_alt',\r\n 'ligature': 'signal_cellular_alt',\r\n 'tags' : ['signal_cellular_alt']\r\n },\r\n {\r\n 'name' : 'signal_cellular_connected_no_internet_4_bar',\r\n 'ligature': 'signal_cellular_connected_no_internet_4_bar',\r\n 'tags' : ['signal_cellular_connected_no_internet_4_bar']\r\n },\r\n {\r\n 'name' : 'signal_cellular_no_sim',\r\n 'ligature': 'signal_cellular_no_sim',\r\n 'tags' : ['signal_cellular_no_sim']\r\n },\r\n {\r\n 'name' : 'signal_cellular_null',\r\n 'ligature': 'signal_cellular_null',\r\n 'tags' : ['signal_cellular_null']\r\n },\r\n {\r\n 'name' : 'signal_cellular_off',\r\n 'ligature': 'signal_cellular_off',\r\n 'tags' : ['signal_cellular_off']\r\n },\r\n {\r\n 'name' : 'signal_wifi_0_bar',\r\n 'ligature': 'signal_wifi_0_bar',\r\n 'tags' : ['signal_wifi_0_bar']\r\n },\r\n {\r\n 'name' : 'signal_wifi_4_bar_lock',\r\n 'ligature': 'signal_wifi_4_bar_lock',\r\n 'tags' : ['signal_wifi_4_bar_lock']\r\n },\r\n {\r\n 'name' : 'signal_wifi_4_bar',\r\n 'ligature': 'signal_wifi_4_bar',\r\n 'tags' : ['signal_wifi_4_bar']\r\n },\r\n {\r\n 'name' : 'signal_wifi_off',\r\n 'ligature': 'signal_wifi_off',\r\n 'tags' : ['signal_wifi_off']\r\n },\r\n {\r\n 'name' : 'sim_card',\r\n 'ligature': 'sim_card',\r\n 'tags' : ['sim_card']\r\n },\r\n {\r\n 'name' : 'skip_next',\r\n 'ligature': 'skip_next',\r\n 'tags' : ['skip_next']\r\n },\r\n {\r\n 'name' : 'skip_previous',\r\n 'ligature': 'skip_previous',\r\n 'tags' : ['skip_previous']\r\n },\r\n {\r\n 'name' : 'slideshow',\r\n 'ligature': 'slideshow',\r\n 'tags' : ['slideshow']\r\n },\r\n {\r\n 'name' : 'slow_motion_video',\r\n 'ligature': 'slow_motion_video',\r\n 'tags' : ['slow_motion_video']\r\n },\r\n {\r\n 'name' : 'smartphone',\r\n 'ligature': 'smartphone',\r\n 'tags' : ['smartphone']\r\n },\r\n {\r\n 'name' : 'smoke_free',\r\n 'ligature': 'smoke_free',\r\n 'tags' : ['smoke_free']\r\n },\r\n {\r\n 'name' : 'smoking_rooms',\r\n 'ligature': 'smoking_rooms',\r\n 'tags' : ['smoking_rooms']\r\n },\r\n {\r\n 'name' : 'sms_failed',\r\n 'ligature': 'sms_failed',\r\n 'tags' : ['sms_failed']\r\n },\r\n {\r\n 'name' : 'sms',\r\n 'ligature': 'sms',\r\n 'tags' : ['sms']\r\n },\r\n {\r\n 'name' : 'snooze',\r\n 'ligature': 'snooze',\r\n 'tags' : ['snooze']\r\n },\r\n {\r\n 'name' : 'sort_by_alpha',\r\n 'ligature': 'sort_by_alpha',\r\n 'tags' : ['sort_by_alpha']\r\n },\r\n {\r\n 'name' : 'sort',\r\n 'ligature': 'sort',\r\n 'tags' : ['sort']\r\n },\r\n {\r\n 'name' : 'spa',\r\n 'ligature': 'spa',\r\n 'tags' : ['spa']\r\n },\r\n {\r\n 'name' : 'space_bar',\r\n 'ligature': 'space_bar',\r\n 'tags' : ['space_bar']\r\n },\r\n {\r\n 'name' : 'speaker_group',\r\n 'ligature': 'speaker_group',\r\n 'tags' : ['speaker_group']\r\n },\r\n {\r\n 'name' : 'speaker_notes_off',\r\n 'ligature': 'speaker_notes_off',\r\n 'tags' : ['speaker_notes_off']\r\n },\r\n {\r\n 'name' : 'speaker_notes',\r\n 'ligature': 'speaker_notes',\r\n 'tags' : ['speaker_notes']\r\n },\r\n {\r\n 'name' : 'speaker_phone',\r\n 'ligature': 'speaker_phone',\r\n 'tags' : ['speaker_phone']\r\n },\r\n {\r\n 'name' : 'speaker',\r\n 'ligature': 'speaker',\r\n 'tags' : ['speaker']\r\n },\r\n {\r\n 'name' : 'spellcheck',\r\n 'ligature': 'spellcheck',\r\n 'tags' : ['spellcheck']\r\n },\r\n {\r\n 'name' : 'star_border',\r\n 'ligature': 'star_border',\r\n 'tags' : ['star_border']\r\n },\r\n {\r\n 'name' : 'star_half',\r\n 'ligature': 'star_half',\r\n 'tags' : ['star_half']\r\n },\r\n {\r\n 'name' : 'star_rate',\r\n 'ligature': 'star_rate',\r\n 'tags' : ['star_rate']\r\n },\r\n {\r\n 'name' : 'star',\r\n 'ligature': 'star',\r\n 'tags' : ['star']\r\n },\r\n {\r\n 'name' : 'stars',\r\n 'ligature': 'stars',\r\n 'tags' : ['stars']\r\n },\r\n {\r\n 'name' : 'stay_current_landscape',\r\n 'ligature': 'stay_current_landscape',\r\n 'tags' : ['stay_current_landscape']\r\n },\r\n {\r\n 'name' : 'stay_current_portrait',\r\n 'ligature': 'stay_current_portrait',\r\n 'tags' : ['stay_current_portrait']\r\n },\r\n {\r\n 'name' : 'stay_primary_landscape',\r\n 'ligature': 'stay_primary_landscape',\r\n 'tags' : ['stay_primary_landscape']\r\n },\r\n {\r\n 'name' : 'stay_primary_portrait',\r\n 'ligature': 'stay_primary_portrait',\r\n 'tags' : ['stay_primary_portrait']\r\n },\r\n {\r\n 'name' : 'stop_screen_share',\r\n 'ligature': 'stop_screen_share',\r\n 'tags' : ['stop_screen_share']\r\n },\r\n {\r\n 'name' : 'stop',\r\n 'ligature': 'stop',\r\n 'tags' : ['stop']\r\n },\r\n {\r\n 'name' : 'storage',\r\n 'ligature': 'storage',\r\n 'tags' : ['storage']\r\n },\r\n {\r\n 'name' : 'store_mall_directory',\r\n 'ligature': 'store_mall_directory',\r\n 'tags' : ['store_mall_directory']\r\n },\r\n {\r\n 'name' : 'store',\r\n 'ligature': 'store',\r\n 'tags' : ['store']\r\n },\r\n {\r\n 'name' : 'straighten',\r\n 'ligature': 'straighten',\r\n 'tags' : ['straighten']\r\n },\r\n {\r\n 'name' : 'streetview',\r\n 'ligature': 'streetview',\r\n 'tags' : ['streetview']\r\n },\r\n {\r\n 'name' : 'strikethrough_s',\r\n 'ligature': 'strikethrough_s',\r\n 'tags' : ['strikethrough_s']\r\n },\r\n {\r\n 'name' : 'style',\r\n 'ligature': 'style',\r\n 'tags' : ['style']\r\n },\r\n {\r\n 'name' : 'subdirectory_arrow_left',\r\n 'ligature': 'subdirectory_arrow_left',\r\n 'tags' : ['subdirectory_arrow_left']\r\n },\r\n {\r\n 'name' : 'subdirectory_arrow_right',\r\n 'ligature': 'subdirectory_arrow_right',\r\n 'tags' : ['subdirectory_arrow_right']\r\n },\r\n {\r\n 'name' : 'subject',\r\n 'ligature': 'subject',\r\n 'tags' : ['subject']\r\n },\r\n {\r\n 'name' : 'subscriptions',\r\n 'ligature': 'subscriptions',\r\n 'tags' : ['subscriptions']\r\n },\r\n {\r\n 'name' : 'subtitles',\r\n 'ligature': 'subtitles',\r\n 'tags' : ['subtitles']\r\n },\r\n {\r\n 'name' : 'subway',\r\n 'ligature': 'subway',\r\n 'tags' : ['subway']\r\n },\r\n {\r\n 'name' : 'supervised_user_circle',\r\n 'ligature': 'supervised_user_circle',\r\n 'tags' : ['supervised_user_circle']\r\n },\r\n {\r\n 'name' : 'supervisor_account',\r\n 'ligature': 'supervisor_account',\r\n 'tags' : ['supervisor_account']\r\n },\r\n {\r\n 'name' : 'surround_sound',\r\n 'ligature': 'surround_sound',\r\n 'tags' : ['surround_sound']\r\n },\r\n {\r\n 'name' : 'swap_calls',\r\n 'ligature': 'swap_calls',\r\n 'tags' : ['swap_calls']\r\n },\r\n {\r\n 'name' : 'swap_horiz',\r\n 'ligature': 'swap_horiz',\r\n 'tags' : ['swap_horiz']\r\n },\r\n {\r\n 'name' : 'swap_horizontal_circle',\r\n 'ligature': 'swap_horizontal_circle',\r\n 'tags' : ['swap_horizontal_circle']\r\n },\r\n {\r\n 'name' : 'swap_vert',\r\n 'ligature': 'swap_vert',\r\n 'tags' : ['swap_vert']\r\n },\r\n {\r\n 'name' : 'swap_vertical_circle',\r\n 'ligature': 'swap_vertical_circle',\r\n 'tags' : ['swap_vertical_circle']\r\n },\r\n {\r\n 'name' : 'switch_camera',\r\n 'ligature': 'switch_camera',\r\n 'tags' : ['switch_camera']\r\n },\r\n {\r\n 'name' : 'switch_video',\r\n 'ligature': 'switch_video',\r\n 'tags' : ['switch_video']\r\n },\r\n {\r\n 'name' : 'sync_disabled',\r\n 'ligature': 'sync_disabled',\r\n 'tags' : ['sync_disabled']\r\n },\r\n {\r\n 'name' : 'sync_problem',\r\n 'ligature': 'sync_problem',\r\n 'tags' : ['sync_problem']\r\n },\r\n {\r\n 'name' : 'sync',\r\n 'ligature': 'sync',\r\n 'tags' : ['sync']\r\n },\r\n {\r\n 'name' : 'system_update',\r\n 'ligature': 'system_update',\r\n 'tags' : ['system_update']\r\n },\r\n {\r\n 'name' : 'tab_unselected',\r\n 'ligature': 'tab_unselected',\r\n 'tags' : ['tab_unselected']\r\n },\r\n {\r\n 'name' : 'tab',\r\n 'ligature': 'tab',\r\n 'tags' : ['tab']\r\n },\r\n {\r\n 'name' : 'table_chart',\r\n 'ligature': 'table_chart',\r\n 'tags' : ['table_chart']\r\n },\r\n {\r\n 'name' : 'tablet_android',\r\n 'ligature': 'tablet_android',\r\n 'tags' : ['tablet_android']\r\n },\r\n {\r\n 'name' : 'tablet_mac',\r\n 'ligature': 'tablet_mac',\r\n 'tags' : ['tablet_mac']\r\n },\r\n {\r\n 'name' : 'tablet',\r\n 'ligature': 'tablet',\r\n 'tags' : ['tablet']\r\n },\r\n {\r\n 'name' : 'tag_faces',\r\n 'ligature': 'tag_faces',\r\n 'tags' : ['tag_faces']\r\n },\r\n {\r\n 'name' : 'tap_and_play',\r\n 'ligature': 'tap_and_play',\r\n 'tags' : ['tap_and_play']\r\n },\r\n {\r\n 'name' : 'terrain',\r\n 'ligature': 'terrain',\r\n 'tags' : ['terrain']\r\n },\r\n {\r\n 'name' : 'text_fields',\r\n 'ligature': 'text_fields',\r\n 'tags' : ['text_fields']\r\n },\r\n {\r\n 'name' : 'text_format',\r\n 'ligature': 'text_format',\r\n 'tags' : ['text_format']\r\n },\r\n {\r\n 'name' : 'text_rotate_up',\r\n 'ligature': 'text_rotate_up',\r\n 'tags' : ['text_rotate_up']\r\n },\r\n {\r\n 'name' : 'text_rotate_vertical',\r\n 'ligature': 'text_rotate_vertical',\r\n 'tags' : ['text_rotate_vertical']\r\n },\r\n {\r\n 'name' : 'text_rotation_down',\r\n 'ligature': 'text_rotation_down',\r\n 'tags' : ['text_rotation_down']\r\n },\r\n {\r\n 'name' : 'text_rotation_none',\r\n 'ligature': 'text_rotation_none',\r\n 'tags' : ['text_rotation_none']\r\n },\r\n {\r\n 'name' : 'textsms',\r\n 'ligature': 'textsms',\r\n 'tags' : ['textsms']\r\n },\r\n {\r\n 'name' : 'texture',\r\n 'ligature': 'texture',\r\n 'tags' : ['texture']\r\n },\r\n {\r\n 'name' : 'theaters',\r\n 'ligature': 'theaters',\r\n 'tags' : ['theaters']\r\n },\r\n {\r\n 'name' : 'thumb_down_alt',\r\n 'ligature': 'thumb_down_alt',\r\n 'tags' : ['thumb_down_alt']\r\n },\r\n {\r\n 'name' : 'thumb_down',\r\n 'ligature': 'thumb_down',\r\n 'tags' : ['thumb_down']\r\n },\r\n {\r\n 'name' : 'thumb_up_alt',\r\n 'ligature': 'thumb_up_alt',\r\n 'tags' : ['thumb_up_alt']\r\n },\r\n {\r\n 'name' : 'thumb_up',\r\n 'ligature': 'thumb_up',\r\n 'tags' : ['thumb_up']\r\n },\r\n {\r\n 'name' : 'thumbs_up_down',\r\n 'ligature': 'thumbs_up_down',\r\n 'tags' : ['thumbs_up_down']\r\n },\r\n {\r\n 'name' : 'time_to_leave',\r\n 'ligature': 'time_to_leave',\r\n 'tags' : ['time_to_leave']\r\n },\r\n {\r\n 'name' : 'timelapse',\r\n 'ligature': 'timelapse',\r\n 'tags' : ['timelapse']\r\n },\r\n {\r\n 'name' : 'timeline',\r\n 'ligature': 'timeline',\r\n 'tags' : ['timeline']\r\n },\r\n {\r\n 'name' : 'timer_3',\r\n 'ligature': 'timer_3',\r\n 'tags' : ['timer_3']\r\n },\r\n {\r\n 'name' : 'timer_10',\r\n 'ligature': 'timer_10',\r\n 'tags' : ['timer_10']\r\n },\r\n {\r\n 'name' : 'timer_off',\r\n 'ligature': 'timer_off',\r\n 'tags' : ['timer_off']\r\n },\r\n {\r\n 'name' : 'timer',\r\n 'ligature': 'timer',\r\n 'tags' : ['timer']\r\n },\r\n {\r\n 'name' : 'title',\r\n 'ligature': 'title',\r\n 'tags' : ['title']\r\n },\r\n {\r\n 'name' : 'toc',\r\n 'ligature': 'toc',\r\n 'tags' : ['toc']\r\n },\r\n {\r\n 'name' : 'today',\r\n 'ligature': 'today',\r\n 'tags' : ['today']\r\n },\r\n {\r\n 'name' : 'toggle_off',\r\n 'ligature': 'toggle_off',\r\n 'tags' : ['toggle_off']\r\n },\r\n {\r\n 'name' : 'toggle_on',\r\n 'ligature': 'toggle_on',\r\n 'tags' : ['toggle_on']\r\n },\r\n {\r\n 'name' : 'toll',\r\n 'ligature': 'toll',\r\n 'tags' : ['toll']\r\n },\r\n {\r\n 'name' : 'tonality',\r\n 'ligature': 'tonality',\r\n 'tags' : ['tonality']\r\n },\r\n {\r\n 'name' : 'touch_app',\r\n 'ligature': 'touch_app',\r\n 'tags' : ['touch_app']\r\n },\r\n {\r\n 'name' : 'toys',\r\n 'ligature': 'toys',\r\n 'tags' : ['toys']\r\n },\r\n {\r\n 'name' : 'track_changes',\r\n 'ligature': 'track_changes',\r\n 'tags' : ['track_changes']\r\n },\r\n {\r\n 'name' : 'traffic',\r\n 'ligature': 'traffic',\r\n 'tags' : ['traffic']\r\n },\r\n {\r\n 'name' : 'train',\r\n 'ligature': 'train',\r\n 'tags' : ['train']\r\n },\r\n {\r\n 'name' : 'tram',\r\n 'ligature': 'tram',\r\n 'tags' : ['tram']\r\n },\r\n {\r\n 'name' : 'transfer_within_a_station',\r\n 'ligature': 'transfer_within_a_station',\r\n 'tags' : ['transfer_within_a_station']\r\n },\r\n {\r\n 'name' : 'transform',\r\n 'ligature': 'transform',\r\n 'tags' : ['transform']\r\n },\r\n {\r\n 'name' : 'transit_enterexit',\r\n 'ligature': 'transit_enterexit',\r\n 'tags' : ['transit_enterexit']\r\n },\r\n {\r\n 'name' : 'translate',\r\n 'ligature': 'translate',\r\n 'tags' : ['translate']\r\n },\r\n {\r\n 'name' : 'trending_down',\r\n 'ligature': 'trending_down',\r\n 'tags' : ['trending_down']\r\n },\r\n {\r\n 'name' : 'trending_flat',\r\n 'ligature': 'trending_flat',\r\n 'tags' : ['trending_flat']\r\n },\r\n {\r\n 'name' : 'trending_up',\r\n 'ligature': 'trending_up',\r\n 'tags' : ['trending_up']\r\n },\r\n {\r\n 'name' : 'trip_origin',\r\n 'ligature': 'trip_origin',\r\n 'tags' : ['trip_origin']\r\n },\r\n {\r\n 'name' : 'tune',\r\n 'ligature': 'tune',\r\n 'tags' : ['tune']\r\n },\r\n {\r\n 'name' : 'turned_in_not',\r\n 'ligature': 'turned_in_not',\r\n 'tags' : ['turned_in_not']\r\n },\r\n {\r\n 'name' : 'turned_in',\r\n 'ligature': 'turned_in',\r\n 'tags' : ['turned_in']\r\n },\r\n {\r\n 'name' : 'tv_off',\r\n 'ligature': 'tv_off',\r\n 'tags' : ['tv_off']\r\n },\r\n {\r\n 'name' : 'tv',\r\n 'ligature': 'tv',\r\n 'tags' : ['tv']\r\n },\r\n {\r\n 'name' : 'unarchive',\r\n 'ligature': 'unarchive',\r\n 'tags' : ['unarchive']\r\n },\r\n {\r\n 'name' : 'undo',\r\n 'ligature': 'undo',\r\n 'tags' : ['undo']\r\n },\r\n {\r\n 'name' : 'unfold_less',\r\n 'ligature': 'unfold_less',\r\n 'tags' : ['unfold_less']\r\n },\r\n {\r\n 'name' : 'unfold_more',\r\n 'ligature': 'unfold_more',\r\n 'tags' : ['unfold_more']\r\n },\r\n {\r\n 'name' : 'unsubscribe',\r\n 'ligature': 'unsubscribe',\r\n 'tags' : ['unsubscribe']\r\n },\r\n {\r\n 'name' : 'update',\r\n 'ligature': 'update',\r\n 'tags' : ['update']\r\n },\r\n {\r\n 'name' : 'usb',\r\n 'ligature': 'usb',\r\n 'tags' : ['usb']\r\n },\r\n {\r\n 'name' : 'verified_user',\r\n 'ligature': 'verified_user',\r\n 'tags' : ['verified_user']\r\n },\r\n {\r\n 'name' : 'vertical_align_bottom',\r\n 'ligature': 'vertical_align_bottom',\r\n 'tags' : ['vertical_align_bottom']\r\n },\r\n {\r\n 'name' : 'vertical_align_center',\r\n 'ligature': 'vertical_align_center',\r\n 'tags' : ['vertical_align_center']\r\n },\r\n {\r\n 'name' : 'vertical_align_top',\r\n 'ligature': 'vertical_align_top',\r\n 'tags' : ['vertical_align_top']\r\n },\r\n {\r\n 'name' : 'vertical_split',\r\n 'ligature': 'vertical_split',\r\n 'tags' : ['vertical_split']\r\n },\r\n {\r\n 'name' : 'vibration',\r\n 'ligature': 'vibration',\r\n 'tags' : ['vibration']\r\n },\r\n {\r\n 'name' : 'video_call',\r\n 'ligature': 'video_call',\r\n 'tags' : ['video_call']\r\n },\r\n {\r\n 'name' : 'video_label',\r\n 'ligature': 'video_label',\r\n 'tags' : ['video_label']\r\n },\r\n {\r\n 'name' : 'video_library',\r\n 'ligature': 'video_library',\r\n 'tags' : ['video_library']\r\n },\r\n {\r\n 'name' : 'videocam_off',\r\n 'ligature': 'videocam_off',\r\n 'tags' : ['videocam_off']\r\n },\r\n {\r\n 'name' : 'videocam',\r\n 'ligature': 'videocam',\r\n 'tags' : ['videocam']\r\n },\r\n {\r\n 'name' : 'videogame_asset',\r\n 'ligature': 'videogame_asset',\r\n 'tags' : ['videogame_asset']\r\n },\r\n {\r\n 'name' : 'view_agenda',\r\n 'ligature': 'view_agenda',\r\n 'tags' : ['view_agenda']\r\n },\r\n {\r\n 'name' : 'view_array',\r\n 'ligature': 'view_array',\r\n 'tags' : ['view_array']\r\n },\r\n {\r\n 'name' : 'view_carousel',\r\n 'ligature': 'view_carousel',\r\n 'tags' : ['view_carousel']\r\n },\r\n {\r\n 'name' : 'view_column',\r\n 'ligature': 'view_column',\r\n 'tags' : ['view_column']\r\n },\r\n {\r\n 'name' : 'view_comfy',\r\n 'ligature': 'view_comfy',\r\n 'tags' : ['view_comfy']\r\n },\r\n {\r\n 'name' : 'view_compact',\r\n 'ligature': 'view_compact',\r\n 'tags' : ['view_compact']\r\n },\r\n {\r\n 'name' : 'view_day',\r\n 'ligature': 'view_day',\r\n 'tags' : ['view_day']\r\n },\r\n {\r\n 'name' : 'view_headline',\r\n 'ligature': 'view_headline',\r\n 'tags' : ['view_headline']\r\n },\r\n {\r\n 'name' : 'view_list',\r\n 'ligature': 'view_list',\r\n 'tags' : ['view_list']\r\n },\r\n {\r\n 'name' : 'view_module',\r\n 'ligature': 'view_module',\r\n 'tags' : ['view_module']\r\n },\r\n {\r\n 'name' : 'view_quilt',\r\n 'ligature': 'view_quilt',\r\n 'tags' : ['view_quilt']\r\n },\r\n {\r\n 'name' : 'view_stream',\r\n 'ligature': 'view_stream',\r\n 'tags' : ['view_stream']\r\n },\r\n {\r\n 'name' : 'view_week',\r\n 'ligature': 'view_week',\r\n 'tags' : ['view_week']\r\n },\r\n {\r\n 'name' : 'vignette',\r\n 'ligature': 'vignette',\r\n 'tags' : ['vignette']\r\n },\r\n {\r\n 'name' : 'visibility_off',\r\n 'ligature': 'visibility_off',\r\n 'tags' : ['visibility_off']\r\n },\r\n {\r\n 'name' : 'visibility',\r\n 'ligature': 'visibility',\r\n 'tags' : ['visibility']\r\n },\r\n {\r\n 'name' : 'voice_chat',\r\n 'ligature': 'voice_chat',\r\n 'tags' : ['voice_chat']\r\n },\r\n {\r\n 'name' : 'voice_over_off',\r\n 'ligature': 'voice_over_off',\r\n 'tags' : ['voice_over_off']\r\n },\r\n {\r\n 'name' : 'voicemail',\r\n 'ligature': 'voicemail',\r\n 'tags' : ['voicemail']\r\n },\r\n {\r\n 'name' : 'volume_down',\r\n 'ligature': 'volume_down',\r\n 'tags' : ['volume_down']\r\n },\r\n {\r\n 'name' : 'volume_mute',\r\n 'ligature': 'volume_mute',\r\n 'tags' : ['volume_mute']\r\n },\r\n {\r\n 'name' : 'volume_off',\r\n 'ligature': 'volume_off',\r\n 'tags' : ['volume_off']\r\n },\r\n {\r\n 'name' : 'volume_up',\r\n 'ligature': 'volume_up',\r\n 'tags' : ['volume_up']\r\n },\r\n {\r\n 'name' : 'vpn_key',\r\n 'ligature': 'vpn_key',\r\n 'tags' : ['vpn_key']\r\n },\r\n {\r\n 'name' : 'vpn_lock',\r\n 'ligature': 'vpn_lock',\r\n 'tags' : ['vpn_lock']\r\n },\r\n {\r\n 'name' : 'wallpaper',\r\n 'ligature': 'wallpaper',\r\n 'tags' : ['wallpaper']\r\n },\r\n {\r\n 'name' : 'warning',\r\n 'ligature': 'warning',\r\n 'tags' : ['warning']\r\n },\r\n {\r\n 'name' : 'watch_later',\r\n 'ligature': 'watch_later',\r\n 'tags' : ['watch_later']\r\n },\r\n {\r\n 'name' : 'watch',\r\n 'ligature': 'watch',\r\n 'tags' : ['watch']\r\n },\r\n {\r\n 'name' : 'waves',\r\n 'ligature': 'waves',\r\n 'tags' : ['waves']\r\n },\r\n {\r\n 'name' : 'wb_auto',\r\n 'ligature': 'wb_auto',\r\n 'tags' : ['wb_auto']\r\n },\r\n {\r\n 'name' : 'wb_cloudy',\r\n 'ligature': 'wb_cloudy',\r\n 'tags' : ['wb_cloudy']\r\n },\r\n {\r\n 'name' : 'wb_incandescent',\r\n 'ligature': 'wb_incandescent',\r\n 'tags' : ['wb_incandescent']\r\n },\r\n {\r\n 'name' : 'wb_iridescent',\r\n 'ligature': 'wb_iridescent',\r\n 'tags' : ['wb_iridescent']\r\n },\r\n {\r\n 'name' : 'wb_sunny',\r\n 'ligature': 'wb_sunny',\r\n 'tags' : ['wb_sunny']\r\n },\r\n {\r\n 'name' : 'wc',\r\n 'ligature': 'wc',\r\n 'tags' : ['wc']\r\n },\r\n {\r\n 'name' : 'web_asset',\r\n 'ligature': 'web_asset',\r\n 'tags' : ['web_asset']\r\n },\r\n {\r\n 'name' : 'web',\r\n 'ligature': 'web',\r\n 'tags' : ['web']\r\n },\r\n {\r\n 'name' : 'weekend',\r\n 'ligature': 'weekend',\r\n 'tags' : ['weekend']\r\n },\r\n {\r\n 'name' : 'whatshot',\r\n 'ligature': 'whatshot',\r\n 'tags' : ['whatshot']\r\n },\r\n {\r\n 'name' : 'where_to_vote',\r\n 'ligature': 'where_to_vote',\r\n 'tags' : ['where_to_vote']\r\n },\r\n {\r\n 'name' : 'widgets',\r\n 'ligature': 'widgets',\r\n 'tags' : ['widgets']\r\n },\r\n {\r\n 'name' : 'wifi_lock',\r\n 'ligature': 'wifi_lock',\r\n 'tags' : ['wifi_lock']\r\n },\r\n {\r\n 'name' : 'wifi_off',\r\n 'ligature': 'wifi_off',\r\n 'tags' : ['wifi_off']\r\n },\r\n {\r\n 'name' : 'wifi_tethering',\r\n 'ligature': 'wifi_tethering',\r\n 'tags' : ['wifi_tethering']\r\n },\r\n {\r\n 'name' : 'wifi',\r\n 'ligature': 'wifi',\r\n 'tags' : ['wifi']\r\n },\r\n {\r\n 'name' : 'work_off',\r\n 'ligature': 'work_off',\r\n 'tags' : ['work_off']\r\n },\r\n {\r\n 'name' : 'work_outline',\r\n 'ligature': 'work_outline',\r\n 'tags' : ['work_outline']\r\n },\r\n {\r\n 'name' : 'work',\r\n 'ligature': 'work',\r\n 'tags' : ['work']\r\n },\r\n {\r\n 'name' : 'wrap_text',\r\n 'ligature': 'wrap_text',\r\n 'tags' : ['wrap_text']\r\n },\r\n {\r\n 'name' : 'youtube_searched_for',\r\n 'ligature': 'youtube_searched_for',\r\n 'tags' : ['youtube_searched_for']\r\n },\r\n {\r\n 'name' : 'zoom_in',\r\n 'ligature': 'zoom_in',\r\n 'tags' : ['zoom_in']\r\n },\r\n {\r\n 'name' : 'zoom_out_map',\r\n 'ligature': 'zoom_out_map',\r\n 'tags' : ['zoom_out_map']\r\n },\r\n {\r\n 'name' : 'zoom_out',\r\n 'ligature': 'zoom_out',\r\n 'tags' : ['zoom_out']\r\n }\r\n ];\r\n}\r\n","export class InvoiceFakeDb\r\n{\r\n public static invoice = {\r\n 'from' : {\r\n 'title' : 'Fuse Inc.',\r\n 'address': '2810 Country Club Road Cranford, NJ 07016',\r\n 'phone' : '+66 123 455 87',\r\n 'email' : 'hello@fuseinc.com',\r\n 'website': 'www.fuseinc.com'\r\n },\r\n 'client' : {\r\n 'title' : 'John Doe',\r\n 'address': '9301 Wood Street Philadelphia, PA 19111',\r\n 'phone' : '+55 552 455 87',\r\n 'email' : 'johndoe@mail.com'\r\n },\r\n 'number' : 'P9-0004',\r\n 'date' : 'Jul 19, 2018',\r\n 'dueDate' : 'Aug 24, 2018',\r\n 'services': [\r\n {\r\n 'title' : 'Prototype & Design',\r\n 'detail' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus accumsan, quam sed eleifend imperdiet.',\r\n 'unit' : 'Hour',\r\n 'unitPrice': '12.00',\r\n 'quantity' : '240',\r\n 'total' : '2880'\r\n },\r\n {\r\n 'title' : 'Coding',\r\n 'detail' : 'Vestibulum ligula sem, rutrum et libero id, porta vehicula metus. Cras dapibus neque sit amet laoreet vestibulum.',\r\n 'unit' : 'Hour',\r\n 'unitPrice': '10.50',\r\n 'quantity' : '350',\r\n 'total' : '3675'\r\n },\r\n {\r\n 'title' : 'Testing',\r\n 'detail' : 'Pellentesque luctus efficitur neque in finibus. Integer ut nunc in augue maximus porttitor id id nulla. In vitae erat.',\r\n 'unit' : 'Hour',\r\n 'unitPrice': '4.00',\r\n 'quantity' : '50',\r\n 'total' : '200'\r\n },\r\n {\r\n 'title' : 'Documentation & Training',\r\n 'detail' : 'Pellentesque luctus efficitur neque in finibus. Integer ut nunc in augue maximus porttitor id id nulla. In vitae erat.',\r\n 'unit' : 'Hour',\r\n 'unitPrice': '6.50',\r\n 'quantity' : '260',\r\n 'total' : '1690'\r\n }\r\n ],\r\n 'subtotal': '8445',\r\n 'tax' : '675.60',\r\n 'discount': '120.60',\r\n 'total' : '9000'\r\n };\r\n}\r\n","export class KnowledgeBaseFakeDb\r\n{\r\n public static data = [\r\n {\r\n 'title' : 'Your Account',\r\n 'path' : '/pages/knowledge-base',\r\n 'articlesCount' : 17,\r\n 'featuredArticles': [\r\n {\r\n 'title' : 'Account limits',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'How do I change my username?',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'How do I change my password?',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'How do I change my email address?',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'How do I close my account?',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n }\r\n ]\r\n },\r\n {\r\n 'title' : 'Selling',\r\n 'path' : '/pages/knowledge-base',\r\n 'articlesCount' : 12,\r\n 'featuredArticles': [\r\n {\r\n 'title' : 'A guide to the upload process',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'Author collaboration',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'Exclusivity policy',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'Promises you make as an author',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'An author’s introduction',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n }\r\n ]\r\n },\r\n {\r\n 'title' : 'Buying',\r\n 'path' : '/pages/knowledge-base',\r\n 'articlesCount' : 19,\r\n 'featuredArticles': [\r\n {\r\n 'title' : 'Where is my purchase code?',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'Can I get a refund?',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'Contact us',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'How do I purchase an item?',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'I\\'m trying to find a specific item',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n }\r\n ]\r\n },\r\n {\r\n 'title' : 'Item Support',\r\n 'path' : '/pages/knowledge-base',\r\n 'articlesCount' : 24,\r\n 'featuredArticles': [\r\n {\r\n 'title' : 'What is Item Support?',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'How to contact an author',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'Rating or review removal policy',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'Purchasing unsupported items',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n },\r\n {\r\n 'title' : 'Item installation guide',\r\n 'content': '

The standard Lorem Ipsum passage, used since the 1500s

\\n

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna\\n aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.\\n Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur\\n sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.\\n

\\n

Section 1.10.32 of \"de Finibus Bonorum et Malorum\", written by Cicero in 45 BC

\\n

Sed ut perspiciatis unde omnis iste natus error sit\\n voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et\\n quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit\\n aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est,\\n qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt\\n ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam\\n corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui\\n in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla\\n pariatur?\\n

\\n

1914 translation by H. Rackham

\\n

\\n But I must explain to you how all this mistaken idea of denouncing pleasure\\n and praising pain was born and I will give you a complete account of the system, and expound the actual teachings of\\n the great explorer of the truth, the master-builder of human happiness. No one rejects, dislikes, or avoids pleasure\\n itself, because it is pleasure, but because those who do not know how to pursue pleasure rationally encounter\\n consequences that are extremely painful. Nor again is there anyone who loves or pursues or desires to obtain pain of\\n itself, because it is pain, but because occasionally circumstances occur in which toil and pain can procure him some\\n great pleasure. To take a trivial example, which of us ever undertakes laborious physical exercise, except to obtain\\n some advantage from it? But who has any right to find fault with a man who chooses to enjoy a pleasure that has no\\n annoying consequences, or one who avoids a pain that produces no resultant pleasure?\\n

\\n'\r\n }\r\n ]\r\n }\r\n ];\r\n}\r\n","export class MailFakeDb\r\n{\r\n public static mails = [\r\n {\r\n 'id' : '15459251a6d6b397565',\r\n 'from' : {\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg',\r\n 'email' : 'alicefreeman@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '28 Jun',\r\n 'read' : false,\r\n 'starred' : false,\r\n 'important' : true,\r\n 'hasAttachments': true,\r\n 'attachments' : [\r\n {\r\n 'type' : 'image',\r\n 'fileName': 'flowers',\r\n 'preview' : 'assets/images/mail/attachment-1.jpg',\r\n 'url' : '',\r\n 'size' : '1.1Mb'\r\n },\r\n {\r\n 'type' : 'image',\r\n 'fileName': 'snow',\r\n 'preview' : 'assets/images/mail/attachment-2.jpg',\r\n 'url' : '',\r\n 'size' : '380kb'\r\n },\r\n {\r\n 'type' : 'image',\r\n 'fileName': 'sunrise',\r\n 'preview' : 'assets/images/mail/attachment-3.jpg',\r\n 'size': '17Mb'\r\n }\r\n ],\r\n 'labels' : [\r\n 1\r\n ],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '154588a0864d2881124',\r\n 'from' : {\r\n 'name' : 'Lawrence Collins',\r\n 'avatar': 'assets/images/avatars/vincent.jpg',\r\n 'email' : 'lawrencecollins@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '28 Jun',\r\n 'read' : false,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '15453ba60d3baa5daaf',\r\n 'from' : {\r\n 'name' : 'Judith Burton',\r\n 'avatar': 'assets/images/avatars/joyce.jpg',\r\n 'email' : 'judithburton@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '28 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [\r\n 3,\r\n 2\r\n ],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '15453a06c08fb021776',\r\n 'from' : {\r\n 'name' : 'Danielle Obrien',\r\n 'avatar': 'assets/images/avatars/danielle.jpg',\r\n 'email' : 'danielleobrien@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '28 Jun',\r\n 'read' : true,\r\n 'starred' : true,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [\r\n 1,\r\n 3\r\n ],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '154537435d5b32bf11a',\r\n 'from' : {\r\n 'name' : 'Brian Flores',\r\n 'avatar': '',\r\n 'email' : 'brianflores@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '26 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '1544e43dcdae6ebf876',\r\n 'from' : {\r\n 'name' : 'Charles Kim',\r\n 'avatar': 'assets/images/avatars/garry.jpg',\r\n 'email' : 'charleskim@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '18 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : true,\r\n 'hasAttachments': false,\r\n 'labels' : [\r\n 2\r\n ],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '1543ee3a5b43e0f9f45',\r\n 'from' : {\r\n 'name' : 'Patricia White',\r\n 'avatar': '',\r\n 'email' : 'patriciawhite@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '15 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '1543cc4515df3146112',\r\n 'from' : {\r\n 'name' : 'Juan Carpenter',\r\n 'avatar': 'assets/images/avatars/james.jpg',\r\n 'email' : 'juancarpenter@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '11 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '154398a4770d7aaf9a2',\r\n 'from' : {\r\n 'name' : 'Maria Gilbert',\r\n 'avatar': 'assets/images/avatars/danielle.jpg',\r\n 'email' : 'mariagilbert@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '5 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '15438351f87dcd68567',\r\n 'from' : {\r\n 'name' : 'Tammy Brooks',\r\n 'avatar': '',\r\n 'email' : 'tammybrooks@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '1 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '1542d75d929a603125',\r\n 'from' : {\r\n 'name' : 'Kathy Price',\r\n 'avatar': '',\r\n 'email' : 'kathyprice@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '1 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '1541ca7af66da284177',\r\n 'from' : {\r\n 'name' : 'Alan Coleman',\r\n 'avatar': '',\r\n 'email' : 'alancoleman@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '28 June',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '154297167e781781745',\r\n 'from' : {\r\n 'name' : 'Thomas Silva',\r\n 'avatar': '',\r\n 'email' : 'thomassilva@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '16 Jun',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 0\r\n },\r\n {\r\n 'id' : '15427f4c1b7f3953234',\r\n 'from' : {\r\n 'name' : 'Jessica Robertson',\r\n 'avatar': '',\r\n 'email' : 'jessicarobertson@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '19 May',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 3\r\n },\r\n {\r\n 'id' : '154204e45a59b168453',\r\n 'from' : {\r\n 'name' : 'John Palmer',\r\n 'avatar': '',\r\n 'email' : 'johnpalmer@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '8 May',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 3\r\n },\r\n {\r\n 'id' : '1541dd1e05dfc439216',\r\n 'from' : {\r\n 'name' : 'David Butler',\r\n 'avatar': '',\r\n 'email' : 'davidbutler@creapond.com'\r\n },\r\n 'to' : [\r\n {\r\n 'name' : 'me',\r\n 'email': 'johndoe@creapond.com'\r\n }\r\n ],\r\n 'subject' : 'Commits that need to be pushed lorem ipsum dolor sit amet, consectetur adipiscing elit.',\r\n 'message' : '

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce lorem diam, pulvinar id nisl non, ultrices maximus nibh. Suspendisse ut justo velit. Nullam ac ultrices risus, quis auctor orci. Vestibulum volutpat nisi et neque porta ullamcorper. Maecenas porttitor porta erat ac suscipit. Sed cursus leo ut elementum fringilla. Maecenas semper viverra erat, vel ullamcorper dui efficitur in. Vestibulum placerat imperdiet tellus, et tincidunt eros posuere eget. Proin sit amet facilisis libero. Nulla eget est ut erat aliquet rhoncus. Quisque ac urna vitae dui hendrerit sollicitudin vel id sem.

In eget ante sapien. Quisque consequat velit non ante finibus, vel placerat erat ultricies. Aliquam bibendum justo erat, ultrices vehicula dolor elementum a. Mauris eu nisl feugiat ligula molestie eleifend. Aliquam efficitur venenatis velit ac porta. Vivamus vitae pulvinar tellus. Donec odio enim, auctor eget nibh mattis, ultricies dignissim lacus. Phasellus non tincidunt dui. Nulla eu arcu lorem.

Donec non hendrerit augue, lobortis sollicitudin odio. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Duis sit amet euismod enim, eget vestibulum justo. Fusce a placerat lectus, eget feugiat purus. Cras risus ante, faucibus eget justo commodo, volutpat tempor ante. Donec sit amet leo venenatis, gravida quam sit amet, blandit dui. In quam ante, elementum ut faucibus nec, tristique vitae dui. Praesent vel erat at enim placerat luctus vel ut ipsum. In congue tempor mi, non ornare lectus condimentum at. Aenean libero diam, finibus eget sapien et, tristique fermentum lorem.

',\r\n 'time' : '7 May',\r\n 'read' : true,\r\n 'starred' : false,\r\n 'important' : false,\r\n 'hasAttachments': false,\r\n 'labels' : [],\r\n 'folder' : 3\r\n }\r\n ];\r\n\r\n public static folders = [\r\n {\r\n 'id' : 0,\r\n 'handle': 'inbox',\r\n 'title' : 'Inbox',\r\n 'icon' : 'inbox'\r\n },\r\n {\r\n 'id' : 1,\r\n 'handle': 'sent',\r\n 'title' : 'Sent',\r\n 'icon' : 'send'\r\n },\r\n {\r\n 'id' : 2,\r\n 'handle': 'drafts',\r\n 'title' : 'Drafts',\r\n 'icon' : 'email_open'\r\n },\r\n {\r\n 'id' : 3,\r\n 'handle': 'spam',\r\n 'title' : 'Spam',\r\n 'icon' : 'error'\r\n },\r\n {\r\n 'id' : 4,\r\n 'handle': 'trash',\r\n 'title' : 'Trash',\r\n 'icon' : 'delete'\r\n }\r\n ];\r\n\r\n public static filters = [\r\n {\r\n 'id' : 0,\r\n 'handle': 'starred',\r\n 'title' : 'Starred',\r\n 'icon' : 'star',\r\n 'color' : 'amber-fg'\r\n },\r\n {\r\n 'id' : 1,\r\n 'handle': 'important',\r\n 'title' : 'Important',\r\n 'icon' : 'label',\r\n 'color' : 'red-fg'\r\n }\r\n ];\r\n\r\n public static labels = [\r\n {\r\n 'id' : 0,\r\n 'handle': 'note',\r\n 'title' : 'Note',\r\n 'color' : '#7cb342'\r\n },\r\n {\r\n 'id' : 1,\r\n 'handle': 'paypal',\r\n 'title' : 'Paypal',\r\n 'color' : '#d84315'\r\n },\r\n {\r\n 'id' : 2,\r\n 'handle': 'invoice',\r\n 'title' : 'Invoice',\r\n 'color' : '#607d8b'\r\n },\r\n {\r\n 'id' : 3,\r\n 'handle': 'amazon',\r\n 'title' : 'Amazon',\r\n 'color' : '#03a9f4'\r\n }\r\n ];\r\n}\r\n","export class ProfileFakeDb\r\n{\r\n public static timeline = {\r\n activities: [\r\n {\r\n 'user' : {\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg'\r\n },\r\n 'message': 'started following you.',\r\n 'time' : '13 mins. ago'\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Andrew Green',\r\n 'avatar': 'assets/images/avatars/andrew.jpg'\r\n },\r\n 'message': 'sent you a message.',\r\n 'time' : 'June 10,2018'\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Garry Newman',\r\n 'avatar': 'assets/images/avatars/garry.jpg'\r\n },\r\n 'message': 'shared a public post with your group.',\r\n 'time' : 'June 9,2018'\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Carl Henderson',\r\n 'avatar': 'assets/images/avatars/carl.jpg'\r\n },\r\n 'message': 'wants to play Fallout Shelter with you.',\r\n 'time' : 'June 8,2018'\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Jane Dean',\r\n 'avatar': 'assets/images/avatars/jane.jpg'\r\n },\r\n 'message': 'started following you.',\r\n 'time' : 'June 7,2018'\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Juan Carpenter',\r\n 'avatar': 'assets/images/avatars/james.jpg'\r\n },\r\n 'message': 'sent you a message.',\r\n 'time' : 'June 6,2018'\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Judith Burton',\r\n 'avatar': 'assets/images/avatars/joyce.jpg'\r\n },\r\n 'message': 'shared a photo with you.',\r\n 'time' : 'June 5,2018'\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Vincent Munoz',\r\n 'avatar': 'assets/images/avatars/vincent.jpg'\r\n },\r\n 'message': 'shared a photo with you.',\r\n 'time' : 'June 4,2018'\r\n }\r\n ],\r\n posts : [\r\n {\r\n 'user' : {\r\n 'name' : 'Garry Newman',\r\n 'avatar': 'assets/images/avatars/garry.jpg'\r\n },\r\n 'message' : 'Remember the place we were talking about the other night? Found it!',\r\n 'time' : '32 minutes ago',\r\n 'type' : 'post',\r\n 'like' : 5,\r\n 'share' : 21,\r\n 'media' : {\r\n 'type' : 'image',\r\n 'preview': 'assets/images/profile/morain-lake.jpg'\r\n },\r\n 'comments': [\r\n {\r\n 'user' : {\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg'\r\n },\r\n 'time' : 'June 10, 2018',\r\n 'message': 'That’s a wonderful place. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce et eleifend ligula. Fusce posuere in sapien ac facilisis. Etiam sit amet justo non felis ornare feugiat.'\r\n }\r\n ]\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Andrew Green',\r\n 'avatar': 'assets/images/avatars/andrew.jpg'\r\n },\r\n 'message' : 'Hey, man! Check this, it’s pretty awesome!',\r\n 'time' : 'June 12, 2018',\r\n 'type' : 'article',\r\n 'like' : 98,\r\n 'share' : 6,\r\n 'article' : {\r\n 'title' : 'Never stop changing!',\r\n 'subtitle': 'John Westrock',\r\n 'excerpt' : 'John Westrock\\'s new photo album called \\'Never stop changing\\' is published! It features more than 200 photos that will take you right in.',\r\n 'media' : {\r\n 'type' : 'image',\r\n 'preview': 'assets/images/profile/never-stop-changing.jpg'\r\n }\r\n },\r\n 'comments': [\r\n {\r\n 'user' : {\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg'\r\n },\r\n 'time' : 'June 10, 2018',\r\n 'message': 'That’s a wonderful place. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce et eleifend ligula. Fusce posuere in sapien ac facilisis. Etiam sit amet justo non felis ornare feugiat.'\r\n }\r\n ]\r\n },\r\n {\r\n 'user' : {\r\n 'name' : 'Carl Henderson',\r\n 'avatar': 'assets/images/avatars/carl.jpg'\r\n },\r\n 'message': 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce et eleifend ligula. Fusce posuere in sapien ac facilisis. Etiam sit amet justo non felis ornare feugiat. Aenean lorem ex, ultrices sit amet ligula sed...',\r\n 'time' : 'June 10, 2018',\r\n 'type' : 'something',\r\n 'like' : 4,\r\n 'share' : 1\r\n }\r\n ]\r\n };\r\n\r\n public static photosVideos = [\r\n {\r\n 'name' : 'June 2018',\r\n 'info' : '5 Photos',\r\n 'media': [\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'A Walk Amongst Friends',\r\n 'preview': 'assets/images/profile/a-walk-amongst-friends-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Braies Lake',\r\n 'preview': 'assets/images/profile/braies-lake-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Fall Glow',\r\n 'preview': 'assets/images/profile/fall-glow-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'First Snow',\r\n 'preview': 'assets/images/profile/first-snow-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Lago di Braies',\r\n 'preview': 'assets/images/profile/lago-di-braies-small.jpg'\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'May 2018',\r\n 'info' : '7 Photos, 3 Videos',\r\n 'media': [\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Lago di Sorapis',\r\n 'preview': 'assets/images/profile/lago-di-sorapis-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Morain Lake',\r\n 'preview': 'assets/images/profile/morain-lake-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Never Stop Changing',\r\n 'preview': 'assets/images/profile/never-stop-changing-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Reaching',\r\n 'preview': 'assets/images/profile/reaching-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Yosemite',\r\n 'preview': 'assets/images/profile/yosemite-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'A Walk Amongst Friends',\r\n 'preview': 'assets/images/profile/a-walk-amongst-friends-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Braies Lake',\r\n 'preview': 'assets/images/profile/braies-lake-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Fall Glow',\r\n 'preview': 'assets/images/profile/fall-glow-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'First Snow',\r\n 'preview': 'assets/images/profile/first-snow-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Lago di Braies',\r\n 'preview': 'assets/images/profile/lago-di-braies-small.jpg'\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'April 2018',\r\n 'info' : '7 Photos',\r\n 'media': [\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Lago di Sorapis',\r\n 'preview': 'assets/images/profile/lago-di-sorapis-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Morain Lake',\r\n 'preview': 'assets/images/profile/morain-lake-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Never Stop Changing',\r\n 'preview': 'assets/images/profile/never-stop-changing-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Reaching',\r\n 'preview': 'assets/images/profile/reaching-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Yosemite',\r\n 'preview': 'assets/images/profile/yosemite-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'A Walk Amongst Friends',\r\n 'preview': 'assets/images/profile/a-walk-amongst-friends-small.jpg'\r\n },\r\n {\r\n 'type' : 'photo',\r\n 'title' : 'Braies Lake',\r\n 'preview': 'assets/images/profile/braies-lake-small.jpg'\r\n }\r\n ]\r\n }\r\n ];\r\n\r\n public static about = {\r\n 'general': {\r\n 'gender' : 'Male',\r\n 'birthday' : 'February 30th, 1974',\r\n 'locations': [\r\n 'London, UK',\r\n 'New York, USA'\r\n ],\r\n 'about' : 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis eget pharetra felis, sed ullamcorper dui. Sed et elementum neque. Vestibulum pellente viverra ultrices. Etiam justo augue, vehicula ac gravida a, interdum sit amet nisl. Integer vitae nisi id nibh dictum mollis in vitae tortor.'\r\n },\r\n 'work' : {\r\n 'occupation': 'Developer',\r\n 'skills' : 'C#, PHP, Javascript, Angular, JS, HTML, CSS',\r\n 'jobs' : [\r\n {\r\n 'company': 'Self-Employed',\r\n 'date' : '2010 - Now'\r\n },\r\n {\r\n 'company': 'Google',\r\n 'date' : '2008 - 2010'\r\n }\r\n ]\r\n },\r\n 'contact': {\r\n 'address' : 'Ut pharetra luctus est quis sodales. Duis nisi tortor, bibendum eget tincidunt, aliquam ac elit. Mauris nec euismod odio.',\r\n 'tel' : [\r\n '+6 555 6600',\r\n '+9 555 5255'\r\n ],\r\n 'websites': [\r\n 'withinpixels.com'\r\n ],\r\n 'emails' : [\r\n 'mail@withinpixels.com',\r\n 'mail@creapond.com'\r\n ]\r\n },\r\n 'groups' : [\r\n {\r\n 'name' : 'Android',\r\n 'category': 'Technology',\r\n 'members' : '1.856.546'\r\n },\r\n {\r\n 'name' : 'Google',\r\n 'category': 'Web',\r\n 'members' : '1.226.121'\r\n },\r\n {\r\n 'name' : 'Fallout',\r\n 'category': 'Games',\r\n 'members' : '526.142'\r\n }\r\n ],\r\n 'friends': [\r\n {\r\n 'name' : 'Garry Newman',\r\n 'avatar': 'assets/images/avatars/garry.jpg'\r\n },\r\n {\r\n 'name' : 'Carl Henderson',\r\n 'avatar': 'assets/images/avatars/carl.jpg'\r\n },\r\n {\r\n 'name' : 'Jane Dean',\r\n 'avatar': 'assets/images/avatars/jane.jpg'\r\n },\r\n {\r\n 'name' : 'Garry Arnold',\r\n 'avatar': 'assets/images/avatars/garry.jpg'\r\n },\r\n {\r\n 'name' : 'Vincent Munoz',\r\n 'avatar': 'assets/images/avatars/vincent.jpg'\r\n },\r\n {\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg'\r\n },\r\n {\r\n 'name' : 'Andrew Green',\r\n 'avatar': 'assets/images/avatars/andrew.jpg'\r\n }\r\n ]\r\n };\r\n}\r\n","export class QuickPanelFakeDb\r\n{\r\n public static notes = [\r\n {\r\n 'title' : 'Best songs to listen while working',\r\n 'detail': 'Last edit: May 8th, 2018'\r\n },\r\n {\r\n 'title' : 'Useful subreddits',\r\n 'detail': 'Last edit: January 12th, 2018'\r\n }\r\n ];\r\n\r\n public static events = [\r\n {\r\n 'title' : 'Group Meeting',\r\n 'detail': 'In 32 Minutes, Room 1B'\r\n },\r\n {\r\n 'title' : 'Public Beta Release',\r\n 'detail': '11:00 PM'\r\n },\r\n {\r\n 'title' : 'Dinner with David',\r\n 'detail': '17:30 PM'\r\n },\r\n {\r\n 'title' : 'Q&A Session',\r\n 'detail': '20:30 PM'\r\n }\r\n ];\r\n}\r\n","export class ScrumboardFakeDb\r\n{\r\n public static boards = [\r\n {\r\n 'id' : '32gfhaf2',\r\n 'name' : 'ACME Frontend Application',\r\n 'uri' : 'acme-frontend-application',\r\n 'settings': {\r\n 'color' : 'fuse-dark',\r\n 'subscribed' : false,\r\n 'cardCoverImages': true\r\n },\r\n 'lists' : [\r\n {\r\n 'id' : '56027cf5a2ca3839a5d36103',\r\n 'name' : 'Design',\r\n 'idCards': [\r\n '5603a2a3cab0c8300f6096b3',\r\n '44d1.2b51ea6cc2b5d.21f4a3412e857.8ffa2d8b44ad9.ac87215ed53a1.67d4921ad8f8d.9f318bcb2'\r\n ]\r\n },\r\n {\r\n 'id' : '56127cf2a2ca3539g7d36103',\r\n 'name' : 'Development',\r\n 'idCards': [\r\n '2837273da9b93dd84243s0f9',\r\n '5787b7e4740c57bf0dffd5b6',\r\n '5637273da9b93bb84743a0f9',\r\n '7987.9740ba532b0d4.f9d12243f7362.507c0738dc561.87fba0a03df6e.75e6508cacf10.7a9835b54'\r\n ]\r\n },\r\n {\r\n 'id' : 'faf244627326f1249525763d',\r\n 'name' : 'Upcoming Features',\r\n 'idCards': [\r\n 'd9005a4b89ed2aadca48a6ad',\r\n 'f6b9d7a9247e5d794a081927',\r\n '80ed.24ad3b18e2668.f28fbbceeeff9.5a834620a42f1.5909be19a2bf2.6c4a54947ce2d.da356b0c1',\r\n '0ad2.7862f947bc456.f42b446df54cb.d1dd9e93601a1.9deb1406d1404.0b3c278fc7001.733341b42',\r\n 'bad3.51be8ad33acaf.9540ecb37f7e8.6bee596cfe7d3.44c68bee289c4.b96ed0b9f0af7.e14846035'\r\n ]\r\n },\r\n {\r\n 'id' : 'ad7d.9fffac5dff412.c83bca6853767.8fd7549b2b1ca.ceda8a01774c4.a5cf3976e87e4.ce79eeeea',\r\n 'name' : 'Known Bugs',\r\n 'idCards': [\r\n 'acc6.9c673cd2f5e35.521e91d8d5991.4b2a95e0539d1.027930c0743c5.7ad1ea7bea476.e8fbe6347',\r\n '3279.3d69b40cc0b75.690252b6bea08.1e1789b0b7c2e.2f264b8661ce2.84d5f56910e23.429be5e8a',\r\n 'ba01.8e1a43f92a03a.0022bd5cbb9ba.275c64d911d8c.880e0846a3966.f75ff43e53ad.48ad612e7'\r\n ]\r\n }\r\n ],\r\n 'cards' : [\r\n {\r\n 'id' : '2837273da9b93dd84243s0f9',\r\n 'name' : 'Update generators',\r\n 'description' : 'Current generator doesn\\'t support Node.js 6 and above.',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '26027s1930450d8bf7b10828'\r\n ],\r\n 'idLabels' : [\r\n '26022e4129ad3a5sc28b36cd'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : false,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'AngularCLI could be a nice alternative.',\r\n 'time' : 'now'\r\n }\r\n ],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : '5603a2a3cab0c8300f6096b3',\r\n 'name' : 'Change background colors',\r\n 'description' : '',\r\n 'idAttachmentCover': '67027cahbe3b52ecf2dc631c',\r\n 'idMembers' : [\r\n '76027g1930450d8bf7b10958'\r\n ],\r\n 'idLabels' : [\r\n '56027e4119ad3a5dc28b36cd',\r\n '5640635e19ad3a5dc21416b2'\r\n ],\r\n 'attachments' : [\r\n {\r\n 'id' : '67027cahbe3b52ecf2dc631c',\r\n 'name': 'mail.jpg',\r\n 'src' : 'assets/images/scrumboard/mail.jpg',\r\n 'time': 'Nov 3 at 15:22AM',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : '56027cfcbe1b72ecf1fc452a',\r\n 'name': 'calendar.jpg',\r\n 'src' : 'assets/images/scrumboard/calendar.jpg',\r\n 'time': 'Nov 1 at 12:34PM',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'subscribed' : true,\r\n 'checklists' : [\r\n {\r\n 'id' : '63021cfdbe1x72wcf1fc451v',\r\n 'name' : 'Checklist',\r\n 'checkItemsChecked': 1,\r\n 'checkItems' : [\r\n {\r\n 'name' : 'Implement a calendar library',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Replace event colors with Material Design colors',\r\n 'checked': true\r\n },\r\n {\r\n 'name' : 'Replace icons with Material Design icons',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Use moment.js',\r\n 'checked': false\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Checklist 2',\r\n 'id' : '74031cfdbe1x72wcz1dc166z',\r\n 'checkItemsChecked': 1,\r\n 'checkItems' : [\r\n {\r\n 'name' : 'Replace event colors with Material Design colors',\r\n 'checked': true\r\n },\r\n {\r\n 'name' : 'Replace icons with Material Design icons',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Use moment.js',\r\n 'checked': false\r\n }\r\n ]\r\n }\r\n ],\r\n 'checkItems' : 7,\r\n 'checkItemsChecked': 2,\r\n 'comments' : [\r\n {\r\n 'idMember': '56027c1930450d8bf7b10758',\r\n 'message' : 'We should be able to add moment.js without any problems',\r\n 'time' : '12 mins. ago'\r\n },\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'I added a link for a page that might help us deciding the colors',\r\n 'time' : '30 mins. ago'\r\n }\r\n ],\r\n 'activities' : [\r\n {\r\n 'idMember': '56027c1930450d8bf7b10758',\r\n 'message' : 'added a comment',\r\n 'time' : '12 mins. ago'\r\n },\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'added a comment',\r\n 'time' : '30 mins. ago'\r\n },\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'attached a link',\r\n 'time' : '45 mins. ago'\r\n }\r\n ],\r\n 'due' : '2017-08-29T10:16:34.000Z'\r\n },\r\n {\r\n 'id' : '5637273da9b93bb84743a0f9',\r\n 'name' : 'Fix splash screen bugs',\r\n 'description' : '',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '56027c1930450d8bf7b10758'\r\n ],\r\n 'idLabels' : [\r\n '5640635e19ad3a5dc21416b2'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : true,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : 'd9005a4b89ed2aadca48a6ad',\r\n 'name' : 'Add alternative authentication pages',\r\n 'description' : '',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '36027j1930450d8bf7b10158'\r\n ],\r\n 'idLabels' : [\r\n '6540635g19ad3s5dc31412b2',\r\n '56027e4119ad3a5dc28b36cd'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : false,\r\n 'checklists' : [\r\n {\r\n 'id' : 'dbfb.99bd0ad37dabc.e05046f0c824d.18f26bb524c96.78bebc8488634.240c0ee6a5e45.4cb872965',\r\n 'name' : 'Pages',\r\n 'checkItemsChecked': 2,\r\n 'checkItems' : [\r\n {\r\n 'name' : 'Login',\r\n 'checked': true\r\n },\r\n {\r\n 'name' : 'Register',\r\n 'checked': true\r\n },\r\n {\r\n 'name' : 'Lost Password',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Recover Password',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Activate Account',\r\n 'checked': false\r\n }\r\n ]\r\n }\r\n ],\r\n 'checkItems' : 5,\r\n 'checkItemsChecked': 2,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : '5787b7e4740c57bf0dffd5b6',\r\n 'name' : 'Fix the console',\r\n 'description' : 'We need to fix the console asap!',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [],\r\n 'idLabels' : [\r\n '26022e4129ad3a5sc28b36cd'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : true,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'I\\'m on it!',\r\n 'time' : 'now'\r\n }\r\n ],\r\n 'activities' : [],\r\n 'due' : '2020-09-07T12:00:00.000Z'\r\n },\r\n {\r\n 'id' : 'f6b9d7a9247e5d794a081927',\r\n 'name' : 'New media player',\r\n 'description' : '',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '76027g1930450d8bf7b10958',\r\n '56027c1930450d8bf7b10758',\r\n '26027s1930450d8bf7b10828'\r\n ],\r\n 'idLabels' : [\r\n '5640635e19ad3a5dc21416b2',\r\n '6540635g19ad3s5dc31412b2'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : false,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : 'acc6.9c673cd2f5e35.521e91d8d5991.4b2a95e0539d1.027930c0743c5.7ad1ea7bea476.e8fbe6347',\r\n 'name' : 'Memory Leak',\r\n 'description' : '',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '36027j1930450d8bf7b10158'\r\n ],\r\n 'idLabels' : [\r\n '26022e4129ad3a5sc28b36cd',\r\n '5640635e19ad3a5dc21416b2'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : false,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : '3279.3d69b40cc0b75.690252b6bea08.1e1789b0b7c2e.2f264b8661ce2.84d5f56910e23.429be5e8a',\r\n 'name' : 'Broken toolbar on profile page',\r\n 'description' : '',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '26027s1930450d8bf7b10828'\r\n ],\r\n 'idLabels' : [\r\n '26022e4129ad3a5sc28b36cd'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : false,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'This should be a medium priority bug, shouldn\\'t it?',\r\n 'time' : 'now'\r\n }\r\n ],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : 'ba01.8e1a43f92a03a.0022bd5cbb9ba.275c64d911d8c.880e0846a3966.f75ff43e53ad.48ad612e7',\r\n 'name' : 'Button hover style',\r\n 'description' : 'If there are 3 or more buttons in certain page, weird flashing happens when you hover over the red ones.',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '26027s1930450d8bf7b10828'\r\n ],\r\n 'idLabels' : [\r\n '26022e4129ad3a5sc28b36cd',\r\n '5640635e19ad3a5dc21416b2'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : true,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : '2017-03-08T09:00:00.000Z'\r\n },\r\n {\r\n 'id' : '80ed.24ad3b18e2668.f28fbbceeeff9.5a834620a42f1.5909be19a2bf2.6c4a54947ce2d.da356b0c1',\r\n 'name' : 'New header designs',\r\n 'description' : '',\r\n 'idAttachmentCover': '12027cafbe3b52ecf2ef632c',\r\n 'idMembers' : [],\r\n 'idLabels' : [\r\n '56027e4119ad3a5dc28b36cd',\r\n '6540635g19ad3s5dc31412b2',\r\n '5640635e19ad3a5dc21416b2'\r\n ],\r\n 'attachments' : [\r\n {\r\n 'id' : '12027cafbe3b52ecf2ef632c',\r\n 'name': 'header-.jpg',\r\n 'src' : 'assets/images/scrumboard/header-1.jpg',\r\n 'time': 'Nov 3 at 15:22AM',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : '55027ced1e1a12ecf1fced2a',\r\n 'name': 'header-2.jpg',\r\n 'src' : 'assets/images/scrumboard/header-2.jpg',\r\n 'time': 'Nov 1 at 12:34PM',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'subscribed' : false,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'Currently we have two new designs ready to ship.',\r\n 'time' : 'now'\r\n }\r\n ],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : '0ad2.7862f947bc456.f42b446df54cb.d1dd9e93601a1.9deb1406d1404.0b3c278fc7001.733341b42',\r\n 'name' : 'Fixed footer',\r\n 'description' : '',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '26027s1930450d8bf7b10828',\r\n '56027c1930450d8bf7b10758'\r\n ],\r\n 'idLabels' : [\r\n '6540635g19ad3s5dc31412b2'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : true,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : 'bad3.51be8ad33acaf.9540ecb37f7e8.6bee596cfe7d3.44c68bee289c4.b96ed0b9f0af7.e14846035',\r\n 'name' : 'Collapsable navigation',\r\n 'description' : '',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [],\r\n 'idLabels' : [\r\n '6540635g19ad3s5dc31412b2'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : false,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'I\\'m not sure why we re-doing the navigation. The current collapsable navigation works flawlessly.',\r\n 'time' : 'now'\r\n }\r\n ],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : '44d1.2b51ea6cc2b5d.21f4a3412e857.8ffa2d8b44ad9.ac87215ed53a1.67d4921ad8f8d.9f318bcb2',\r\n 'name' : 'Mail app new layout',\r\n 'description' : 'Current layout has lots of flaws in mobile. Outlook view should help with that.',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '56027c1930450d8bf7b10758',\r\n '26027s1930450d8bf7b10828',\r\n '76027g1930450d8bf7b10958',\r\n '36027j1930450d8bf7b10158'\r\n ],\r\n 'idLabels' : [\r\n '56027e4119ad3a5dc28b36cd',\r\n '26022e4129ad3a5sc28b36cd'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : false,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : '7987.9740ba532b0d4.f9d12243f7362.507c0738dc561.87fba0a03df6e.75e6508cacf10.7a9835b54',\r\n 'name' : 'API recover and monitoring',\r\n 'description' : 'We need a service to monitor and recover failed APIs.',\r\n 'idAttachmentCover': '',\r\n 'idMembers' : [\r\n '36027j1930450d8bf7b10158',\r\n '76027g1930450d8bf7b10958'\r\n ],\r\n 'idLabels' : [\r\n '26022e4129ad3a5sc28b36cd',\r\n '5640635e19ad3a5dc21416b2'\r\n ],\r\n 'attachments' : [],\r\n 'subscribed' : true,\r\n 'checklists' : [\r\n {\r\n 'id' : '6926.2b31d119e4a.889401e0ca7a0.13ad8ce2e569d.976e54e8b5d87.456afccd7e820.d6c77106a',\r\n 'name' : 'API Monitoring',\r\n 'checkItemsChecked': 2,\r\n 'checkItems' : [\r\n {\r\n 'name' : 'Simple dashboard design',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Should be able to see different time periods on the same dashboard',\r\n 'checked': true\r\n },\r\n {\r\n 'name' : 'Different colors for different clusters',\r\n 'checked': true\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : '7c22.5261c7924387f.248e8b1d32205.003f7a9f501d1.1d48dcdbe8b23.8099dcc5f75a7.29a966196',\r\n 'name' : 'API Recovery',\r\n 'checkItemsChecked': 1,\r\n 'checkItems' : [\r\n {\r\n 'name' : 'Warning notifications to all developers',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Immediate recovery options attached to the notifications',\r\n 'checked': true\r\n },\r\n {\r\n 'name' : 'Backups every 6hours',\r\n 'checked': false\r\n }\r\n ]\r\n }\r\n ],\r\n 'checkItems' : 6,\r\n 'checkItemsChecked': 3,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : '2017-02-02T11:20:34.000Z'\r\n }\r\n ],\r\n 'members' : [\r\n {\r\n 'id' : '56027c1930450d8bf7b10758',\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg'\r\n },\r\n {\r\n 'id' : '26027s1930450d8bf7b10828',\r\n 'name' : 'Danielle Obrien',\r\n 'avatar': 'assets/images/avatars/danielle.jpg'\r\n },\r\n {\r\n 'id' : '76027g1930450d8bf7b10958',\r\n 'name' : 'James Lewis',\r\n 'avatar': 'assets/images/avatars/james.jpg'\r\n },\r\n {\r\n 'id' : '36027j1930450d8bf7b10158',\r\n 'name' : 'Vincent Munoz',\r\n 'avatar': 'assets/images/avatars/vincent.jpg'\r\n }\r\n ],\r\n 'labels' : [\r\n {\r\n 'id' : '26022e4129ad3a5sc28b36cd',\r\n 'name' : 'High Priority',\r\n 'color': 'red-500'\r\n },\r\n {\r\n 'id' : '56027e4119ad3a5dc28b36cd',\r\n 'name' : 'Design',\r\n 'color': 'orange-400'\r\n },\r\n {\r\n 'id' : '5640635e19ad3a5dc21416b2',\r\n 'name' : 'App',\r\n 'color': 'blue-600'\r\n },\r\n {\r\n 'id' : '6540635g19ad3s5dc31412b2',\r\n 'name' : 'Feature',\r\n 'color': 'green-400'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : '27cfcbe1',\r\n 'name' : 'ACME Backend Application',\r\n 'uri' : 'acme-backend-application',\r\n 'settings': {\r\n 'color' : 'blue-grey',\r\n 'subscribed' : false,\r\n 'cardCoverImages': true\r\n },\r\n 'lists' : [\r\n {\r\n 'id' : '56027cf5a2ca3839a5d36103',\r\n 'name' : 'Designs',\r\n 'idCards': [\r\n '5603a2a3cab0c8300f6096b3'\r\n ]\r\n },\r\n {\r\n 'id' : '56127cf2a2ca3539g7d36103',\r\n 'name' : 'Development',\r\n 'idCards': [\r\n '5637273da9b93bb84743a0f9'\r\n ]\r\n }\r\n ],\r\n 'cards' : [\r\n {\r\n 'id' : '5603a2a3cab0c8300f6096b3',\r\n 'name' : 'Calendar App Design',\r\n 'description' : '',\r\n 'idAttachmentCover': '56027cfcbe1b72ecf1fc452a',\r\n 'idMembers' : [\r\n '56027c1930450d8bf7b10758',\r\n '36027j1930450d8bf7b10158'\r\n ],\r\n 'idLabels' : [\r\n '56027e4119ad3a5dc28b36cd',\r\n '5640635e19ad3a5dc21416b2'\r\n ],\r\n 'attachments' : [\r\n {\r\n 'id' : '56027cfcbe1b72ecf1fc452a',\r\n 'name': 'calendar-app-design.jpg',\r\n 'src' : 'assets/images/scrumboard/calendar.jpg',\r\n 'time': 'Nov 1 at 12:34PM',\r\n 'type': 'image'\r\n },\r\n {\r\n 'id' : '67027cahbe3b52ecf2dc631c',\r\n 'url' : 'assets/images/scrumboard/calendar.jpg',\r\n 'time': 'Nov 3 at 15:22AM',\r\n 'type': 'link'\r\n }\r\n ],\r\n 'subscribed' : true,\r\n 'checklists' : [\r\n {\r\n 'id' : '63021cfdbe1x72wcf1fc451v',\r\n 'name' : 'Checklist',\r\n 'checkItemsChecked': 1,\r\n 'checkItems' : [\r\n {\r\n 'name' : 'Implement a calendar library',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Replace event colors with Material Design colors',\r\n 'checked': true\r\n },\r\n {\r\n 'name' : 'Replace icons with Material Design icons',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Use moment.js',\r\n 'checked': false\r\n }\r\n ]\r\n },\r\n {\r\n 'name' : 'Checklist 2',\r\n 'id' : '74031cfdbe1x72wcz1dc166z',\r\n 'checkItemsChecked': 1,\r\n 'checkItems' : [\r\n {\r\n 'name' : 'Replace event colors with Material Design colors',\r\n 'checked': true\r\n },\r\n {\r\n 'name' : 'Replace icons with Material Design icons',\r\n 'checked': false\r\n },\r\n {\r\n 'name' : 'Use moment.js',\r\n 'checked': false\r\n }\r\n ]\r\n }\r\n ],\r\n 'checkItems' : 7,\r\n 'checkItemsChecked': 2,\r\n 'comments' : [\r\n {\r\n 'idMember': '56027c1930450d8bf7b10758',\r\n 'message' : 'We should be able to add moment.js without any problems',\r\n 'time' : '12 mins. ago'\r\n },\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'I added a link for a page that might help us deciding the colors',\r\n 'time' : '30 mins. ago'\r\n }\r\n ],\r\n 'activities' : [\r\n {\r\n 'idMember': '56027c1930450d8bf7b10758',\r\n 'message' : 'added a comment',\r\n 'time' : '12 mins. ago'\r\n },\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'added a comment',\r\n 'time' : '30 mins. ago'\r\n },\r\n {\r\n 'idMember': '36027j1930450d8bf7b10158',\r\n 'message' : 'attached a link',\r\n 'time' : '45 mins. ago'\r\n }\r\n ],\r\n 'due' : null\r\n },\r\n {\r\n 'id' : '5637273da9b93bb84743a0f9',\r\n 'name' : 'Fix Splash Screen bugs',\r\n 'description' : '',\r\n 'idAttachmentCover': '5603a2ae2bbd55bb2db57478',\r\n 'idMembers' : [\r\n '56027c1930450d8bf7b10758'\r\n ],\r\n 'idLabels' : [],\r\n 'attachments' : [\r\n {\r\n 'id' : '5603a2ae2bbd55bb2db57478',\r\n 'name': 'mail-app-design.jpg',\r\n 'src' : 'assets/images/scrumboard/mail.jpg',\r\n 'time': 'Nov 1 at 12:34PM',\r\n 'type': 'image'\r\n }\r\n ],\r\n 'subscribed' : true,\r\n 'checklists' : [],\r\n 'checkItems' : 0,\r\n 'checkItemsChecked': 0,\r\n 'comments' : [],\r\n 'activities' : [],\r\n 'due' : null\r\n }\r\n ],\r\n 'members' : [\r\n {\r\n 'id' : '56027c1930450d8bf7b10758',\r\n 'name' : 'Alice Freeman',\r\n 'avatar': 'assets/images/avatars/alice.jpg'\r\n },\r\n {\r\n 'id' : '26027s1930450d8bf7b10828',\r\n 'name' : 'Danielle Obrien',\r\n 'avatar': 'assets/images/avatars/danielle.jpg'\r\n },\r\n {\r\n 'id' : '76027g1930450d8bf7b10958',\r\n 'name' : 'James Lewis',\r\n 'avatar': 'assets/images/avatars/james.jpg'\r\n },\r\n {\r\n 'id' : '36027j1930450d8bf7b10158',\r\n 'name' : 'Vincent Munoz',\r\n 'avatar': 'assets/images/avatars/vincent.jpg'\r\n }\r\n ],\r\n 'labels' : [\r\n {\r\n 'id' : '56027e4119ad3a5dc28b36cd',\r\n 'name' : 'Design',\r\n 'color': 'red-500'\r\n },\r\n {\r\n 'id' : '5640635e19ad3a5dc21416b2',\r\n 'name' : 'App',\r\n 'color': 'blue-500'\r\n },\r\n {\r\n 'id' : '6540635g19ad3s5dc31412b2',\r\n 'name' : 'Feature',\r\n 'color': 'green-400'\r\n }\r\n ]\r\n }\r\n ];\r\n}\r\n","export class SearchFakeDb\r\n{\r\n public static search = [\r\n {\r\n 'title' : 'Dynamically Procrastinate B2C',\r\n 'url' : 'ourwebaddress.com/articles/procrastinate',\r\n 'excerpt': 'Collaboratively administrate empowered markets via plug-and-play networks. Dynamically procrastinate B2C users after installed base benefits.'\r\n },\r\n {\r\n 'title' : 'Cross Media',\r\n 'url' : 'ourwebaddress.com/articles/cross-media',\r\n 'excerpt': 'Efficiently unleash cross-media information without cross-media value. Quickly maximize timely deliverables for real-time schemas.'\r\n },\r\n {\r\n 'title' : 'Synergize',\r\n 'url' : 'ourwebaddress.com/articles/synergize',\r\n 'excerpt': 'Completely synergize resource taxing relationships via premier niche markets. Professionally cultivate one-to-one customer service with robust ideas.'\r\n },\r\n {\r\n 'title' : 'Parallel Platforms',\r\n 'url' : 'ourwebaddress.com/articles/parallel-paltforms',\r\n 'excerpt': 'Objectively innovate empowered manufactured products whereas parallel platforms. Holisticly predominate extensible testing procedures for reliable supply chains.'\r\n },\r\n {\r\n 'title' : 'Growth Strategies',\r\n 'url' : 'ourwebaddress.com/articles/growth-strategies',\r\n 'excerpt': 'Proactively envisioned multimedia based expertise and cross-media growth strategies. Holistically pontificate installed base portals after maintainable products.'\r\n },\r\n {\r\n 'title' : 'Methodologies',\r\n 'url' : 'ourwebaddress.com/articles/methodologies',\r\n 'excerpt': 'Phosfluorescently engage worldwide methodologies with web-enabled technology. Completely pursue scalable customer service through sustainable potentialities.'\r\n },\r\n {\r\n 'title' : 'E-tailers',\r\n 'url' : 'ourwebaddress.com/articles/e-trailers',\r\n 'excerpt': 'Collaboratively administrate turnkey channels whereas virtual e-tailers. Objectively seize scalable metrics whereas proactive e-services.'\r\n },\r\n {\r\n 'title' : 'Web Readiness',\r\n 'url' : 'ourwebaddress.com/articles/web-readiness',\r\n 'excerpt': 'Credibly innovate granular internal or organic sources whereas high standards in web-readiness. Dramatically synthesize integrated schemas with optimal networks.'\r\n }\r\n ];\r\n\r\n}\r\n","export class TodoFakeDb\r\n{\r\n public static todos = [\r\n {\r\n 'id' : '561551bd7fe2ff461101c192',\r\n 'title' : 'Proident tempor est nulla irure ad est',\r\n 'notes' : 'Id nulla nulla proident deserunt deserunt proident in quis. Cillum reprehenderit labore id anim laborum.',\r\n 'startDate': 'Wednesday, January 29, 2017 3:17 PM',\r\n 'dueDate' : null,\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [1]\r\n },\r\n {\r\n 'id' : '561551bd4ac1e7eb77a3a750',\r\n 'title' : 'Magna quis irure quis ea pariatur laborum',\r\n 'notes' : '',\r\n 'startDate': 'Sunday, February 1, 2018 1:30 PM',\r\n 'dueDate' : 'Friday, December 30, 2019 10:07 AM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': true,\r\n 'deleted' : false,\r\n 'tags' : [1, 4]\r\n },\r\n {\r\n 'id' : '561551bd917bfec2ddef2d49',\r\n 'title' : 'Ullamco duis commodo sint ad aliqua aute',\r\n 'notes' : 'Sunt laborum enim nostrud ea fugiat cillum mollit aliqua exercitation ad elit.',\r\n 'startDate': 'Friday, April 11, 2017 3:43 AM',\r\n 'dueDate' : 'Wednesday, July 26, 2017 11:14 AM',\r\n 'completed': false,\r\n 'starred' : true,\r\n 'important': true,\r\n 'deleted' : false,\r\n 'tags' : [3]\r\n },\r\n {\r\n 'id' : '561551bdeeb2fd6877e18c29',\r\n 'title' : 'Eiusmod non occaecat pariatur Lorem in ex',\r\n 'notes' : 'Nostrud anim mollit incididunt qui qui sit commodo duis. Anim amet irure aliquip duis nostrud sit quis fugiat ullamco non dolor labore. Lorem sunt voluptate laboris culpa proident. Aute eiusmod aliqua exercitation irure exercitation qui laboris mollit occaecat eu occaecat fugiat.',\r\n 'startDate': 'Wednesday, May 7, 2017 4:14 AM',\r\n 'dueDate' : 'Friday, December 15, 2017 4:01 AM',\r\n 'completed': true,\r\n 'starred' : true,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [2]\r\n },\r\n {\r\n 'id' : '561551bdf38eae0134ae43d4',\r\n 'title' : 'Lorem magna cillum consequat consequat mollit',\r\n 'notes' : 'Velit ipsum proident ea incididunt et. Consectetur eiusmod laborum voluptate duis occaecat ullamco sint enim proident.',\r\n 'startDate': 'Sunday, August 23, 2018 11:19 PM',\r\n 'dueDate' : 'Friday, July 8, 2019 10:49 AM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [5, 4]\r\n },\r\n {\r\n 'id' : '561551bd32f1588c814a0ccd',\r\n 'title' : 'Quis irure cupidatat ad consequat reprehenderit excepteur',\r\n 'notes' : 'Esse nisi mollit aliquip mollit aute consequat adipisicing. Do excepteur dolore proident cupidatat pariatur irure consequat incididunt.',\r\n 'startDate': 'Sunday, June 7, 2018 10:49 AM',\r\n 'dueDate' : 'Monday, January 9, 2017 8:34 AM',\r\n 'completed': false,\r\n 'starred' : true,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [2, 3]\r\n },\r\n {\r\n 'id' : '561551bd0bb4b08ca77038ef',\r\n 'title' : 'Officia voluptate tempor ut mollit ea cillum',\r\n 'notes' : 'Deserunt veniam reprehenderit do elit magna ut.',\r\n 'startDate': 'Saturday, October 18, 2017 4:25 AM',\r\n 'dueDate' : 'Sunday, August 21, 2019 10:48 PM',\r\n 'completed': true,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [2, 4]\r\n },\r\n {\r\n 'id' : '561551bdf84eec913835ebe5',\r\n 'title' : 'Sit exercitation cupidatat minim est ipsum excepteur',\r\n 'notes' : '',\r\n 'startDate': 'Friday, August 8, 2017 5:45 AM',\r\n 'dueDate' : 'Wednesday, June 15, 2019 1:53 PM',\r\n 'completed': true,\r\n 'starred' : false,\r\n 'important': true,\r\n 'deleted' : false,\r\n 'tags' : [1, 3]\r\n },\r\n {\r\n 'id' : '561551bd2047cc709af0f670',\r\n 'title' : 'Sunt fugiat officia nisi minim sunt duis',\r\n 'notes' : 'Eiusmod eiusmod sint aliquip exercitation cillum. Magna nulla officia ex consectetur ea ad excepteur in qui.',\r\n 'startDate': 'Monday, July 13, 2018 1:55 PM',\r\n 'dueDate' : 'Thursday, March 3, 2019 2:26 PM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [\r\n {\r\n 'id' : 5,\r\n 'name' : 'mobile',\r\n 'label': 'Mobile',\r\n 'color': '#9C27B0'\r\n }\r\n ]\r\n },\r\n {\r\n 'id' : '561551bd73d1a627e97005ce',\r\n 'title' : 'Non cupidatat enim quis aliquip minim laborum',\r\n 'notes' : 'Qui cillum eiusmod nostrud sunt dolore velit nostrud labore voluptate ad dolore. Eu Lorem anim pariatur aliqua. Ullamco ut dolor velit esse occaecat dolore eu cillum commodo qui. Nulla dolor consequat voluptate magna ut commodo magna consectetur non aute proident.',\r\n 'startDate': 'Tuesday, November 11, 2017 6:36 PM',\r\n 'dueDate' : 'Tuesday, August 9, 2019 7:18 AM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [2]\r\n },\r\n {\r\n 'id' : '561551bd8f7d793ded0a2353',\r\n 'title' : 'Dolor ex occaecat magna labore laboris qui',\r\n 'notes' : 'Incididunt qui excepteur eiusmod elit cillum occaecat voluptate cillum nostrud. Dolor ullamco ullamco eiusmod do sunt adipisicing pariatur. In esse esse labore id reprehenderit sint do. Pariatur culpa dolor tempor qui excepteur duis do anim minim ipsum.',\r\n 'startDate': 'Monday, June 9, 2017 3:15 PM',\r\n 'dueDate' : 'Wednesday, October 19, 2019 3:38 PM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': true,\r\n 'deleted' : false,\r\n 'tags' : [3]\r\n },\r\n {\r\n 'id' : '561551bdaa586f72d0be02cc',\r\n 'title' : 'Ex nisi amet id dolore nostrud esse',\r\n 'notes' : '',\r\n 'startDate': 'Thursday, January 15, 2018 6:11 PM',\r\n 'dueDate' : 'Sunday, August 20, 2017 10:02 AM',\r\n 'completed': false,\r\n 'starred' : true,\r\n 'important': true,\r\n 'deleted' : false,\r\n 'tags' : [4]\r\n },\r\n {\r\n 'id' : '561551bd9f1c2de5b27f537b',\r\n 'title' : 'In dolor velit labore dolore ex eiusmod',\r\n 'notes' : '',\r\n 'startDate': 'Monday, March 10, 2017 12:50 AM',\r\n 'dueDate' : 'Thursday, January 26, 2017 3:10 PM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [4]\r\n },\r\n {\r\n 'id' : '561551bd26e21bb5e85b35cb',\r\n 'title' : 'Sunt voluptate aliquip exercitation minim magna sit',\r\n 'notes' : '',\r\n 'startDate': 'Tuesday, March 24, 2018 10:54 PM',\r\n 'dueDate' : 'Wednesday, August 23, 2017 5:35 PM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [4]\r\n },\r\n {\r\n 'id' : '561551bd719860cf0ad2011a',\r\n 'title' : 'Nisi et ullamco minim ea proident tempor',\r\n 'notes' : 'Dolor veniam dolor cillum Lorem magna nisi in occaecat nulla dolor ea eiusmod.',\r\n 'startDate': 'Friday, February 14, 2017 10:03 AM',\r\n 'dueDate' : 'Saturday, July 8, 2017 11:54 PM',\r\n 'completed': false,\r\n 'starred' : true,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [2, 4]\r\n },\r\n {\r\n 'id' : '561551bd49d800c243264a91',\r\n 'title' : 'Sit ipsum mollit cupidatat adipisicing officia aliquip',\r\n 'notes' : '',\r\n 'startDate': 'Wednesday, December 10, 2017 9:25 AM',\r\n 'dueDate' : 'Friday, March 25, 2019 12:29 AM',\r\n 'completed': true,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [1]\r\n },\r\n {\r\n 'id' : '561551bd061990eaf40fb64f',\r\n 'title' : 'Amet sunt et quis amet commodo quis',\r\n 'notes' : 'Nulla dolore consequat aliqua sint consequat elit qui occaecat et.',\r\n 'startDate': 'Saturday, March 1, 2017 3:59 PM',\r\n 'dueDate' : 'Saturday, November 7, 2018 2:00 PM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': true,\r\n 'deleted' : false,\r\n 'tags' : [1]\r\n },\r\n {\r\n 'id' : '561551be81d05fa94711e7f3',\r\n 'title' : 'Ut eiusmod ex ea eiusmod culpa incididunt',\r\n 'notes' : 'Fugiat non incididunt officia ex incididunt occaecat. Voluptate nostrud culpa aliquip mollit incididunt non dolore.',\r\n 'startDate': 'Monday, February 2, 2018 3:07 PM',\r\n 'dueDate' : 'Saturday, October 14, 2017 6:57 AM',\r\n 'completed': false,\r\n 'starred' : false,\r\n 'important': false,\r\n 'deleted' : false,\r\n 'tags' : [2]\r\n },\r\n {\r\n 'id' : '561551be05c093a80e0c8d05',\r\n 'title' : 'Proident reprehenderit laboris pariatur ut et nisi',\r\n 'notes' : 'Reprehenderit proident ut ad cillum quis velit quis aliqua ut aliquip tempor ullamco.',\r\n 'startDate': 'Sunday, June 14, 2018 4:40 AM',\r\n 'dueDate' : 'Wednesday, February 10, 2019 10:47 AM',\r\n 'completed': true,\r\n 'starred' : true,\r\n 'important': true,\r\n 'deleted' : false,\r\n 'tags' : [5]\r\n },\r\n {\r\n 'id' : '561551be3bb43a5bd431c2fc',\r\n 'title' : 'Aliqua aliquip aliquip aliquip et exercitation aute',\r\n 'notes' : 'Adipisicing Lorem tempor ex anim. Labore tempor laboris nostrud dolore voluptate ullamco. Fugiat ex deserunt anim minim esse velit laboris aute ea duis incididunt. Elit irure id Lorem incididunt laborum aliquip consectetur est irure sunt. Ut labore anim nisi aliqua tempor laborum nulla cillum. Duis irure consequat cillum magna cillum eiusmod ut. Et exercitation voluptate quis deserunt elit quis dolor deserunt ex ex esse ex.',\r\n 'startDate': 'Saturday, May 3, 2017 1:32 AM',\r\n 'dueDate' : 'Monday, September 12, 2019 9:16 PM',\r\n 'completed': true,\r\n 'starred' : false,\r\n 'important': true,\r\n 'deleted' : true,\r\n 'tags' : [3]\r\n }\r\n ];\r\n\r\n public static filters = [\r\n {\r\n 'id' : 0,\r\n 'handle': 'starred',\r\n 'title' : 'Starred',\r\n 'icon' : 'star'\r\n },\r\n {\r\n 'id' : 1,\r\n 'handle': 'important',\r\n 'title' : 'Priority',\r\n 'icon' : 'error'\r\n },\r\n {\r\n 'id' : 2,\r\n 'handle': 'dueDate',\r\n 'title' : 'Sheduled',\r\n 'icon' : 'schedule'\r\n },\r\n {\r\n 'id' : 3,\r\n 'handle': 'today',\r\n 'title' : 'Today',\r\n 'icon' : 'today'\r\n },\r\n {\r\n 'id' : 4,\r\n 'handle': 'completed',\r\n 'title' : 'Done',\r\n 'icon' : 'check'\r\n },\r\n {\r\n 'id' : 4,\r\n 'handle': 'deleted',\r\n 'title' : 'Deleted',\r\n 'icon' : 'delete'\r\n }\r\n ];\r\n\r\n public static tags = [\r\n {\r\n 'id' : 1,\r\n 'handle': 'frontend',\r\n 'title' : 'Frontend',\r\n 'color' : '#388E3C'\r\n },\r\n {\r\n 'id' : 2,\r\n 'handle': 'backend',\r\n 'title' : 'Backend',\r\n 'color' : '#F44336'\r\n },\r\n {\r\n 'id' : 3,\r\n 'handle': 'api',\r\n 'title' : 'API',\r\n 'color' : '#FF9800'\r\n },\r\n {\r\n 'id' : 4,\r\n 'handle': 'issue',\r\n 'title' : 'Issue',\r\n 'color' : '#0091EA'\r\n },\r\n {\r\n 'id' : 5,\r\n 'handle': 'mobile',\r\n 'title' : 'Mobile',\r\n 'color' : '#9C27B0'\r\n }\r\n ];\r\n}\r\n","import { FuseConfig } from '@fuse/types';\r\n\r\n/**\r\n * Default Fuse Configuration\r\n *\r\n * You can edit these options to change the default options. All these options also can be\r\n * changed per component basis. See `app/main/pages/authentication/login/login.component.ts`\r\n * constructor method to learn more about changing these options per component basis.\r\n */\r\n\r\nexport const fuseConfig: FuseConfig = {\r\n // Color themes can be defined in src/app/app.theme.scss\r\n colorTheme : 'theme-default',\r\n customScrollbars: true,\r\n layout : {\r\n style : 'vertical-layout-1',\r\n width : 'fullwidth',\r\n navbar : {\r\n primaryBackground : 'fuse-navy-700',\r\n secondaryBackground: 'fuse-navy-900',\r\n folded : false,\r\n hidden : false,\r\n position : 'left',\r\n variant : 'vertical-style-1'\r\n },\r\n toolbar : {\r\n customBackgroundColor: false,\r\n background : 'fuse-white-500',\r\n hidden : false,\r\n position : 'below-static'\r\n },\r\n footer : {\r\n customBackgroundColor: true,\r\n background : 'fuse-navy-900',\r\n hidden : false,\r\n position : 'below-fixed'\r\n },\r\n sidepanel: {\r\n hidden : false,\r\n position: 'right'\r\n }\r\n }\r\n};\r\n","import { Injectable } from '@angular/core';\r\nimport { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor } from '@angular/common/http';\r\nimport { Observable, throwError, from } from 'rxjs';\r\nimport { catchError } from 'rxjs/operators';\r\nimport {Router} from '@angular/router';\r\nimport { AuthService } from 'app/shared/auth.service';\r\nimport { ToastrService } from 'ngx-toastr';\r\n\r\n@Injectable()\r\nexport class ErrorInterceptor implements HttpInterceptor {\r\n constructor(\r\n private _router : Router,\r\n private _authService : AuthService,\r\n private _toastr: ToastrService,\r\n ) { }\r\n\r\n intercept(request: HttpRequest, next: HttpHandler): Observable> {\r\n return next.handle(request).pipe(catchError(err => {\r\n if (err.status === 401) {\r\n this._toastr.error('your session is over !! please login to continue.','Error');\r\n this._authService.logout();\r\n }\r\n\r\n return throwError(err);\r\n }))\r\n }\r\n}","export default \"content {\\n position: relative;\\n display: flex;\\n z-index: 1;\\n flex: 1 0 auto;\\n}\\ncontent > *:not(router-outlet) {\\n display: flex;\\n flex: 1 0 auto;\\n width: 100%;\\n min-width: 100%;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9hcHAvbGF5b3V0L2NvbXBvbmVudHMvY29udGVudC9DOlxcUHJvZ3JhbURhdGFcXEplbmtpbnNcXC5qZW5raW5zXFx3b3Jrc3BhY2VcXFJQTVNcXFVJXFxMaXZlIChVSSBydW5uaW5nIG9uIFBheW1lbnR1cmUgQVdTKVxccGF5bWVudHVyZS5jb20vc3JjXFxhcHBcXGxheW91dFxcY29tcG9uZW50c1xcY29udGVudFxcY29udGVudC5jb21wb25lbnQuc2NzcyIsInNyYy9hcHAvbGF5b3V0L2NvbXBvbmVudHMvY29udGVudC9jb250ZW50LmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0ksa0JBQUE7RUFDQSxhQUFBO0VBQ0EsVUFBQTtFQUNBLGNBQUE7QUNDSjtBRENJO0VBQ0ksYUFBQTtFQUNBLGNBQUE7RUFDQSxXQUFBO0VBQ0EsZUFBQTtBQ0NSIiwiZmlsZSI6InNyYy9hcHAvbGF5b3V0L2NvbXBvbmVudHMvY29udGVudC9jb250ZW50LmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiY29udGVudCB7XHJcbiAgICBwb3NpdGlvbjogcmVsYXRpdmU7XHJcbiAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgei1pbmRleDogMTtcclxuICAgIGZsZXg6IDEgMCBhdXRvO1xyXG5cclxuICAgID4gKjpub3Qocm91dGVyLW91dGxldCkge1xyXG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XHJcbiAgICAgICAgZmxleDogMSAwIGF1dG87XHJcbiAgICAgICAgd2lkdGg6IDEwMCU7XHJcbiAgICAgICAgbWluLXdpZHRoOiAxMDAlO1xyXG4gICAgfVxyXG59IiwiY29udGVudCB7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgei1pbmRleDogMTtcbiAgZmxleDogMSAwIGF1dG87XG59XG5jb250ZW50ID4gKjpub3Qocm91dGVyLW91dGxldCkge1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4OiAxIDAgYXV0bztcbiAgd2lkdGg6IDEwMCU7XG4gIG1pbi13aWR0aDogMTAwJTtcbn0iXX0= */\"","import { Component, ViewEncapsulation } from '@angular/core';\r\n\r\n@Component({\r\n selector : 'content',\r\n templateUrl : './content.component.html',\r\n styleUrls : ['./content.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ContentComponent\r\n{\r\n /**\r\n * Constructor\r\n */\r\n constructor()\r\n {\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { FuseSharedModule } from '@fuse/shared.module';\r\n\r\nimport { ContentComponent } from 'app/layout/components/content/content.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n ContentComponent\r\n ],\r\n imports : [\r\n RouterModule,\r\n FuseSharedModule\r\n ],\r\n exports : [\r\n ContentComponent\r\n ]\r\n})\r\nexport class ContentModule\r\n{\r\n}\r\n","export default \"\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJzcmMvYXBwL2xheW91dC9jb21wb25lbnRzL25hdmJhci9uYXZiYXIuY29tcG9uZW50LnNjc3MifQ== */\"","import { Component, ElementRef, Input, Renderer2, ViewEncapsulation } from '@angular/core';\r\n\r\n@Component({\r\n selector : 'navbar',\r\n templateUrl : './navbar.component.html',\r\n styleUrls : ['./navbar.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\nexport class NavbarComponent\r\n{\r\n // Private\r\n _variant: string;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {ElementRef} _elementRef\r\n * @param {Renderer2} _renderer\r\n */\r\n constructor(\r\n private _elementRef: ElementRef,\r\n private _renderer: Renderer2\r\n )\r\n {\r\n // Set the private defaults\r\n this._variant = 'vertical-style-1';\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Variant\r\n */\r\n get variant(): string\r\n {\r\n return this._variant;\r\n }\r\n\r\n @Input()\r\n set variant(value: string)\r\n {\r\n // Remove the old class name\r\n this._renderer.removeClass(this._elementRef.nativeElement, this.variant);\r\n\r\n // Store the variant value\r\n this._variant = value;\r\n\r\n // Add the new class name\r\n this._renderer.addClass(this._elementRef.nativeElement, value);\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { FuseSharedModule } from '@fuse/shared.module';\r\n\r\nimport { NavbarComponent } from 'app/layout/components/navbar/navbar.component';\r\nimport { NavbarVerticalStyle1Module } from 'app/layout/components/navbar/vertical/style-1/style-1.module';\r\n// import { NavbarVerticalStyle2Module } from 'app/layout/components/navbar/vertical/style-2/style-2.module';\r\n\r\n@NgModule({\r\n declarations: [\r\n NavbarComponent\r\n ],\r\n imports : [\r\n FuseSharedModule,\r\n\r\n NavbarVerticalStyle1Module,\r\n // NavbarVerticalStyle2Module\r\n ],\r\n exports : [\r\n NavbarComponent\r\n ]\r\n})\r\nexport class NavbarModule\r\n{\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\nfuse-sidebar.navbar-fuse-sidebar {\\n overflow: hidden;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-top {\\n padding: 12px 0;\\n justify-content: center;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-top .buttons {\\n display: none;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-top .logo .logo-icon {\\n width: 32px;\\n height: 32px;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-top .logo .logo-text {\\n display: none;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user {\\n padding: 12px 0;\\n height: 64px;\\n min-height: 64px;\\n max-height: 64px;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container {\\n position: relative;\\n top: auto;\\n padding: 0;\\n transform: translateX(0);\\n left: auto;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container .avatar {\\n width: 40px;\\n height: 40px;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user .username,\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user .email {\\n display: none;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .navbar-content {\\n padding-top: 0;\\n}\\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .navbar-content .material2 .nav-item .nav-link {\\n border-radius: 20px;\\n margin: 0 12px;\\n padding: 0 12px;\\n}\\nnavbar.vertical-style-1 {\\n display: flex;\\n flex-direction: column;\\n flex: 1 1 auto;\\n width: 100%;\\n height: 100%;\\n}\\nnavbar.vertical-style-1.right-navbar .toggle-sidebar-opened mat-icon {\\n transform: rotate(180deg);\\n}\\nnavbar navbar-vertical-style-1 {\\n display: flex;\\n flex-direction: column;\\n width: 100%;\\n height: 100%;\\n}\\nnavbar navbar-vertical-style-1 .navbar-top {\\n display: flex;\\n flex-direction: row;\\n flex: 1 0 auto;\\n align-items: center;\\n justify-content: space-between;\\n min-height: 64px;\\n max-height: 64px;\\n height: 64px;\\n padding: 12px 12px 12px 20px;\\n}\\n@media screen and (max-width: 599px) {\\n navbar navbar-vertical-style-1 .navbar-top {\\n min-height: 56px;\\n max-height: 56px;\\n height: 56px;\\n }\\n}\\nnavbar navbar-vertical-style-1 .navbar-top .logo {\\n display: flex;\\n align-items: center;\\n}\\nnavbar navbar-vertical-style-1 .navbar-top .logo .logo-icon {\\n width: 24px;\\n height: 24px;\\n}\\nnavbar navbar-vertical-style-1 .navbar-top .logo .logo-text {\\n margin-left: 12px;\\n font-size: 16px;\\n font-weight: 300;\\n letter-spacing: 0.4px;\\n line-height: normal;\\n}\\nnavbar navbar-vertical-style-1 .navbar-top .buttons {\\n display: flex;\\n align-items: center;\\n}\\nnavbar navbar-vertical-style-1 .navbar-scroll-container {\\n display: flex;\\n flex-direction: column;\\n flex: 1 1 auto;\\n overflow-y: auto;\\n -webkit-overflow-scrolling: touch;\\n background: linear-gradient(rgba(0, 0, 0, 0) 30%, rgba(0, 0, 0, 0) 30%), linear-gradient(rgba(0, 0, 0, 0.25) 0, rgba(0, 0, 0, 0) 40%);\\n background-repeat: no-repeat;\\n background-size: 100% 40px, 100% 10px;\\n background-attachment: local, scroll;\\n}\\nnavbar navbar-vertical-style-1 .navbar-scroll-container .user {\\n position: relative;\\n display: flex;\\n align-items: center;\\n justify-content: flex-start;\\n width: 100%;\\n height: 136px;\\n min-height: 136px;\\n max-height: 136px;\\n padding: 24px 0 64px 0;\\n}\\nnavbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container {\\n position: absolute;\\n top: 92px;\\n border-radius: 50%;\\n padding: 8px;\\n transform: translateX(-50%);\\n left: 50%;\\n}\\nnavbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container .avatar {\\n width: 72px;\\n height: 72px;\\n margin: 0;\\n}\\nnavbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container mat-icon {\\n position: absolute;\\n right: 0px;\\n top: 5px;\\n cursor: pointer;\\n color: var(--primary-color);\\n}\\nnavbar navbar-vertical-style-1 .navbar-scroll-container .navbar-content {\\n flex: 1 1 auto;\\n padding-top: 32px;\\n margin-top: 20px;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/layout/components/navbar/vertical/style-1/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/app/layout/components/navbar/vertical/style-1/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\app\\layout\\components\\navbar\\vertical\\style-1\\style-1.component.scss","src/app/layout/components/navbar/vertical/style-1/style-1.component.scss","src/app/layout/components/navbar/vertical/style-1/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC55FI;EACI,gBAAA;ACAR;ADQoB;EACI,eAAA;EACA,uBAAA;ACNxB;ADQwB;EACI,aAAA;ACN5B;ADW4B;EACI,WAAA;EACA,YAAA;ACThC;ADY4B;EACI,aAAA;ACVhC;ADiBwB;EACI,eAAA;EACA,YAAA;EACA,gBAAA;EACA,gBAAA;ACf5B;ADiB4B;EACI,kBAAA;EACA,SAAA;EACA,UAAA;EACA,wBAAA;EACA,UAAA;ACfhC;ADkBgC;EACI,WAAA;EACA,YAAA;AChBpC;ADoB4B;;EAEI,aAAA;AClBhC;ADsBwB;EACI,cAAA;ACpB5B;AD2BoC;EACI,mBAAA;EACA,cAAA;EACA,eAAA;ACzBxC;ADuCI;EACI,aAAA;EACA,sBAAA;EACA,cAAA;EACA,WAAA;EACA,YAAA;ACpCR;AD0CgB;EACI,yBAAA;ACxCpB;AD8CI;EACI,aAAA;EACA,sBAAA;EACA,WAAA;EACA,YAAA;AC5CR;AD8CQ;EACI,aAAA;EACA,mBAAA;EACA,cAAA;EACA,mBAAA;EACA,8BAAA;EACA,gBAAA;EACA,gBAAA;EACA,YAAA;EACA,4BAAA;AC5CZ;AC3CQ;EF8EA;IAYQ,gBAAA;IACA,gBAAA;IACA,YAAA;EC3Cd;AACF;AD6CY;EACI,aAAA;EACA,mBAAA;AC3ChB;AD6CgB;EACI,WAAA;EACA,YAAA;AC3CpB;AD8CgB;EACI,iBAAA;EACA,eAAA;EACA,gBAAA;EACA,qBAAA;EACA,mBAAA;AC5CpB;ADgDY;EACI,aAAA;EACA,mBAAA;AC9ChB;ADkDQ;EACI,aAAA;EACA,sBAAA;EACA,cAAA;EACA,gBAAA;EACA,iCAAA;EAEA,qIAAA;EAGA,4BAAA;EACA,qCAAA;EACA,oCAAA;ACnDZ;ADqDY;EACI,kBAAA;EACA,aAAA;EACA,mBAAA;EACA,2BAAA;EACA,WAAA;EACA,aAAA;EACA,iBAAA;EACA,iBAAA;EACA,sBAAA;ACnDhB;ADqDgB;EACI,kBAAA;EACA,SAAA;EACA,kBAAA;EACA,YAAA;EACA,2BAAA;EACA,SAAA;ACnDpB;ADoDoB;EACI,WAAA;EACA,YAAA;EACA,SAAA;AClDxB;ADoDoB;EACI,kBAAA;EACA,UAAA;EACA,QAAA;EACA,eAAA;EAEA,2BAAA;ACnDxB;ADwDY;EACI,cAAA;EACA,iBAAA;EACA,gBAAA;ACtDhB","file":"src/app/layout/components/navbar/vertical/style-1/style-1.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\n\r\nfuse-sidebar {\r\n\r\n    &.navbar-fuse-sidebar {\r\n        overflow: hidden;\r\n\r\n        &.folded:not(.unfolded) {\r\n\r\n            navbar {\r\n\r\n                navbar-vertical-style-1 {\r\n\r\n                    .navbar-top {\r\n                        padding: 12px 0;\r\n                        justify-content: center;\r\n\r\n                        .buttons {\r\n                            display: none;\r\n                        }\r\n\r\n                        .logo {\r\n\r\n                            .logo-icon {\r\n                                width: 32px;\r\n                                height: 32px;\r\n                            }\r\n\r\n                            .logo-text {\r\n                                display: none;\r\n                            }\r\n                        }\r\n                    }\r\n\r\n                    .navbar-scroll-container {\r\n\r\n                        .user {\r\n                            padding: 12px 0;\r\n                            height: 64px;\r\n                            min-height: 64px;\r\n                            max-height: 64px;\r\n\r\n                            .avatar-container {\r\n                                position: relative;\r\n                                top: auto;\r\n                                padding: 0;\r\n                                transform: translateX(0);\r\n                                left: auto;\r\n                                \r\n\r\n                                .avatar {\r\n                                    width: 40px;\r\n                                    height: 40px;\r\n                                }\r\n                            }\r\n\r\n                            .username,\r\n                            .email {\r\n                                display: none;\r\n                            }\r\n                        }\r\n\r\n                        .navbar-content {\r\n                            padding-top: 0;\r\n\r\n                            // Material 2 specific style\r\n                            .material2 {\r\n\r\n                                .nav-item {\r\n\r\n                                    .nav-link {\r\n                                        border-radius: 20px;\r\n                                        margin: 0 12px;\r\n                                        padding: 0 12px;\r\n                                    }\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n\r\nnavbar {\r\n\r\n    &.vertical-style-1 {\r\n        display: flex;\r\n        flex-direction: column;\r\n        flex: 1 1 auto;\r\n        width: 100%;\r\n        height: 100%;\r\n\r\n        &.right-navbar {\r\n\r\n            .toggle-sidebar-opened {\r\n\r\n                mat-icon {\r\n                    transform: rotate(180deg);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    navbar-vertical-style-1 {\r\n        display: flex;\r\n        flex-direction: column;\r\n        width: 100%;\r\n        height: 100%;\r\n\r\n        .navbar-top {\r\n            display: flex;\r\n            flex-direction: row;\r\n            flex: 1 0 auto;\r\n            align-items: center;\r\n            justify-content: space-between;\r\n            min-height: 64px;\r\n            max-height: 64px;\r\n            height: 64px;\r\n            padding: 12px 12px 12px 20px;\r\n\r\n            @include media-breakpoint('xs') {\r\n                min-height: 56px;\r\n                max-height: 56px;\r\n                height: 56px;\r\n            }\r\n\r\n            .logo {\r\n                display: flex;\r\n                align-items: center;\r\n\r\n                .logo-icon {\r\n                    width: 24px;\r\n                    height: 24px;\r\n                }\r\n\r\n                .logo-text {\r\n                    margin-left: 12px;\r\n                    font-size: 16px;\r\n                    font-weight: 300;\r\n                    letter-spacing: 0.4px;\r\n                    line-height: normal;\r\n                }\r\n            }\r\n\r\n            .buttons {\r\n                display: flex;\r\n                align-items: center;\r\n            }\r\n        }\r\n\r\n        .navbar-scroll-container {\r\n            display: flex;\r\n            flex-direction: column;\r\n            flex: 1 1 auto;\r\n            overflow-y: auto;\r\n            -webkit-overflow-scrolling: touch;\r\n\r\n            background: linear-gradient(rgba(0, 0, 0, 0) 30%, rgba(0, 0, 0, 0) 30%),\r\n            linear-gradient(rgba(0, 0, 0, 0.25) 0, rgba(0, 0, 0, 0) 40%);\r\n\r\n            background-repeat: no-repeat;\r\n            background-size: 100% 40px, 100% 10px;\r\n            background-attachment: local, scroll;\r\n\r\n            .user {\r\n                position: relative;\r\n                display: flex;\r\n                align-items: center;\r\n                justify-content: flex-start;\r\n                width: 100%;\r\n                height: 136px;\r\n                min-height: 136px;\r\n                max-height: 136px;\r\n                padding: 24px 0 64px 0;\r\n\r\n                .avatar-container {\r\n                    position: absolute;\r\n                    top: 92px;\r\n                    border-radius: 50%;\r\n                    padding: 8px;\r\n                    transform: translateX(-50%);\r\n                    left: 50%;\r\n                    .avatar {\r\n                        width: 72px;\r\n                        height: 72px;\r\n                        margin: 0;\r\n                    }\r\n                    mat-icon{\r\n                        position: absolute;\r\n                        right: 0px;\r\n                        top: 5px;\r\n                        cursor: pointer;\r\n                        // color: #039be5;\r\n                        color: var(--primary-color);\r\n                    }\r\n                }\r\n            }\r\n\r\n            .navbar-content {\r\n                flex: 1 1 auto;\r\n                padding-top: 32px;\r\n                margin-top: 20px;\r\n            }\r\n        }\r\n    }\r\n}","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\nfuse-sidebar.navbar-fuse-sidebar {\n  overflow: hidden;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-top {\n  padding: 12px 0;\n  justify-content: center;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-top .buttons {\n  display: none;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-top .logo .logo-icon {\n  width: 32px;\n  height: 32px;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-top .logo .logo-text {\n  display: none;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user {\n  padding: 12px 0;\n  height: 64px;\n  min-height: 64px;\n  max-height: 64px;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container {\n  position: relative;\n  top: auto;\n  padding: 0;\n  transform: translateX(0);\n  left: auto;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container .avatar {\n  width: 40px;\n  height: 40px;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user .username,\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .user .email {\n  display: none;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .navbar-content {\n  padding-top: 0;\n}\nfuse-sidebar.navbar-fuse-sidebar.folded:not(.unfolded) navbar navbar-vertical-style-1 .navbar-scroll-container .navbar-content .material2 .nav-item .nav-link {\n  border-radius: 20px;\n  margin: 0 12px;\n  padding: 0 12px;\n}\n\nnavbar.vertical-style-1 {\n  display: flex;\n  flex-direction: column;\n  flex: 1 1 auto;\n  width: 100%;\n  height: 100%;\n}\nnavbar.vertical-style-1.right-navbar .toggle-sidebar-opened mat-icon {\n  transform: rotate(180deg);\n}\nnavbar navbar-vertical-style-1 {\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  height: 100%;\n}\nnavbar navbar-vertical-style-1 .navbar-top {\n  display: flex;\n  flex-direction: row;\n  flex: 1 0 auto;\n  align-items: center;\n  justify-content: space-between;\n  min-height: 64px;\n  max-height: 64px;\n  height: 64px;\n  padding: 12px 12px 12px 20px;\n}\n@media screen and (max-width: 599px) {\n  navbar navbar-vertical-style-1 .navbar-top {\n    min-height: 56px;\n    max-height: 56px;\n    height: 56px;\n  }\n}\nnavbar navbar-vertical-style-1 .navbar-top .logo {\n  display: flex;\n  align-items: center;\n}\nnavbar navbar-vertical-style-1 .navbar-top .logo .logo-icon {\n  width: 24px;\n  height: 24px;\n}\nnavbar navbar-vertical-style-1 .navbar-top .logo .logo-text {\n  margin-left: 12px;\n  font-size: 16px;\n  font-weight: 300;\n  letter-spacing: 0.4px;\n  line-height: normal;\n}\nnavbar navbar-vertical-style-1 .navbar-top .buttons {\n  display: flex;\n  align-items: center;\n}\nnavbar navbar-vertical-style-1 .navbar-scroll-container {\n  display: flex;\n  flex-direction: column;\n  flex: 1 1 auto;\n  overflow-y: auto;\n  -webkit-overflow-scrolling: touch;\n  background: linear-gradient(rgba(0, 0, 0, 0) 30%, rgba(0, 0, 0, 0) 30%), linear-gradient(rgba(0, 0, 0, 0.25) 0, rgba(0, 0, 0, 0) 40%);\n  background-repeat: no-repeat;\n  background-size: 100% 40px, 100% 10px;\n  background-attachment: local, scroll;\n}\nnavbar navbar-vertical-style-1 .navbar-scroll-container .user {\n  position: relative;\n  display: flex;\n  align-items: center;\n  justify-content: flex-start;\n  width: 100%;\n  height: 136px;\n  min-height: 136px;\n  max-height: 136px;\n  padding: 24px 0 64px 0;\n}\nnavbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container {\n  position: absolute;\n  top: 92px;\n  border-radius: 50%;\n  padding: 8px;\n  transform: translateX(-50%);\n  left: 50%;\n}\nnavbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container .avatar {\n  width: 72px;\n  height: 72px;\n  margin: 0;\n}\nnavbar navbar-vertical-style-1 .navbar-scroll-container .user .avatar-container mat-icon {\n  position: absolute;\n  right: 0px;\n  top: 5px;\n  cursor: pointer;\n  color: var(--primary-color);\n}\nnavbar navbar-vertical-style-1 .navbar-scroll-container .navbar-content {\n  flex: 1 1 auto;\n  padding-top: 32px;\n  margin-top: 20px;\n}","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n"]} */\"","import { Component, OnDestroy, OnInit, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { NavigationEnd, Router } from '@angular/router';\r\nimport { Subject } from 'rxjs';\r\nimport { delay, filter, take, takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseConfigService } from '@fuse/services/config.service';\r\nimport { FuseNavigationService } from '@fuse/components/navigation/navigation.service';\r\nimport { FusePerfectScrollbarDirective } from '@fuse/directives/fuse-perfect-scrollbar/fuse-perfect-scrollbar.directive';\r\nimport { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service';\r\nimport { AuthService } from 'app/shared/auth.service';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { UserService } from '../../../../../shared/user.service';\r\nimport { RestService } from '../../../../../shared/rest.service';\r\nimport { ProfileService } from 'app/main/pages/profile/profile.service';\r\nimport { FuseSplashScreenService } from '@fuse/services/splash-screen.service';\r\n\r\n@Component({\r\n selector : 'navbar-vertical-style-1',\r\n templateUrl : './style-1.component.html',\r\n styleUrls : ['./style-1.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\nexport class NavbarVerticalStyle1Component implements OnInit, OnDestroy\r\n{\r\n fuseConfig: any;\r\n navigation: any;\r\n userFullName:any;\r\n userEmail: any;\r\n companyName: any;\r\n url;\r\n role;\r\n userDetails;\r\n // Private\r\n private _fusePerfectScrollbar: FusePerfectScrollbarDirective;\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {FuseConfigService} _fuseConfigService\r\n * @param {FuseNavigationService} _fuseNavigationService\r\n * @param {FuseSidebarService} _fuseSidebarService\r\n * @param {Router} _router\r\n */\r\n constructor(\r\n private _userService : UserService,\r\n private _fuseConfigService: FuseConfigService,\r\n private _fuseNavigationService: FuseNavigationService,\r\n private _fuseSidebarService: FuseSidebarService,\r\n private _router: Router,\r\n private _authService: AuthService,\r\n private _toastr: ToastrService,\r\n private _restService: RestService,\r\n private _ProfileService:ProfileService,\r\n private fuseSplashScreenService:FuseSplashScreenService\r\n )\r\n {\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Accessors\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n // Directive\r\n @ViewChild(FusePerfectScrollbarDirective, {static: true})\r\n set directive(theDirective: FusePerfectScrollbarDirective)\r\n {\r\n if ( !theDirective )\r\n {\r\n return;\r\n }\r\n\r\n this._fusePerfectScrollbar = theDirective;\r\n\r\n // Update the scrollbar on collapsable item toggle\r\n this._fuseNavigationService.onItemCollapseToggled\r\n .pipe(\r\n delay(500),\r\n takeUntil(this._unsubscribeAll)\r\n )\r\n .subscribe(() => {\r\n this._fusePerfectScrollbar.update();\r\n });\r\n\r\n // Scroll to the active item position\r\n this._router.events\r\n .pipe(\r\n filter((event) => event instanceof NavigationEnd),\r\n take(1)\r\n )\r\n .subscribe(() => {\r\n setTimeout(() => {\r\n this._fusePerfectScrollbar.scrollToElement('navbar .nav-link.active', -120);\r\n });\r\n }\r\n );\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n\r\n // this._ProfileService.getProfile().subscribe((res: any) => {\r\n // this.url = res.data.profileImage\r\n // })\r\n \r\n\r\n this._router.events\r\n .pipe(\r\n filter((event) => event instanceof NavigationEnd),\r\n takeUntil(this._unsubscribeAll)\r\n )\r\n .subscribe(() => {\r\n if ( this._fuseSidebarService.getSidebar('navbar') )\r\n {\r\n this._fuseSidebarService.getSidebar('navbar').close();\r\n }\r\n }\r\n );\r\n\r\n // Subscribe to the config changes\r\n this._fuseConfigService.config\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((config) => {\r\n this.fuseConfig = config;\r\n });\r\n\r\n // Get current navigation\r\n this._fuseNavigationService.onNavigationChanged\r\n .pipe(\r\n filter(value => value !== null),\r\n takeUntil(this._unsubscribeAll)\r\n )\r\n .subscribe(() => {\r\n this.navigation = this._fuseNavigationService.getCurrentNavigation();\r\n });\r\n\r\n // Get User Data\r\n if(localStorage.getItem('LoggedInUserData') !== null){\r\n this._userService.getActiveUser$().subscribe((data: any) => { \r\n if(data!=null){\r\n this.userFullName = data.firstName;\r\n this.userEmail = data.email; \r\n this.companyName = data.companyName;\r\n this.url = data.companyLogo;\r\n this.role= data.role\r\n }\r\n })\r\n this.userDetails = JSON.parse(\r\n localStorage.getItem(\"LoggedInUserData\")\r\n );\r\n }\r\n\r\n \r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Toggle sidebar opened status\r\n */\r\n toggleSidebarOpened(): void\r\n {\r\n this._fuseSidebarService.getSidebar('navbar').toggleOpen();\r\n }\r\n\r\n /**\r\n * Toggle sidebar folded status\r\n */\r\n toggleSidebarFolded(): void\r\n {\r\n this._fuseSidebarService.getSidebar('navbar').toggleFold();\r\n }\r\n uploadImage(ev){\r\n this.fuseSplashScreenService.show();\r\n var file=ev.target.files[0];\r\n var formData=new FormData();\r\n formData.append('file',file);\r\n formData.append('companyId', this.userDetails.companyId);\r\n formData.append('companyKey',this.userDetails.companyKey);\r\n this._authService.setCompanyLogo(formData).subscribe(\r\n (res:any)=>{\r\n this.fuseSplashScreenService.hide();\r\n this.url= res.data;\r\n if(res.status.toLowerCase() == \"failed\"){\r\n this._toastr.error(\"Error while updating profile\",'Error'); \r\n }else{\r\n this._toastr.success(\"Company Logo updated successfully\",'Success');\r\n }\r\n this._restService.GetUserProfile().subscribe(\r\n (res: any) => {\r\n this._authService.sendUserData(JSON.stringify(res.data)); \r\n }); \r\n },() => {\r\n this.fuseSplashScreenService.hide();\r\n }\r\n )\r\n }\r\n\r\n \r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\n\r\nimport { FuseNavigationModule } from '@fuse/components';\r\nimport { FuseSharedModule } from '@fuse/shared.module';\r\nimport { ProfileService } from 'app/main/pages/profile/profile.service';\r\n\r\nimport { NavbarVerticalStyle1Component } from 'app/layout/components/navbar/vertical/style-1/style-1.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n NavbarVerticalStyle1Component\r\n ],\r\n imports : [\r\n MatButtonModule,\r\n MatIconModule,\r\n\r\n FuseSharedModule,\r\n FuseNavigationModule\r\n ],\r\n providers : [\r\n ProfileService\r\n ],\r\n exports : [\r\n NavbarVerticalStyle1Component\r\n ]\r\n})\r\nexport class NavbarVerticalStyle1Module\r\n{\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\nquick-panel {\\n display: flex;\\n flex-direction: column;\\n flex: 1 1 auto;\\n width: 280px;\\n min-width: 280px;\\n max-width: 280px;\\n z-index: 99;\\n}\\nquick-panel .mat-slide-toggle-content {\\n flex: 1;\\n}\\nquick-panel .secondary-text {\\n font-size: 20px;\\n}\\nquick-panel .buttons-list {\\n margin-bottom: 10px;\\n}\\nquick-panel .search_button {\\n margin: 10px;\\n}\\nquick-panel .optout-form {\\n padding: 0 20px;\\n}\\nquick-panel .mat-list-base.list-horizontal {\\n display: flex;\\n}\\nquick-panel .text-trun {\\n display: block;\\n overflow: hidden;\\n text-overflow: ellipsis;\\n word-break: break-all;\\n}\\n@media screen and (max-width: 600px) {\\n quick-panel .saveButton {\\n float: none !important;\\n display: block;\\n margin-top: 5px;\\n }\\n quick-panel .mat-list-base.list-horizontal {\\n display: block;\\n }\\n quick-panel .table-content {\\n width: -webkit-max-content;\\n width: -moz-max-content;\\n width: max-content;\\n }\\n quick-panel .PointAccountIdsForm {\\n width: 100% !important;\\n }\\n}\\nquick-panel .saveButton {\\n float: right;\\n margin-right: 20px;\\n}\\nquick-panel .f-s-12 {\\n font-size: 12px;\\n}\\nquick-panel .p-5 {\\n padding: 5px !important;\\n}\\nquick-panel .break-word {\\n word-break: break-all;\\n}\\nquick-panel .ViewDetail {\\n cursor: pointer;\\n text-decoration: none;\\n}\\nquick-panel .ViewDetail:hover {\\n text-decoration: none !important;\\n}\\nquick-panel .PointAccountIdsForm {\\n width: 25%;\\n}\\nquick-panel .PointAccountIdsForm .mat-form-field-wrapper {\\n padding: 0px !important;\\n}\\nquick-panel .p-10 {\\n padding: 10px !important;\\n}\\nquick-panel .table-content {\\n display: flex;\\n flex: 1 1 auto;\\n width: 100%;\\n}\\nquick-panel .table-content .content-card {\\n margin-top: 10px;\\n width: 100%;\\n border-radius: 8px;\\n}\\nquick-panel .table-content .details {\\n overflow: auto;\\n}\\nquick-panel .table-content .details .mat-table {\\n width: 100%;\\n background: transparent;\\n box-shadow: none;\\n}\\n@media screen and (max-width: 599px) {\\n quick-panel .table-content .details .mat-table {\\n overflow-x: scroll;\\n }\\n quick-panel .table-content .details .mat-table .mat-row,\\nquick-panel .table-content .details .mat-table .mat-header-row {\\n width: 300vw;\\n }\\n}\\nquick-panel .table-content .details .mat-table .mat-row {\\n position: relative;\\n cursor: default;\\n}\\nquick-panel .table-content .details .mat-table .mat-row .mat-cell {\\n min-width: 0;\\n}\\nquick-panel .table-content .details .mat-table .mat-row .mat-cell.mat-column-detail-button {\\n flex: 0 1 auto;\\n padding: 0 24px 0 0;\\n}\\n@media screen and (min-width: 1280px) {\\n quick-panel .table-content .details .mat-table .mat-row .mat-cell.mat-column-detail-button {\\n display: none;\\n }\\n}\\nquick-panel .table-content .details .mat-table .mat-header-row {\\n position: relative;\\n}\\nquick-panel .wh-100 {\\n width: 100%;\\n}\\n.text-red {\\n color: red !important;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/layout/components/quick-panel/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/app/layout/components/quick-panel/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\app\\layout\\components\\quick-panel\\quick-panel.component.scss","src/app/layout/components/quick-panel/quick-panel.component.scss","src/app/layout/components/quick-panel/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC/5FA;EACI,aAAA;EACA,sBAAA;EACA,cAAA;EACA,YAAA;EACA,gBAAA;EACA,gBAAA;EACA,WAAA;ACGJ;ADDI;EACI,OAAA;ACGR;ADDI;EACQ,eAAA;ACGZ;ADDI;EACI,mBAAA;ACGR;ADDI;EACI,YAAA;ACGR;ADDI;EACI,eAAA;ACGR;ADDI;EACI,aAAA;ACGR;ADDI;EACI,cAAA;EACA,gBAAA;EACA,uBAAA;EACD,qBAAA;ACGP;ADDI;EACI;IACI,sBAAA;IACA,cAAA;IACA,eAAA;ECGV;EDDM;IACI,cAAA;ECGV;EDDM;IACI,0BAAA;IAAA,uBAAA;IAAA,kBAAA;ECGV;EDDM;IACI,sBAAA;ECGV;AACF;ADDI;EACI,YAAA;EACA,kBAAA;ACGR;ADDI;EACI,eAAA;ACGR;ADDI;EACI,uBAAA;ACGR;ADDI;EACI,qBAAA;ACGR;ADDI;EACI,eAAA;EACA,qBAAA;ACGR;ADDI;EACI,gCAAA;ACGR;ADDI;EACI,UAAA;ACGR;ADCQ;EAEI,uBAAA;ACAZ;ADGI;EACI,wBAAA;ACDR;ADGI;EACI,aAAA;EACA,cAAA;EACA,WAAA;ACDR;ADIQ;EACI,gBAAA;EACA,WAAA;EACA,kBAAA;ACFZ;ADQQ;EACI,cAAA;ACNZ;ADQY;EACI,WAAA;EACA,uBAAA;EACA,gBAAA;ACNhB;ACjEQ;EFoEI;IAMQ,kBAAA;ECLlB;EDOkB;;IAEI,YAAA;ECLtB;AACF;ADWgB;EACI,kBAAA;EACA,eAAA;ACTpB;ADWoB;EACI,YAAA;ACTxB;ADWwB;EACI,cAAA;EACA,mBAAA;ACT5B;ACrFQ;EF4FgB;IAKQ,aAAA;ECR9B;AACF;ADagB;EACI,kBAAA;ACXpB;AD6BI;EACI,WAAA;AC3BR;AD8BA;EACI,qBAAA;AC3BJ","file":"src/app/layout/components/quick-panel/quick-panel.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\nquick-panel {\r\n    display: flex;\r\n    flex-direction: column;\r\n    flex: 1 1 auto;\r\n    width: 280px;\r\n    min-width: 280px;\r\n    max-width: 280px;\r\n    z-index: 99;\r\n\r\n    .mat-slide-toggle-content {\r\n        flex: 1;\r\n    }\r\n    .secondary-text {\r\n            font-size:20px;\r\n    }\r\n    .buttons-list{\r\n        margin-bottom: 10px;\r\n    }\r\n    .search_button{\r\n        margin: 10px;\r\n    }\r\n    .optout-form{\r\n        padding: 0 20px;\r\n    }\r\n    .mat-list-base.list-horizontal {\r\n        display: flex;\r\n    }\r\n    .text-trun {\r\n        display: block;\r\n        overflow: hidden;\r\n        text-overflow: ellipsis;\r\n       word-break: break-all;\r\n      }\r\n    @media screen and (max-width: 600px){\r\n        .saveButton{\r\n            float: none !important;\r\n            display: block;\r\n            margin-top: 5px;\r\n        }\r\n        .mat-list-base.list-horizontal {\r\n            display: block;\r\n        }\r\n        .table-content{\r\n            width: max-content;\r\n        }\r\n        .PointAccountIdsForm{\r\n            width: 100% !important;\r\n        }\r\n    }\r\n    .saveButton{\r\n        float: right;\r\n        margin-right: 20px;\r\n    }\r\n    .f-s-12{\r\n        font-size: 12px;\r\n    }\r\n    .p-5 {\r\n        padding: 5px !important;\r\n    }\r\n    .break-word{\r\n        word-break: break-all;\r\n    }\r\n    .ViewDetail {\r\n        cursor: pointer;\r\n        text-decoration: none;\r\n    }\r\n    .ViewDetail:hover {\r\n        text-decoration: none !important;\r\n    }\r\n    .PointAccountIdsForm{\r\n        width: 25%;\r\n        // display: inline-flex !important;\r\n        // margin-left: 15%;\r\n\r\n        .mat-form-field-wrapper\r\n        {\r\n            padding: 0px !important;\r\n        }\r\n    }\r\n    .p-10 {\r\n        padding: 10px !important;\r\n    }\r\n    .table-content {\r\n        display: flex;\r\n        flex: 1 1 auto;\r\n        width: 100%;\r\n\r\n\r\n        .content-card {\r\n            margin-top: 10px;\r\n            width: 100%;\r\n            border-radius: 8px;\r\n        }\r\n\r\n\r\n\r\n\r\n        .details {\r\n            overflow: auto;\r\n\r\n            .mat-table {\r\n                width: 100%;\r\n                background: transparent;\r\n                box-shadow: none;\r\n\r\n                @include media-breakpoint(\"xs\") {\r\n                    overflow-x: scroll;\r\n\r\n                    .mat-row,\r\n                    .mat-header-row {\r\n                        width: 300vw;\r\n                    }\r\n                }\r\n\r\n\r\n\r\n\r\n                .mat-row {\r\n                    position: relative;\r\n                    cursor: default;\r\n\r\n                    .mat-cell {\r\n                        min-width: 0;\r\n\r\n                        &.mat-column-detail-button {\r\n                            flex: 0 1 auto;\r\n                            padding: 0 24px 0 0;\r\n\r\n                            @include media-breakpoint(\"gt-md\") {\r\n                                display: none;\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n\r\n                .mat-header-row {\r\n                    position: relative;\r\n                    // cursor: pointer;\r\n\r\n\r\n                }\r\n\r\n\r\n\r\n            }\r\n\r\n\r\n\r\n\r\n        }\r\n\r\n\r\n\r\n    }\r\n    .wh-100{\r\n        width: 100%;\r\n    }\r\n}\r\n.text-red{\r\n    color: red !important;\r\n}\r\n","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\nquick-panel {\n  display: flex;\n  flex-direction: column;\n  flex: 1 1 auto;\n  width: 280px;\n  min-width: 280px;\n  max-width: 280px;\n  z-index: 99;\n}\nquick-panel .mat-slide-toggle-content {\n  flex: 1;\n}\nquick-panel .secondary-text {\n  font-size: 20px;\n}\nquick-panel .buttons-list {\n  margin-bottom: 10px;\n}\nquick-panel .search_button {\n  margin: 10px;\n}\nquick-panel .optout-form {\n  padding: 0 20px;\n}\nquick-panel .mat-list-base.list-horizontal {\n  display: flex;\n}\nquick-panel .text-trun {\n  display: block;\n  overflow: hidden;\n  text-overflow: ellipsis;\n  word-break: break-all;\n}\n@media screen and (max-width: 600px) {\n  quick-panel .saveButton {\n    float: none !important;\n    display: block;\n    margin-top: 5px;\n  }\n  quick-panel .mat-list-base.list-horizontal {\n    display: block;\n  }\n  quick-panel .table-content {\n    width: max-content;\n  }\n  quick-panel .PointAccountIdsForm {\n    width: 100% !important;\n  }\n}\nquick-panel .saveButton {\n  float: right;\n  margin-right: 20px;\n}\nquick-panel .f-s-12 {\n  font-size: 12px;\n}\nquick-panel .p-5 {\n  padding: 5px !important;\n}\nquick-panel .break-word {\n  word-break: break-all;\n}\nquick-panel .ViewDetail {\n  cursor: pointer;\n  text-decoration: none;\n}\nquick-panel .ViewDetail:hover {\n  text-decoration: none !important;\n}\nquick-panel .PointAccountIdsForm {\n  width: 25%;\n}\nquick-panel .PointAccountIdsForm .mat-form-field-wrapper {\n  padding: 0px !important;\n}\nquick-panel .p-10 {\n  padding: 10px !important;\n}\nquick-panel .table-content {\n  display: flex;\n  flex: 1 1 auto;\n  width: 100%;\n}\nquick-panel .table-content .content-card {\n  margin-top: 10px;\n  width: 100%;\n  border-radius: 8px;\n}\nquick-panel .table-content .details {\n  overflow: auto;\n}\nquick-panel .table-content .details .mat-table {\n  width: 100%;\n  background: transparent;\n  box-shadow: none;\n}\n@media screen and (max-width: 599px) {\n  quick-panel .table-content .details .mat-table {\n    overflow-x: scroll;\n  }\n  quick-panel .table-content .details .mat-table .mat-row,\nquick-panel .table-content .details .mat-table .mat-header-row {\n    width: 300vw;\n  }\n}\nquick-panel .table-content .details .mat-table .mat-row {\n  position: relative;\n  cursor: default;\n}\nquick-panel .table-content .details .mat-table .mat-row .mat-cell {\n  min-width: 0;\n}\nquick-panel .table-content .details .mat-table .mat-row .mat-cell.mat-column-detail-button {\n  flex: 0 1 auto;\n  padding: 0 24px 0 0;\n}\n@media screen and (min-width: 1280px) {\n  quick-panel .table-content .details .mat-table .mat-row .mat-cell.mat-column-detail-button {\n    display: none;\n  }\n}\nquick-panel .table-content .details .mat-table .mat-header-row {\n  position: relative;\n}\nquick-panel .wh-100 {\n  width: 100%;\n}\n\n.text-red {\n  color: red !important;\n}","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n"]} */\"","import { Component, Input, OnDestroy, OnInit, ViewEncapsulation, ViewChild} from '@angular/core';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { CustomersService } from '../../../main/pages/customers/customers-service';\r\nimport { FormGroup, FormBuilder } from '@angular/forms';\r\nimport * as moment from 'moment';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { CustomerBalanceAdjustmentComponent } from 'app/main/pages/customers/customer-balance-adjustment/customer-balance-adjustment.component';\r\nimport { fuseAnimations } from '@fuse/animations';\r\nimport { MatTableDataSource, MatPaginator } from '@angular/material';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { AuthService } from 'app/shared/auth.service';\r\nimport { FuseSplashScreenService } from '@fuse/services/splash-screen.service';\r\nimport { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service';\r\nimport { CustomerMaxLimitComponent } from 'app/main/pages/customers/customer-maxlimit/customer-maxlimit.component';\r\nimport { FuseConfirmDialogComponent } from '@fuse/components/confirm-dialog/confirm-dialog.component';\r\nimport { PayoutReceiptComponent } from 'app/main/pages/reports/payout-receipt/payout-receipt.component';\r\nimport { ResendTriggerComponent } from './resend-trigger/resend-trigger.component';\r\nimport { isLiveEnv } from 'app/constants';\r\nimport { TwoStepModalComponent } from '../two-step-modal/two-step-modal.component';\r\nimport { Router } from '@angular/router';\r\n\r\n@Component({\r\n selector : 'quick-panel',\r\n templateUrl : './quick-panel.component.html',\r\n styleUrls : ['./quick-panel.component.scss'],\r\n encapsulation: ViewEncapsulation.None,\r\n animations: fuseAnimations\r\n})\r\nexport class QuickPanelComponent implements OnInit, OnDestroy\r\n{\r\n customerDetails;\r\n displayedColumns = ['lastupdated', 'amount', 'updatedBalance', 'redeemType', 'referenceNo', 'transactionID','sourse', 'comment','secondaryPointAccountID','createdBy'];\r\n displayedColumns2 = ['HoldAmount', 'CreatedDate', 'ExpiryDate'];\r\n redeemTypes: any = [];\r\n PointAccounts;\r\n date: Date;\r\n events: any[];\r\n notes: any[];\r\n settings: any;\r\n searchForm: FormGroup;\r\n public currentdate = new Date();\r\n public currentyear : number = this.currentdate.getFullYear();\r\n PageSize: number = 10;\r\n pageNumber: number = 1;\r\n dataSource = new MatTableDataSource([]);\r\n @ViewChild(MatPaginator, {static: false }) paginator: MatPaginator;\r\n isBlockText:any=''; \r\n selectedPointID: any;\r\n PointAccountIds: any = [];\r\n PointAccountIdForm: FormGroup;\r\n maxdate = new Date(this.currentyear, 12,0)\r\n minDate = new Date(2000, 0, 1);\r\n refNumber = \"\";\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n userDetails: any;\r\n writePermissions: boolean = false;\r\n impersonation: boolean = false;\r\n manualAdjustment: boolean = false;\r\n isTgyaAccountExist:boolean = false;\r\n /**\r\n * Constructor\r\n *\r\n * @param {HttpClient} _httpClient\r\n * \r\n */\r\n constructor(\r\n private _httpClient: HttpClient, \r\n public CustomersService: CustomersService,\r\n private _formBuilder: FormBuilder,\r\n private _matDialog: MatDialog,\r\n private _toastr: ToastrService,\r\n public _AuthService: AuthService,\r\n private _fuseSplashScreenService: FuseSplashScreenService,\r\n private _fuseSidebarService: FuseSidebarService,\r\n private _router: Router,\r\n )\r\n {\r\n // Set the defaults\r\n this.date = new Date();\r\n this.settings = {\r\n notify: true,\r\n cloud : false,\r\n retro : true\r\n };\r\n this.searchForm = this._formBuilder.group({\r\n searchByFromDate: [moment().add(-30,\"days\")],\r\n searchByToDate: [moment()]\r\n });\r\n this.PointAccountIdForm = this._formBuilder.group({\r\n SelectedPointAccountID:[this.selectedPointID],\r\n });\r\n this.PointAccountIdForm.get('SelectedPointAccountID').valueChanges.subscribe(value => {\r\n this.pointAccountIdChange(value)\r\n })\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n this.userDetails = JSON.parse(this._AuthService.getUserData());\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Subscribe to the events\r\n this._httpClient.get('api/quick-panel-events')\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((response: any) => {\r\n this.events = response;\r\n });\r\n\r\n // Subscribe to the notes\r\n this._httpClient.get('api/quick-panel-notes')\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((response: any) => {\r\n this.notes = response;\r\n });\r\n\r\n let that = this;\r\n this._fuseSidebarService.getSidebar('quickPanel').openedChanged.subscribe(function(isOpened){\r\n if(isOpened) {\r\n that.writePermissions = false;\r\n that.impersonation = false;\r\n that.manualAdjustment = false;\r\n that.userDetails = JSON.parse(that._AuthService.getUserData());\r\n that.searchForm.get('searchByFromDate').setValue(moment().add(-30,\"days\"));\r\n that.searchForm.get('searchByToDate').setValue(new Date());\r\n that.getRedeemTypeList();\r\n if (that.userDetails.role != 3) {\r\n that.writePermissions = true;\r\n that.impersonation = true;\r\n that.manualAdjustment = true;\r\n } else {\r\n that.userDetails.writePermissions.forEach((obj) => {\r\n if (obj == \"customers\") {\r\n that.writePermissions = true;\r\n }\r\n });\r\n that.userDetails.permissions.forEach((obj) => {\r\n if (obj == \"impersonation\") {\r\n that.impersonation = true;\r\n }\r\n\r\n if (obj == \"manual-adjustment\") {\r\n that.manualAdjustment = true;\r\n }\r\n });\r\n }\r\n }\r\n });\r\n }\r\n resetsearchForm() {\r\n //this.searchForm.get('pointAccount').setValue(this.PointAccounts[0].id);\r\n this.searchForm.get('searchByFromDate').setValue(moment().add(-30,\"days\"));\r\n this.searchForm.get('searchByToDate').setValue(new Date());\r\n this.getAllPointTransactions();\r\n }\r\n pointAccountIdChange(selectedPointId)\r\n {\r\n this.selectedPointID = selectedPointId;\r\n this.getAllPointTransactions();\r\n }\r\n getAllPointTransactions() {\r\n this._fuseSplashScreenService.show();\r\n this.customerDetails = JSON.parse(localStorage.getItem('customer'));\r\n const request = {\r\n CustomerID: this.CustomersService.selectedCustomerid,\r\n PointAccountID: this.PointAccountIds.length > 0 ? this.selectedPointID : localStorage.getItem(\"pointAccountIDValue\"),\r\n CompanyID: this.CustomersService.selectedCompanyid,\r\n SortBy: \"lastupdated\",\r\n SortDirection: \"Desc\",\r\n StartDate: this.searchForm.get('searchByFromDate').value ? moment(this.searchForm.get('searchByFromDate').value).format('MM/DD/YYYY') : moment().format('MM/DD/YYYY'),\r\n EndDate: this.searchForm.get('searchByToDate').value ? moment(this.searchForm.get('searchByToDate').value).format('MM/DD/YYYY') : moment().format('MM/DD/YYYY')\r\n }\r\n this.CustomersService.GetAllPointAccountTransactons(request).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide();\r\n this.CustomersService.customerTransactionDetails = res.data;\r\n this.CustomersService.customerDetails = res.data.customerDetails;\r\n this.CustomersService.customerPointBalancesDetails = res.data.customerPointBalancesDetails;\r\n this.CustomersService.accountTotalCount = res.data.transactionsDetails.length;\r\n this.CustomersService.holdTotalCount = res.data.holdTransactionDetails.length;\r\n this.CustomersService.holdTransactionDetails = new MatTableDataSource(res.data.holdTransactionDetails);\r\n this.CustomersService.AccountTransactionList = new MatTableDataSource(res.data.transactionsDetails);\r\n this.CustomersService.AccountTransactionList.paginator = this.paginator;\r\n\r\n this.checkIsCustomerBlock();\r\n this.checkTygaAccount();\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n\r\n adjustBalance(customer: any = null) {\r\n this.customerDetails = JSON.parse(localStorage.getItem('customer'));\r\n const dialogRef = this._matDialog.open(CustomerBalanceAdjustmentComponent, {\r\n width: '650px',\r\n panelClass: 'adjust-balance',\r\n data: {\r\n action: customer ? 'edit' : 'new',\r\n data: this.customerDetails\r\n }\r\n });\r\n \r\n dialogRef.afterClosed().subscribe(result => {\r\n if (result == 'Success') {\r\n this.getAllPointTransactions();\r\n }\r\n });\r\n }\r\n\r\n\r\n getPointAccounts() {\r\n const request = '?companyId=' + this.CustomersService.selectedCompanyid;\r\n this._fuseSplashScreenService.show();\r\n this.CustomersService.GetCompanyPointDetail(request).subscribe((res: any) => {\r\n if (res.data) {\r\n this._fuseSplashScreenService.hide();\r\n this.PointAccountIds = res.data;\r\n var PointAccountIds:any = localStorage.getItem(\"pointAccountIDValue\");\r\n this.selectedPointID = this.PointAccountIds.some(e => e.id == PointAccountIds) ? PointAccountIds : this.PointAccountIds[0].id ;\r\n this.PointAccountIdForm.controls['SelectedPointAccountID'].setValue(this.selectedPointID);\r\n } else {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error('Error');\r\n }\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n\r\n setMaxLimit(customer: any = null) {\r\n this.customerDetails = JSON.parse(localStorage.getItem('customer'));\r\n const dialogRef = this._matDialog.open(CustomerMaxLimitComponent, {\r\n width: '650px',\r\n panelClass: 'adjust-balance',\r\n data: {\r\n action: customer ? 'edit' : 'new',\r\n data: this.customerDetails\r\n }\r\n });\r\n \r\n dialogRef.afterClosed().subscribe(result => {\r\n if (result == 'Success') {\r\n this.getAllPointTransactions();\r\n }\r\n });\r\n }\r\n toggleBlock() {\r\n if (this.isBlockText == \"Disable\") {\r\n this.blockCustomer();\r\n }else{\r\n this.unBlockCustomer();\r\n }\r\n }\r\n\r\n blockCustomer() {\r\n //this._fuseSplashScreenService.show();\r\n var confirmDialogRef = this._matDialog.open(\r\n FuseConfirmDialogComponent,\r\n {\r\n disableClose: false,\r\n panelClass: \"confirm-dialog\",\r\n }\r\n );\r\n confirmDialogRef.componentInstance.confirmMessage =\r\n \"Are you sure you want to Block User?\";\r\n confirmDialogRef.afterClosed().subscribe((result) => {\r\n if (result) {\r\n const request = {\r\n externalCustomerId: this.CustomersService.customerDetails.externalCustomerID,\r\n customerId: this.CustomersService.customerDetails.id,\r\n companyID: this.CustomersService.selectedCompanyid,\r\n pointAccountID: this.PointAccountIds.length > 0 ? this.selectedPointID : localStorage.getItem(\"pointAccountIDValue\")\r\n }\r\n this.CustomersService.BlockCustomer(request).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide();\r\n if (res && res.data) {\r\n this._fuseSplashScreenService.hide();\r\n this.isBlockText = \"Enable\";\r\n this._toastr.success('Customer blocked!', 'Success');\r\n } else {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(res.errorDescription, 'Error');\r\n }\r\n\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n });\r\n }\r\n unBlockCustomer() {\r\n //this._fuseSplashScreenService.show();\r\n var confirmDialogRef = this._matDialog.open(\r\n FuseConfirmDialogComponent,\r\n {\r\n disableClose: false,\r\n panelClass: \"confirm-dialog\",\r\n }\r\n );\r\n confirmDialogRef.componentInstance.confirmMessage =\r\n \"Are you sure you want to UnBlock User?\";\r\n confirmDialogRef.afterClosed().subscribe((result) => {\r\n if (result) {\r\n const request = {\r\n customerId: this.CustomersService.customerDetails.id,\r\n companyID: this.CustomersService.selectedCompanyid\r\n }\r\n this.CustomersService.UnBlockCustomer(request).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide();\r\n if (res && res.data) {\r\n this._fuseSplashScreenService.hide();\r\n this.isBlockText = \"Disable\";\r\n this._toastr.success('Customer unblocked!', 'Success');\r\n } else {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(res.errorDescription, 'Error');\r\n }\r\n\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n });\r\n }\r\n checkIsCustomerBlock() {\r\n this._fuseSplashScreenService.show();\r\n const request = {\r\n customerId: this.CustomersService.customerDetails.id,\r\n companyID: this.CustomersService.selectedCompanyid,\r\n pointAccountID: this.PointAccountIds.length > 0 ? this.selectedPointID : localStorage.getItem(\"pointAccountIDValue\")\r\n }\r\n this.CustomersService.IsCustomerBlock(request).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide();\r\n if(res){\r\n this.isBlockText= \"Enable\";\r\n }else{\r\n this.isBlockText= \"Disable\";\r\n }\r\n\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n openPayoutRecipe(transaction){\r\n\r\n const dialogRef = this._matDialog.open(PayoutReceiptComponent, {\r\n panelClass: \"payout-receipt-details\",\r\n disableClose: true,\r\n data: {\r\n transactionID: transaction.id,\r\n },\r\n });\r\n dialogRef.afterClosed().subscribe((response) => {\r\n if (!response) {\r\n return;\r\n }\r\n this.getAllPointTransactions();\r\n });\r\n }\r\n getRedeemTypeList(){\r\n this.CustomersService.GetRedeemType().subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide();\r\n if(res){\r\n this.redeemTypes = res;\r\n this.getPointAccounts()\r\n }\r\n\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n getRedeemType(redeemType){\r\n return this.redeemTypes.find(val => val.value == redeemType).name;\r\n }\r\n getPointAccName(redeemType){\r\n if(redeemType){\r\n return this.PointAccountIds.find(val => val.id == redeemType).accountName;\r\n }\r\n return redeemType;\r\n }\r\n syncCustomer() {\r\n this._fuseSplashScreenService.show();\r\n var req = {\r\n \"externalCustomerID\":this.CustomersService.customerDetails.externalCustomerID,\r\n \"companyId\":this.CustomersService.customerDetails.companyID\r\n }\r\n this.CustomersService.syncCustomer(req).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide(); \r\n if(res.data == \"true\" || res.data){\r\n this._toastr.success(\"Customer synced successfully!\", 'Success');\r\n this.getAllPointTransactions();\r\n }else{\r\n this._toastr.error(res.message, 'Error');\r\n }\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n impersonate(code) {\r\n this._fuseSplashScreenService.show();\r\n var req = {\r\n \"backofficeID\":this.CustomersService.customerDetails.backofficeID,\r\n \"companyId\":this.CustomersService.customerDetails.companyID\r\n }\r\n var headers = {\r\n 'refNumber': this.refNumber,\r\n 'code': code\r\n }\r\n this.CustomersService.ImpersonateToCustomerPortal(req,headers).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide();\r\n if(res){\r\n var companyKey = \"\";\r\n if(this.userDetails.role == 1){\r\n this.customerDetails = JSON.parse(localStorage.getItem('customer'));\r\n companyKey = this.customerDetails.companyKey;\r\n }else{\r\n companyKey = this.userDetails.companyKey;\r\n }\r\n var url = isLiveEnv ? `https://${companyKey}.paymenture.com/login/${res}` : `https://${companyKey}.stage.paymenture.com/login/${res}`;\r\n window.open(url, \"_blank\");\r\n }\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n // this._toastr.error(error, 'Error');\r\n\r\n if (error) {\r\n\t\t\t\tconst data = error.error;\t\r\n\t\t\t\tif (data.message === '2FA required please enter code.') {\r\n\t\t\t\t\tif (this.userDetails.twoWayAuth) {\r\n\t\t\t\t\t\tthis.refNumber = data.data;\r\n this._toastr.error(data.message || 'An error occurred!');\r\n var dialogRef = this._matDialog.open(TwoStepModalComponent, {\r\n panelClass: 'twostepdialog',\r\n data:{\r\n event:\"impersonate\"\r\n }\r\n });\r\n dialogRef.afterClosed().subscribe((res) => {\r\n this._fuseSplashScreenService.hide();\r\n console.log('res',res);\r\n \r\n if (res && res.event == 'impersonate') {\r\n if(res.code){\r\n this.impersonate(res.code);\r\n } else {\r\n this.impersonate(\"\");\r\n } \r\n }\r\n });\r\n\t\t\t\t\t} else {\r\n // for showing two 2fa enable model\r\n this._fuseSidebarService.getSidebar('quickPanel').close();\r\n this._router.navigate(['/pages/profile']);\r\n this._toastr.error('Please enable 2 Step Verification!');\r\n\t\t\t\t\t}\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis._toastr.error(data.message || 'An error occurred!');\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tthis._toastr.error('An unexpected error occurred!!');\r\n\t\t\t}\r\n });\r\n }\r\n checkTygaAccount() {\r\n this._fuseSplashScreenService.show();\r\n var req = {\r\n \"externalCustomerID\":this.CustomersService.customerDetails.externalCustomerID,\r\n \"companyId\":this.CustomersService.customerDetails.companyID\r\n }\r\n this.CustomersService.checkTygaAccount(req).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide(); \r\n if(res){\r\n this.isTgyaAccountExist = res;\r\n }else if(res == false){\r\n this.isTgyaAccountExist = res;\r\n }else{\r\n this._toastr.error(res, 'Error');\r\n }\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n openTygaModal(){\r\n var confirmDialogRef = this._matDialog.open(\r\n FuseConfirmDialogComponent,\r\n {\r\n disableClose: false,\r\n panelClass: \"confirm-dialog\",\r\n }\r\n );\r\n confirmDialogRef.componentInstance.confirmMessage =\r\n \"Are you sure you want to Unlink Tyga Account?\";\r\n confirmDialogRef.afterClosed().subscribe((result) => {\r\n if (result) {\r\n this._fuseSplashScreenService.show();\r\n const request = {\r\n externalCustomerId: this.CustomersService.customerDetails.externalCustomerID,\r\n companyID: this.CustomersService.selectedCompanyid\r\n }\r\n this.CustomersService.removeTygaAccount(request).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide();\r\n if (res && res.data == true) {\r\n this._toastr.success(\"Success\", \"Account successfully unlinked!\");\r\n this.checkTygaAccount();\r\n } else {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(res.message, 'Error');\r\n }\r\n\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n });\r\n }\r\n ExportCustomerAllPointTransactions() {\r\n this._fuseSplashScreenService.show();\r\n this.customerDetails = JSON.parse(localStorage.getItem('customer'));\r\n const request = {\r\n CustomerID: this.CustomersService.selectedCustomerid,\r\n PointAccountID: this.PointAccountIds.length > 0 ? this.selectedPointID : localStorage.getItem(\"pointAccountIDValue\"),\r\n CompanyID: this.CustomersService.selectedCompanyid,\r\n SortBy: \"lastupdated\",\r\n SortDirection: \"Desc\",\r\n StartDate: this.searchForm.get('searchByFromDate').value ? moment(this.searchForm.get('searchByFromDate').value).format('MM/DD/YYYY') : moment().format('MM/DD/YYYY'),\r\n EndDate: this.searchForm.get('searchByToDate').value ? moment(this.searchForm.get('searchByToDate').value).format('MM/DD/YYYY') : moment().format('MM/DD/YYYY')\r\n }\r\n this.CustomersService.ExportCustomerAllPointTransactions(request).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide();\r\n var blob = new Blob([res], { type: 'text/csv;charset=utf-8;' });\r\n this.CustomersService.SaveFile(blob, \"CustomerAllPointTransactions\");\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n}\r\n resendTrigger(){\r\n var confirmDialogRef = this._matDialog.open(\r\n ResendTriggerComponent,\r\n {\r\n width: '500px',\r\n disableClose: false,\r\n panelClass: \"confirm-dialog\",\r\n }\r\n );\r\n }\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { MatDividerModule } from '@angular/material/divider';\r\nimport { MatListModule } from '@angular/material/list';\r\nimport { MatSlideToggleModule } from '@angular/material/slide-toggle';\r\n\r\nimport { FuseSharedModule } from '@fuse/shared.module';\r\n\r\nimport { QuickPanelComponent } from 'app/layout/components/quick-panel/quick-panel.component';\r\nimport { CustomerBalanceAdjustmentComponent } from 'app/main/pages/customers/customer-balance-adjustment/customer-balance-adjustment.component';\r\nimport { ResendTriggerComponent } from './resend-trigger/resend-trigger.component';\r\nimport { TwoStepModalModule } from '../two-step-modal/two-step-modal.module';\r\n\r\n@NgModule({\r\n declarations: [\r\n QuickPanelComponent,\r\n ResendTriggerComponent\r\n ],\r\n imports : [\r\n MatDividerModule,\r\n MatListModule,\r\n MatSlideToggleModule,\r\n\r\n FuseSharedModule,\r\n TwoStepModalModule\r\n ],\r\n exports: [\r\n QuickPanelComponent\r\n ],\r\n entryComponents:[\r\n ResendTriggerComponent\r\n ]\r\n})\r\nexport class QuickPanelModule\r\n{\r\n}\r\n","export default \".w-full {\\n width: 100%;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9hcHAvbGF5b3V0L2NvbXBvbmVudHMvcXVpY2stcGFuZWwvcmVzZW5kLXRyaWdnZXIvQzpcXFByb2dyYW1EYXRhXFxKZW5raW5zXFwuamVua2luc1xcd29ya3NwYWNlXFxSUE1TXFxVSVxcTGl2ZSAoVUkgcnVubmluZyBvbiBQYXltZW50dXJlIEFXUylcXHBheW1lbnR1cmUuY29tL3NyY1xcYXBwXFxsYXlvdXRcXGNvbXBvbmVudHNcXHF1aWNrLXBhbmVsXFxyZXNlbmQtdHJpZ2dlclxccmVzZW5kLXRyaWdnZXIuY29tcG9uZW50LnNjc3MiLCJzcmMvYXBwL2xheW91dC9jb21wb25lbnRzL3F1aWNrLXBhbmVsL3Jlc2VuZC10cmlnZ2VyL3Jlc2VuZC10cmlnZ2VyLmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0ksV0FBQTtBQ0NKIiwiZmlsZSI6InNyYy9hcHAvbGF5b3V0L2NvbXBvbmVudHMvcXVpY2stcGFuZWwvcmVzZW5kLXRyaWdnZXIvcmVzZW5kLXRyaWdnZXIuY29tcG9uZW50LnNjc3MiLCJzb3VyY2VzQ29udGVudCI6WyIudy1mdWxse1xyXG4gICAgd2lkdGg6IDEwMCU7XHJcbn0iLCIudy1mdWxsIHtcbiAgd2lkdGg6IDEwMCU7XG59Il19 */\"","import { Component, OnInit, Inject, ViewEncapsulation, Input } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { fuseAnimations } from '@fuse/animations';\r\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { FuseSplashScreenService } from '@fuse/services/splash-screen.service';\r\nimport { CustomersService } from 'app/main/pages/customers/customers-service';\r\nimport { ToastrService } from 'ngx-toastr';\r\n\r\n\r\n@Component({\r\n selector: 'app-resend-trigger',\r\n templateUrl: './resend-trigger.component.html',\r\n styleUrls: ['./resend-trigger.component.scss'],\r\n encapsulation: ViewEncapsulation.None,\r\n animations: fuseAnimations\r\n})\r\nexport class ResendTriggerComponent implements OnInit {\r\n dialogTitle: string;\r\n triggers = [\r\n {id:\"CommissionPaid\", name:\"Last Commission Paid\"},\r\n {id:\"CardOrdered\", name:\"Last Card Ordered\"},\r\n {id:\"CardShipped\", name:\"Last Card Shipped\"},\r\n {id:\"ResetPassword\", name:\"Reset Password\"},\r\n {id:\"Enrollment\", name:\"eWallet Activation\"}\r\n ];\r\n selectedTrigger = \"CommissionPaid\";\r\n constructor(\r\n public matDialogRef: MatDialogRef,\r\n @Inject(MAT_DIALOG_DATA) public _data: any,\r\n private _fuseSplashScreenService: FuseSplashScreenService,\r\n public CustomersService: CustomersService,\r\n private _toastr: ToastrService\r\n ) {\r\n \r\n \r\n }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n triggerUnifyEvent() {\r\n this._fuseSplashScreenService.show();\r\n var req = {\r\n \"eventName\":this.selectedTrigger,\r\n \"externalCustomerID\":this.CustomersService.customerDetails.externalCustomerID,\r\n \"companyId\":this.CustomersService.customerDetails.companyID\r\n }\r\n this.CustomersService.TriggerUnifyEvent(req).subscribe((res: any) => {\r\n this._fuseSplashScreenService.hide(); \r\n if(res.data || res.data == true){\r\n this._toastr.success(\"Successfully Resend\", 'Success');\r\n this.matDialogRef.close()\r\n }else{\r\n this._toastr.error(res.message, 'Error');\r\n }\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n}","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\ntoolbar {\\n position: relative;\\n display: flex;\\n flex: 0 0 auto;\\n z-index: 4;\\n}\\ntoolbar.below {\\n z-index: 2;\\n}\\ntoolbar .mat-toolbar {\\n position: relative;\\n background: inherit !important;\\n color: inherit !important;\\n}\\ntoolbar .logo {\\n display: flex;\\n align-items: center;\\n}\\ntoolbar .logo .logo-icon {\\n width: 38px;\\n}\\ntoolbar .m-t-20 {\\n margin-top: 20px;\\n}\\ntoolbar .user-button,\\ntoolbar fuse-search-bar,\\ntoolbar .language-button,\\ntoolbar .chat-panel-toggle-button,\\ntoolbar .quick-panel-toggle-button {\\n min-width: 64px;\\n height: 64px;\\n}\\n@media screen and (max-width: 599px) {\\n toolbar .user-button,\\ntoolbar fuse-search-bar,\\ntoolbar .language-button,\\ntoolbar .chat-panel-toggle-button,\\ntoolbar .quick-panel-toggle-button {\\n height: 56px;\\n }\\n}\\ntoolbar .navbar-toggle-button {\\n min-width: 56px;\\n height: 56px;\\n}\\ntoolbar .toolbar-separator {\\n height: 64px;\\n width: 1px;\\n}\\n@media screen and (max-width: 599px) {\\n toolbar .toolbar-separator {\\n height: 56px;\\n }\\n}\\ntoolbar .mat-select-company.mat-form-field-should-float .mat-form-field-infix {\\n padding: 0.5em !important;\\n}\\ntoolbar .pointAcc {\\n width: 200px;\\n padding-top: 10px;\\n margin-right: 30px;\\n color: black;\\n}\\n@media screen and (max-width: 599px) {\\n toolbar .pointAcc {\\n width: 160px;\\n }\\n}\\ntoolbar .pointAcc2 {\\n color: black;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/layout/components/toolbar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/app/layout/components/toolbar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\app\\layout\\components\\toolbar\\toolbar.component.scss","src/app/layout/components/toolbar/toolbar.component.scss","src/app/layout/components/toolbar/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC95FA;EACI,kBAAA;EACA,aAAA;EACA,cAAA;EACA,UAAA;ACEJ;ADAI;EACI,UAAA;ACER;ADCI;EACI,kBAAA;EACA,8BAAA;EACA,yBAAA;ACCR;ADEI;EACI,aAAA;EACA,mBAAA;ACAR;ADEQ;EACI,WAAA;ACAZ;ADGI;EACI,gBAAA;ACDR;ADGI;;;;;EAKI,eAAA;EACA,YAAA;ACDR;ACDQ;EFJJ;;;;;IASQ,YAAA;ECIV;AACF;ADDI;EACI,eAAA;EACA,YAAA;ACGR;ADAI;EACI,YAAA;EACA,UAAA;ACER;AClBQ;EFcJ;IAKQ,YAAA;ECGV;AACF;ADAI;EACI,yBAAA;ACER;ADAI;EACI,YAAA;EACA,iBAAA;EACA,kBAAA;EACA,YAAA;ACER;AChCQ;EF0BJ;IAMQ,YAAA;ECIV;AACF;ADFI;EACI,YAAA;ACIR","file":"src/app/layout/components/toolbar/toolbar.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\n\r\ntoolbar {\r\n    position: relative;\r\n    display: flex;\r\n    flex: 0 0 auto;\r\n    z-index: 4;\r\n\r\n    &.below {\r\n        z-index: 2;\r\n    }\r\n\r\n    .mat-toolbar {\r\n        position: relative;\r\n        background: inherit !important;\r\n        color: inherit !important;\r\n    }\r\n\r\n    .logo {\r\n        display: flex;\r\n        align-items: center;\r\n\r\n        .logo-icon {\r\n            width: 38px;\r\n        }\r\n    }\r\n    .m-t-20{\r\n        margin-top: 20px;\r\n    }\r\n    .user-button,\r\n    fuse-search-bar,\r\n    .language-button,\r\n    .chat-panel-toggle-button,\r\n    .quick-panel-toggle-button {\r\n        min-width: 64px;\r\n        height: 64px;\r\n\r\n        @include media-breakpoint('xs') {\r\n            height: 56px;\r\n        }\r\n    }\r\n\r\n    .navbar-toggle-button {\r\n        min-width: 56px;\r\n        height: 56px;\r\n    }\r\n\r\n    .toolbar-separator {\r\n        height: 64px;\r\n        width: 1px;\r\n\r\n        @include media-breakpoint('xs') {\r\n            height: 56px;\r\n        }\r\n    }\r\n   \r\n    .mat-select-company.mat-form-field-should-float .mat-form-field-infix {\r\n        padding: 0.5em !important;\r\n    }\r\n    .pointAcc{\r\n        width: 200px;\r\n        padding-top: 10px;\r\n        margin-right:30px;\r\n        color: black; \r\n        @include media-breakpoint('xs') {\r\n            width: 160px;\r\n        }  \r\n    }\r\n    .pointAcc2{\r\n        color:black;\r\n    }\r\n  \r\n}\r\n","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\ntoolbar {\n  position: relative;\n  display: flex;\n  flex: 0 0 auto;\n  z-index: 4;\n}\ntoolbar.below {\n  z-index: 2;\n}\ntoolbar .mat-toolbar {\n  position: relative;\n  background: inherit !important;\n  color: inherit !important;\n}\ntoolbar .logo {\n  display: flex;\n  align-items: center;\n}\ntoolbar .logo .logo-icon {\n  width: 38px;\n}\ntoolbar .m-t-20 {\n  margin-top: 20px;\n}\ntoolbar .user-button,\ntoolbar fuse-search-bar,\ntoolbar .language-button,\ntoolbar .chat-panel-toggle-button,\ntoolbar .quick-panel-toggle-button {\n  min-width: 64px;\n  height: 64px;\n}\n@media screen and (max-width: 599px) {\n  toolbar .user-button,\ntoolbar fuse-search-bar,\ntoolbar .language-button,\ntoolbar .chat-panel-toggle-button,\ntoolbar .quick-panel-toggle-button {\n    height: 56px;\n  }\n}\ntoolbar .navbar-toggle-button {\n  min-width: 56px;\n  height: 56px;\n}\ntoolbar .toolbar-separator {\n  height: 64px;\n  width: 1px;\n}\n@media screen and (max-width: 599px) {\n  toolbar .toolbar-separator {\n    height: 56px;\n  }\n}\ntoolbar .mat-select-company.mat-form-field-should-float .mat-form-field-infix {\n  padding: 0.5em !important;\n}\ntoolbar .pointAcc {\n  width: 200px;\n  padding-top: 10px;\n  margin-right: 30px;\n  color: black;\n}\n@media screen and (max-width: 599px) {\n  toolbar .pointAcc {\n    width: 160px;\n  }\n}\ntoolbar .pointAcc2 {\n  color: black;\n}","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n"]} */\"","import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport * as _ from 'lodash';\r\nimport { objectToParams } from '../../../constants';\r\nimport { FuseConfigService } from '@fuse/services/config.service';\r\nimport { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service';\r\nimport { RestService } from 'app/shared/rest.service';\r\nimport { navigation } from 'app/navigation/navigation';\r\nimport { AuthService } from 'app/shared/auth.service';\r\nimport { CustomTranslateService } from 'app/shared/custom-translate.service';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { UserService } from '../../../shared/user.service';\r\nimport { Router } from '@angular/router';\r\nimport { FuseSplashScreenService } from '@fuse/services/splash-screen.service';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\nimport { CustomersService } from '../../../main/pages/customers/customers-service';\r\nimport { SharedService } from 'app/shared/share.service';\r\n@Component({\r\n selector: 'toolbar',\r\n templateUrl: './toolbar.component.html',\r\n styleUrls: ['./toolbar.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\n\r\nexport class ToolbarComponent implements OnInit, OnDestroy {\r\n horizontalNavbar: boolean;\r\n rightNavbar: boolean;\r\n isLogging: boolean;\r\n hiddenNavbar: boolean;\r\n languages: any;\r\n navigation: any;\r\n selectedLanguage: any;\r\n userStatusOptions: any[];\r\n userName: any;\r\n firstName: any;\r\n url;\r\n isLangMenu: boolean;\r\n companyList;\r\n userDetails: any;\r\n companyId;\r\n isImpersonate;\r\n PointAccounts;\r\n companyAccountid:any =\"\";\r\n searchPointAccountID:FormGroup;\r\n ReportType:any;\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {FuseConfigService} _fuseConfigService\r\n * @param {FuseSidebarService} _fuseSidebarService\r\n * @param {TranslateService} _translateService\r\n */\r\n constructor(\r\n public CustomersService: CustomersService,\r\n private _fuseConfigService: FuseConfigService,\r\n private _fuseSidebarService: FuseSidebarService,\r\n private _translateService: TranslateService,\r\n private _customTranslateService: CustomTranslateService,\r\n private _router: Router,\r\n private _authService: AuthService,\r\n private _restService: RestService,\r\n private _userService: UserService,\r\n private _toastr: ToastrService,\r\n private _fuseSplashScreenService: FuseSplashScreenService,\r\n private _formBuilder: FormBuilder,\r\n private sharedserive: SharedService,\r\n ) {\r\n // Set the defaults\r\n this.userStatusOptions = [\r\n {\r\n title: 'Online',\r\n icon: 'icon-checkbox-marked-circle',\r\n color: '#4CAF50'\r\n },\r\n {\r\n title: 'Away',\r\n icon: 'icon-clock',\r\n color: '#FFC107'\r\n },\r\n {\r\n title: 'Do not Disturb',\r\n icon: 'icon-minus-circle',\r\n color: '#F44336'\r\n },\r\n {\r\n title: 'Invisible',\r\n icon: 'icon-checkbox-blank-circle-outline',\r\n color: '#BDBDBD'\r\n },\r\n {\r\n title: 'Offline',\r\n icon: 'icon-checkbox-blank-circle-outline',\r\n color: '#616161'\r\n }\r\n ];\r\n\r\n\r\n // this.languages = [\r\n // {\r\n // id : 'en',\r\n // title: 'English',\r\n // flag : 'us'\r\n // },\r\n // {\r\n // id : 'tr',\r\n // title: 'Turkish',\r\n // flag : 'tr'\r\n // }\r\n // ];\r\n\r\n this.navigation = navigation;\r\n\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n\r\n this.searchPointAccountID = this._formBuilder.group({\r\n PointAccountIDValue:[],\r\n })\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void {\r\n this.ReportType = localStorage.getItem('ReportType');\r\n let customerData = JSON.parse(this._authService.getUserData());\r\n if(customerData && customerData.role !== 1){\r\n const request = '?companyId=' + customerData.companyId;\r\n this._fuseSplashScreenService.show();\r\n this.CustomersService.GetCompanyPointDetail(request).subscribe((res: any) => {\r\n if (res.data) {\r\n this._fuseSplashScreenService.hide();\r\n this.PointAccounts = res.data;\r\n if(this.PointAccounts.length>0){\r\n localStorage.setItem(\"pointAccountIDValue\", this.PointAccounts[0].id);\r\n \r\n }else{\r\n localStorage.setItem(\"pointAccountIDValue\", \"5ef71e903901f313a0d34971\");\r\n }\r\n if(this.companyAccountid ==\"\"){\r\n this.companyAccountid = localStorage.getItem(\"pointAccountIDValue\");\r\n this.searchPointAccountID.controls['PointAccountIDValue'].setValue(localStorage.getItem(\"pointAccountIDValue\"));\r\n }\r\n\r\n this.sharedserive.pointAccountIDChanged.emit(this.companyAccountid);\r\n } else {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error('Error');\r\n }\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n \r\n // Subscribe to the config changes\r\n if (localStorage.getItem('LoggedInUserData')) {\r\n this.userDetails = JSON.parse(localStorage.getItem('LoggedInUserData'));\r\n if (this.userDetails && this.userDetails.role == 1) {\r\n this.GetCompanyList();\r\n }\r\n }\r\n if (localStorage.getItem('isImpersonate')) {\r\n this.isImpersonate = localStorage.getItem('isImpersonate');\r\n }\r\n this._fuseConfigService.config\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((settings) => {\r\n this.horizontalNavbar = settings.layout.navbar.position === 'top';\r\n this.rightNavbar = settings.layout.navbar.position === 'right';\r\n this.hiddenNavbar = settings.layout.navbar.hidden === true;\r\n });\r\n\r\n //check User\r\n if (localStorage.getItem('LoggedInUserData') !== null) {\r\n this._userService.getActiveUser$().subscribe((data: any) => {\r\n if (data != null) {\r\n this.firstName = data.firstName;\r\n this.url = data.profileImage;\r\n this.userName = data.username;\r\n }\r\n });\r\n }\r\n\r\n //check Lang Menu\r\n this.isLangMenu = localStorage.getItem('LanguageMenuList') !== null;\r\n if (this.isLangMenu) {\r\n // Set the selected language from default languages \r\n this.languages = JSON.parse(localStorage.getItem(\"LanguageMenuList\"));\r\n var currentLang = this._translateService.currentLang;\r\n //var currentLang = localStorage.getItem(\"DefaultLanguageCountryCode\");\r\n var temp_obj = _.find(this.languages, function (t) { return t.Code == currentLang });\r\n if (temp_obj != undefined && temp_obj != null) {\r\n this.selectedLanguage = temp_obj;\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Public methods\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * Toggle sidebar open\r\n *\r\n * @param key\r\n */\r\n toggleSidebarOpen(key): void {\r\n this._fuseSidebarService.getSidebar(key).toggleOpen();\r\n }\r\n GetCompanyList() {\r\n this._restService.GetCompanyList().subscribe((res: any) => {\r\n if (res.data) {\r\n this.companyList = res.data;\r\n\r\n }\r\n })\r\n }\r\n backToAdmin() {\r\n this._authService.sendToken(JSON.parse(this._authService.getAdminToken()));\r\n this.userProfile(true, false);\r\n }\r\n backToCompany() {\r\n this._authService.sendToken(JSON.parse(this._authService.getCompanyToken()));\r\n this.userProfile(false, true);\r\n }\r\n userProfile(backToAdmin, backToCompany) {\r\n const self = this;\r\n self._restService.GetUserProfile().subscribe((res: any) => {\r\n this.isLogging = false;\r\n if (res.data.role != 4) {\r\n self._authService.sendUserData(JSON.stringify(res.data));\r\n //self._router.navigate(['pages/companies']);\r\n // self._router.navigate(['pages/dashboards/project']);\r\n self._toastr.success('Welcome' + \" \" + res.data.firstName + \" \" + '!');\r\n if (res.data.role == 1) {\r\n localStorage.removeItem(\"isImpersonate\");\r\n localStorage.removeItem(\"superAdmin\");\r\n }\r\n if (backToCompany) {\r\n let backToUrl: string = self._authService.getCompanyBackToUrl();\r\n localStorage.removeItem(\"LoggedInCompany\");\r\n localStorage.removeItem(\"CompanyBackToUrl\");\r\n // localStorage.removeItem(\"CompanyToken\");\r\n self._router.navigate([backToUrl]);\r\n }\r\n if (backToAdmin) {\r\n let backToUrl: string = self._authService.getAdminBackToUrl();\r\n localStorage.removeItem(\"LoggedInAdmin\");\r\n localStorage.removeItem(\"LoggedInCompany\");\r\n localStorage.removeItem(\"AdminBackToUrl\");\r\n localStorage.removeItem(\"CompanyBackToUrl\");\r\n localStorage.removeItem(\"CompanyToken\");\r\n self._router.navigate([backToUrl]);\r\n }\r\n setTimeout(() => {\r\n window.location.reload();\r\n });\r\n // window.location.reload();\r\n }\r\n else {\r\n self._toastr.error('This User is Restricted to login!!', 'Error');\r\n }\r\n // self._auth.sendDefaultCountryCode(\"1\");\r\n // self._customTranslateService.GetLanguageCodeCombination(\"1\",function(list: any){ \r\n\r\n // });\r\n },\r\n error => {\r\n this.isLogging = false;\r\n console.log(error);\r\n }\r\n )\r\n }\r\n Impersonate() {\r\n const self = this;\r\n if (this.userDetails.role == 1) {\r\n localStorage.setItem(\"superAdmin\", this.userDetails.id);\r\n }\r\n // if (localStorage.getItem(\"isImpersonate\")) {\r\n // // this.companyId = (localStorage.getItem(\"superAdmin\")).slice(1,-1);\r\n // this.companyId = localStorage.getItem(\"superAdmin\");\r\n // }\r\n var request = objectToParams({\r\n username: '',\r\n password: '',\r\n grant_type: (this.userDetails.role == 1) ? 'sso_token' : 'admin_token',\r\n client_id: this.companyId\r\n });\r\n this.isLogging = true;\r\n\r\n self._restService.Token(request).subscribe((result) => {\r\n if (result) {\r\n this._authService.sendToken(result);\r\n localStorage.setItem(\"isImpersonate\", \"1\");\r\n // this.userProfile();\r\n }\r\n }, function (error) {\r\n self.isLogging = false;\r\n self._toastr.error(error.error.error_description, 'Error');\r\n })\r\n }\r\n onSelectChangeCompany(event, value) {\r\n this.companyId = value.id;\r\n }\r\n /**\r\n * Search\r\n *\r\n * @param value\r\n */\r\n search(value): void {\r\n // Do your search here...\r\n console.log(value);\r\n }\r\n\r\n /**\r\n * Set the language\r\n *\r\n * @param lang\r\n */\r\n // setLanguage(lang): void {\r\n // // Set the selected language for the toolbar\r\n // this.selectedLanguage = lang;\r\n // // Use the selected language for translations\r\n // //this._translateService.use(lang.id);\r\n // this._customTranslateService.SetTranslation(lang.Code);\r\n // }\r\n\r\n onLogOut() {\r\n this._authService.logout();\r\n }\r\n\r\n getPointAccountID(){\r\n this.companyAccountid = this.searchPointAccountID.get(\"PointAccountIDValue\").value\r\n this.sharedserive.pointAccountIDChanged.emit(this.companyAccountid);\r\n localStorage.setItem(\"pointAccountIDValue\", this.companyAccountid);\r\n const currentUrl = this._router.url;\r\n this._router.navigateByUrl('/', {skipLocationChange: true}).then(() => {\r\n this._router.navigate([currentUrl]);\r\n });\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { RouterModule } from '@angular/router';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatMenuModule } from '@angular/material/menu';\r\nimport { MatToolbarModule } from '@angular/material/toolbar';\r\n\r\nimport { FuseSearchBarModule, FuseShortcutsModule } from '@fuse/components';\r\nimport { FuseSharedModule } from '@fuse/shared.module';\r\n\r\nimport { ToolbarComponent } from 'app/layout/components/toolbar/toolbar.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n ToolbarComponent\r\n ],\r\n imports : [\r\n RouterModule,\r\n MatButtonModule,\r\n MatIconModule,\r\n MatMenuModule,\r\n MatToolbarModule,\r\n\r\n FuseSharedModule,\r\n FuseSearchBarModule,\r\n FuseShortcutsModule\r\n ],\r\n exports : [\r\n ToolbarComponent\r\n ]\r\n})\r\nexport class ToolbarModule\r\n{\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\n.dialog-content-wrapper {\\n display: flex;\\n flex-direction: column;\\n position: relative;\\n padding-bottom: 3%;\\n}\\n.dialog-content-wrapper .mat-form-field {\\n margin: 5px;\\n width: 350px;\\n}\\n.p-24 {\\n display: flex;\\n justify-content: center;\\n padding-top: 10%;\\n}\\n@media screen and (max-width: 599px) {\\n .dialog-content-wrapper {\\n width: 100%;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/layout/components/two-step-modal/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/app/layout/components/two-step-modal/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\app\\layout\\components\\two-step-modal\\two-step-modal.component.scss","src/app/layout/components/two-step-modal/two-step-modal.component.scss","src/app/layout/components/two-step-modal/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC95FA;EACI,aAAA;EACA,sBAAA;EACA,kBAAA;EAOA,kBAAA;ACJJ;ADDI;EACI,WAAA;EACA,YAAA;ACGR;ADKA;EACI,aAAA;EACA,uBAAA;EACA,gBAAA;ACFJ;ACeQ;EFTJ;IACI,WAAA;ECFN;AACF","file":"src/app/layout/components/two-step-modal/two-step-modal.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\n\r\n.dialog-content-wrapper {\r\n    display: flex;\r\n    flex-direction: column;\r\n    position: relative;\r\n\r\n    .mat-form-field {\r\n        margin: 5px;\r\n        width: 350px;\r\n    }\r\n\r\n    padding-bottom: 3%;\r\n\r\n\r\n}\r\n\r\n.p-24 {\r\n    display: flex;\r\n    justify-content: center;\r\n    padding-top: 10%;\r\n}\r\n\r\n@include media-breakpoint(\"xs\") {\r\n    .dialog-content-wrapper {\r\n        width: 100%;\r\n    }\r\n}","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\n.dialog-content-wrapper {\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  padding-bottom: 3%;\n}\n.dialog-content-wrapper .mat-form-field {\n  margin: 5px;\n  width: 350px;\n}\n\n.p-24 {\n  display: flex;\n  justify-content: center;\n  padding-top: 10%;\n}\n\n@media screen and (max-width: 599px) {\n  .dialog-content-wrapper {\n    width: 100%;\n  }\n}","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n"]} */\"","import { Component, Inject, OnInit } from '@angular/core';\r\nimport { FormBuilder, FormControl, FormGroup, Validators } from '@angular/forms';\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { FuseSplashScreenService } from '@fuse/services/splash-screen.service';\r\nimport { objectToParams } from 'app/constants';\r\nimport { AuthService } from 'app/shared/auth.service';\r\nimport { RestService } from 'app/shared/rest.service';\r\nimport { ToastrService } from 'ngx-toastr';\r\n\r\n@Component({\r\n selector: 'app-two-step-modal',\r\n templateUrl: './two-step-modal.component.html',\r\n styleUrls: ['./two-step-modal.component.scss']\r\n})\r\nexport class TwoStepModalComponent implements OnInit {\r\n twoStepVerification: FormGroup;\r\n dialogTitle: string = \"Two Step Verification\";\r\n IsDialogMax: boolean = false;\r\n hostHeight: any;\r\n hostWidth: any;\r\n otp: FormControl = new FormControl('', [Validators.required]);\r\n\r\n constructor(\r\n public matDialogRef: MatDialogRef,\r\n @Inject(MAT_DIALOG_DATA) private _data: any,\r\n private _formBuilder: FormBuilder,\r\n public _matDialog: MatDialog,\r\n private _fuseSplashScreenService: FuseSplashScreenService,\r\n private _restService: RestService,\r\n private _auth: AuthService,\r\n private _toastr: ToastrService,\r\n ) {}\r\n\r\n ngOnInit() {\r\n this.twoStepVerification = this._formBuilder.group({\r\n otp: [''],\r\n });\r\n\r\n\r\n }\r\n\r\n verifyCode() {\r\n if (this.matDialogRef && this.otp.valid) {\r\n var res = {\r\n event: this._data.event,\r\n code: this.otp.value\r\n }\r\n this.matDialogRef.close(res);\r\n }else{\r\n this._toastr.error(\"Please enter verification code\");\r\n }\r\n }\r\n resendOTP() {\r\n if (this.matDialogRef && this.otp.valid) {\r\n var res = {\r\n event: this._data.event,\r\n code: \"\"\r\n }\r\n this.matDialogRef.close(res);\r\n }\r\n }\r\n\r\n minimizeDialog() {\r\n let elements: any = document.getElementsByClassName(\"twostepdialog\");\r\n for (var i = 0; i < elements.length; i++) {\r\n elements[i].style.width = (this.hostWidth + 1 + 'px');\r\n elements[i].style.height = (this.hostHeight + 1 + 'px');\r\n }\r\n document.getElementById(\"two-way-content\").style.maxHeight = \"65vh\";\r\n document.getElementById(\"two-way-wrapper\").style.maxHeight = \"85vh\";\r\n this.IsDialogMax = !this.IsDialogMax;\r\n }\r\n maximizeDialog() {\r\n let elements: any = document.getElementsByClassName(\"twostepdialog\");\r\n for (var i = 0; i < elements.length; i++) {\r\n this.hostHeight = elements[i].clientHeight;\r\n this.hostWidth = elements[i].clientWidth;\r\n elements[i].style.width = (\"100%\");\r\n elements[i].style.height = (\"100%\");\r\n }\r\n document.getElementById(\"two-way-content\").style.maxHeight = \"100vh\";\r\n document.getElementById(\"two-way-wrapper\").style.maxHeight = \"100vh\";\r\n this.IsDialogMax = !this.IsDialogMax;\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { RouterModule } from '@angular/router';\r\nimport { FuseSharedModule } from '@fuse/shared.module';\r\nimport { TwoStepModalComponent } from './two-step-modal.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n TwoStepModalComponent\r\n ],\r\n imports: [\r\n RouterModule,\r\n FuseSharedModule\r\n ],\r\n exports: [\r\n TwoStepModalComponent\r\n ],\r\n entryComponents:[\r\n TwoStepModalComponent\r\n ]\r\n})\r\nexport class TwoStepModalModule {\r\n}\r\n","import { NgModule } from '@angular/core';\r\n\r\nimport { VerticalLayout1Module } from 'app/layout/vertical/layout-1/layout-1.module';\r\n\r\n@NgModule({\r\n imports: [\r\n VerticalLayout1Module,\r\n ],\r\n exports: [\r\n VerticalLayout1Module,\r\n ]\r\n})\r\nexport class LayoutModule\r\n{\r\n}\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\nvertical-layout-1 {\\n display: flex;\\n flex: 1 1 auto;\\n width: 100%;\\n height: 100%;\\n}\\nvertical-layout-1 .quick-panel {\\n width: 78%;\\n min-width: 78%;\\n max-width: 78%;\\n}\\nvertical-layout-1 quick-panel {\\n width: 100%;\\n min-width: 100%;\\n max-width: 100%;\\n}\\nvertical-layout-1 #main {\\n position: relative;\\n display: flex;\\n flex: 1 1 auto;\\n flex-direction: column;\\n width: 100%;\\n height: 100%;\\n z-index: 1;\\n min-width: 0;\\n}\\nvertical-layout-1 #main > .container {\\n position: relative;\\n display: flex;\\n flex: 1 1 0%;\\n width: 100%;\\n min-height: 0;\\n min-width: 0;\\n}\\nvertical-layout-1 #main > .container > .container {\\n position: relative;\\n display: flex;\\n flex: 1 1 0%;\\n flex-direction: column;\\n min-width: 0;\\n}\\nvertical-layout-1 #main > .container > .container > .container {\\n position: relative;\\n display: flex;\\n flex: 1 1 0%;\\n flex-direction: column;\\n overflow-x: hidden;\\n overflow-y: auto;\\n -webkit-overflow-scrolling: touch;\\n}\\nvertical-layout-1 #main > .container > .container > .container content.inner-scroll {\\n flex: 1 1 0%;\\n min-height: 0;\\n}\\nvertical-layout-1 #main > .container > .container > .container content.inner-scroll > *:not(router-outlet) {\\n flex: 1 1 0%;\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/layout/vertical/layout-1/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/app/layout/vertical/layout-1/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\app\\layout\\vertical\\layout-1\\layout-1.component.scss","src/app/layout/vertical/layout-1/layout-1.component.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC95FA;EACI,aAAA;EACA,cAAA;EACA,WAAA;EACA,YAAA;ACEJ;ADDI;EACI,UAAA;EACA,cAAA;EACA,cAAA;ACGR;ADDI;EACI,WAAA;EACA,eAAA;EACA,eAAA;ACGR;ADDI;EACI,kBAAA;EACA,aAAA;EACA,cAAA;EACA,sBAAA;EACA,WAAA;EACA,YAAA;EACA,UAAA;EACA,YAAA;ACGR;ADAQ;EACI,kBAAA;EACA,aAAA;EACA,YAAA;EACA,WAAA;EACA,aAAA;EACA,YAAA;ACEZ;ADCY;EACI,kBAAA;EACA,aAAA;EACA,YAAA;EACA,sBAAA;EACA,YAAA;ACChB;ADEgB;EACI,kBAAA;EACA,aAAA;EACA,YAAA;EACA,sBAAA;EACA,kBAAA;EACA,gBAAA;EACA,iCAAA;ACApB;ADKwB;EACI,YAAA;EACA,aAAA;ACH5B;ADK4B;EACI,YAAA;ACHhC","file":"src/app/layout/vertical/layout-1/layout-1.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","@import \"src/@fuse/scss/fuse\";\r\n\r\nvertical-layout-1 {\r\n    display: flex;\r\n    flex: 1 1 auto;\r\n    width: 100%;\r\n    height: 100%;\r\n    .quick-panel{\r\n        width: 78%;\r\n        min-width:78%;\r\n        max-width: 78%;\r\n    }\r\n    quick-panel{\r\n        width: 100%;\r\n        min-width:100%;\r\n        max-width: 100%;\r\n    }\r\n    #main {\r\n        position: relative;\r\n        display: flex;\r\n        flex: 1 1 auto;\r\n        flex-direction: column;\r\n        width: 100%;\r\n        height: 100%;\r\n        z-index: 1;\r\n        min-width: 0;\r\n\r\n        // Container 1\r\n        > .container {\r\n            position: relative;\r\n            display: flex;\r\n            flex: 1 1 0%;\r\n            width: 100%;\r\n            min-height: 0;\r\n            min-width: 0;\r\n\r\n            // Container 2\r\n            > .container {\r\n                position: relative;\r\n                display: flex;\r\n                flex: 1 1 0%;\r\n                flex-direction: column;\r\n                min-width: 0;\r\n\r\n                // Container 3 (Scrollable)\r\n                > .container {\r\n                    position: relative;\r\n                    display: flex;\r\n                    flex: 1 1 0%;\r\n                    flex-direction: column;\r\n                    overflow-x: hidden;\r\n                    overflow-y: auto;\r\n                    -webkit-overflow-scrolling: touch;\r\n\r\n                    // Content component\r\n                    content {\r\n\r\n                        &.inner-scroll {\r\n                            flex: 1 1 0%;\r\n                            min-height: 0;\r\n\r\n                            > *:not(router-outlet) {\r\n                                flex: 1 1 0%;\r\n                            }\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n    }\r\n}","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\nvertical-layout-1 {\n  display: flex;\n  flex: 1 1 auto;\n  width: 100%;\n  height: 100%;\n}\nvertical-layout-1 .quick-panel {\n  width: 78%;\n  min-width: 78%;\n  max-width: 78%;\n}\nvertical-layout-1 quick-panel {\n  width: 100%;\n  min-width: 100%;\n  max-width: 100%;\n}\nvertical-layout-1 #main {\n  position: relative;\n  display: flex;\n  flex: 1 1 auto;\n  flex-direction: column;\n  width: 100%;\n  height: 100%;\n  z-index: 1;\n  min-width: 0;\n}\nvertical-layout-1 #main > .container {\n  position: relative;\n  display: flex;\n  flex: 1 1 0%;\n  width: 100%;\n  min-height: 0;\n  min-width: 0;\n}\nvertical-layout-1 #main > .container > .container {\n  position: relative;\n  display: flex;\n  flex: 1 1 0%;\n  flex-direction: column;\n  min-width: 0;\n}\nvertical-layout-1 #main > .container > .container > .container {\n  position: relative;\n  display: flex;\n  flex: 1 1 0%;\n  flex-direction: column;\n  overflow-x: hidden;\n  overflow-y: auto;\n  -webkit-overflow-scrolling: touch;\n}\nvertical-layout-1 #main > .container > .container > .container content.inner-scroll {\n  flex: 1 1 0%;\n  min-height: 0;\n}\nvertical-layout-1 #main > .container > .container > .container content.inner-scroll > *:not(router-outlet) {\n  flex: 1 1 0%;\n}"]} */\"","import { Component, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { FuseConfigService } from '@fuse/services/config.service';\r\nimport { navigation } from 'app/navigation/navigation';\r\n\r\n@Component({\r\n selector : 'vertical-layout-1',\r\n templateUrl : './layout-1.component.html',\r\n styleUrls : ['./layout-1.component.scss'],\r\n encapsulation: ViewEncapsulation.None\r\n})\r\nexport class VerticalLayout1Component implements OnInit, OnDestroy\r\n{\r\n fuseConfig: any;\r\n navigation: any;\r\n\r\n // Private\r\n private _unsubscribeAll: Subject;\r\n\r\n /**\r\n * Constructor\r\n *\r\n * @param {FuseConfigService} _fuseConfigService\r\n */\r\n constructor(\r\n private _fuseConfigService: FuseConfigService\r\n )\r\n {\r\n // Set the defaults\r\n this.navigation = navigation;\r\n\r\n // Set the private defaults\r\n this._unsubscribeAll = new Subject();\r\n }\r\n\r\n // -----------------------------------------------------------------------------------------------------\r\n // @ Lifecycle hooks\r\n // -----------------------------------------------------------------------------------------------------\r\n\r\n /**\r\n * On init\r\n */\r\n ngOnInit(): void\r\n {\r\n // Subscribe to config changes\r\n this._fuseConfigService.config\r\n .pipe(takeUntil(this._unsubscribeAll))\r\n .subscribe((config) => {\r\n this.fuseConfig = config;\r\n });\r\n }\r\n\r\n /**\r\n * On destroy\r\n */\r\n ngOnDestroy(): void\r\n {\r\n // Unsubscribe from all subscriptions\r\n this._unsubscribeAll.next();\r\n this._unsubscribeAll.complete();\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { FuseSidebarModule } from '@fuse/components';\r\nimport { FuseSharedModule } from '@fuse/shared.module';\r\n\r\nimport { ContentModule } from 'app/layout/components/content/content.module';\r\nimport { NavbarModule } from 'app/layout/components/navbar/navbar.module';\r\nimport { QuickPanelModule } from 'app/layout/components/quick-panel/quick-panel.module';\r\nimport { ToolbarModule } from 'app/layout/components/toolbar/toolbar.module';\r\n\r\nimport { VerticalLayout1Component } from 'app/layout/vertical/layout-1/layout-1.component';\r\n\r\n@NgModule({\r\n declarations: [\r\n VerticalLayout1Component\r\n ],\r\n imports : [\r\n RouterModule,\r\n\r\n FuseSharedModule,\r\n FuseSidebarModule,\r\n QuickPanelModule,\r\n ContentModule,\r\n NavbarModule,\r\n ToolbarModule\r\n ],\r\n exports : [\r\n VerticalLayout1Component\r\n ]\r\n})\r\nexport class VerticalLayout1Module\r\n{\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport {RestService} from '../../../shared/rest.service';\r\n\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class PointAccountsService {\r\n \r\n constructor( private _restService:RestService\r\n ) { }\r\n\r\n SaveCompanyPointAccount(request: any) {\r\n var _url = \"/CompanyPointAccount/SaveCompanyPointAccount\";\r\n return this._restService.Post(_url, request);\r\n }\r\n\r\n DeleteCompanyPointAccount(deleteRequest: any) {\r\n var _url = \"/api/CompanyPointAccount/DeleteCompanyPointAccount\" + deleteRequest;\r\n return this._restService.Delete(_url);\r\n \r\n }\r\n\r\n UpdateCompanyPointAccount(updateRequest: any){\r\n var _url = \"/CompanyPointAccount/UpdateCompanyPointAccount\";\r\n return this._restService.Post(_url, updateRequest);\r\n }\r\n \r\n GetCompanyPointDetail(request: any) {\r\n var _url = '/CompanyPointAccount/GetCompanyPointAccounts' + request;\r\n return this._restService.Get(_url);\r\n }\r\n GetCurrencycode() {\r\n var _url = '/v1/Currencies';\r\n return this._restService.Get(_url);\r\n }\r\n GetPointAccountType() {\r\n var _url = '/PointAccountType/GetPointAccountType';\r\n return this._restService.Get(_url);\r\n }\r\n}\r\n","export default \".company-form-dialog {\\n width: 500px;\\n}\\n.company-form-dialog mat-dialog-container {\\n padding: 0px !important;\\n}\\n.adjust-balance .mat-dialog-container {\\n padding: 0px;\\n}\\nbody.theme-default .mat-button[disabled] {\\n background: transparent !important;\\n color: rgba(0, 0, 0, 0.26) !important;\\n}\\n.save-button {\\n background: var(--primary-color) !important;\\n color: white !important;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9hcHAvbWFpbi9wYWdlcy9jdXN0b21lcnMvY3VzdG9tZXItYmFsYW5jZS1hZGp1c3RtZW50L0M6XFxQcm9ncmFtRGF0YVxcSmVua2luc1xcLmplbmtpbnNcXHdvcmtzcGFjZVxcUlBNU1xcVUlcXExpdmUgKFVJIHJ1bm5pbmcgb24gUGF5bWVudHVyZSBBV1MpXFxwYXltZW50dXJlLmNvbS9zcmNcXGFwcFxcbWFpblxccGFnZXNcXGN1c3RvbWVyc1xcY3VzdG9tZXItYmFsYW5jZS1hZGp1c3RtZW50XFxjdXN0b21lci1iYWxhbmNlLWFkanVzdG1lbnQuY29tcG9uZW50LnNjc3MiLCJzcmMvYXBwL21haW4vcGFnZXMvY3VzdG9tZXJzL2N1c3RvbWVyLWJhbGFuY2UtYWRqdXN0bWVudC9jdXN0b21lci1iYWxhbmNlLWFkanVzdG1lbnQuY29tcG9uZW50LnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7RUFDSSxZQUFBO0FDQ0o7QURBSTtFQUNJLHVCQUFBO0FDRVI7QURHQTtFQUNJLFlBQUE7QUNBSjtBRElFO0VBQ0Usa0NBQUE7RUFDQSxxQ0FBQTtBQ0RKO0FER0U7RUFDRSwyQ0FBQTtFQUVELHVCQUFBO0FDREgiLCJmaWxlIjoic3JjL2FwcC9tYWluL3BhZ2VzL2N1c3RvbWVycy9jdXN0b21lci1iYWxhbmNlLWFkanVzdG1lbnQvY3VzdG9tZXItYmFsYW5jZS1hZGp1c3RtZW50LmNvbXBvbmVudC5zY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLmNvbXBhbnktZm9ybS1kaWFsb2cge1xyXG4gICAgd2lkdGg6IDUwMHB4O1xyXG4gICAgbWF0LWRpYWxvZy1jb250YWluZXIge1xyXG4gICAgICAgIHBhZGRpbmc6IDBweCAhaW1wb3J0YW50O1xyXG4gICAgfVxyXG4gICAgXHJcbiAgfVxyXG5cclxuLmFkanVzdC1iYWxhbmNlIC5tYXQtZGlhbG9nLWNvbnRhaW5lciB7XHJcbiAgICBwYWRkaW5nOiAwcHg7XHJcbn1cclxuXHJcblxyXG4gIGJvZHkudGhlbWUtZGVmYXVsdCAubWF0LWJ1dHRvbltkaXNhYmxlZF0ge1xyXG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQgIWltcG9ydGFudDtcclxuICAgIGNvbG9yOiByZ2JhKDAsIDAsIDAsIDAuMjYpICFpbXBvcnRhbnQ7XHJcbiAgfVxyXG4gIC5zYXZlLWJ1dHRvbiB7XHJcbiAgICBiYWNrZ3JvdW5kOiB2YXIoLS1wcmltYXJ5LWNvbG9yKSAhaW1wb3J0YW50O1xyXG4gICAgLy8gYmFja2dyb3VuZDogIzAzOWJlNSAhaW1wb3J0YW50O1xyXG4gICBjb2xvcjogd2hpdGUgIWltcG9ydGFudDtcclxuICAgfSIsIi5jb21wYW55LWZvcm0tZGlhbG9nIHtcbiAgd2lkdGg6IDUwMHB4O1xufVxuLmNvbXBhbnktZm9ybS1kaWFsb2cgbWF0LWRpYWxvZy1jb250YWluZXIge1xuICBwYWRkaW5nOiAwcHggIWltcG9ydGFudDtcbn1cblxuLmFkanVzdC1iYWxhbmNlIC5tYXQtZGlhbG9nLWNvbnRhaW5lciB7XG4gIHBhZGRpbmc6IDBweDtcbn1cblxuYm9keS50aGVtZS1kZWZhdWx0IC5tYXQtYnV0dG9uW2Rpc2FibGVkXSB7XG4gIGJhY2tncm91bmQ6IHRyYW5zcGFyZW50ICFpbXBvcnRhbnQ7XG4gIGNvbG9yOiByZ2JhKDAsIDAsIDAsIDAuMjYpICFpbXBvcnRhbnQ7XG59XG5cbi5zYXZlLWJ1dHRvbiB7XG4gIGJhY2tncm91bmQ6IHZhcigtLXByaW1hcnktY29sb3IpICFpbXBvcnRhbnQ7XG4gIGNvbG9yOiB3aGl0ZSAhaW1wb3J0YW50O1xufSJdfQ== */\"","import { Component, OnInit, Inject, ViewEncapsulation } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { fuseAnimations } from '@fuse/animations';\r\nimport { FormBuilder, ValidatorFn, FormGroup, Validators, FormControl } from '@angular/forms';\r\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { Subject } from 'rxjs';\r\nimport { FuseSplashScreenService } from '../../../../../@fuse/services/splash-screen.service';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { PageService } from '../../page.service';\r\nimport { CustomersService } from '../customers-service';\r\nimport { PointAccountsService } from '../../company-point-accounts/point-accounts.service';\r\nimport { TwoStepModalComponent } from 'app/layout/components/two-step-modal/two-step-modal.component';\r\nimport { FuseSidebarService } from '@fuse/components/sidebar/sidebar.service';\r\nimport { Router } from '@angular/router';\r\nconst trimValidator: ValidatorFn = (control: FormControl) => {\r\n if(control.value){\r\n if (control.value.startsWith(' ')) {\r\n return {\r\n 'trimError': { value: 'This field is required' }\r\n };\r\n }\r\n }\r\n}\r\n\r\n@Component({\r\n selector: 'app-customer-balance-adjustment',\r\n templateUrl: './customer-balance-adjustment.component.html',\r\n styleUrls: ['./customer-balance-adjustment.component.scss'],\r\n encapsulation: ViewEncapsulation.None,\r\n animations: fuseAnimations\r\n})\r\nexport class CustomerBalanceAdjustmentComponent implements OnInit {\r\n pointAccountForm: FormGroup;\r\n dialogTitle: string;\r\n action: string;\r\n userDetails: any;\r\n currencyCode;\r\n currencyList;\r\n pointAccountType;\r\n pointAccountTypeList;\r\n transactionTypeList;\r\n transactionType;\r\n Isdisabled: boolean = true\r\n refNumber = \"\";\r\n constructor(\r\n public matDialogRef: MatDialogRef,\r\n @Inject(MAT_DIALOG_DATA) private _data: any,\r\n private _formBuilder: FormBuilder,\r\n private _fuseSplashScreenService: FuseSplashScreenService,\r\n private _toastr: ToastrService,\r\n private _pageService: PageService,\r\n private _CustomersService: CustomersService,\r\n private _PointAccountsService: PointAccountsService,\r\n private _matDialog: MatDialog,\r\n private _fuseSidebarService: FuseSidebarService,\r\n private _router: Router,\r\n ) { // Set the defaults\r\n this.action = _data.action;\r\n \r\n // Set the private defaults\r\n \r\n this.dialogTitle = 'Adjust Point Balance';\r\n\r\n this.pointAccountForm = this._formBuilder.group({\r\n // pointAccountType: ['',[Validators.required, trimValidator]],\r\n transactionType: ['',[Validators.required]],\r\n amount: ['',[Validators.required, Validators.pattern(\"^[0-9]+(.[0-9]{0,2})?$\")]],\r\n reason: ['',[Validators.required, trimValidator]]\r\n });\r\n this.transactionTypeList = [{ transactionTypeName: 'Credit', id: 0 }, { transactionTypeName: 'Debit', id: 1 }];\r\n }\r\n\r\n ngOnInit() {\r\n if (localStorage.getItem('LoggedInUserData')) {\r\n this.userDetails = JSON.parse(localStorage.getItem('LoggedInUserData'));\r\n }\r\n this.getPointAccounts();\r\n \r\n }\r\n onSelectCurrency(event, value) {\r\n this.currencyCode = value.id;\r\n }\r\n onSelectPointAccountType(event, value) {\r\n this.pointAccountType = value.id;\r\n }\r\n onSelectTansactionType(event, value) {\r\n this.transactionType = value.id;\r\n }\r\n\r\n//GetPointAccountType(){\r\n// this._CustomersService.GetPointAccountType().subscribe((res: any) => {\r\n// if (res.status == \"Success\") {\r\n// this.pointAccountTypeList = res.data;\r\n// console.log(this.pointAccountTypeList);\r\n// } else {\r\n// this._fuseSplashScreenService.hide();\r\n// this._toastr.error(res.errorDescription, 'Error');\r\n// }\r\n// });\r\n// }\r\n \r\n getPointAccounts() {\r\n const request = '?companyId=' + (this._data.data.companyID || this.userDetails.companyId);\r\n this._fuseSplashScreenService.show();\r\n this._PointAccountsService.GetCompanyPointDetail(request).subscribe((res: any) => {\r\n\r\n if (res.data) {\r\n this._fuseSplashScreenService.hide();\r\n this.pointAccountTypeList = res.data;\r\n if(this.pointAccountTypeList && this.pointAccountTypeList.length > 1){\r\n this.pointAccountForm.addControl('pointAccountIDValue', new FormControl('', Validators.required));\r\n }\r\n } else {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error('Error');\r\n }\r\n }, error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n }\r\n \r\n AdjustCustomerBalance(code) { \r\n this.Isdisabled = false\r\n var form = this.pointAccountForm.getRawValue();\r\n if(!this.pointAccountForm.valid){\r\n this._toastr.error(\"Please add Balance Info\", 'Error');\r\n return\r\n }\r\n const request = {\r\n \"CompanyID\": this._data.data.companyID ||this.userDetails.companyId,\r\n \"CustomerID\": this._data.data.id,\r\n \"PointAccountID\": (this.pointAccountTypeList && this.pointAccountTypeList.length > 1) ? this.pointAccountForm.get('pointAccountIDValue').value : this.pointAccountTypeList.length > 0 ? this.pointAccountTypeList[0].id : localStorage.getItem(\"pointAccountIDValue\"),\r\n \"TransactionType\": this.pointAccountForm.get('transactionType').value,\r\n \"RedeemType\": 5,\r\n \"Amount\": this.pointAccountForm.get('amount').value,\r\n \"Reason\": this.pointAccountForm.get('reason').value\r\n };\r\n var headers = {\r\n 'refNumber': this.refNumber,\r\n 'code': code\r\n }\r\n this._CustomersService.AdjustCustomerBalance(request,headers).subscribe((res: any) => {\r\n if (res.status == \"Success\") {\r\n this.currencyList = res.data;\r\n this.matDialogRef.close(res.status);\r\n this._toastr.success('Amount adjusted successfully !');\r\n } else {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(res.message, 'Error');\r\n }\r\n this.Isdisabled = true\r\n },error =>{\r\n this._fuseSplashScreenService.hide(); \r\n if (error) {\r\n const data = error.error;\r\n if (data.message === '2FA required please enter code.') {\r\n if (this.userDetails.twoWayAuth) {\r\n this.refNumber = data.data;\r\n this._toastr.error(data.message || 'An error occurred!');\r\n var dialogRef = this._matDialog.open(TwoStepModalComponent, {\r\n panelClass: 'twostepdialog',\r\n data: {\r\n event: \"adjustCustomerBalance\"\r\n }\r\n });\r\n dialogRef.afterClosed().subscribe((res) => {\r\n this._fuseSplashScreenService.hide();\r\n console.log('res', res);\r\n\r\n if (res && res.event == 'adjustCustomerBalance') {\r\n if (res.code) {\r\n this.AdjustCustomerBalance(res.code);\r\n } else {\r\n this.AdjustCustomerBalance(\"\");\r\n }\r\n }\r\n });\r\n } else {\r\n // for showing two 2fa enable model\r\n setTimeout(() => {\r\n this.matDialogRef.close(\"\");\r\n }, 500);\r\n this._fuseSidebarService.getSidebar('quickPanel').close();\r\n this._router.navigate(['/pages/profile']);\r\n this._toastr.error('Please enable 2 Step Verification!');\r\n }\r\n } else {\r\n this._toastr.error(data.message || 'An error occurred!');\r\n }\r\n } else {\r\n this._toastr.error('An unexpected error occurred');\r\n }\r\n });\r\n }\r\n}\r\n","export default \".company-form-dialog {\\n width: 500px;\\n}\\n.company-form-dialog mat-dialog-container {\\n padding: 0px !important;\\n}\\n.adjust-balance .mat-dialog-container {\\n padding: 0px;\\n}\\nbody.theme-default .mat-button[disabled] {\\n background: transparent !important;\\n color: rgba(0, 0, 0, 0.26) !important;\\n}\\n.save-button {\\n background: var(--primary-color) !important;\\n color: white !important;\\n}\\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9hcHAvbWFpbi9wYWdlcy9jdXN0b21lcnMvY3VzdG9tZXItbWF4bGltaXQvQzpcXFByb2dyYW1EYXRhXFxKZW5raW5zXFwuamVua2luc1xcd29ya3NwYWNlXFxSUE1TXFxVSVxcTGl2ZSAoVUkgcnVubmluZyBvbiBQYXltZW50dXJlIEFXUylcXHBheW1lbnR1cmUuY29tL3NyY1xcYXBwXFxtYWluXFxwYWdlc1xcY3VzdG9tZXJzXFxjdXN0b21lci1tYXhsaW1pdFxcY3VzdG9tZXItbWF4bGltaXQuY29tcG9uZW50LnNjc3MiLCJzcmMvYXBwL21haW4vcGFnZXMvY3VzdG9tZXJzL2N1c3RvbWVyLW1heGxpbWl0L2N1c3RvbWVyLW1heGxpbWl0LmNvbXBvbmVudC5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0ksWUFBQTtBQ0NKO0FEQUk7RUFDSSx1QkFBQTtBQ0VSO0FER0E7RUFDSSxZQUFBO0FDQUo7QURJRTtFQUNFLGtDQUFBO0VBQ0EscUNBQUE7QUNESjtBREdFO0VBQ0UsMkNBQUE7RUFFRCx1QkFBQTtBQ0RIIiwiZmlsZSI6InNyYy9hcHAvbWFpbi9wYWdlcy9jdXN0b21lcnMvY3VzdG9tZXItbWF4bGltaXQvY3VzdG9tZXItbWF4bGltaXQuY29tcG9uZW50LnNjc3MiLCJzb3VyY2VzQ29udGVudCI6WyIuY29tcGFueS1mb3JtLWRpYWxvZyB7XHJcbiAgICB3aWR0aDogNTAwcHg7XHJcbiAgICBtYXQtZGlhbG9nLWNvbnRhaW5lciB7XHJcbiAgICAgICAgcGFkZGluZzogMHB4ICFpbXBvcnRhbnQ7XHJcbiAgICB9XHJcbiAgICBcclxuICB9XHJcblxyXG4uYWRqdXN0LWJhbGFuY2UgLm1hdC1kaWFsb2ctY29udGFpbmVyIHtcclxuICAgIHBhZGRpbmc6IDBweDtcclxufVxyXG5cclxuXHJcbiAgYm9keS50aGVtZS1kZWZhdWx0IC5tYXQtYnV0dG9uW2Rpc2FibGVkXSB7XHJcbiAgICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudCAhaW1wb3J0YW50O1xyXG4gICAgY29sb3I6IHJnYmEoMCwgMCwgMCwgMC4yNikgIWltcG9ydGFudDtcclxuICB9XHJcbiAgLnNhdmUtYnV0dG9uIHtcclxuICAgIGJhY2tncm91bmQ6IHZhcigtLXByaW1hcnktY29sb3IpICFpbXBvcnRhbnQ7XHJcbiAgICAvLyBiYWNrZ3JvdW5kOiAjMDM5YmU1ICFpbXBvcnRhbnQ7XHJcbiAgIGNvbG9yOiB3aGl0ZSAhaW1wb3J0YW50O1xyXG4gICB9IiwiLmNvbXBhbnktZm9ybS1kaWFsb2cge1xuICB3aWR0aDogNTAwcHg7XG59XG4uY29tcGFueS1mb3JtLWRpYWxvZyBtYXQtZGlhbG9nLWNvbnRhaW5lciB7XG4gIHBhZGRpbmc6IDBweCAhaW1wb3J0YW50O1xufVxuXG4uYWRqdXN0LWJhbGFuY2UgLm1hdC1kaWFsb2ctY29udGFpbmVyIHtcbiAgcGFkZGluZzogMHB4O1xufVxuXG5ib2R5LnRoZW1lLWRlZmF1bHQgLm1hdC1idXR0b25bZGlzYWJsZWRdIHtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQgIWltcG9ydGFudDtcbiAgY29sb3I6IHJnYmEoMCwgMCwgMCwgMC4yNikgIWltcG9ydGFudDtcbn1cblxuLnNhdmUtYnV0dG9uIHtcbiAgYmFja2dyb3VuZDogdmFyKC0tcHJpbWFyeS1jb2xvcikgIWltcG9ydGFudDtcbiAgY29sb3I6IHdoaXRlICFpbXBvcnRhbnQ7XG59Il19 */\"","import { Component, OnInit, Inject, ViewEncapsulation } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { fuseAnimations } from '@fuse/animations';\r\nimport { FormBuilder, ValidatorFn, FormGroup, Validators, FormControl } from '@angular/forms';\r\nimport { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';\r\nimport { Subject } from 'rxjs';\r\nimport { FuseSplashScreenService } from '../../../../../@fuse/services/splash-screen.service';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { PageService } from '../../page.service';\r\nimport { CustomersService } from '../customers-service';\r\nimport { PointAccountsService } from '../../company-point-accounts/point-accounts.service';\r\nconst trimValidator: ValidatorFn = (control: FormControl) => {\r\n if (control.value) {\r\n if (control.value.startsWith(' ')) {\r\n return {\r\n 'trimError': { value: 'This field is required' }\r\n };\r\n }\r\n }\r\n}\r\n\r\n@Component({\r\n selector: 'app-customer-maxlimit',\r\n templateUrl: './customer-maxlimit.component.html',\r\n styleUrls: ['./customer-maxlimit.component.scss'],\r\n encapsulation: ViewEncapsulation.None,\r\n animations: fuseAnimations\r\n})\r\nexport class CustomerMaxLimitComponent implements OnInit {\r\n pointAccountForm: FormGroup;\r\n dialogTitle: string;\r\n action: string;\r\n userDetails: any;\r\n currencyCode;\r\n currencyList;\r\n pointAccountType;\r\n pointAccountTypeList;\r\n transactionTypeList;\r\n transactionType;\r\n Isdisabled: boolean = true;\r\n maxTransferLimit = '';\r\n constructor(\r\n public matDialogRef: MatDialogRef,\r\n @Inject(MAT_DIALOG_DATA) private _data: any,\r\n private _formBuilder: FormBuilder,\r\n private _fuseSplashScreenService: FuseSplashScreenService,\r\n private _toastr: ToastrService,\r\n private _CustomersService: CustomersService,\r\n ) { // Set the defaults\r\n this.action = _data.action;\r\n if(_data.data && (_data.data.maxTransferLimit || this._CustomersService.customerDetails)){\r\n this.maxTransferLimit = _data.data.maxTransferLimit || this._CustomersService.customerDetails.maxTransferLimit;\r\n }\r\n this.dialogTitle = 'Set Maximum Transfer Limit';\r\n\r\n this.pointAccountForm = this._formBuilder.group({\r\n amount: [this.maxTransferLimit, [Validators.required, Validators.pattern(\"^[0-9]+(.[0-9]{0,2})?$\")]],\r\n });\r\n }\r\n\r\n ngOnInit() {\r\n if (localStorage.getItem('LoggedInUserData')) {\r\n this.userDetails = JSON.parse(localStorage.getItem('LoggedInUserData'));\r\n }\r\n\r\n }\r\n\r\n AdjustCustomerBalance() {\r\n if (!this.pointAccountForm.valid) {\r\n this._toastr.error(\"Please add Balance Info\", 'Error');\r\n return\r\n }\r\n const request = {\r\n \"customerId\": this._data.data.id,\r\n \"maxTransferLimit\": this.pointAccountForm.get('amount').value\r\n };\r\n this._CustomersService.SetCustomerMaxLimit(request).subscribe((res: any) => {\r\n if (res.status == \"Success\" && res.data) {\r\n this.matDialogRef.close(res.status);\r\n this._toastr.success('limit set successfully !');\r\n } else {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(res.message, 'Error');\r\n }\r\n });\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport {RestService} from '../../../shared/rest.service';\r\nimport {AuthService} from '../../../shared/auth.service';\r\nimport { API_URL} from '../../../constants';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class CustomersService {\r\n public companyPageSize = 10;\r\n public companyPageNumber = 1;\r\n apiUrl: string = API_URL;\r\n public selectedCustomerid;\r\n public selectedCompanyid;\r\n public customerTransactionDetails = {};\r\n public accountTotalCount: Number = 0;\r\n public holdTotalCount:Number = 0;\r\n public holdTransactionDetails: MatTableDataSource;\r\n public AccountTransactionList: MatTableDataSource;\r\n public customerDetails = {\r\n firstName: '',\r\n lastName:'',\r\n externalCustomerID: 0,\r\n backofficeID: 0,\r\n createdDate: new Date(),\r\n maxTransferLimit: 0,\r\n companyID:\"\",\r\n id:''\r\n };\r\n public customerPointBalancesDetails = {\r\n activeAmount: 0,\r\n amount:0,\r\n holdAmount:0 \r\n };\r\n constructor(public _RestService: RestService, public _AuthService: AuthService, ) {\r\n\r\n }\r\n\r\n\r\n IsActiveCustomer(id,active) {\r\n let _url = \"/api/Customer/IsActiveCustomer?id=\" + id +'&active='+active;\r\n return this._RestService.Delete(_url);\r\n }\r\n EditCustomer(EditCustomerRequest,headers) {\r\n var _url = \"/Customer/UpdateCustomer\";\r\n return this._RestService.Post(_url, EditCustomerRequest,0,headers);\r\n }\r\n\r\n AddCustomer(customerRequest: any) {\r\n var _url = \"/Customer/CreateCustomerDetails\";\r\n return this._RestService.Post(_url, customerRequest);\r\n }\r\n SetCustomerStatus(customerRequest: any) {\r\n var _url = \"/Customer/SetCustomerStatus\";\r\n return this._RestService.Post(_url, customerRequest);\r\n }\r\n\r\n GetCustomerList(request: any) {\r\n var _url = '/Customer/GetCustomerList';\r\n return this._RestService.Post(_url, request);\r\n }\r\n importFile(data) {\r\n var _url = \"/Customer/CustomerImport\";\r\n return this._RestService.PostFile(_url, data);\r\n }\r\n GetCompanyPointDetail(request: any) {\r\n var _url = '/CompanyPointAccount/GetCompanyPointAccounts' + request;\r\n return this._RestService.Get(_url);\r\n }\r\n GetAllPointAccountTransactons(request) {\r\n var _url = \"/CustomerPointTransactions/GetCustomerAllPointTransactions\";\r\n return this._RestService.Post(_url, request);\r\n }\r\n CustomerAllTransactionsHistory(request) {\r\n var _url = \"/CustomerPointTransactions/CustomerAllTransactionsHistory\";\r\n return this._RestService.Post(_url, request);\r\n }\r\n GetPointAccountType() {\r\n var _url = '/PointAccountType/GetPointAccountType';\r\n return this._RestService.Get(_url);\r\n }\r\n GetCurrencycode() {\r\n var _url = '/v1/Currencies';\r\n return this._RestService.Get(_url);\r\n }\r\n AdjustCustomerBalance(request,header) {\r\n var _url = '/CustomerPointTransactions/AdjustPointAccountTransaction';\r\n return this._RestService.Post(_url, request,0,header);\r\n }\r\n IsCustomerExist(request)\r\n {\r\n \r\n var _url=\"/Customer/IsCustomerExist\";\r\n return this._RestService.Post(_url,request);\r\n }\r\n SetCustomerMaxLimit(request) {\r\n var _url = '/Customer/SetCustomerMaxLimit';\r\n return this._RestService.Post(_url, request);\r\n }\r\n IsCustomerBlock(request) {\r\n var _url = `/Customer/IsCustomerBlock?companyID=${request.companyID}&pointAccountID=${request.pointAccountID}&customerID=${request.customerId}`;\r\n return this._RestService.Post(_url,null);\r\n }\r\n BlockCustomer(request) {\r\n var _url = `/Customer/BlockCustomer?companyID=${request.companyID}&pointAccountID=${request.pointAccountID}&externalCustomerId=${request.externalCustomerId}&customerId=${request.customerId}`;\r\n return this._RestService.Post(_url,null);\r\n }\r\n UnBlockCustomer(request) {\r\n var _url = `/api/Customer/UnBlockCustomer?companyId=${request.companyID}&customerId=${request.customerId}`;\r\n return this._RestService.Delete(_url);\r\n }\r\n GetAllLanguages() {\r\n var _url = `/Language/GetAllLanguages`;\r\n return this._RestService.Get(_url);\r\n }\r\n public Getcountries() {\r\n var _url = \"/v1/Address/countries\";\r\n return this._RestService.Get(_url);\r\n }\r\n public GetRegions(countryCode:string){\r\n var _url = `/v1/Address/${countryCode}/regions`;\r\n return this._RestService.Get(_url);\r\n }\r\n public GetRedeemType(){\r\n var _url = `/Utils/GetRedeemType`;\r\n return this._RestService.Get(_url);\r\n }\r\n public ValidateCustomerEmail(email,companyId){\r\n var _url = `/Customer/ValidateCustomerEmail?email=${email}&companyId=${companyId}`;\r\n return this._RestService.Get(_url);\r\n }\r\n public ImpersonateToCustomerPortal(req,headers){\r\n var _url = `/users/ssotoken?customerId=${req.backofficeID}&companyId=${req.companyId}`;\r\n return this._RestService.Get(_url, false, headers);\r\n }\r\n public syncCustomer(req){\r\n var _url = `/Customer/SyncCustomerDetails?externalCustomerID=${req.externalCustomerID}&companyId=${req.companyId}`;\r\n return this._RestService.Get(_url);\r\n }\r\n public checkTygaAccount(req){\r\n var _url = `/Tyga/CheckAccount?externalCustomerId=${req.externalCustomerID}&companyId=${req.companyId}`;\r\n return this._RestService.Get(_url);\r\n }\r\n public removeTygaAccount(req){\r\n var _url = `/Tyga/RemoveAccount?externalCustomerId=${req.externalCustomerId}&companyId=${req.companyID}`;\r\n return this._RestService.Post(_url,{});\r\n }\r\n ExportCustomerAllPointTransactions(request) {\r\n var _url = \"/CustomerPointTransactions/ExportCustomerAllPointTransactions\";\r\n return this._RestService.Postblob(_url, request);\r\n }\r\n SaveFile(blob, fileName) {\r\n return this._RestService.saveFile(blob, fileName);\r\n }\r\n public TriggerUnifyEvent(req){\r\n var _url = `/Customer/TriggerUnifyEvent?eventName=${req.eventName}&externalCustomerID=${req.externalCustomerID}&companyId=${req.companyId}`;\r\n return this._RestService.Post(_url,{});\r\n }\r\n ExportCustomerReport(request) {\r\n var _url =`/Customer/GetCustomerListExport?${request}`;\r\n return this._RestService.Getblob(_url);\r\n }\r\n getCustomerBatchList() {\r\n var _url =`/Customer/GetCustomerBatchList`;\r\n return this._RestService.Get(_url);\r\n }\r\n getCustomerBatchDetail(batchId) {\r\n var _url =`/Customer/GetCustomerBatchDetail?batchId=${batchId}`;\r\n return this._RestService.Get(_url);\r\n }\r\n getCustomerBatchListByStatus(status) {\r\n var _url =`/Customer/GetCustomerBatchListByStatus?status=${status}`;\r\n return this._RestService.Get(_url);\r\n }\r\n ExportCustomersWithBalance(request:any){\r\n let _url = `/Customer/ExportCustomersWithBalance?${request}`\r\n return this._RestService.Get(_url);\r\n }\r\n}","import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class PageService {\r\n public CompanyList = [\r\n { companyName: 'Wakaya', description: 'this is wakaya', companyId: 1, provider: 'Exigo' },\r\n { companyName: 'TruVision', description: 'this is truvision', companyId: 2, provider: 'Disco' },\r\n { companyName: 'QSC', description: 'this is qsc', companyId: 3, provider: 'Exigo' }\r\n ];\r\n\r\n\r\n constructor() { }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { FormControl, FormGroup, ValidatorFn, Validators } from '@angular/forms';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport {RestService} from '../../../shared/rest.service';\r\n@Injectable()\r\nexport class ProfileService\r\n{\r\n onCountryChanged = new BehaviorSubject([]);\r\n userDetails = JSON.parse(localStorage.getItem(\"LoggedInUserData\"));\r\n isAgentView: any = this.userDetails && this.userDetails.defaultAgentView;\r\n /**\r\n * Constructor\r\n *\r\n * @param {HttpClient} _httpClient\r\n */\r\n constructor(\r\n private _restService:RestService\r\n )\r\n {\r\n this.init();\r\n }\r\n init(){\r\n this.onCountryChanged = new BehaviorSubject([]);\r\n this.userDetails = JSON.parse(localStorage.getItem(\"LoggedInUserData\"));\r\n this.isAgentView = this.userDetails && this.userDetails.defaultAgentView;\r\n\r\n }\r\n /*\r\n *\r\n * @param {ActivatedRouteSnapshot} route\r\n * @param {RouterStateSnapshot} state\r\n * @returns {Observable | Promise | any}\r\n */\r\n\r\n getProfile(){\r\n var _url=\"/Users/GetUsersDetails\";\r\n return this._restService.Get(_url);\r\n }\r\n updateProfile(data){\r\n var _url=\"/Users/UpdateUser\";\r\n return this._restService.Post(_url,data);\r\n }\r\n uploadImage(data){\r\n var _url=\"/Users/SetProfileImage\";\r\n return this._restService.PostFile(_url,data);\r\n }\r\n validateAllFormFields(formGroup: FormGroup) {\r\n Object.keys(formGroup.controls).forEach(field => {\r\n const control: any = formGroup.get(field);\r\n if (control instanceof FormControl) {\r\n control.markAsTouched({ onlySelf: true });\r\n } else {\r\n this.validateAllFormFields(control);\r\n }\r\n });\r\n }\r\n removeValidators(form: FormGroup, formControl: any) {\r\n form.get(formControl).clearValidators();\r\n form.get(formControl).updateValueAndValidity();\r\n }\r\n addValidators(form: FormGroup, formControl: any) {\r\n form.get(formControl).setValidators([Validators.required, trimValidator]);\r\n form.get(formControl).updateValueAndValidity();\r\n }\r\n SetTwoWA(req) {\r\n var _url=\"/Users/SetTwoWA\"\r\n return this._restService.Post(_url, req);\r\n }\r\n}\r\n\r\nconst trimValidator: ValidatorFn = (control: FormControl) => {\r\n if (control && control.value && typeof control.value == \"string\" && !control.value.replace(/\\s/g, '').length) {\r\n return {\r\n 'trimError': { value: 'control has leading whitespace' }\r\n };\r\n }\r\n\r\n return null;\r\n};\r\n","export default \"/* Theme for the ripple elements.*/\\n/* stylelint-disable material/no-prefixes */\\n/* stylelint-enable */\\n@media screen and (max-width: 599px) {\\n .payout-receipt-details {\\n max-width: 100vw !important;\\n width: 100%;\\n height: 100%;\\n }\\n}\\n@media screen and (min-width: 600px) and (max-width: 959px) {\\n .payout-receipt-details {\\n max-width: 100vw !important;\\n width: 100%;\\n height: 100%;\\n }\\n}\\n@media screen and (min-width: 960px) {\\n .payout-receipt-details {\\n max-width: 100vw !important;\\n width: 100%;\\n }\\n}\\n.payout-receipt-details .header-tab-action {\\n background: #00000026 !important;\\n margin: 0px 5px;\\n border-radius: 10px;\\n}\\n.payout-receipt-details .mat-dialog-container {\\n padding: 0;\\n}\\n.payout-receipt-details .transactionDetails {\\n margin: 20px 70px 70px 60px;\\n}\\n.payout-receipt-details .transactionDetails .imageLogo img {\\n width: 180px;\\n}\\n.payout-receipt-details .transactionDetails .transactionField .field {\\n padding-bottom: 32px;\\n font-family: Helvetica, Arial, sans-serif;\\n}\\n.payout-receipt-details .transactionDetails .address {\\n font-size: 10px;\\n font-weight: bold;\\n}\\n.payout-receipt-details .transactionDetails .address pre {\\n line-height: 1;\\n}\\n.payout-receipt-details .transactionDetails .transactionField .field label {\\n font-weight: bold;\\n font-size: 16px;\\n}\\n@media print {\\n .forPrint {\\n display: none;\\n }\\n\\n @page {\\n Pages: 1;\\n }\\n .print-none {\\n visibility: hidden;\\n }\\n}\\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/app/main/pages/reports/payout-receipt/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/node_modules\\@angular\\material\\_theming.scss","src/app/main/pages/reports/payout-receipt/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\@fuse\\scss\\partials\\_breakpoints.scss","src/app/main/pages/reports/payout-receipt/C:\\ProgramData\\Jenkins\\.jenkins\\workspace\\RPMS\\UI\\Live (UI running on Paymenture AWS)\\paymenture.com/src\\app\\main\\pages\\reports\\payout-receipt\\payout-receipt.component.scss","src/app/main/pages/reports/payout-receipt/payout-receipt.component.scss"],"names":[],"mappings":"AA01CA,kCAAA;AA8hDA,2CAAA;AAwCA,qBAAA;AC/3FQ;EChCR;IAEQ,2BAAA;IACA,WAAA;IACA,YAAA;ECGN;AACF;AFwBQ;EChCR;IAOQ,2BAAA;IACA,WAAA;IACA,YAAA;ECKN;AACF;AFiBQ;EChCR;IAaQ,2BAAA;IACA,WAAA;ECMN;AACF;ADLI;EACI,gCAAA;EACA,eAAA;EACA,mBAAA;ACOR;ADJI;EACI,UAAA;ACMR;ADJI;EACI,2BAAA;ACMR;ADJI;EACI,YAAA;ACMR;ADJI;EACI,oBAAA;EACA,yCAAA;ACMR;ADJI;EACI,eAAA;EACA,iBAAA;ACMR;ADHI;EACI,cAAA;ACKR;ADHI;EACI,iBAAA;EACA,eAAA;ACKR;ADDA;EACI;IACE,aAAA;ECIJ;;EDFE;IACI,QAAA;ECKN;EDHE;IACI,kBAAA;ECKN;AACF","file":"src/app/main/pages/reports/payout-receipt/payout-receipt.component.scss","sourcesContent":["// Import all the theming functionality.\n// We can use relative imports for imports from the cdk because we bundle everything\n// up into a single flat scss file for material.\n// We want overlays to always appear over user content, so set a baseline\n// very high z-index for the overlay container, which is where we create the new\n// stacking context for all overlays.\n$cdk-z-index-overlay-container: 1000 !default;\n$cdk-z-index-overlay: 1000 !default;\n$cdk-z-index-overlay-backdrop: 1000 !default;\n\n// Background color for all of the backdrops\n$cdk-overlay-dark-backdrop-background: rgba(0, 0, 0, 0.32) !default;\n\n// Default backdrop animation is based on the Material Design swift-ease-out.\n$backdrop-animation-duration: 400ms !default;\n$backdrop-animation-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n\n\n@mixin cdk-overlay() {\n  .cdk-overlay-container, .cdk-global-overlay-wrapper {\n    // Disable events from being captured on the overlay container.\n    pointer-events: none;\n\n    // The container should be the size of the viewport.\n    top: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  // The overlay-container is an invisible element which contains all individual overlays.\n  .cdk-overlay-container {\n    position: fixed;\n    z-index: $cdk-z-index-overlay-container;\n\n    &:empty {\n      // Hide the element when it doesn't have any child nodes. This doesn't\n      // include overlays that have been detached, rather than disposed.\n      display: none;\n    }\n  }\n\n  // We use an extra wrapper element in order to use make the overlay itself a flex item.\n  // This makes centering the overlay easy without running into the subpixel rendering\n  // problems tied to using `transform` and without interfering with the other position\n  // strategies.\n  .cdk-global-overlay-wrapper {\n    display: flex;\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n  }\n\n  // A single overlay pane.\n  .cdk-overlay-pane {\n    // Note: it's important for this one to start off `absolute`,\n    // in order for us to be able to measure it correctly.\n    position: absolute;\n    pointer-events: auto;\n    box-sizing: border-box;\n    z-index: $cdk-z-index-overlay;\n\n    // For connected-position overlays, we set `display: flex` in\n    // order to force `max-width` and `max-height` to take effect.\n    display: flex;\n    max-width: 100%;\n    max-height: 100%;\n  }\n\n  .cdk-overlay-backdrop {\n    // TODO(jelbourn): reuse sidenav fullscreen mixin.\n    position: absolute;\n    top: 0;\n    bottom: 0;\n    left: 0;\n    right: 0;\n\n    z-index: $cdk-z-index-overlay-backdrop;\n    pointer-events: auto;\n    -webkit-tap-highlight-color: transparent;\n    transition: opacity $backdrop-animation-duration $backdrop-animation-timing-function;\n    opacity: 0;\n\n    &.cdk-overlay-backdrop-showing {\n      opacity: 1;\n\n      // In high contrast mode the rgba background will become solid so we need to fall back\n      // to making it opaque using `opacity`. Note that we can't use the `cdk-high-contrast`\n      // mixin, because we can't normalize the import path to the _a11y.scss both for the\n      // source and when this file is distributed. See #10908.\n      @media screen and (-ms-high-contrast: active) {\n        opacity: 0.6;\n      }\n    }\n  }\n\n  .cdk-overlay-dark-backdrop {\n    background: $cdk-overlay-dark-backdrop-background;\n  }\n\n  .cdk-overlay-transparent-backdrop {\n    // Note: as of Firefox 57, having the backdrop be `background: none` will prevent it from\n    // capturing the user's mouse scroll events. Since we also can't use something like\n    // `rgba(0, 0, 0, 0)`, we work around the inconsistency by not setting the background at\n    // all and using `opacity` to make the element transparent.\n    &, &.cdk-overlay-backdrop-showing {\n      opacity: 0;\n    }\n  }\n\n  // Overlay parent element used with the connected position strategy. Used to constrain the\n  // overlay element's size to fit within the viewport.\n  .cdk-overlay-connected-position-bounding-box {\n    position: absolute;\n    z-index: $cdk-z-index-overlay;\n\n    // We use `display: flex` on this element exclusively for centering connected overlays.\n    // When *not* centering, a top/left/bottom/right will be set which overrides the normal\n    // flex layout.\n    display: flex;\n\n    // We use the `column` direction here to avoid some flexbox issues in Edge\n    // when using the \"grow after open\" options.\n    flex-direction: column;\n\n    // Add some dimensions so the element has an `innerText` which some people depend on in tests.\n    min-width: 1px;\n    min-height: 1px;\n  }\n\n  // Used when disabling global scrolling.\n  .cdk-global-scrollblock {\n    position: fixed;\n\n    // Necessary for the content not to lose its width. Note that we're using 100%, instead of\n    // 100vw, because 100vw includes the width plus the scrollbar, whereas 100% is the width\n    // that the element had before we made it `fixed`.\n    width: 100%;\n\n    // Note: this will always add a scrollbar to whatever element it is on, which can\n    // potentially result in double scrollbars. It shouldn't be an issue, because we won't\n    // block scrolling on a page that doesn't have a scrollbar in the first place.\n    overflow-y: scroll;\n  }\n}\n\n@mixin cdk-a11y {\n  .cdk-visually-hidden {\n    border: 0;\n    clip: rect(0 0 0 0);\n    height: 1px;\n    margin: -1px;\n    overflow: hidden;\n    padding: 0;\n    position: absolute;\n    width: 1px;\n\n    // Avoid browsers rendering the focus ring in some cases.\n    outline: 0;\n\n    // Avoid some cases where the browser will still render the native controls (see #9049).\n    -webkit-appearance: none;\n    -moz-appearance: none;\n  }\n}\n\n// Applies styles for users in high contrast mode. Note that this only applies\n// to Microsoft browsers. Chrome can be included by checking for the `html[hc]`\n// attribute, however Chrome handles high contrast differently.\n//\n// @param target Which kind of high contrast setting to target. Defaults to `active`, can be\n//    `white-on-black` or `black-on-white`.\n@mixin cdk-high-contrast($target: active) {\n  @media (-ms-high-contrast: $target) {\n    @content;\n  }\n}\n\n// Core styles that enable monitoring autofill state of text fields.\n@mixin cdk-text-field {\n  // Keyframes that apply no styles, but allow us to monitor when an text field becomes autofilled\n  // by watching for the animation events that are fired when they start. Note: the /*!*/ comment is\n  // needed to prevent LibSass from stripping the keyframes out.\n  // Based on: https://medium.com/@brunn/detecting-autofilled-fields-in-javascript-aed598d25da7\n  @keyframes cdk-text-field-autofill-start {/*!*/}\n  @keyframes cdk-text-field-autofill-end {/*!*/}\n\n  .cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start;\n  }\n\n  .cdk-text-field-autofill-monitored:not(:-webkit-autofill) {\n    animation-name: cdk-text-field-autofill-end;\n  }\n\n  // Remove the resize handle on autosizing textareas, because whatever height\n  // the user resized to will be overwritten once they start typing again.\n  textarea.cdk-textarea-autosize {\n    resize: none;\n  }\n\n  // This class is temporarily applied to the textarea when it is being measured. It is immediately\n  // removed when measuring is complete. We use `!important` rules here to make sure user-specified\n  // rules do not interfere with the measurement.\n  textarea.cdk-textarea-autosize-measuring {\n    height: auto !important;\n    overflow: hidden !important;\n    // Having 2px top and bottom padding seems to fix a bug where Chrome gets an incorrect\n    // measurement. We just have to account for it later and subtract it off the final result.\n    padding: 2px 0 !important;\n    box-sizing: content-box !important;\n  }\n}\n\n// Used to generate UIDs for keyframes used to change the text field autofill styles.\n$cdk-text-field-autofill-color-frame-count: 0;\n\n// Mixin used to apply custom background and foreground colors to an autofilled text field.\n// Based on: https://stackoverflow.com/questions/2781549/\n// removing-input-background-colour-for-chrome-autocomplete#answer-37432260\n@mixin cdk-text-field-autofill-color($background, $foreground:'') {\n  @keyframes cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count} {\n    to {\n      background: $background;\n      @if $foreground != '' { color: $foreground; }\n    }\n  }\n\n  &:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n    animation-fill-mode: both;\n  }\n\n  &.cdk-text-field-autofill-monitored:-webkit-autofill {\n    animation-name: cdk-text-field-autofill-start,\n                    cdk-text-field-autofill-color-#{$cdk-text-field-autofill-color-frame-count};\n  }\n\n  $cdk-text-field-autofill-color-frame-count:\n      $cdk-text-field-autofill-color-frame-count + 1 !global;\n}\n\n\n// Core styles that can be used to apply material design treatments to any element.\n// Media queries\n// TODO(josephperrott): Change $mat-xsmall and $mat-small usages to rely on BreakpointObserver,\n$mat-xsmall: 'max-width: 599px';\n$mat-small: 'max-width: 959px';\n\n// TODO: Revisit all z-indices before beta\n// z-index master list\n\n$z-index-fab: 20 !default;\n$z-index-drawer: 100 !default;\n\n// Global constants\n$pi: 3.14159265;\n\n// Padding between input toggles and their labels\n$mat-toggle-padding: 8px !default;\n// Width and height of input toggles\n$mat-toggle-size: 20px !default;\n\n// Easing Curves\n// TODO(jelbourn): all of these need to be revisited\n\n// The default animation curves used by material design.\n$mat-linear-out-slow-in-timing-function: cubic-bezier(0, 0, 0.2, 0.1) !default;\n$mat-fast-out-slow-in-timing-function: cubic-bezier(0.4, 0, 0.2, 1) !default;\n$mat-fast-out-linear-in-timing-function: cubic-bezier(0.4, 0, 1, 1) !default;\n\n$ease-in-out-curve-function: cubic-bezier(0.35, 0, 0.25, 1) !default;\n\n$swift-ease-out-duration: 400ms !default;\n$swift-ease-out-timing-function: cubic-bezier(0.25, 0.8, 0.25, 1) !default;\n$swift-ease-out: all $swift-ease-out-duration $swift-ease-out-timing-function !default;\n\n$swift-ease-in-duration: 300ms !default;\n$swift-ease-in-timing-function: cubic-bezier(0.55, 0, 0.55, 0.2) !default;\n$swift-ease-in: all $swift-ease-in-duration $swift-ease-in-timing-function !default;\n\n$swift-ease-in-out-duration: 500ms !default;\n$swift-ease-in-out-timing-function: $ease-in-out-curve-function !default;\n$swift-ease-in-out: all $swift-ease-in-out-duration $swift-ease-in-out-timing-function !default;\n\n$swift-linear-duration: 80ms !default;\n$swift-linear-timing-function: linear !default;\n$swift-linear: all $swift-linear-duration $swift-linear-timing-function !default;\n\n\n\n// A collection of mixins and CSS classes that can be used to apply elevation to a material\n// element.\n// See: https://material.io/design/environment/elevation.html\n// Examples:\n//\n//\n// .mat-foo {\n//   @include $mat-elevation(2);\n//\n//   &:active {\n//     @include $mat-elevation(8);\n//   }\n// }\n//\n// <div id=\"external-card\" class=\"mat-elevation-z2\"><p>Some content</p></div>\n//\n// For an explanation of the design behind how elevation is implemented, see the design doc at\n// https://goo.gl/Kq0k9Z.\n\n// Colors for umbra, penumbra, and ambient shadows. As described in the design doc, each elevation\n// level is created using a set of 3 shadow values, one for umbra (the shadow representing the\n// space completely obscured by an object relative to its light source), one for penumbra (the\n// space partially obscured by an object), and one for ambient (the space which contains the object\n// itself). For a further explanation of these terms and their meanings, see\n// https://en.wikipedia.org/wiki/Umbra,_penumbra_and_antumbra.\n\n// Maps for the different shadow sets and their values within each z-space. These values were\n// created by taking a few reference shadow sets created by Google's Designers and interpolating\n// all of the values between them.\n\n@function _get-umbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.2), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 2px 1px -1px #{$shadow-color}',\n    2: '0px 3px 1px -2px #{$shadow-color}',\n    3: '0px 3px 3px -2px #{$shadow-color}',\n    4: '0px 2px 4px -1px #{$shadow-color}',\n    5: '0px 3px 5px -1px #{$shadow-color}',\n    6: '0px 3px 5px -1px #{$shadow-color}',\n    7: '0px 4px 5px -2px #{$shadow-color}',\n    8: '0px 5px 5px -3px #{$shadow-color}',\n    9: '0px 5px 6px -3px #{$shadow-color}',\n    10: '0px 6px 6px -3px #{$shadow-color}',\n    11: '0px 6px 7px -4px #{$shadow-color}',\n    12: '0px 7px 8px -4px #{$shadow-color}',\n    13: '0px 7px 8px -4px #{$shadow-color}',\n    14: '0px 7px 9px -4px #{$shadow-color}',\n    15: '0px 8px 9px -5px #{$shadow-color}',\n    16: '0px 8px 10px -5px #{$shadow-color}',\n    17: '0px 8px 11px -5px #{$shadow-color}',\n    18: '0px 9px 11px -5px #{$shadow-color}',\n    19: '0px 9px 12px -6px #{$shadow-color}',\n    20: '0px 10px 13px -6px #{$shadow-color}',\n    21: '0px 10px 13px -6px #{$shadow-color}',\n    22: '0px 10px 14px -6px #{$shadow-color}',\n    23: '0px 11px 14px -7px #{$shadow-color}',\n    24: '0px 11px 15px -7px #{$shadow-color}'\n  );\n}\n\n@function _get-penumbra-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.14), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 1px 0px #{$shadow-color}',\n    2: '0px 2px 2px 0px #{$shadow-color}',\n    3: '0px 3px 4px 0px #{$shadow-color}',\n    4: '0px 4px 5px 0px #{$shadow-color}',\n    5: '0px 5px 8px 0px #{$shadow-color}',\n    6: '0px 6px 10px 0px #{$shadow-color}',\n    7: '0px 7px 10px 1px #{$shadow-color}',\n    8: '0px 8px 10px 1px #{$shadow-color}',\n    9: '0px 9px 12px 1px #{$shadow-color}',\n    10: '0px 10px 14px 1px #{$shadow-color}',\n    11: '0px 11px 15px 1px #{$shadow-color}',\n    12: '0px 12px 17px 2px #{$shadow-color}',\n    13: '0px 13px 19px 2px #{$shadow-color}',\n    14: '0px 14px 21px 2px #{$shadow-color}',\n    15: '0px 15px 22px 2px #{$shadow-color}',\n    16: '0px 16px 24px 2px #{$shadow-color}',\n    17: '0px 17px 26px 2px #{$shadow-color}',\n    18: '0px 18px 28px 2px #{$shadow-color}',\n    19: '0px 19px 29px 2px #{$shadow-color}',\n    20: '0px 20px 31px 3px #{$shadow-color}',\n    21: '0px 21px 33px 3px #{$shadow-color}',\n    22: '0px 22px 35px 3px #{$shadow-color}',\n    23: '0px 23px 36px 3px #{$shadow-color}',\n    24: '0px 24px 38px 3px #{$shadow-color}'\n  );\n}\n\n@function _get-ambient-map($color, $opacity) {\n  $shadow-color: if(type-of($color) == color, rgba($color, $opacity * 0.12), $color);\n\n  @return (\n    0: '0px 0px 0px 0px #{$shadow-color}',\n    1: '0px 1px 3px 0px #{$shadow-color}',\n    2: '0px 1px 5px 0px #{$shadow-color}',\n    3: '0px 1px 8px 0px #{$shadow-color}',\n    4: '0px 1px 10px 0px #{$shadow-color}',\n    5: '0px 1px 14px 0px #{$shadow-color}',\n    6: '0px 1px 18px 0px #{$shadow-color}',\n    7: '0px 2px 16px 1px #{$shadow-color}',\n    8: '0px 3px 14px 2px #{$shadow-color}',\n    9: '0px 3px 16px 2px #{$shadow-color}',\n    10: '0px 4px 18px 3px #{$shadow-color}',\n    11: '0px 4px 20px 3px #{$shadow-color}',\n    12: '0px 5px 22px 4px #{$shadow-color}',\n    13: '0px 5px 24px 4px #{$shadow-color}',\n    14: '0px 5px 26px 4px #{$shadow-color}',\n    15: '0px 6px 28px 5px #{$shadow-color}',\n    16: '0px 6px 30px 5px #{$shadow-color}',\n    17: '0px 6px 32px 5px #{$shadow-color}',\n    18: '0px 7px 34px 6px #{$shadow-color}',\n    19: '0px 7px 36px 6px #{$shadow-color}',\n    20: '0px 8px 38px 7px #{$shadow-color}',\n    21: '0px 8px 40px 7px #{$shadow-color}',\n    22: '0px 8px 42px 7px #{$shadow-color}',\n    23: '0px 9px 44px 8px #{$shadow-color}',\n    24: '0px 9px 46px 8px #{$shadow-color}'\n  );\n}\n\n// The default duration value for elevation transitions.\n$mat-elevation-transition-duration: 280ms !default;\n\n// The default easing value for elevation transitions.\n$mat-elevation-transition-timing-function: $mat-fast-out-slow-in-timing-function;\n\n// The default color for elevation shadows.\n$mat-elevation-color: black !default;\n\n// The default opacity scaling value for elevation shadows.\n$mat-elevation-opacity: 1 !default;\n\n// Prefix for elevation-related selectors.\n$_mat-elevation-prefix: 'mat-elevation-z';\n\n// Applies the correct css rules to an element to give it the elevation specified by $zValue.\n// The $zValue must be between 0 and 24.\n@mixin mat-elevation($zValue, $color: $mat-elevation-color, $opacity: $mat-elevation-opacity) {\n  @if type-of($zValue) != number or not unitless($zValue) {\n    @error '$zValue must be a unitless number';\n  }\n  @if $zValue < 0 or $zValue > 24 {\n    @error '$zValue must be between 0 and 24';\n  }\n\n  box-shadow: #{map-get(_get-umbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-penumbra-map($color, $opacity), $zValue)},\n              #{map-get(_get-ambient-map($color, $opacity), $zValue)};\n}\n\n@mixin _mat-theme-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Applies the elevation to an element in a manner that allows\n// consumers to override it via the Material elevation classes.\n@mixin mat-overridable-elevation(\n    $zValue,\n    $color: $mat-elevation-color,\n    $opacity: $mat-elevation-opacity) {\n  &:not([class*='#{$_mat-elevation-prefix}']) {\n    @include mat-elevation($zValue, $color, $opacity);\n  }\n}\n\n@mixin _mat-theme-overridable-elevation($zValue, $theme, $opacity: $mat-elevation-opacity) {\n  $foreground: map-get($theme, foreground);\n  $elevation-color: map-get($foreground, elevation);\n  $elevation-color-or-default: if($elevation-color == null, $mat-elevation-color, $elevation-color);\n\n  @include mat-overridable-elevation($zValue, $elevation-color-or-default, $opacity);\n}\n\n// Returns a string that can be used as the value for a transition property for elevation.\n// Calling this function directly is useful in situations where a component needs to transition\n// more than one property.\n//\n// .foo {\n//   transition: mat-elevation-transition-property-value(), opacity 100ms ease;\n// }\n@function mat-elevation-transition-property-value(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  @return box-shadow #{$duration} #{$easing};\n}\n\n// Applies the correct css rules needed to have an element transition between elevations.\n// This mixin should be applied to elements whose elevation values will change depending on their\n// context (e.g. when active or disabled).\n//\n// NOTE(traviskaufman): Both this mixin and the above function use default parameters so they can\n// be used in the same way by clients.\n@mixin mat-elevation-transition(\n    $duration: $mat-elevation-transition-duration,\n    $easing: $mat-elevation-transition-timing-function) {\n  transition: mat-elevation-transition-property-value($duration, $easing);\n}\n\n// Color palettes from the Material Design spec.\n// See https://material.io/design/color/\n//\n// Contrast colors are hard-coded because it is too difficult (probably impossible) to\n// calculate them. These contrast colors are pulled from the public Material Design spec swatches.\n// While the contrast colors in the spec are not prescriptive, we use them for convenience.\n\n\n// @deprecated renamed to $dark-primary-text.\n// @breaking-change 8.0.0\n$black-87-opacity: rgba(black, 0.87);\n// @deprecated renamed to $light-primary-text.\n// @breaking-change 8.0.0\n$white-87-opacity: rgba(white, 0.87);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-12-opacity: rgba(black, 0.12);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-12-opacity: rgba(white, 0.12);\n// @deprecated use $dark-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$black-6-opacity: rgba(black, 0.06);\n// @deprecated use $light-[secondary-text,disabled-text,dividers,focused] instead.\n// @breaking-change 8.0.0\n$white-6-opacity: rgba(white, 0.06);\n\n$dark-primary-text: rgba(black, 0.87);\n$dark-secondary-text: rgba(black, 0.54);\n$dark-disabled-text: rgba(black, 0.38);\n$dark-dividers: rgba(black, 0.12);\n$dark-focused: rgba(black, 0.12);\n$light-primary-text: white;\n$light-secondary-text: rgba(white, 0.7);\n$light-disabled-text: rgba(white, 0.5);\n$light-dividers: rgba(white, 0.12);\n$light-focused: rgba(white, 0.12);\n\n$mat-red: (\n  50: #ffebee,\n  100: #ffcdd2,\n  200: #ef9a9a,\n  300: #e57373,\n  400: #ef5350,\n  500: #f44336,\n  600: #e53935,\n  700: #d32f2f,\n  800: #c62828,\n  900: #b71c1c,\n  A100: #ff8a80,\n  A200: #ff5252,\n  A400: #ff1744,\n  A700: #d50000,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-pink: (\n  50: #fce4ec,\n  100: #f8bbd0,\n  200: #f48fb1,\n  300: #f06292,\n  400: #ec407a,\n  500: #e91e63,\n  600: #d81b60,\n  700: #c2185b,\n  800: #ad1457,\n  900: #880e4f,\n  A100: #ff80ab,\n  A200: #ff4081,\n  A400: #f50057,\n  A700: #c51162,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-purple: (\n  50: #f3e5f5,\n  100: #e1bee7,\n  200: #ce93d8,\n  300: #ba68c8,\n  400: #ab47bc,\n  500: #9c27b0,\n  600: #8e24aa,\n  700: #7b1fa2,\n  800: #6a1b9a,\n  900: #4a148c,\n  A100: #ea80fc,\n  A200: #e040fb,\n  A400: #d500f9,\n  A700: #aa00ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-deep-purple: (\n  50: #ede7f6,\n  100: #d1c4e9,\n  200: #b39ddb,\n  300: #9575cd,\n  400: #7e57c2,\n  500: #673ab7,\n  600: #5e35b1,\n  700: #512da8,\n  800: #4527a0,\n  900: #311b92,\n  A100: #b388ff,\n  A200: #7c4dff,\n  A400: #651fff,\n  A700: #6200ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-indigo: (\n  50: #e8eaf6,\n  100: #c5cae9,\n  200: #9fa8da,\n  300: #7986cb,\n  400: #5c6bc0,\n  500: #3f51b5,\n  600: #3949ab,\n  700: #303f9f,\n  800: #283593,\n  900: #1a237e,\n  A100: #8c9eff,\n  A200: #536dfe,\n  A400: #3d5afe,\n  A700: #304ffe,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-blue: (\n  50: #e3f2fd,\n  100: #bbdefb,\n  200: #90caf9,\n  300: #64b5f6,\n  400: #42a5f5,\n  500: #2196f3,\n  600: #1e88e5,\n  700: #1976d2,\n  800: #1565c0,\n  900: #0d47a1,\n  A100: #82b1ff,\n  A200: #448aff,\n  A400: #2979ff,\n  A700: #2962ff,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $light-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-light-blue: (\n  50: #e1f5fe,\n  100: #b3e5fc,\n  200: #81d4fa,\n  300: #4fc3f7,\n  400: #29b6f6,\n  500: #03a9f4,\n  600: #039be5,\n  700: #0288d1,\n  800: #0277bd,\n  900: #01579b,\n  A100: #80d8ff,\n  A200: #40c4ff,\n  A400: #00b0ff,\n  A700: #0091ea,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-cyan: (\n  50: #e0f7fa,\n  100: #b2ebf2,\n  200: #80deea,\n  300: #4dd0e1,\n  400: #26c6da,\n  500: #00bcd4,\n  600: #00acc1,\n  700: #0097a7,\n  800: #00838f,\n  900: #006064,\n  A100: #84ffff,\n  A200: #18ffff,\n  A400: #00e5ff,\n  A700: #00b8d4,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-teal: (\n  50: #e0f2f1,\n  100: #b2dfdb,\n  200: #80cbc4,\n  300: #4db6ac,\n  400: #26a69a,\n  500: #009688,\n  600: #00897b,\n  700: #00796b,\n  800: #00695c,\n  900: #004d40,\n  A100: #a7ffeb,\n  A200: #64ffda,\n  A400: #1de9b6,\n  A700: #00bfa5,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-green: (\n  50: #e8f5e9,\n  100: #c8e6c9,\n  200: #a5d6a7,\n  300: #81c784,\n  400: #66bb6a,\n  500: #4caf50,\n  600: #43a047,\n  700: #388e3c,\n  800: #2e7d32,\n  900: #1b5e20,\n  A100: #b9f6ca,\n  A200: #69f0ae,\n  A400: #00e676,\n  A700: #00c853,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-light-green: (\n  50: #f1f8e9,\n  100: #dcedc8,\n  200: #c5e1a5,\n  300: #aed581,\n  400: #9ccc65,\n  500: #8bc34a,\n  600: #7cb342,\n  700: #689f38,\n  800: #558b2f,\n  900: #33691e,\n  A100: #ccff90,\n  A200: #b2ff59,\n  A400: #76ff03,\n  A700: #64dd17,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-lime: (\n  50: #f9fbe7,\n  100: #f0f4c3,\n  200: #e6ee9c,\n  300: #dce775,\n  400: #d4e157,\n  500: #cddc39,\n  600: #c0ca33,\n  700: #afb42b,\n  800: #9e9d24,\n  900: #827717,\n  A100: #f4ff81,\n  A200: #eeff41,\n  A400: #c6ff00,\n  A700: #aeea00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-yellow: (\n  50: #fffde7,\n  100: #fff9c4,\n  200: #fff59d,\n  300: #fff176,\n  400: #ffee58,\n  500: #ffeb3b,\n  600: #fdd835,\n  700: #fbc02d,\n  800: #f9a825,\n  900: #f57f17,\n  A100: #ffff8d,\n  A200: #ffff00,\n  A400: #ffea00,\n  A700: #ffd600,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-amber: (\n  50: #fff8e1,\n  100: #ffecb3,\n  200: #ffe082,\n  300: #ffd54f,\n  400: #ffca28,\n  500: #ffc107,\n  600: #ffb300,\n  700: #ffa000,\n  800: #ff8f00,\n  900: #ff6f00,\n  A100: #ffe57f,\n  A200: #ffd740,\n  A400: #ffc400,\n  A700: #ffab00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $dark-primary-text,\n    900: $dark-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $dark-primary-text,\n  )\n);\n\n$mat-orange: (\n  50: #fff3e0,\n  100: #ffe0b2,\n  200: #ffcc80,\n  300: #ffb74d,\n  400: #ffa726,\n  500: #ff9800,\n  600: #fb8c00,\n  700: #f57c00,\n  800: #ef6c00,\n  900: #e65100,\n  A100: #ffd180,\n  A200: #ffab40,\n  A400: #ff9100,\n  A700: #ff6d00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $dark-primary-text,\n    700: $dark-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: black,\n  )\n);\n\n$mat-deep-orange: (\n  50: #fbe9e7,\n  100: #ffccbc,\n  200: #ffab91,\n  300: #ff8a65,\n  400: #ff7043,\n  500: #ff5722,\n  600: #f4511e,\n  700: #e64a19,\n  800: #d84315,\n  900: #bf360c,\n  A100: #ff9e80,\n  A200: #ff6e40,\n  A400: #ff3d00,\n  A700: #dd2c00,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-brown: (\n  50: #efebe9,\n  100: #d7ccc8,\n  200: #bcaaa4,\n  300: #a1887f,\n  400: #8d6e63,\n  500: #795548,\n  600: #6d4c41,\n  700: #5d4037,\n  800: #4e342e,\n  900: #3e2723,\n  A100: #d7ccc8,\n  A200: #bcaaa4,\n  A400: #8d6e63,\n  A700: #5d4037,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $light-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n$mat-grey: (\n  50: #fafafa,\n  100: #f5f5f5,\n  200: #eeeeee,\n  300: #e0e0e0,\n  400: #bdbdbd,\n  500: #9e9e9e,\n  600: #757575,\n  700: #616161,\n  800: #424242,\n  900: #212121,\n  A100: #ffffff,\n  A200: #eeeeee,\n  A400: #bdbdbd,\n  A700: #616161,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $dark-primary-text,\n    500: $dark-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $dark-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-gray: $mat-grey;\n\n$mat-blue-grey: (\n  50: #eceff1,\n  100: #cfd8dc,\n  200: #b0bec5,\n  300: #90a4ae,\n  400: #78909c,\n  500: #607d8b,\n  600: #546e7a,\n  700: #455a64,\n  800: #37474f,\n  900: #263238,\n  A100: #cfd8dc,\n  A200: #b0bec5,\n  A400: #78909c,\n  A700: #455a64,\n  contrast: (\n    50: $dark-primary-text,\n    100: $dark-primary-text,\n    200: $dark-primary-text,\n    300: $dark-primary-text,\n    400: $light-primary-text,\n    500: $light-primary-text,\n    600: $light-primary-text,\n    700: $light-primary-text,\n    800: $light-primary-text,\n    900: $light-primary-text,\n    A100: $dark-primary-text,\n    A200: $dark-primary-text,\n    A400: $light-primary-text,\n    A700: $light-primary-text,\n  )\n);\n\n// Alias for alternate spelling.\n$mat-blue-gray: $mat-blue-grey;\n\n\n// Background palette for light themes.\n$mat-light-theme-background: (\n  status-bar: map_get($mat-grey, 300),\n  app-bar:    map_get($mat-grey, 100),\n  background: map_get($mat-grey, 50),\n  hover:      rgba(black, 0.04), // TODO(kara): check style with Material Design UX\n  card:       white,\n  dialog:     white,\n  disabled-button: rgba(black, 0.12),\n  raised-button: white,\n  focused-button: $dark-focused,\n  selected-button: map_get($mat-grey, 300),\n  selected-disabled-button: map_get($mat-grey, 400),\n  disabled-button-toggle: map_get($mat-grey, 200),\n  unselected-chip: map_get($mat-grey, 300),\n  disabled-list-option: map_get($mat-grey, 200),\n);\n\n// Background palette for dark themes.\n$mat-dark-theme-background: (\n  status-bar: black,\n  app-bar:    map_get($mat-grey, 900),\n  background: #303030,\n  hover:      rgba(white, 0.04), // TODO(kara): check style with Material Design UX\n  card:       map_get($mat-grey, 800),\n  dialog:     map_get($mat-grey, 800),\n  disabled-button: rgba(white, 0.12),\n  raised-button: map-get($mat-grey, 800),\n  focused-button: $light-focused,\n  selected-button: map_get($mat-grey, 900),\n  selected-disabled-button: map_get($mat-grey, 800),\n  disabled-button-toggle: black,\n  unselected-chip: map_get($mat-grey, 700),\n  disabled-list-option: black,\n);\n\n// Foreground palette for light themes.\n$mat-light-theme-foreground: (\n  base:              black,\n  divider:           $dark-dividers,\n  dividers:          $dark-dividers,\n  disabled:          $dark-disabled-text,\n  disabled-button:   rgba(black, 0.26),\n  disabled-text:     $dark-disabled-text,\n  elevation:         black,\n  hint-text:         $dark-disabled-text,\n  secondary-text:    $dark-secondary-text,\n  icon:              rgba(black, 0.54),\n  icons:             rgba(black, 0.54),\n  text:              rgba(black, 0.87),\n  slider-min:        rgba(black, 0.87),\n  slider-off:        rgba(black, 0.26),\n  slider-off-active: rgba(black, 0.38),\n);\n\n// Foreground palette for dark themes.\n$mat-dark-theme-foreground: (\n  base:              white,\n  divider:           $light-dividers,\n  dividers:          $light-dividers,\n  disabled:          $light-disabled-text,\n  disabled-button:   rgba(white, 0.3),\n  disabled-text:     $light-disabled-text,\n  elevation:         black,\n  hint-text:         $light-disabled-text,\n  secondary-text:    $light-secondary-text,\n  icon:              white,\n  icons:             white,\n  text:              white,\n  slider-min:        white,\n  slider-off:        rgba(white, 0.3),\n  slider-off-active: rgba(white, 0.3),\n);\n\n\n\n// For a given hue in a palette, return the contrast color from the map of contrast palettes.\n// @param $color-map\n// @param $hue\n@function mat-contrast($palette, $hue) {\n  @return map-get(map-get($palette, contrast), $hue);\n}\n\n\n// Creates a map of hues to colors for a theme. This is used to define a theme palette in terms\n// of the Material Design hues.\n// @param $color-map\n// @param $primary\n// @param $lighter\n@function mat-palette($base-palette, $default: 500, $lighter: 100, $darker: 700, $text: $default) {\n  $result: map_merge($base-palette, (\n    default: map-get($base-palette, $default),\n    lighter: map-get($base-palette, $lighter),\n    darker: map-get($base-palette, $darker),\n    text: map-get($base-palette, $text),\n\n    default-contrast: mat-contrast($base-palette, $default),\n    lighter-contrast: mat-contrast($base-palette, $lighter),\n    darker-contrast: mat-contrast($base-palette, $darker)\n  ));\n\n  // For each hue in the palette, add a \"-contrast\" color to the map.\n  @each $hue, $color in $base-palette {\n    $result: map_merge($result, (\n      '#{$hue}-contrast': mat-contrast($base-palette, $hue)\n    ));\n  }\n\n  @return $result;\n}\n\n\n// Gets a color from a theme palette (the output of mat-palette).\n// The hue can be one of the standard values (500, A400, etc.), one of the three preconfigured\n// hues (default, lighter, darker), or any of the aforementioned prefixed with \"-contrast\".\n//\n// @param $color-map The theme palette (output of mat-palette).\n// @param $hue The hue from the palette to use. If this is a value between 0 and 1, it will\n//     be treated as opacity.\n// @param $opacity The alpha channel value for the color.\n@function mat-color($palette, $hue: default, $opacity: null) {\n  // If hueKey is a number between zero and one, then it actually contains an\n  // opacity value, so recall this function with the default hue and that given opacity.\n  @if type-of($hue) == number and $hue >= 0 and $hue <= 1 {\n    @return mat-color($palette, default, $hue);\n  }\n\n  $color: map-get($palette, $hue);\n\n  @if (type-of($color) != color) {\n    // If the $color resolved to something different from a color (e.g. a CSS variable),\n    // we can't apply the opacity anyway so we return the value as is, otherwise Sass can\n    // throw an error or output something invalid.\n    @return $color;\n  }\n\n  @return rgba($color, if($opacity == null, opacity($color), $opacity));\n}\n\n\n// Creates a container object for a light theme to be given to individual component theme mixins.\n@function mat-light-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: false,\n    foreground: $mat-light-theme-foreground,\n    background: $mat-light-theme-background,\n  );\n}\n\n\n// Creates a container object for a dark theme to be given to individual component theme mixins.\n@function mat-dark-theme($primary, $accent, $warn: mat-palette($mat-red)) {\n  @return (\n    primary: $primary,\n    accent: $accent,\n    warn: $warn,\n    is-dark: true,\n    foreground: $mat-dark-theme-foreground,\n    background: $mat-dark-theme-background,\n  );\n}\n\n\n\n$mat-ripple-color-opacity: 0.1;\n\n@mixin mat-ripple() {\n\n  // The host element of an mat-ripple directive should always have a position of \"absolute\" or\n  // \"relative\" so that the ripples inside are correctly positioned relatively to the container.\n  .mat-ripple {\n    overflow: hidden;\n\n    // By default, every ripple container should have position: relative in favor of creating an\n    // easy API for developers using the MatRipple directive.\n    position: relative;\n  }\n\n  .mat-ripple.mat-ripple-unbounded {\n    overflow: visible;\n  }\n\n  .mat-ripple-element {\n    position: absolute;\n    border-radius: 50%;\n    pointer-events: none;\n\n    transition: opacity, transform 0ms cubic-bezier(0, 0, 0.2, 1);\n    transform: scale(0);\n\n    // In high contrast mode the ripple is opaque, causing it to obstruct the content.\n    @include cdk-high-contrast {\n      display: none;\n    }\n  }\n}\n\n/* Theme for the ripple elements.*/\n@mixin mat-ripple-theme($theme) {\n  $foreground: map_get($theme, foreground);\n  $foreground-base: map_get($foreground, base);\n\n  .mat-ripple-element {\n    // If the ripple color is resolves to a color *type*, we can use it directly, otherwise\n    // (e.g. it resolves to a CSS variable) we fall back to using the color and setting an opacity.\n    @if (type-of($foreground-base) == color) {\n      background-color: rgba($foreground-base, $mat-ripple-color-opacity);\n    }\n    @else {\n      background-color: $foreground-base;\n      opacity: $mat-ripple-color-opacity;\n    }\n  }\n}\n\n\n\n// Utility for fetching a nested value from a typography config.\n@function _mat-get-type-value($config, $level, $name) {\n  @return map-get(map-get($config, $level), $name);\n}\n\n// Gets the font size for a level inside a typography config.\n@function mat-font-size($config, $level) {\n  @return _mat-get-type-value($config, $level, font-size);\n}\n\n// Gets the line height for a level inside a typography config.\n@function mat-line-height($config, $level) {\n  @return _mat-get-type-value($config, $level, line-height);\n}\n\n// Gets the font weight for a level inside a typography config.\n@function mat-font-weight($config, $level) {\n  @return _mat-get-type-value($config, $level, font-weight);\n}\n\n// Gets the letter spacing for a level inside a typography config.\n@function mat-letter-spacing($config, $level) {\n  @return _mat-get-type-value($config, $level, letter-spacing);\n}\n\n// Gets the font-family from a typography config and removes the quotes around it.\n@function mat-font-family($config, $level: null) {\n  $font-family: map-get($config, font-family);\n\n  @if $level != null {\n    $font-family: _mat-get-type-value($config, $level, font-family);\n  }\n\n  // Guard against unquoting non-string values, because it's deprecated.\n  @return if(type-of($font-family) == string, unquote($font-family), $font-family);\n}\n\n// Outputs the shorthand `font` CSS property, based on a set of typography values. Falls back to\n// the individual properties if a value that isn't allowed in the shorthand is passed in.\n@mixin mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family) {\n  // If any of the values are set to `inherit`, we can't use the shorthand\n  // so we fall back to passing in the individual properties.\n  @if ($font-size == inherit or\n       $font-weight == inherit or\n       $line-height == inherit or\n       $font-family == inherit or\n       $font-size == null or\n       $font-weight == null or\n       $line-height == null or\n       $font-family == null) {\n\n    font-size: $font-size;\n    font-weight: $font-weight;\n    line-height: $line-height;\n    font-family: $font-family;\n  }\n  @else {\n    // Otherwise use the shorthand `font`, because it's the least amount of bytes. Note\n    // that we need to use interpolation for `font-size/line-height` in order to prevent\n    // Sass from dividing the two values.\n    font: $font-weight #{$font-size}/#{$line-height} $font-family;\n  }\n}\n\n// Converts a typography level into CSS styles.\n@mixin mat-typography-level-to-styles($config, $level) {\n  $font-size: mat-font-size($config, $level);\n  $font-weight: mat-font-weight($config, $level);\n  $line-height: mat-line-height($config, $level);\n  $font-family: mat-font-family($config, $level);\n\n  @include mat-typography-font-shorthand($font-size, $font-weight, $line-height, $font-family);\n  letter-spacing: mat-letter-spacing($config, $level);\n}\n\n\n@mixin mat-option-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-option {\n    color: mat-color($foreground, text);\n\n    &:hover:not(.mat-option-disabled),\n    &:focus:not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    // In multiple mode there is a checkbox to show that the option is selected.\n    &.mat-selected:not(.mat-option-multiple):not(.mat-option-disabled) {\n      background: mat-color($background, hover);\n    }\n\n    &.mat-active {\n      background: mat-color($background, hover);\n      color: mat-color($foreground, text);\n    }\n\n    &.mat-option-disabled {\n      color: mat-color($foreground, hint-text);\n    }\n  }\n\n  .mat-primary .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($primary, text);\n  }\n\n  .mat-accent .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-option.mat-selected:not(.mat-option-disabled) {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-option-typography($config) {\n  .mat-option {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, subheading-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-optgroup-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-optgroup-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-optgroup-disabled .mat-optgroup-label {\n    color: mat-color($foreground, hint-text);\n  }\n}\n\n@mixin mat-optgroup-typography($config) {\n  .mat-optgroup-label {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n}\n\n\n\n@mixin mat-pseudo-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n  $colored-box-selector: '.mat-pseudo-checkbox-checked, .mat-pseudo-checkbox-indeterminate';\n\n  .mat-pseudo-checkbox {\n    color: mat-color(map-get($theme, foreground), secondary-text);\n\n    &::after {\n      color: mat-color($background, background);\n    }\n  }\n\n  .mat-pseudo-checkbox-disabled {\n    color: $disabled-color;\n  }\n\n  // Default to the accent color. Note that the pseudo checkboxes are meant to inherit the\n  // theme from their parent, rather than implementing their own theming, which is why we\n  // don't attach to the `mat-*` classes.\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate,\n  .mat-accent .mat-pseudo-checkbox-checked,\n  .mat-accent .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, accent));\n  }\n\n  .mat-primary .mat-pseudo-checkbox-checked,\n  .mat-primary .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, primary));\n  }\n\n  .mat-warn .mat-pseudo-checkbox-checked,\n  .mat-warn .mat-pseudo-checkbox-indeterminate {\n    background: mat-color(map-get($theme, warn));\n  }\n\n  .mat-pseudo-checkbox-checked,\n  .mat-pseudo-checkbox-indeterminate {\n    &.mat-pseudo-checkbox-disabled {\n      background: $disabled-color;\n    }\n  }\n}\n\n\n\n// Represents a typography level from the Material design spec.\n@function mat-typography-level(\n  $font-size,\n  $line-height: $font-size,\n  $font-weight: 400,\n  $font-family: null,\n  $letter-spacing: null) {\n\n  @return (\n    font-size: $font-size,\n    line-height: $line-height,\n    font-weight: $font-weight,\n    font-family: $font-family,\n    letter-spacing: $letter-spacing\n  );\n}\n\n// Represents a collection of typography levels.\n// Defaults come from https://material.io/guidelines/style/typography.html\n// Note: The spec doesn't mention letter spacing. The values here come from\n// eyeballing it until it looked exactly like the spec examples.\n@function mat-typography-config(\n  $font-family:   'Roboto, \"Helvetica Neue\", sans-serif',\n  $display-4:     mat-typography-level(112px, 112px, 300, $letter-spacing: -0.05em),\n  $display-3:     mat-typography-level(56px, 56px, 400, $letter-spacing: -0.02em),\n  $display-2:     mat-typography-level(45px, 48px, 400, $letter-spacing: -0.005em),\n  $display-1:     mat-typography-level(34px, 40px, 400),\n  $headline:      mat-typography-level(24px, 32px, 400),\n  $title:         mat-typography-level(20px, 32px, 500),\n  $subheading-2:  mat-typography-level(16px, 28px, 400),\n  $subheading-1:  mat-typography-level(15px, 24px, 400),\n  $body-2:        mat-typography-level(14px, 24px, 500),\n  $body-1:        mat-typography-level(14px, 20px, 400),\n  $caption:       mat-typography-level(12px, 20px, 400),\n  $button:        mat-typography-level(14px, 14px, 500),\n  // Line-height must be unit-less fraction of the font-size.\n  $input:         mat-typography-level(inherit, 1.125, 400)\n) {\n\n  // Declare an initial map with all of the levels.\n  $config: (\n    display-4:      $display-4,\n    display-3:      $display-3,\n    display-2:      $display-2,\n    display-1:      $display-1,\n    headline:       $headline,\n    title:          $title,\n    subheading-2:   $subheading-2,\n    subheading-1:   $subheading-1,\n    body-2:         $body-2,\n    body-1:         $body-1,\n    caption:        $caption,\n    button:         $button,\n    input:          $input,\n  );\n\n  // Loop through the levels and set the `font-family` of the ones that don't have one to the base.\n  // Note that Sass can't modify maps in place, which means that we need to merge and re-assign.\n  @each $key, $level in $config {\n    @if map-get($level, font-family) == null {\n      $new-level: map-merge($level, (font-family: $font-family));\n      $config: map-merge($config, ($key: $new-level));\n    }\n  }\n\n  // Add the base font family to the config.\n  @return map-merge($config, (font-family: $font-family));\n}\n\n// Adds the base typography styles, based on a config.\n@mixin mat-base-typography($config, $selector: '.mat-typography') {\n  .mat-h1, .mat-headline, #{$selector} h1 {\n    @include mat-typography-level-to-styles($config, headline);\n    margin: 0 0 16px;\n  }\n\n  .mat-h2, .mat-title, #{$selector} h2 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0 0 16px;\n  }\n\n  .mat-h3, .mat-subheading-2, #{$selector} h3 {\n    @include mat-typography-level-to-styles($config, subheading-2);\n    margin: 0 0 16px;\n  }\n\n  .mat-h4, .mat-subheading-1, #{$selector} h4 {\n    @include mat-typography-level-to-styles($config, subheading-1);\n    margin: 0 0 16px;\n  }\n\n  // Note: the spec doesn't have anything that would correspond to h5 and h6, but we add these for\n  // consistency. The font sizes come from the Chrome user agent styles which have h5 at 0.83em\n  // and h6 at 0.67em.\n  .mat-h5, #{$selector} h5 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.83,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-h6, #{$selector} h6 {\n    @include mat-typography-font-shorthand(\n      mat-font-size($config, body-1) * 0.67,\n      mat-font-weight($config, body-1),\n      mat-line-height($config, body-1),\n      mat-font-family($config, body-1)\n    );\n\n    margin: 0 0 12px;\n  }\n\n  .mat-body-strong, .mat-body-2 {\n    @include mat-typography-level-to-styles($config, body-2);\n  }\n\n  .mat-body, .mat-body-1, #{$selector} {\n    @include mat-typography-level-to-styles($config, body-1);\n\n    p {\n      margin: 0 0 12px;\n    }\n  }\n\n  .mat-small, .mat-caption {\n    @include mat-typography-level-to-styles($config, caption);\n  }\n\n  .mat-display-4, #{$selector} .mat-display-4 {\n    @include mat-typography-level-to-styles($config, display-4);\n    margin: 0 0 56px;\n  }\n\n  .mat-display-3, #{$selector} .mat-display-3 {\n    @include mat-typography-level-to-styles($config, display-3);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-2, #{$selector} .mat-display-2 {\n    @include mat-typography-level-to-styles($config, display-2);\n    margin: 0 0 64px;\n  }\n\n  .mat-display-1, #{$selector} .mat-display-1 {\n    @include mat-typography-level-to-styles($config, display-1);\n    margin: 0 0 64px;\n  }\n}\n\n\n\n\n@mixin mat-autocomplete-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-autocomplete-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Selected options in autocompletes should not be gray, but we\n    // only want to override the background for selected options if\n    // they are *not* in hover or focus state. This change has to be\n    // made here because base option styles are shared between the\n    // autocomplete and the select.\n    .mat-option.mat-selected:not(.mat-active):not(:hover) {\n      background: mat-color($background, card);\n\n      &:not(.mat-option-disabled) {\n        color: mat-color($foreground, text);\n      }\n    }\n  }\n\n}\n\n@mixin mat-autocomplete-typography($config) { }\n\n// This contains all of the styles for the badge\n// rather than just the color/theme because of\n// no style sheet support for directives.\n\n\n\n\n\n$mat-badge-font-size: 12px;\n$mat-badge-font-weight: 600;\n$mat-badge-default-size: 22px !default;\n$mat-badge-small-size: $mat-badge-default-size - 6;\n$mat-badge-large-size: $mat-badge-default-size + 6;\n\n// Mixin for building offset given different sizes\n@mixin _mat-badge-size($size) {\n  .mat-badge-content {\n    width: $size;\n    height: $size;\n    line-height: $size;\n  }\n\n  &.mat-badge-above {\n    .mat-badge-content {\n      top: -$size / 2;\n    }\n  }\n\n  &.mat-badge-below {\n    .mat-badge-content {\n      bottom: -$size / 2;\n    }\n  }\n\n  &.mat-badge-before {\n    .mat-badge-content {\n      left: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-before {\n    .mat-badge-content {\n      left: auto;\n      right: -$size;\n    }\n  }\n\n  &.mat-badge-after {\n    .mat-badge-content {\n      right: -$size;\n    }\n  }\n\n  [dir='rtl'] &.mat-badge-after {\n    .mat-badge-content {\n      right: auto;\n      left: -$size;\n    }\n  }\n\n  &.mat-badge-overlap {\n    &.mat-badge-before {\n      .mat-badge-content {\n        left: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-before {\n      .mat-badge-content {\n        left: auto;\n        right: -$size / 2;\n      }\n    }\n\n    &.mat-badge-after {\n      .mat-badge-content {\n        right: -$size / 2;\n      }\n    }\n\n    [dir='rtl'] &.mat-badge-after {\n      .mat-badge-content {\n        right: auto;\n        left: -$size / 2;\n      }\n    }\n  }\n}\n\n@mixin mat-badge-theme($theme) {\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $primary: map-get($theme, primary);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-badge-content {\n    color: mat-color($primary, default-contrast);\n    background: mat-color($primary);\n\n    @include cdk-high-contrast {\n      outline: solid 1px;\n      border-radius: 0;\n    }\n  }\n\n  .mat-badge-accent {\n    .mat-badge-content {\n      background: mat-color($accent);\n      color: mat-color($accent, default-contrast);\n    }\n  }\n\n  .mat-badge-warn {\n    .mat-badge-content {\n      color: mat-color($warn, default-contrast);\n      background: mat-color($warn);\n    }\n  }\n\n  .mat-badge {\n    position: relative;\n  }\n\n  .mat-badge-hidden {\n    .mat-badge-content {\n      display: none;\n    }\n  }\n\n  .mat-badge-disabled {\n    .mat-badge-content {\n      $app-background: mat-color($background, 'background');\n      $badge-color: mat-color($foreground, disabled-button);\n\n      // The disabled color usually has some kind of opacity, but because the badge is overlayed\n      // on top of something else, it won't look good if it's opaque. If it is a color *type*,\n      // we convert it into a solid color by taking the opacity from the rgba value and using\n      // the value to determine the percentage of the background to put into foreground when\n      // mixing the colors together.\n      @if (type-of($badge-color) == color and type-of($app-background) == color) {\n        $badge-opacity: opacity($badge-color);\n        background: mix($app-background, rgba($badge-color, 1), (1 - $badge-opacity) * 100%);\n      }\n      @else {\n        background: $badge-color;\n      }\n\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-badge-content {\n    position: absolute;\n    text-align: center;\n    display: inline-block;\n    border-radius: 50%;\n    transition: transform 200ms ease-in-out;\n    transform: scale(0.6);\n    overflow: hidden;\n    white-space: nowrap;\n    text-overflow: ellipsis;\n    pointer-events: none;\n  }\n\n  .ng-animate-disabled .mat-badge-content,\n  .mat-badge-content._mat-animation-noopable {\n    transition: none;\n  }\n\n  // The active class is added after the element is added\n  // so it can animate scale to default\n  .mat-badge-content.mat-badge-active {\n    // Scale to `none` instead of `1` to avoid blurry text in some browsers.\n    transform: none;\n  }\n\n  .mat-badge-small {\n    @include _mat-badge-size($mat-badge-small-size);\n  }\n  .mat-badge-medium {\n    @include _mat-badge-size($mat-badge-default-size);\n  }\n  .mat-badge-large {\n    @include _mat-badge-size($mat-badge-large-size);\n  }\n}\n\n@mixin mat-badge-typography($config) {\n  .mat-badge-content {\n    font-weight: $mat-badge-font-weight;\n    font-size: $mat-badge-font-size;\n    font-family: mat-font-family($config);\n  }\n\n  .mat-badge-small .mat-badge-content {\n    // Set the font size to 75% of the original.\n    font-size: $mat-badge-font-size * 0.75;\n  }\n\n  .mat-badge-large .mat-badge-content {\n    font-size: $mat-badge-font-size * 2;\n  }\n}\n\n\n\n\n\n@mixin mat-bottom-sheet-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-bottom-sheet-container {\n    @include _mat-theme-elevation(16, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-bottom-sheet-typography($config) {\n  .mat-bottom-sheet-container {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n\n$_mat-button-ripple-opacity: 0.1;\n\n// Applies a focus style to an mat-button element for each of the supported palettes.\n@mixin _mat-button-focus-overlay-color($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-button-focus-overlay {\n    background-color: mat-color($primary);\n  }\n\n  &.mat-accent .mat-button-focus-overlay {\n    background-color: mat-color($accent);\n  }\n\n  &.mat-warn .mat-button-focus-overlay {\n    background-color: mat-color($warn);\n  }\n\n  &[disabled] .mat-button-focus-overlay {\n    background-color: transparent;\n  }\n}\n\n@mixin _mat-button-ripple-color($theme, $hue, $opacity: $_mat-button-ripple-opacity) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  &.mat-primary .mat-ripple-element {\n    background-color: mat-color($primary, $hue, $opacity);\n  }\n\n  &.mat-accent .mat-ripple-element {\n    background-color: mat-color($accent, $hue, $opacity);\n  }\n\n  &.mat-warn .mat-ripple-element {\n    background-color: mat-color($warn, $hue, $opacity);\n  }\n}\n\n// Applies a property to an mat-button element for each of the supported palettes.\n@mixin _mat-button-theme-property($theme, $property, $hue) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  &.mat-primary {\n    #{$property}: mat-color($primary, $hue);\n  }\n  &.mat-accent {\n    #{$property}: mat-color($accent, $hue);\n  }\n  &.mat-warn {\n    #{$property}: mat-color($warn, $hue);\n  }\n\n  &.mat-primary, &.mat-accent, &.mat-warn, &[disabled] {\n    &[disabled] {\n      $palette: if($property == 'color', $foreground, $background);\n      #{$property}: mat-color($palette, disabled-button);\n    }\n  }\n}\n\n@mixin mat-button-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-button, .mat-icon-button, .mat-stroked-button {\n    // Buttons without a background color should inherit the font color. This is necessary to\n    // ensure that the button is readable on custom background colors. It's wrong to always assume\n    // that those buttons are always placed inside of containers with the default background\n    // color of the theme (e.g. themed toolbars).\n    color: inherit;\n    background: transparent;\n\n    @include _mat-button-theme-property($theme, 'color', text);\n    @include _mat-button-focus-overlay-color($theme);\n\n    // Setup the ripple color to be based on the text color. This ensures that the ripples\n    // are matching with the current theme palette and are in contrast to the background color\n    // (e.g in themed toolbars).\n    .mat-ripple-element {\n      opacity: $_mat-button-ripple-opacity;\n      background-color: currentColor;\n    }\n  }\n\n  .mat-button-focus-overlay {\n    background: map_get($foreground, base);\n  }\n\n  // Note: this needs a bit extra specificity, because we're not guaranteed the inclusion\n  // order of the theme styles and the button reset may end up resetting this as well.\n  .mat-stroked-button:not([disabled]) {\n    border-color: mat-color($foreground, divider);\n  }\n\n  .mat-flat-button, .mat-raised-button, .mat-fab, .mat-mini-fab {\n    // Default font and background color when not using any color palette.\n    color: mat-color($foreground, text);\n    background-color: mat-color($background, raised-button);\n\n    @include _mat-button-theme-property($theme, 'color', default-contrast);\n    @include _mat-button-theme-property($theme, 'background-color', default);\n    @include _mat-button-ripple-color($theme, default-contrast);\n  }\n\n  .mat-stroked-button, .mat-flat-button {\n    @include _mat-theme-overridable-elevation(0, $theme);\n  }\n\n  .mat-raised-button {\n    @include _mat-theme-overridable-elevation(2, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(8, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-fab, .mat-mini-fab {\n    @include _mat-theme-overridable-elevation(6, $theme);\n\n    &:not([disabled]):active {\n      @include _mat-theme-overridable-elevation(12, $theme);\n    }\n\n    &[disabled] {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n}\n\n@mixin mat-button-typography($config) {\n  .mat-button, .mat-raised-button, .mat-icon-button, .mat-stroked-button,\n  .mat-flat-button, .mat-fab, .mat-mini-fab {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-button-toggle-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $divider-color: mat-color($foreground, divider);\n\n  .mat-button-toggle-standalone,\n  .mat-button-toggle-group {\n    @include _mat-theme-elevation(2, $theme);\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    box-shadow: none;\n  }\n\n  .mat-button-toggle {\n    color: mat-color($foreground, hint-text);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button);\n    }\n  }\n\n  .mat-button-toggle-appearance-standard {\n    color: mat-color($foreground, text);\n    background: mat-color($background, card);\n\n    .mat-button-toggle-focus-overlay {\n      background-color: mat-color($background, focused-button, 1);\n    }\n  }\n\n  .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: solid 1px $divider-color;\n  }\n\n  [dir='rtl'] .mat-button-toggle-group-appearance-standard .mat-button-toggle + .mat-button-toggle {\n    border-left: none;\n    border-right: solid 1px $divider-color;\n  }\n\n  .mat-button-toggle-group-appearance-standard.mat-button-toggle-vertical {\n    .mat-button-toggle + .mat-button-toggle {\n      border-left: none;\n      border-right: none;\n      border-top: solid 1px $divider-color;\n    }\n  }\n\n  .mat-button-toggle-checked {\n    background-color: mat-color($background, selected-button);\n    color: mat-color($foreground, secondary-text);\n\n    &.mat-button-toggle-appearance-standard {\n      color: mat-color($foreground, text);\n    }\n  }\n\n  .mat-button-toggle-disabled {\n    color: mat-color($foreground, disabled-button);\n    background-color: mat-color($background, disabled-button-toggle);\n\n    &.mat-button-toggle-appearance-standard {\n      background: mat-color($background, card);\n    }\n\n    &.mat-button-toggle-checked {\n      background-color: mat-color($background, selected-disabled-button);\n    }\n  }\n\n  .mat-button-toggle-standalone.mat-button-toggle-appearance-standard,\n  .mat-button-toggle-group-appearance-standard {\n    border: solid 1px $divider-color;\n  }\n}\n\n@mixin mat-button-toggle-typography($config) {\n  .mat-button-toggle {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-card-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-card {\n    @include _mat-theme-overridable-elevation(1, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    // Needs extra specificity to be able to override the elevation selectors.\n    &.mat-card-flat {\n      @include _mat-theme-overridable-elevation(0, $theme);\n    }\n  }\n\n  .mat-card-subtitle {\n    color: mat-color($foreground, secondary-text);\n  }\n}\n\n@mixin mat-card-typography($config) {\n  .mat-card {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-card-title {\n    font: {\n      size: mat-font-size($config, headline);\n      weight: mat-font-weight($config, title);\n    }\n  }\n\n  .mat-card-header .mat-card-title {\n    font-size: mat-font-size($config, title);\n  }\n\n  .mat-card-subtitle,\n  .mat-card-content {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n@mixin mat-checkbox-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n\n  // The color of the checkbox's checkmark / mixedmark.\n  $checkbox-mark-color: mat-color($background, background);\n\n  // NOTE(traviskaufman): While the spec calls for translucent blacks/whites for disabled colors,\n  // this does not work well with elements layered on top of one another. To get around this we\n  // blend the colors together based on the base color and the theme background.\n  $white-30pct-opacity-on-dark: #686868;\n  $black-26pct-opacity-on-light: #b0b0b0;\n  $disabled-color: if($is-dark-theme, $white-30pct-opacity-on-dark, $black-26pct-opacity-on-light);\n\n  .mat-checkbox-frame {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-checkbox-checkmark {\n    fill: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-checkmark-path {\n    // !important is needed here because a stroke must be set as an\n    // attribute on the SVG in order for line animation to work properly.\n    stroke: $checkbox-mark-color !important;\n\n    @include cdk-high-contrast(black-on-white) {\n      // Having the one above be !important ends up overriding the browser's automatic\n      // color inversion so we need to re-invert it ourselves for black-on-white.\n      stroke: #000 !important;\n    }\n  }\n\n  .mat-checkbox-mixedmark {\n    background-color: $checkbox-mark-color;\n  }\n\n  .mat-checkbox-indeterminate, .mat-checkbox-checked {\n    &.mat-primary .mat-checkbox-background {\n      background-color: mat-color($primary);\n    }\n\n    &.mat-accent .mat-checkbox-background {\n      background-color: mat-color($accent);\n    }\n\n    &.mat-warn .mat-checkbox-background {\n      background-color: mat-color($warn);\n    }\n  }\n\n  .mat-checkbox-disabled {\n    &.mat-checkbox-checked,\n    &.mat-checkbox-indeterminate {\n      .mat-checkbox-background {\n        background-color: $disabled-color;\n      }\n    }\n\n    &:not(.mat-checkbox-checked) {\n      .mat-checkbox-frame {\n        border-color: $disabled-color;\n      }\n    }\n\n    .mat-checkbox-label {\n      color: mat-color($foreground, secondary-text);\n    }\n\n    @include cdk-high-contrast {\n      opacity: 0.5;\n    }\n  }\n\n  // This one is moved down here so it can target both\n  // the theme colors and the disabled state.\n  @include cdk-high-contrast {\n    .mat-checkbox-background {\n      // Needs to be removed because it hides the checkbox outline.\n      background: none;\n    }\n  }\n\n  // Switch this to a solid color since we're using `opacity`\n  // to control how opaque the ripple should be.\n  .mat-checkbox .mat-ripple-element {\n    background-color: map_get(map-get($theme, foreground), base);\n  }\n\n  .mat-checkbox-checked:not(.mat-checkbox-disabled),\n  .mat-checkbox:active:not(.mat-checkbox-disabled) {\n    &.mat-primary .mat-ripple-element {\n      background: mat-color($primary);\n    }\n\n    &.mat-accent .mat-ripple-element {\n      background: mat-color($accent);\n    }\n\n    &.mat-warn .mat-ripple-element {\n      background: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-checkbox-typography($config) {\n  .mat-checkbox {\n    font-family: mat-font-family($config);\n  }\n\n  // TODO(kara): Remove this style when fixing vertical baseline\n  .mat-checkbox-layout .mat-checkbox-label {\n    line-height: mat-line-height($config, body-2);\n  }\n}\n\n\n\n\n\n\n$mat-chip-remove-font-size: 18px;\n\n@mixin mat-chips-color($foreground, $background) {\n  background-color: $background;\n  color: $foreground;\n\n  .mat-chip-remove {\n    color: $foreground;\n    opacity: 0.4;\n  }\n}\n\n@mixin mat-chips-theme-color($palette) {\n  @include mat-chips-color(mat-color($palette, default-contrast), mat-color($palette));\n\n  .mat-ripple-element {\n    background: mat-color($palette, default-contrast, 0.1);\n  }\n}\n\n@mixin mat-chips-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $unselected-background: mat-color($background, unselected-chip);\n  $unselected-foreground: mat-color($foreground, text);\n\n  .mat-chip.mat-standard-chip {\n    @include mat-chips-color($unselected-foreground, $unselected-background);\n\n    &:not(.mat-chip-disabled) {\n      &:active {\n        @include _mat-theme-elevation(3, $theme);\n      }\n\n      .mat-chip-remove:hover {\n        opacity: 0.54;\n      }\n    }\n\n    &.mat-chip-disabled {\n      opacity: 0.4;\n    }\n\n    &::after {\n      background: map_get($foreground, base);\n    }\n  }\n\n  .mat-chip.mat-standard-chip.mat-chip-selected {\n    &.mat-primary {\n      @include mat-chips-theme-color($primary);\n    }\n\n    &.mat-warn {\n      @include mat-chips-theme-color($warn);\n    }\n\n    &.mat-accent {\n      @include mat-chips-theme-color($accent);\n    }\n  }\n}\n\n@mixin mat-chips-typography($config) {\n  .mat-chip {\n    font-size: mat-font-size($config, body-2);\n    font-weight: mat-font-weight($config, body-2);\n\n    .mat-chip-trailing-icon.mat-icon,\n    .mat-chip-remove.mat-icon {\n      font-size: $mat-chip-remove-font-size;\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-table-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-table {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-table thead, .mat-table tbody, .mat-table tfoot,\n  mat-header-row, mat-row, mat-footer-row,\n  [mat-header-row], [mat-row], [mat-footer-row],\n  .mat-table-sticky {\n    background: inherit;\n  }\n\n  mat-row, mat-header-row, mat-footer-row,\n  th.mat-header-cell, td.mat-cell, td.mat-footer-cell {\n    border-bottom-color: mat-color($foreground, divider);\n  }\n\n  .mat-header-cell {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-table-typography($config) {\n  .mat-table {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-header-cell {\n    font-size: mat-font-size($config, caption);\n    font-weight: mat-font-weight($config, body-2);\n  }\n\n  .mat-cell, .mat-footer-cell {\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n\n\n\n$mat-datepicker-selected-today-box-shadow-width: 1px;\n$mat-datepicker-selected-fade-amount: 0.6;\n$mat-datepicker-today-fade-amount: 0.2;\n$mat-calendar-body-font-size: 13px !default;\n$mat-calendar-weekday-table-font-size: 11px !default;\n\n@mixin _mat-datepicker-color($palette) {\n  .mat-calendar-body-selected {\n    background-color: mat-color($palette);\n    color: mat-color($palette, default-contrast);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-selected {\n    $background: mat-color($palette);\n\n    @if (type-of($background) == color) {\n      background-color: fade-out($background, $mat-datepicker-selected-fade-amount);\n    }\n    @else {\n      // If we couldn't resolve to background to a color (e.g. it's a CSS variable),\n      // fall back to fading the content out via `opacity`.\n      opacity: $mat-datepicker-today-fade-amount;\n    }\n  }\n\n  .mat-calendar-body-today.mat-calendar-body-selected {\n    box-shadow: inset 0 0 0 $mat-datepicker-selected-today-box-shadow-width\n                mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-datepicker-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-calendar-arrow {\n    border-top-color: mat-color($foreground, icon);\n  }\n\n  // The prev/next buttons need a bit more specificity to\n  // avoid being overwritten by the .mat-icon-button.\n  .mat-datepicker-toggle,\n  .mat-datepicker-content .mat-calendar-next-button,\n  .mat-datepicker-content .mat-calendar-previous-button {\n    color: mat-color($foreground, icon);\n  }\n\n  .mat-calendar-table-header {\n    color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-table-header-divider::after {\n    background: mat-color($foreground, divider);\n  }\n\n  .mat-calendar-body-label {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-calendar-body-cell-content {\n    color: mat-color($foreground, text);\n    border-color: transparent;\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover,\n  .cdk-keyboard-focused .mat-calendar-body-active,\n  .cdk-program-focused .mat-calendar-body-active {\n    & > .mat-calendar-body-cell-content:not(.mat-calendar-body-selected) {\n      background-color: mat-color($background, hover);\n    }\n  }\n\n  .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    // Note: though it's not text, the border is a hint about the fact that this is today's date,\n    // so we use the hint color.\n    border-color: mat-color($foreground, hint-text);\n  }\n\n  .mat-calendar-body-disabled > .mat-calendar-body-today:not(.mat-calendar-body-selected) {\n    $color: mat-color($foreground, hint-text);\n\n    @if (type-of($color) == color) {\n      border-color: fade-out($color, $mat-datepicker-today-fade-amount);\n    }\n    @else {\n      // If the color didn't resolve to a color value, but something like a CSS variable, we can't\n      // fade it out so we fall back to reducing the element opacity. Note that we don't use the\n      // $mat-datepicker-today-fade-amount, because hint text usually has some opacity applied\n      // to it already and we don't want them to stack on top of each other.\n      opacity: 0.5;\n    }\n  }\n\n  @include _mat-datepicker-color(map-get($theme, primary));\n\n  .mat-datepicker-content {\n    @include _mat-theme-elevation(4, $theme);\n    background-color: mat-color($background, card);\n    color: mat-color($foreground, text);\n\n    &.mat-accent {\n      @include _mat-datepicker-color(map-get($theme, accent));\n    }\n\n    &.mat-warn {\n      @include _mat-datepicker-color(map-get($theme, warn));\n    }\n  }\n\n  .mat-datepicker-content-touch {\n    @include _mat-theme-elevation(0, $theme);\n  }\n\n  .mat-datepicker-toggle-active {\n    color: mat-color(map-get($theme, primary), text);\n\n    &.mat-accent {\n      color: mat-color(map-get($theme, accent), text);\n    }\n\n    &.mat-warn {\n      color: mat-color(map-get($theme, warn), text);\n    }\n  }\n}\n\n@mixin mat-datepicker-typography($config) {\n  .mat-calendar {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-calendar-body {\n    font-size: $mat-calendar-body-font-size;\n  }\n\n  .mat-calendar-body-label,\n  .mat-calendar-period-button {\n    font: {\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n\n  .mat-calendar-table-header th {\n    font: {\n      size: $mat-calendar-weekday-table-font-size;\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-dialog-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-dialog-container {\n    @include _mat-theme-elevation(24, $theme);\n    background: mat-color($background, dialog);\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-dialog-typography($config) {\n  .mat-dialog-title {\n    @include mat-typography-level-to-styles($config, title);\n  }\n}\n\n\n\n\n\n\n@mixin mat-expansion-panel-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-expansion-panel {\n    @include _mat-theme-overridable-elevation(2, $theme);\n    background: mat-color($background, card);\n    color: mat-color($foreground, text);\n  }\n\n  .mat-action-row {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-expansion-panel:not(.mat-expanded) .mat-expansion-panel-header {\n    &:not([aria-disabled='true']) {\n      &.cdk-keyboard-focused,\n      &.cdk-program-focused,\n      &:hover {\n        background: mat-color($background, hover);\n      }\n    }\n  }\n\n  // Disable the hover on touch devices since it can appear like it is stuck. We can't use\n  // `@media (hover)` above, because the desktop support browser support isn't great.\n  @media (hover: none) {\n    .mat-expansion-panel:not(.mat-expanded):not([aria-disabled='true'])\n      .mat-expansion-panel-header:hover {\n      background: mat-color($background, card);\n    }\n  }\n\n  .mat-expansion-panel-header-title {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-expansion-panel-header-description,\n  .mat-expansion-indicator::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-expansion-panel-header[aria-disabled='true'] {\n    color: mat-color($foreground, disabled-button);\n\n    .mat-expansion-panel-header-title,\n    .mat-expansion-panel-header-description {\n      color: inherit;\n    }\n  }\n}\n\n@mixin mat-expansion-panel-typography($config) {\n  .mat-expansion-panel-header {\n    font: {\n      family: mat-font-family($config, subheading-1);\n      size: mat-font-size($config, subheading-1);\n      weight: mat-font-weight($config, subheading-1);\n    }\n  }\n\n  .mat-expansion-panel-content {\n    @include mat-typography-level-to-styles($config, body-1);\n  }\n}\n\n\n\n\n// This mixin will ensure that lines that overflow the container will hide the overflow and\n// truncate neatly with an ellipsis.\n@mixin mat-truncate-line() {\n  white-space: nowrap;\n  overflow: hidden;\n  text-overflow: ellipsis;\n}\n\n// Mixin to provide all mat-line styles, changing secondary font size based on whether the list\n// is in dense mode.\n@mixin mat-line-base($secondary-font-size) {\n  .mat-line {\n    @include mat-truncate-line();\n    display: block;\n    box-sizing: border-box;\n\n    // all lines but the top line should have smaller text\n    &:nth-child(n+2) {\n      font-size: $secondary-font-size;\n    }\n  }\n}\n\n// This mixin normalizes default element styles, e.g. font weight for heading text.\n@mixin mat-normalize-text() {\n  & > * {\n    margin: 0;\n    padding: 0;\n    font-weight: normal;\n    font-size: inherit;\n  }\n}\n\n// This mixin provides base styles for the wrapper around mat-line elements in a list.\n@mixin mat-line-wrapper-base() {\n  @include mat-normalize-text();\n\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  box-sizing: border-box;\n  overflow: hidden;\n\n  // Must remove wrapper when lines are empty or it takes up horizontal\n  // space and pushes other elements to the right.\n  &:empty {\n    display: none;\n  }\n}\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-grid-list-theme($theme) { }\n\n@mixin mat-grid-list-typography($config) {\n  .mat-grid-tile-header,\n  .mat-grid-tile-footer {\n    @include mat-line-base(mat-font-size($config, caption));\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n\n// Include this empty mixin for consistency with the other components.\n@mixin mat-icon-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-icon {\n    &.mat-primary {\n      color: mat-color($primary, text);\n    }\n\n    &.mat-accent {\n      color: mat-color($accent, text);\n    }\n\n    &.mat-warn {\n      color: mat-color($warn, text);\n    }\n  }\n}\n\n@mixin mat-icon-typography($config) { }\n\n\n\n\n\n// Renders a gradient for showing the dashed line when the input is disabled.\n// Unlike using a border, a gradient allows us to adjust the spacing of the dotted line\n// to match the Material Design spec.\n@mixin mat-control-disabled-underline($color) {\n  background-image: linear-gradient(to right, $color 0%, $color 33%, transparent 0%);\n  background-size: 4px 100%;\n  background-repeat: repeat-x;\n}\n\n// Figures out the color of the placeholder for a form control.\n// Used primarily to prevent the various form controls from\n// becoming out of sync since these colors aren't in a palette.\n@function _mat-control-placeholder-color($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n  @return mat-color($foreground, secondary-text, if($is-dark-theme, 0.5, 0.42));\n}\n\n\n/* stylelint-disable material/no-prefixes */\n@mixin user-select($value) {\n  -webkit-user-select: $value;\n  -moz-user-select: $value;\n  -ms-user-select: $value;\n  user-select: $value;\n}\n\n@mixin input-placeholder {\n  &::placeholder {\n    @content;\n  }\n\n  &::-moz-placeholder {\n    @content;\n  }\n\n  &::-webkit-input-placeholder {\n    @content;\n  }\n\n  &:-ms-input-placeholder {\n    @content;\n  }\n}\n\n@mixin cursor-grab {\n  cursor: -webkit-grab;\n  cursor: grab;\n}\n\n@mixin cursor-grabbing {\n  cursor: -webkit-grabbing;\n  cursor: grabbing;\n}\n\n@mixin backface-visibility($value) {\n  -webkit-backface-visibility: $value;\n  backface-visibility: $value;\n}\n/* stylelint-enable */\n\n\n\n@mixin mat-input-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n\n  .mat-form-field-type-mat-native-select .mat-form-field-infix::after {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-input-element:disabled,\n  .mat-form-field-type-mat-native-select.mat-form-field-disabled .mat-form-field-infix::after {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-input-element {\n    caret-color: mat-color($primary, text);\n\n    @include input-placeholder {\n      color: _mat-control-placeholder-color($theme);\n    }\n\n    // On dark themes we set the native `select` color to some shade of white,\n    // however the color propagates to all of the `option` elements, which are\n    // always on a white background inside the dropdown, causing them to blend in.\n    // Since we can't change background of the dropdown, we need to explicitly\n    // reset the color of the options to something dark.\n    @if (map-get($theme, is-dark)) {\n      option {\n        color: $dark-primary-text;\n      }\n\n      option:disabled {\n        color: $dark-disabled-text;\n      }\n    }\n  }\n\n  .mat-accent .mat-input-element {\n    caret-color: mat-color($accent, text);\n  }\n\n  .mat-warn .mat-input-element,\n  .mat-form-field-invalid .mat-input-element {\n    caret-color: mat-color($warn, text);\n  }\n\n  .mat-form-field-type-mat-native-select.mat-form-field-invalid .mat-form-field-infix::after {\n    color: mat-color($warn, text);\n  }\n}\n\n@mixin mat-input-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n\n  // <input> elements seem to have their height set slightly too large on Safari causing the text to\n  // be misaligned w.r.t. the placeholder. Adding this margin corrects it.\n  input.mat-input-element {\n    margin-top: -$line-spacing * 1em;\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-list-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-list-base {\n    .mat-list-item {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-list-option {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-subheader {\n      color: mat-color($foreground, secondary-text);\n    }\n  }\n\n  .mat-list-item-disabled {\n    background-color: mat-color($background, disabled-list-option);\n  }\n\n  .mat-list-option,\n  .mat-nav-list .mat-list-item,\n  .mat-action-list .mat-list-item {\n    &:hover, &:focus {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-list-typography($config) {\n  $font-family: mat-font-family($config);\n\n  .mat-list-item {\n    font-family: $font-family;\n  }\n\n  .mat-list-option {\n    font-family: $font-family;\n  }\n\n  // Default list\n  .mat-list-base {\n    .mat-list-item {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, subheading-2);\n      @include mat-line-base(mat-font-size($config, body-1));\n    }\n\n    .mat-subheader {\n      font-family: mat-font-family($config, body-2);\n      font-size: mat-font-size($config, body-2);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n\n  // Dense list\n  .mat-list-base[dense] {\n    .mat-list-item {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-list-option {\n      font-size: mat-font-size($config, caption);\n      @include mat-line-base(mat-font-size($config, caption));\n    }\n\n    .mat-subheader {\n      font-family: $font-family;\n      font-size: mat-font-size($config, caption);\n      font-weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n\n\n@mixin mat-menu-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-menu-panel {\n    @include _mat-theme-overridable-elevation(4, $theme);\n    background: mat-color($background, 'card');\n  }\n\n  .mat-menu-item {\n    background: transparent;\n    color: mat-color($foreground, 'text');\n\n    &[disabled] {\n      &, &::after {\n        color: mat-color($foreground, 'disabled');\n      }\n    }\n  }\n\n  .mat-menu-item .mat-icon-no-color,\n  .mat-menu-item-submenu-trigger::after {\n    color: mat-color($foreground, 'icon');\n  }\n\n  .mat-menu-item:hover,\n  .mat-menu-item.cdk-program-focused,\n  .mat-menu-item.cdk-keyboard-focused,\n  .mat-menu-item-highlighted {\n    &:not([disabled]) {\n      background: mat-color($background, 'hover');\n    }\n  }\n}\n\n@mixin mat-menu-typography($config) {\n  .mat-menu-item {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin mat-paginator-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n\n  .mat-paginator {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-paginator-decrement,\n  .mat-paginator-increment {\n    border-top: 2px solid mat-color($foreground, 'icon');\n    border-right: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-paginator-first,\n  .mat-paginator-last {\n    border-top: 2px solid mat-color($foreground, 'icon');\n  }\n\n  .mat-icon-button[disabled] {\n    .mat-paginator-decrement,\n    .mat-paginator-increment,\n    .mat-paginator-first,\n    .mat-paginator-last {\n      border-color: mat-color($foreground, 'disabled');\n    }\n  }\n}\n\n@mixin mat-paginator-typography($config) {\n  .mat-paginator,\n  .mat-paginator-page-size .mat-select-trigger {\n    font: {\n      family: mat-font-family($config, caption);\n      size: mat-font-size($config, caption);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-progress-bar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-bar-background {\n    fill: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-buffer {\n    background-color: mat-color($primary, lighter);\n  }\n\n  .mat-progress-bar-fill::after {\n    background-color: mat-color($primary);\n  }\n\n  .mat-progress-bar.mat-accent {\n    .mat-progress-bar-background {\n      fill: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($accent, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($accent);\n    }\n  }\n\n  .mat-progress-bar.mat-warn {\n    .mat-progress-bar-background {\n      fill: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-buffer {\n      background-color: mat-color($warn, lighter);\n    }\n\n    .mat-progress-bar-fill::after {\n      background-color: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-bar-typography($config) { }\n\n\n\n\n\n\n@mixin mat-progress-spinner-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-progress-spinner, .mat-spinner {\n    circle {\n      stroke: mat-color($primary);\n    }\n\n    &.mat-accent circle {\n      stroke: mat-color($accent);\n    }\n\n    &.mat-warn circle {\n      stroke: mat-color($warn);\n    }\n  }\n}\n\n@mixin mat-progress-spinner-typography($config) { }\n\n\n\n\n\n@mixin _mat-radio-color($palette) {\n  &.mat-radio-checked .mat-radio-outer-circle {\n    border-color: mat-color($palette);\n  }\n\n  .mat-radio-inner-circle,\n  .mat-radio-ripple .mat-ripple-element:not(.mat-radio-persistent-ripple),\n  &.mat-radio-checked .mat-radio-persistent-ripple,\n  &:active .mat-radio-persistent-ripple {\n    background-color: mat-color($palette);\n  }\n}\n\n@mixin mat-radio-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-radio-outer-circle {\n    border-color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-radio-button {\n    &.mat-primary {\n      @include _mat-radio-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-radio-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-radio-color($warn);\n    }\n\n    // This needs extra specificity, because the classes above are combined\n    // (e.g. `.mat-radio-button.mat-accent`) which increases their specificity a lot.\n    // TODO: consider making the selectors into descendants (`.mat-primary .mat-radio-button`).\n    &.mat-radio-disabled {\n      &.mat-radio-checked .mat-radio-outer-circle,\n      .mat-radio-outer-circle {\n        border-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-ripple .mat-ripple-element,\n      .mat-radio-inner-circle {\n        background-color: mat-color($foreground, disabled);\n      }\n\n      .mat-radio-label-content {\n        color: mat-color($foreground, disabled);\n      }\n    }\n\n    // Switch this to a solid color since we're using `opacity`\n    // to control how opaque the ripple should be.\n    .mat-ripple-element {\n      background-color: map_get($foreground, base);\n    }\n  }\n}\n\n@mixin mat-radio-typography($config) {\n  .mat-radio-button {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n\n\n\n@mixin mat-select-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n\n  .mat-select-value {\n    color: mat-color($foreground, text);\n  }\n\n  .mat-select-placeholder {\n    color: _mat-control-placeholder-color($theme);\n  }\n\n  .mat-select-disabled .mat-select-value {\n    color: mat-color($foreground, disabled-text);\n  }\n\n  .mat-select-arrow {\n    color: mat-color($foreground, secondary-text);\n  }\n\n  .mat-select-panel {\n    background: mat-color($background, card);\n    @include _mat-theme-overridable-elevation(4, $theme);\n\n    .mat-option.mat-selected:not(.mat-option-multiple) {\n      background: mat-color($background, hover, 0.12);\n    }\n  }\n\n  .mat-form-field {\n    &.mat-focused {\n      &.mat-primary .mat-select-arrow {\n        color: mat-color($primary, text);\n      }\n\n      &.mat-accent .mat-select-arrow {\n        color: mat-color($accent, text);\n      }\n\n      &.mat-warn .mat-select-arrow {\n        color: mat-color($warn, text);\n      }\n    }\n\n    .mat-select.mat-select-invalid .mat-select-arrow {\n      color: mat-color($warn, text);\n    }\n\n    .mat-select.mat-select-disabled .mat-select-arrow {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n}\n\n@mixin mat-select-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  .mat-select {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-select-trigger {\n    height: $line-height * 1em;\n  }\n}\n\n\n\n\n\n\n@mixin mat-sidenav-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $drawer-background-color: mat-color($background, dialog);\n  $drawer-container-background-color:  mat-color($background, background);\n  $drawer-push-background-color: mat-color($background, dialog);\n  $drawer-side-border: solid 1px mat-color($foreground, divider);\n\n  .mat-drawer-container {\n    background-color: $drawer-container-background-color;\n    color: mat-color($foreground, text);\n  }\n\n  .mat-drawer {\n    background-color: $drawer-background-color;\n    color: mat-color($foreground, text);\n\n    &.mat-drawer-push {\n      background-color: $drawer-push-background-color;\n    }\n\n    &:not(.mat-drawer-side) {\n      // The elevation of z-16 is noted in the design specifications.\n      // See https://material.io/design/components/navigation-drawer.html\n      @include _mat-theme-elevation(16, $theme);\n    }\n  }\n\n  .mat-drawer-side {\n    border-right: $drawer-side-border;\n\n    &.mat-drawer-end {\n      border-left: $drawer-side-border;\n      border-right: none;\n    }\n  }\n\n  [dir='rtl'] .mat-drawer-side {\n    border-left: $drawer-side-border;\n    border-right: none;\n\n    &.mat-drawer-end {\n      border-left: none;\n      border-right: $drawer-side-border;\n    }\n  }\n\n  .mat-drawer-backdrop.mat-drawer-shown {\n    $opacity: 0.6;\n    $backdrop-color: mat-color($background, card, $opacity);\n\n    @if (type-of($backdrop-color) == color) {\n      // We use invert() here to have the darken the background color expected to be used. If the\n      // background is light, we use a dark backdrop. If the background is dark,\n      // we use a light backdrop.\n      background-color: invert($backdrop-color);\n    }\n    @else {\n      // If we couldn't resolve the backdrop color to a color value, fall back to using\n      // `opacity` to make it opaque since its end value could be a solid color.\n      background-color: $backdrop-color;\n      opacity: $opacity;\n    }\n  }\n}\n\n@mixin mat-sidenav-typography($config) { }\n\n\n\n\n\n\n@mixin _mat-slide-toggle-checked($palette, $thumb-checked-hue) {\n  &.mat-checked {\n    .mat-slide-toggle-thumb {\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n\n    .mat-slide-toggle-bar {\n      // Opacity is determined from the specs for the selection controls.\n      // See: https://material.io/design/components/selection-controls.html#specs\n      background-color: mat-color($palette, $thumb-checked-hue, 0.54);\n    }\n\n    .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: mat-color($palette, $thumb-checked-hue);\n    }\n  }\n}\n\n@mixin mat-slide-toggle-theme($theme) {\n  $is-dark: map_get($theme, is-dark);\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  // Color hues are based on the specs which briefly show the hues that are applied to a switch.\n  // The 2018 specs no longer describe how dark switches should look like. Due to the lack of\n  // information for dark themed switches, we partially keep the old behavior that is based on\n  // the previous specifications. For the checked color we always use the `default` hue because\n  // that follows MDC and also makes it easier for people to create a custom theme without needing\n  // to specify each hue individually.\n  $thumb-unchecked-hue: if($is-dark, 400, 50);\n  $thumb-checked-hue: default;\n\n  $bar-unchecked-color: mat-color($foreground, disabled);\n  $ripple-unchecked-color: mat-color($foreground, base);\n\n  .mat-slide-toggle {\n    @include _mat-slide-toggle-checked($accent, $thumb-checked-hue);\n\n    &.mat-primary {\n      @include _mat-slide-toggle-checked($primary, $thumb-checked-hue);\n    }\n\n    &.mat-warn {\n      @include _mat-slide-toggle-checked($warn, $thumb-checked-hue);\n    }\n\n    &:not(.mat-checked) .mat-ripple-element {\n      // Set no opacity for the ripples because the ripple opacity will be adjusted dynamically\n      // based on the type of interaction with the slide-toggle (e.g. for hover, focus)\n      background-color: $ripple-unchecked-color;\n    }\n  }\n\n  .mat-slide-toggle-thumb {\n    @include _mat-theme-elevation(1, $theme);\n    background-color: mat-color($mat-grey, $thumb-unchecked-hue);\n  }\n\n  .mat-slide-toggle-bar {\n    background-color: $bar-unchecked-color;\n  }\n}\n\n@mixin mat-slide-toggle-typography($config) {\n  .mat-slide-toggle-content {\n    font-family: mat-font-family($config);\n  }\n}\n\n\n\n\n\n@mixin _mat-slider-inner-content-theme($palette) {\n  .mat-slider-track-fill,\n  .mat-slider-thumb,\n  .mat-slider-thumb-label {\n    background-color: mat-color($palette);\n  }\n\n  .mat-slider-thumb-label-text {\n    color: mat-color($palette, default-contrast);\n  }\n}\n\n@mixin mat-slider-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  $mat-slider-off-color: mat-color($foreground, slider-off);\n  $mat-slider-off-focused-color: mat-color($foreground, slider-off-active);\n  $mat-slider-disabled-color: mat-color($foreground, slider-off);\n  $mat-slider-labeled-min-value-thumb-color: mat-color($foreground, slider-min);\n  $mat-slider-labeled-min-value-thumb-label-color: mat-color($foreground, slider-off);\n  $mat-slider-focus-ring-color: mat-color($accent, default, 0.2);\n  $mat-slider-focus-ring-min-value-color: mat-color($foreground, base, 0.12);\n  $mat-slider-tick-color: mat-color($foreground, base, 0.7);\n  $mat-slider-tick-size: 2px;\n\n  .mat-slider-track-background {\n    background-color: $mat-slider-off-color;\n  }\n\n  .mat-primary {\n    @include _mat-slider-inner-content-theme($primary);\n  }\n\n  .mat-accent {\n    @include _mat-slider-inner-content-theme($accent);\n  }\n\n  .mat-warn {\n    @include _mat-slider-inner-content-theme($warn);\n  }\n\n  .mat-slider-focus-ring {\n    background-color: $mat-slider-focus-ring-color;\n  }\n\n  .mat-slider:hover,\n  .cdk-focused {\n    .mat-slider-track-background {\n      background-color: $mat-slider-off-focused-color;\n    }\n  }\n\n  .mat-slider-disabled {\n    .mat-slider-track-background,\n    .mat-slider-track-fill,\n    .mat-slider-thumb {\n      background-color: $mat-slider-disabled-color;\n    }\n\n    &:hover {\n      .mat-slider-track-background {\n        background-color: $mat-slider-disabled-color;\n      }\n    }\n  }\n\n  .mat-slider-min-value {\n    .mat-slider-focus-ring {\n      background-color: $mat-slider-focus-ring-min-value-color;\n    }\n\n    &.mat-slider-thumb-label-showing {\n      .mat-slider-thumb,\n      .mat-slider-thumb-label {\n        background-color: $mat-slider-labeled-min-value-thumb-color;\n      }\n\n      &.cdk-focused {\n        .mat-slider-thumb,\n        .mat-slider-thumb-label {\n          background-color: $mat-slider-labeled-min-value-thumb-label-color;\n        }\n      }\n    }\n\n    &:not(.mat-slider-thumb-label-showing) {\n      .mat-slider-thumb {\n        border-color: $mat-slider-off-color;\n        background-color: transparent;\n      }\n\n      &:hover,\n      &.cdk-focused {\n        .mat-slider-thumb {\n          border-color: $mat-slider-off-focused-color;\n        }\n\n        &.mat-slider-disabled .mat-slider-thumb {\n          border-color: $mat-slider-disabled-color;\n        }\n      }\n    }\n  }\n\n  .mat-slider-has-ticks .mat-slider-wrapper::after {\n    border-color: $mat-slider-tick-color;\n  }\n\n  .mat-slider-horizontal .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to right, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n    // Firefox doesn't draw the gradient correctly with 'to right'\n    // (see https://bugzilla.mozilla.org/show_bug.cgi?id=1314319).\n    background-image: -moz-repeating-linear-gradient(0.0001deg, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n\n  .mat-slider-vertical .mat-slider-ticks {\n    background-image: repeating-linear-gradient(to bottom, $mat-slider-tick-color,\n        $mat-slider-tick-color $mat-slider-tick-size, transparent 0, transparent);\n  }\n}\n\n@mixin mat-slider-typography($config) {\n  .mat-slider-thumb-label-text {\n    font: {\n      family: mat-font-family($config);\n      size: mat-font-size($config, caption);\n      weight: mat-font-weight($config, body-2);\n    }\n  }\n}\n\n\n\n\n\n@mixin mat-stepper-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $background: map-get($theme, background);\n  $primary: map-get($theme, primary);\n  $warn: map-get($theme, warn);\n\n  .mat-step-header {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused,\n    &:hover {\n      background-color: mat-color($background, hover);\n    }\n\n    // On touch devices the :hover state will linger on the element after a tap.\n    // Reset it via `@media` after the declaration, because the media query isn't\n    // supported by all browsers yet.\n    @media (hover: none) {\n      &:hover {\n        background: none;\n      }\n    }\n\n    .mat-step-label,\n    .mat-step-optional {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      color: mat-color($foreground, secondary-text);\n    }\n\n    .mat-step-icon {\n      // TODO(josephperrott): Update to using a corrected disabled-text contrast\n      // instead of secondary-text.\n      background-color: mat-color($foreground, secondary-text);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-selected,\n    .mat-step-icon-state-done,\n    .mat-step-icon-state-edit {\n      background-color: mat-color($primary);\n      color: mat-color($primary, default-contrast);\n    }\n\n    .mat-step-icon-state-error {\n      background-color: transparent;\n      color: mat-color($warn, text);\n    }\n\n    .mat-step-label.mat-step-label-active {\n      color: mat-color($foreground, text);\n    }\n\n    .mat-step-label.mat-step-label-error {\n      color: mat-color($warn, text);\n    }\n  }\n\n  .mat-stepper-horizontal, .mat-stepper-vertical {\n    background-color: mat-color($background, card);\n  }\n\n  .mat-stepper-vertical-line::before {\n    border-left-color: mat-color($foreground, divider);\n  }\n\n  .mat-horizontal-stepper-header::before,\n  .mat-horizontal-stepper-header::after,\n  .mat-stepper-horizontal-line {\n    border-top-color: mat-color($foreground, divider);\n  }\n}\n\n@mixin mat-stepper-typography($config) {\n  .mat-stepper-vertical, .mat-stepper-horizontal {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-step-label {\n    font: {\n      size: mat-font-size($config, body-1);\n      weight: mat-font-weight($config, body-1);\n    };\n  }\n\n  .mat-step-sub-label-error {\n    font-weight: normal;\n  }\n\n  .mat-step-label-error {\n    font-size: mat-font-size($config, body-2);\n  }\n\n  .mat-step-label-selected {\n    font: {\n      size: mat-font-size($config, body-2);\n      weight: mat-font-weight($config, body-2);\n    };\n  }\n}\n\n@mixin mat-sort-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-sort-header-arrow {\n    $table-background: mat-color($background, 'card');\n    $text-color: mat-color($foreground, secondary-text);\n\n    // Because the arrow is made up of multiple elements that are stacked on top of each other,\n    // we can't use the semi-trasparent color from the theme directly. If the value is a color\n    // *type*, we convert it into a solid color by taking the opacity from the rgba value and\n    // using the value to determine the percentage of the background to put into foreground\n    // when mixing the colors together. Otherwise, if it resolves to something different\n    // (e.g. it resolves to a CSS variable), we use the color directly.\n    @if (type-of($table-background) == color and type-of($text-color) == color) {\n      $text-opacity: opacity($text-color);\n      color: mix($table-background, rgba($text-color, 1), (1 - $text-opacity) * 100%);\n    }\n    @else {\n      color: $text-color;\n    }\n  }\n}\n\n@mixin mat-sort-typography($config) { }\n\n\n\n\n\n@mixin mat-tabs-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $header-border: 1px solid mat-color($foreground, divider);\n\n  .mat-tab-nav-bar,\n  .mat-tab-header {\n    border-bottom: $header-border;\n  }\n\n  .mat-tab-group-inverted-header {\n    .mat-tab-nav-bar,\n    .mat-tab-header {\n      border-top: $header-border;\n      border-bottom: none;\n    }\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($foreground, text);\n\n    &.mat-tab-disabled {\n      color: mat-color($foreground, disabled-text);\n    }\n  }\n\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, text);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($foreground, disabled-text);\n  }\n\n  // Remove header border when there is a background color\n  .mat-tab-group[class*='mat-background-'] .mat-tab-header,\n  .mat-tab-nav-bar[class*='mat-background-'] {\n    border-bottom: none;\n    border-top: none;\n  }\n\n  .mat-tab-group, .mat-tab-nav-bar {\n    $theme-colors: (\n      primary: $primary,\n      accent: $accent,\n      warn: $warn\n    );\n\n    @each $name, $color in $theme-colors {\n      // Set the foreground color of the tabs\n      &.mat-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-ink-bar($color);\n\n        // Override ink bar when background color is the same\n        &.mat-background-#{$name} {\n          @include _mat-ink-bar($color, default-contrast);\n        }\n      }\n    }\n\n    @each $name, $color in $theme-colors {\n      // Set background color of the tabs and override focus color\n      &.mat-background-#{$name} {\n        @include _mat-tab-label-focus($color);\n        @include _mat-tabs-background($color);\n      }\n    }\n  }\n}\n\n@mixin _mat-ink-bar($color, $hue: default) {\n  .mat-ink-bar {\n    background-color: mat-color($color, $hue);\n  }\n}\n\n@mixin _mat-tab-label-focus($tab-focus-color) {\n  .mat-tab-label,\n  .mat-tab-link {\n    &.cdk-keyboard-focused,\n    &.cdk-program-focused {\n      &:not(.mat-tab-disabled) {\n        background-color: mat-color($tab-focus-color, lighter, 0.3);\n      }\n    }\n  }\n}\n\n@mixin _mat-tabs-background($background-color) {\n  // Set background color for the tab group\n  .mat-tab-header, .mat-tab-links, .mat-tab-header-pagination {\n    background-color: mat-color($background-color);\n  }\n\n  // Set labels to contrast against background\n  .mat-tab-label, .mat-tab-link {\n    color: mat-color($background-color, default-contrast);\n\n    &.mat-tab-disabled {\n      color: mat-color($background-color, default-contrast, 0.4);\n    }\n  }\n\n  // Set pagination chevrons to contrast background\n  .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast);\n  }\n\n  .mat-tab-header-pagination-disabled .mat-tab-header-pagination-chevron {\n    border-color: mat-color($background-color, default-contrast, 0.4);\n  }\n\n  // Set ripples color to be the contrast color of the new background. Otherwise the ripple\n  // color will be based on the app background color.\n  .mat-ripple-element {\n    background-color: mat-color($background-color, default-contrast, 0.12);\n  }\n}\n\n@mixin mat-tabs-typography($config) {\n  .mat-tab-group {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tab-label, .mat-tab-link {\n    font: {\n      family: mat-font-family($config, button);\n      size: mat-font-size($config, button);\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n@mixin _mat-toolbar-color($palette) {\n  background: mat-color($palette);\n  color: mat-color($palette, default-contrast);\n}\n\n@mixin _mat-toolbar-form-field-overrides {\n  .mat-form-field-underline,\n  .mat-form-field-ripple,\n  .mat-focused .mat-form-field-ripple {\n    background-color: currentColor;\n  }\n\n  .mat-form-field-label,\n  .mat-focused .mat-form-field-label,\n  .mat-select-value,\n  .mat-select-arrow,\n  .mat-form-field.mat-focused .mat-select-arrow {\n    color: inherit;\n  }\n\n  .mat-input-element {\n    caret-color: currentColor;\n  }\n}\n\n@mixin mat-toolbar-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-toolbar {\n    background: mat-color($background, app-bar);\n    color: mat-color($foreground, text);\n\n    &.mat-primary {\n      @include _mat-toolbar-color($primary);\n    }\n\n    &.mat-accent {\n      @include _mat-toolbar-color($accent);\n    }\n\n    &.mat-warn {\n      @include _mat-toolbar-color($warn);\n    }\n\n    @include _mat-toolbar-form-field-overrides;\n  }\n}\n\n@mixin mat-toolbar-typography($config) {\n  .mat-toolbar,\n  .mat-toolbar h1,\n  .mat-toolbar h2,\n  .mat-toolbar h3,\n  .mat-toolbar h4,\n  .mat-toolbar h5,\n  .mat-toolbar h6 {\n    @include mat-typography-level-to-styles($config, title);\n    margin: 0;\n  }\n}\n\n\n\n\n\n$mat-tooltip-target-height: 22px;\n$mat-tooltip-font-size: 10px;\n$mat-tooltip-vertical-padding: ($mat-tooltip-target-height - $mat-tooltip-font-size) / 2;\n\n$mat-tooltip-handset-target-height: 30px;\n$mat-tooltip-handset-font-size: 14px;\n$mat-tooltip-handset-vertical-padding:\n    ($mat-tooltip-handset-target-height - $mat-tooltip-handset-font-size) / 2;\n\n@mixin mat-tooltip-theme($theme) {\n  .mat-tooltip {\n    background: mat-color($mat-grey, 700, 0.9);\n  }\n}\n\n@mixin mat-tooltip-typography($config) {\n  .mat-tooltip {\n    font-family: mat-font-family($config);\n    font-size: $mat-tooltip-font-size;\n    padding-top: $mat-tooltip-vertical-padding;\n    padding-bottom: $mat-tooltip-vertical-padding;\n  }\n\n  .mat-tooltip-handset {\n    font-size: $mat-tooltip-handset-font-size;\n    padding-top: $mat-tooltip-handset-vertical-padding;\n    padding-bottom: $mat-tooltip-handset-vertical-padding;\n  }\n}\n\n\n\n\n\n@mixin mat-snack-bar-theme($theme) {\n  $is-dark-theme: map-get($theme, is-dark);\n  $accent: map-get($theme, accent);\n\n  .mat-snack-bar-container {\n    // Use the primary text on the dark theme, even though the lighter one uses\n    // a secondary, because the contrast on the light primary text is poor.\n    color: if($is-dark-theme, $dark-primary-text, $light-secondary-text);\n    background: if($is-dark-theme, map-get($mat-grey, 50), #323232);\n\n    @include _mat-theme-elevation(6, $theme);\n  }\n\n  .mat-simple-snackbar-action {\n    color: if($is-dark-theme, inherit, mat-color($accent, text));\n  }\n}\n\n@mixin mat-snack-bar-typography($config) {\n  .mat-simple-snackbar {\n    font: {\n      family: mat-font-family($config, body-1);\n      size: mat-font-size($config, body-1);\n    }\n  }\n\n  .mat-simple-snackbar-action {\n    line-height: 1;\n    font: {\n      family: inherit;\n      size: inherit;\n      weight: mat-font-weight($config, button);\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Theme styles that only apply to the fill appearance of the form-field.\n\n@mixin mat-form-field-fill-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $fill-background: mat-color($foreground, base, if($is-dark-theme, 0.1, 0.04));\n  $fill-disabled-background: mat-color($foreground, base, if($is-dark-theme, 0.05, 0.02));\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.5, 0.42));\n  $label-disabled-color: mat-color($foreground, disabled-text);\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-flex {\n      background-color: $fill-background;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-flex {\n      background-color: $fill-disabled-background;\n    }\n\n    .mat-form-field-underline::before {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-underline::before {\n        background-color: transparent;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-fill-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-fill-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-fill-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-fill-dedupe;\n\n  $mat-form-field-fill-dedupe: $mat-form-field-fill-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-fill-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding on top of the infix.\n  $infix-padding-top: 0.25em;\n  // The padding below the infix.\n  $infix-padding-bottom: 0.75em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The amount we offset the label from the input text in the fill appearance.\n  $fill-appearance-label-offset: -0.5em;\n\n  .mat-form-field-appearance-fill {\n    .mat-form-field-infix {\n      padding: $infix-padding-top 0 $infix-padding-bottom 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding-top;\n      margin-top: $fill-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-fill-label-floating(\n                $subscript-font-scale, $infix-padding-top + $fill-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the legacy appearance of the form-field.\n\n@mixin mat-form-field-legacy-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-color: mat-color($foreground, secondary-text);\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-label {\n      color: $label-color;\n    }\n\n    .mat-hint {\n      color: $label-color;\n    }\n\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-legacy-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-legacy-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  // We use perspective to fix the text blurriness as described here:\n  // http://www.useragentman.com/blog/2014/05/04/fixing-typography-inside-of-2-d-css-transforms/\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding) scale($font-scale) perspective(100px)\n  translateZ(0.001px + $mat-form-field-legacy-dedupe);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  -ms-transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n\n  width: 100% / $font-scale + $mat-form-field-legacy-dedupe;\n\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n// Same as mixin above, but omits the translateZ for printing purposes.\n@mixin _mat-form-field-legacy-label-floating-print($font-scale, $infix-padding, $infix-margin-top) {\n  // This results in a small jitter after the label floats on Firefox, which the\n  // translateZ fixes.\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-legacy-dedupe)\n                  scale($font-scale);\n  // The tricks above used to smooth out the animation on chrome and firefox actually make things\n  // worse on IE, so we don't include them in the IE version.\n  $mat-form-field-legacy-dedupe: $mat-form-field-legacy-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-legacy-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount of space between the top of the line and the top of the actual text\n  // (as a fraction of the font-size).\n  $line-spacing: ($line-height - 1) / 2;\n  // The padding on the infix. Mocks show half of the text size, but seem to measure from the edge\n  // of the text itself, not the edge of the line; therefore we subtract off the line spacing.\n  $infix-padding: 0.5em - $line-spacing;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size. We again need to subtract off the line spacing since the mocks measure to the edge of the\n  // text, not the  edge of the line.\n  $subscript-margin-top: 0.5em / $subscript-font-scale - ($line-spacing * 2);\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field-appearance-legacy {\n    .mat-form-field-wrapper {\n      padding-bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-infix {\n      padding: $infix-padding 0;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n      .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-legacy-label-floating(\n                $subscript-font-scale, $infix-padding, $infix-margin-top);\n      }\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n    }\n\n    .mat-form-field-underline {\n      // We want the underline to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount.\n      bottom: $wrapper-padding-bottom;\n    }\n\n    .mat-form-field-subscript-wrapper {\n      margin-top: $subscript-margin-top;\n\n      // We want the subscript to start at the end of the content box, not the padding box,\n      // so we move it up by the padding amount (adjusted for the smaller font size);\n      top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n    }\n  }\n\n  // translateZ causes the label to not appear while printing, so we override it to not\n  // apply translateZ while printing\n  @media print {\n    .mat-form-field-appearance-legacy {\n      &.mat-form-field-can-float {\n        &.mat-form-field-should-float .mat-form-field-label,\n        .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // @breaking-change 8.0.0 will rely on AutofillMonitor instead.\n        .mat-form-field-autofill-control:-webkit-autofill + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n\n        // Server-side rendered matInput with a label attribute but label not shown\n        // (used as a pure CSS stand-in for mat-form-field-should-float).\n        .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n          @include _mat-form-field-legacy-label-floating-print(\n                  $subscript-font-scale, $infix-padding, $infix-margin-top);\n        }\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the outline appearance of the form-field.\n\n@mixin mat-form-field-outline-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $label-disabled-color: mat-color($foreground, disabled-text);\n  $outline-color: mat-color($foreground, divider, if($is-dark-theme, 0.3, 0.12));\n  $outline-color-hover: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $outline-color-primary: mat-color($primary);\n  $outline-color-accent: mat-color($accent);\n  $outline-color-warn: mat-color($warn);\n  $outline-color-disabled: mat-color($foreground, divider, if($is-dark-theme, 0.15, 0.06));\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-outline {\n      color: $outline-color;\n    }\n\n    .mat-form-field-outline-thick {\n      color: $outline-color-hover;\n    }\n\n    &.mat-focused {\n      .mat-form-field-outline-thick {\n        color: $outline-color-primary;\n      }\n\n      &.mat-accent .mat-form-field-outline-thick {\n        color: $outline-color-accent;\n      }\n\n      &.mat-warn .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    // Class repeated so that rule is specific enough to override focused accent color case.\n    &.mat-form-field-invalid.mat-form-field-invalid {\n      .mat-form-field-outline-thick {\n        color: $outline-color-warn;\n      }\n    }\n\n    &.mat-form-field-disabled {\n      .mat-form-field-label {\n        color: $label-disabled-color;\n      }\n\n      .mat-form-field-outline {\n        color: $outline-color-disabled;\n      }\n    }\n  }\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-outline-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-outline-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-outline-dedupe)\n  scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-outline-dedupe;\n\n  $mat-form-field-outline-dedupe: $mat-form-field-outline-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-outline-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The padding above and below the infix.\n  $infix-padding: 1em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n  // The amount we offset the label from the input text in the outline appearance.\n  $outline-appearance-label-offset: -0.25em;\n\n  .mat-form-field-appearance-outline {\n    .mat-form-field-infix {\n      padding: $infix-padding 0 $infix-padding 0;\n    }\n\n    .mat-form-field-label {\n      top: $infix-margin-top + $infix-padding;\n      margin-top: $outline-appearance-label-offset;\n    }\n\n    &.mat-form-field-can-float {\n      &.mat-form-field-should-float .mat-form-field-label,\n      .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n\n      // Server-side rendered matInput with a label attribute but label not shown\n      // (used as a pure CSS stand-in for mat-form-field-should-float).\n      .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n      .mat-form-field-label {\n        @include _mat-form-field-outline-label-floating(\n                $subscript-font-scale, $infix-padding + $outline-appearance-label-offset,\n                $infix-margin-top);\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n// Theme styles that only apply to the standard appearance of the form-field.\n\n@mixin mat-form-field-standard-theme($theme) {\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  $underline-color: mat-color($foreground, divider, if($is-dark-theme, 0.7, 0.42));\n\n  .mat-form-field-appearance-standard {\n    .mat-form-field-underline {\n      background-color: $underline-color;\n    }\n\n    &.mat-form-field-disabled .mat-form-field-underline {\n      @include mat-control-disabled-underline($underline-color);\n    }\n  }\n}\n\n@mixin mat-form-field-standard-typography($config) {}\n\n\n// Theme styles that apply to all appearances of the form-field.\n@mixin mat-form-field-theme($theme) {\n  $primary: map-get($theme, primary);\n  $accent: map-get($theme, accent);\n  $warn: map-get($theme, warn);\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n  $is-dark-theme: map-get($theme, is-dark);\n\n  // Label colors. Required is used for the `*` star shown in the label.\n  $label-color: mat-color($foreground, secondary-text, if($is-dark-theme, 0.7, 0.6));\n  $focused-label-color: mat-color($primary, text);\n  $required-label-color: mat-color($accent, text);\n\n  // Underline colors.\n  $underline-color-base: mat-color($foreground, divider, if($is-dark-theme, 1, 0.87));\n  $underline-color-accent: mat-color($accent, text);\n  $underline-color-warn: mat-color($warn, text);\n  $underline-focused-color: mat-color($primary, text);\n\n  .mat-form-field-label {\n    color: $label-color;\n  }\n\n  .mat-hint {\n    color: $label-color;\n  }\n\n  .mat-form-field.mat-focused .mat-form-field-label {\n    color: $focused-label-color;\n\n    &.mat-accent {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn {\n      color: $underline-color-warn;\n    }\n  }\n\n  .mat-focused .mat-form-field-required-marker {\n    color: $required-label-color;\n  }\n\n  .mat-form-field-ripple {\n    background-color: $underline-color-base;\n  }\n\n  .mat-form-field.mat-focused {\n    .mat-form-field-ripple {\n      background-color: $underline-focused-color;\n\n      &.mat-accent {\n        background-color: $underline-color-accent;\n      }\n\n      &.mat-warn {\n        background-color: $underline-color-warn;\n      }\n    }\n  }\n\n  .mat-form-field-type-mat-native-select.mat-focused:not(.mat-form-field-invalid) {\n    .mat-form-field-infix::after {\n      color: $underline-focused-color;\n    }\n\n    &.mat-accent .mat-form-field-infix::after {\n      color: $underline-color-accent;\n    }\n\n    &.mat-warn .mat-form-field-infix::after {\n      color: $underline-color-warn;\n    }\n  }\n\n  // Styling for the error state of the form field. Note that while the same can be\n  // achieved with the ng-* classes, we use this approach in order to ensure that the same\n  // logic is used to style the error state and to show the error messages.\n  .mat-form-field.mat-form-field-invalid {\n    .mat-form-field-label {\n      color: $underline-color-warn;\n\n      &.mat-accent,\n      .mat-form-field-required-marker {\n        color: $underline-color-warn;\n      }\n    }\n\n    .mat-form-field-ripple,\n    .mat-form-field-ripple.mat-accent {\n      background-color: $underline-color-warn;\n    }\n  }\n\n  .mat-error {\n    color: $underline-color-warn;\n  }\n\n  @include mat-form-field-legacy-theme($theme);\n  @include mat-form-field-standard-theme($theme);\n  @include mat-form-field-fill-theme($theme);\n  @include mat-form-field-outline-theme($theme);\n}\n\n// Used to make instances of the _mat-form-field-label-floating mixin negligibly different,\n// and prevent Google's CSS Optimizer from collapsing the declarations. This is needed because some\n// of the selectors contain pseudo-classes not recognized in all browsers. If a browser encounters\n// an unknown pseudo-class it will discard the entire rule set.\n$mat-form-field-dedupe: 0;\n\n// Applies a floating label above the form field control itself.\n@mixin _mat-form-field-label-floating($font-scale, $infix-padding, $infix-margin-top) {\n  transform: translateY(-$infix-margin-top - $infix-padding + $mat-form-field-dedupe)\n             scale($font-scale);\n  width: 100% / $font-scale + $mat-form-field-dedupe;\n\n  $mat-form-field-dedupe: $mat-form-field-dedupe + 0.00001 !global;\n}\n\n@mixin mat-form-field-typography($config) {\n  // The unit-less line-height from the font config.\n  $line-height: mat-line-height($config, input);\n\n  // The amount to scale the font for the floating label and subscript.\n  $subscript-font-scale: 0.75;\n  // The amount to scale the font for the prefix and suffix icons.\n  $prefix-suffix-icon-font-scale: 1.5;\n\n  // The padding on the infix. Mocks show half of the text size.\n  $infix-padding: 0.5em;\n  // The margin applied to the form-field-infix to reserve space for the floating label.\n  $infix-margin-top: 1em * $line-height * $subscript-font-scale;\n  // Font size to use for the label and subscript text.\n  $subscript-font-size: $subscript-font-scale * 100%;\n  // Font size to use for the for the prefix and suffix icons.\n  $prefix-suffix-icon-font-size: $prefix-suffix-icon-font-scale * 100%;\n  // The space between the bottom of the .mat-form-field-flex area and the subscript wrapper.\n  // Mocks show half of the text size, but this margin is applied to an element with the subscript\n  // text font size, so we need to divide by the scale factor to make it half of the original text\n  // size.\n  $subscript-margin-top: 0.5em / $subscript-font-scale;\n  // The padding applied to the form-field-wrapper to reserve space for the subscript, since it's\n  // absolutely positioned. This is a combination of the subscript's margin and line-height, but we\n  // need to multiply by the subscript font scale factor since the wrapper has a larger font size.\n  $wrapper-padding-bottom: ($subscript-margin-top + $line-height) * $subscript-font-scale;\n\n  .mat-form-field {\n    @include mat-typography-level-to-styles($config, input);\n  }\n\n  .mat-form-field-wrapper {\n    padding-bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-prefix,\n  .mat-form-field-suffix {\n    // Allow icons in a prefix or suffix to adapt to the correct size.\n    .mat-icon {\n      font-size: $prefix-suffix-icon-font-size;\n      line-height: $line-height;\n    }\n\n    // Allow icon buttons in a prefix or suffix to adapt to the correct size.\n    .mat-icon-button {\n      height: $prefix-suffix-icon-font-scale * 1em;\n      width: $prefix-suffix-icon-font-scale * 1em;\n\n      .mat-icon {\n        height: $line-height * 1em;\n        line-height: $line-height;\n      }\n    }\n  }\n\n  .mat-form-field-infix {\n    padding: $infix-padding 0;\n    // Throws off the baseline if we do it as a real margin, so we do it as a border instead.\n    border-top: $infix-margin-top solid transparent;\n  }\n\n  .mat-form-field-can-float {\n    &.mat-form-field-should-float .mat-form-field-label,\n    .mat-input-server:focus + .mat-form-field-label-wrapper .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n\n    // Server-side rendered matInput with a label attribute but label not shown\n    // (used as a pure CSS stand-in for mat-form-field-should-float).\n    .mat-input-server[label]:not(:label-shown) + .mat-form-field-label-wrapper\n        .mat-form-field-label {\n      @include _mat-form-field-label-floating(\n              $subscript-font-scale, $infix-padding, $infix-margin-top);\n    }\n  }\n\n  .mat-form-field-label-wrapper {\n    top: -$infix-margin-top;\n    padding-top: $infix-margin-top;\n  }\n\n  .mat-form-field-label {\n    top: $infix-margin-top + $infix-padding;\n  }\n\n  .mat-form-field-underline {\n    // We want the underline to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount.\n    bottom: $wrapper-padding-bottom;\n  }\n\n  .mat-form-field-subscript-wrapper {\n    font-size: $subscript-font-size;\n    margin-top: $subscript-margin-top;\n\n    // We want the subscript to start at the end of the content box, not the padding box,\n    // so we move it up by the padding amount (adjusted for the smaller font size);\n    top: calc(100% - #{$wrapper-padding-bottom / $subscript-font-scale});\n  }\n\n  @include mat-form-field-legacy-typography($config);\n  @include mat-form-field-standard-typography($config);\n  @include mat-form-field-fill-typography($config);\n  @include mat-form-field-outline-typography($config);\n}\n\n\n\n\n\n@mixin mat-tree-theme($theme) {\n  $background: map-get($theme, background);\n  $foreground: map-get($theme, foreground);\n\n  .mat-tree {\n    background: mat-color($background, 'card');\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    color: mat-color($foreground, text);\n  }\n}\n\n@mixin mat-tree-typography($config) {\n  .mat-tree {\n    font-family: mat-font-family($config);\n  }\n\n  .mat-tree-node,\n  .mat-nested-tree-node {\n    font-weight: mat-font-weight($config, body-1);\n    font-size: mat-font-size($config, body-1);\n  }\n}\n\n\n\n// Includes all of the typographic styles.\n@mixin angular-material-typography($config: null) {\n  @if $config == null {\n    $config: mat-typography-config();\n  }\n\n  @include mat-badge-typography($config);\n  @include mat-base-typography($config);\n  @include mat-autocomplete-typography($config);\n  @include mat-bottom-sheet-typography($config);\n  @include mat-button-typography($config);\n  @include mat-button-toggle-typography($config);\n  @include mat-card-typography($config);\n  @include mat-checkbox-typography($config);\n  @include mat-chips-typography($config);\n  @include mat-table-typography($config);\n  @include mat-datepicker-typography($config);\n  @include mat-dialog-typography($config);\n  @include mat-expansion-panel-typography($config);\n  @include mat-form-field-typography($config);\n  @include mat-grid-list-typography($config);\n  @include mat-icon-typography($config);\n  @include mat-input-typography($config);\n  @include mat-menu-typography($config);\n  @include mat-paginator-typography($config);\n  @include mat-progress-bar-typography($config);\n  @include mat-progress-spinner-typography($config);\n  @include mat-radio-typography($config);\n  @include mat-select-typography($config);\n  @include mat-sidenav-typography($config);\n  @include mat-slide-toggle-typography($config);\n  @include mat-slider-typography($config);\n  @include mat-stepper-typography($config);\n  @include mat-sort-typography($config);\n  @include mat-tabs-typography($config);\n  @include mat-toolbar-typography($config);\n  @include mat-tooltip-typography($config);\n  @include mat-list-typography($config);\n  @include mat-option-typography($config);\n  @include mat-optgroup-typography($config);\n  @include mat-snack-bar-typography($config);\n  @include mat-tree-typography($config);\n}\n\n\n// Mixin that renders all of the core styles that are not theme-dependent.\n@mixin mat-core($typography-config: null) {\n  @include angular-material-typography($typography-config);\n  @include mat-ripple();\n  @include cdk-a11y();\n  @include cdk-overlay();\n  @include cdk-text-field();\n}\n\n// Mixin that renders all of the core styles that depend on the theme.\n@mixin mat-core-theme($theme) {\n  @include mat-ripple-theme($theme);\n  @include mat-option-theme($theme);\n  @include mat-optgroup-theme($theme);\n  @include mat-pseudo-checkbox-theme($theme);\n\n  // Provides external CSS classes for each elevation value. Each CSS class is formatted as\n  // `mat-elevation-z$zValue` where `$zValue` corresponds to the z-space to which the element is\n  // elevated.\n  @for $zValue from 0 through 24 {\n    .#{$_mat-elevation-prefix}#{$zValue} {\n      @include _mat-theme-elevation($zValue, $theme);\n    }\n  }\n\n  // Wrapper element that provides the theme background when the user's content isn't\n  // inside of a `mat-sidenav-container`. Note that we need to exclude the ampersand\n  // selector in case the mixin is included at the top level.\n  .mat-app-background#{if(&, ', &.mat-app-background', '')} {\n    $background: map-get($theme, background);\n    $foreground: map-get($theme, foreground);\n\n    background-color: mat-color($background, background);\n    color: mat-color($foreground, text);\n  }\n\n  // Marker that is used to determine whether the user has added a theme to their page.\n  @at-root {\n    .mat-theme-loaded-marker {\n      display: none;\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n@mixin mat-divider-theme($theme) {\n  $foreground: map-get($theme, foreground);\n\n  .mat-divider {\n    border-top-color: mat-color($foreground, divider);\n  }\n\n  .mat-divider-vertical {\n    border-right-color: mat-color($foreground, divider);\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// Create a theme.\n@mixin angular-material-theme($theme) {\n  @include mat-core-theme($theme);\n  @include mat-autocomplete-theme($theme);\n  @include mat-badge-theme($theme);\n  @include mat-bottom-sheet-theme($theme);\n  @include mat-button-theme($theme);\n  @include mat-button-toggle-theme($theme);\n  @include mat-card-theme($theme);\n  @include mat-checkbox-theme($theme);\n  @include mat-chips-theme($theme);\n  @include mat-table-theme($theme);\n  @include mat-datepicker-theme($theme);\n  @include mat-dialog-theme($theme);\n  @include mat-divider-theme($theme);\n  @include mat-expansion-panel-theme($theme);\n  @include mat-form-field-theme($theme);\n  @include mat-grid-list-theme($theme);\n  @include mat-icon-theme($theme);\n  @include mat-input-theme($theme);\n  @include mat-list-theme($theme);\n  @include mat-menu-theme($theme);\n  @include mat-paginator-theme($theme);\n  @include mat-progress-bar-theme($theme);\n  @include mat-progress-spinner-theme($theme);\n  @include mat-radio-theme($theme);\n  @include mat-select-theme($theme);\n  @include mat-sidenav-theme($theme);\n  @include mat-slide-toggle-theme($theme);\n  @include mat-slider-theme($theme);\n  @include mat-stepper-theme($theme);\n  @include mat-sort-theme($theme);\n  @include mat-tabs-theme($theme);\n  @include mat-toolbar-theme($theme);\n  @include mat-tooltip-theme($theme);\n  @include mat-tree-theme($theme);\n  @include mat-snack-bar-theme($theme);\n}\n","// Media step breakpoint mixin based on Angular Material lib\r\n$breakpoints: (\r\n    xs: 'screen and (max-width: 599px)',\r\n    sm: 'screen and (min-width: 600px) and (max-width: 959px)',\r\n    md: 'screen and (min-width: 960px) and (max-width: 1279px)',\r\n    lg: 'screen and (min-width: 1280px) and (max-width: 1919px)',\r\n    xl: 'screen and (min-width: 1920px) and (max-width: 5000px)',\r\n    lt-sm: 'screen and (max-width: 599px)',\r\n    lt-md: 'screen and (max-width: 959px)',\r\n    lt-lg: 'screen and (max-width: 1279px)',\r\n    lt-xl: 'screen and (max-width: 1919px)',\r\n    gt-xs: 'screen and (min-width: 600px)',\r\n    gt-sm: 'screen and (min-width: 960px)',\r\n    gt-md: 'screen and (min-width: 1280px)',\r\n    gt-lg: 'screen and (min-width: 1920px)'\r\n) !default;\r\n\r\n// Re-map the breakpoints for the helper classes\r\n$helper-breakpoints: (\r\n    xs: null,\r\n    sm: 'gt-xs',\r\n    md: 'gt-sm',\r\n    lg: 'gt-md',\r\n    xl: 'gt-lg'\r\n);\r\n\r\n@mixin media-breakpoint($breakpointName) {\r\n\r\n    $mediaQuery: map-get($breakpoints, $breakpointName);\r\n\r\n    @if ($mediaQuery == null) {\r\n        @content\r\n    } @else {\r\n        @media #{$mediaQuery} {\r\n            @content\r\n        }\r\n    }\r\n}\r\n","@import \"src/@fuse/scss/fuse\";\r\n.payout-receipt-details {\r\n    @include media-breakpoint(\"xs\") {\r\n        max-width: 100vw !important;\r\n        width: 100%;\r\n        height: 100%;\r\n      }\r\n    @include media-breakpoint(\"sm\") {\r\n        max-width: 100vw !important;\r\n        width: 100%;\r\n        height: 100%;\r\n    }\r\n    \r\n    @include media-breakpoint(\"gt-sm\") {\r\n        max-width: 100vw !important;\r\n        width: 100%;\r\n    }\r\n    .header-tab-action {\r\n        background: #00000026 !important;\r\n        margin: 0px 5px;\r\n        border-radius: 10px;\r\n    }\r\n    \r\n    .mat-dialog-container {\r\n        padding: 0;\r\n    }\r\n    .transactionDetails {\r\n        margin: 20px 70px 70px 60px;\r\n    }\r\n    .transactionDetails .imageLogo img {\r\n        width: 180px;\r\n    }\r\n    .transactionDetails .transactionField .field {\r\n        padding-bottom: 32px;\r\n        font-family: Helvetica, Arial, sans-serif;\r\n    }\r\n    .transactionDetails .address {\r\n        font-size: 10px;\r\n        font-weight: bold;\r\n        \r\n    }\r\n    .transactionDetails .address pre {\r\n        line-height: 1;\r\n    }\r\n    .transactionDetails .transactionField .field label {\r\n        font-weight: bold;\r\n        font-size: 16px;\r\n    } \r\n   \r\n}\r\n@media print {\r\n    .forPrint {\r\n      display: none;\r\n    }\r\n    @page {\r\n        Pages:1\r\n    }\r\n    .print-none{\r\n        visibility: hidden;\r\n    }\r\n}","/* Theme for the ripple elements.*/\n/* stylelint-disable material/no-prefixes */\n/* stylelint-enable */\n@media screen and (max-width: 599px) {\n  .payout-receipt-details {\n    max-width: 100vw !important;\n    width: 100%;\n    height: 100%;\n  }\n}\n@media screen and (min-width: 600px) and (max-width: 959px) {\n  .payout-receipt-details {\n    max-width: 100vw !important;\n    width: 100%;\n    height: 100%;\n  }\n}\n@media screen and (min-width: 960px) {\n  .payout-receipt-details {\n    max-width: 100vw !important;\n    width: 100%;\n  }\n}\n.payout-receipt-details .header-tab-action {\n  background: #00000026 !important;\n  margin: 0px 5px;\n  border-radius: 10px;\n}\n.payout-receipt-details .mat-dialog-container {\n  padding: 0;\n}\n.payout-receipt-details .transactionDetails {\n  margin: 20px 70px 70px 60px;\n}\n.payout-receipt-details .transactionDetails .imageLogo img {\n  width: 180px;\n}\n.payout-receipt-details .transactionDetails .transactionField .field {\n  padding-bottom: 32px;\n  font-family: Helvetica, Arial, sans-serif;\n}\n.payout-receipt-details .transactionDetails .address {\n  font-size: 10px;\n  font-weight: bold;\n}\n.payout-receipt-details .transactionDetails .address pre {\n  line-height: 1;\n}\n.payout-receipt-details .transactionDetails .transactionField .field label {\n  font-weight: bold;\n  font-size: 16px;\n}\n\n@media print {\n  .forPrint {\n    display: none;\n  }\n\n  @page {\n    Pages: 1;\n  }\n  .print-none {\n    visibility: hidden;\n  }\n}"]} */\"","import { stringify } from '@angular/compiler/src/util';\r\nimport { Component, Inject, OnInit } from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material';\r\nimport { FuseSplashScreenService } from '@fuse/services/splash-screen.service';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { ReportsService } from '../reports.service';\r\n\r\n@Component({\r\n selector: 'app-payout-receipt',\r\n templateUrl: './payout-receipt.component.html',\r\n styleUrls: ['./payout-receipt.component.scss']\r\n})\r\nexport class PayoutReceiptComponent implements OnInit {\r\n hostHeight: any;\r\n hostWidth: any;\r\n IsDialogMax: boolean = false;\r\n cambridgePaymentDetails:any;\r\n withdrawlAmount:any;\r\n currencyRate:any;\r\n serviceCharge:any;\r\n totalCost:any;\r\n depositAmount:any;\r\n dealDate:any;\r\n dealNumber:any;\r\n conversionCurrency:any;\r\n currency:any;\r\n depositCurrency:any;\r\n serviceChargeCurrency:any;\r\n estimateCostCurrency:any;\r\n EstimateCostAmount : any;\r\n SellCurrency : any;\r\n SellAmount : any;\r\n constructor(\r\n public matDialogRef: MatDialogRef,\r\n @Inject(MAT_DIALOG_DATA) private _data: any,\r\n private _fuseSplashScreenService: FuseSplashScreenService,\r\n public _reportsService: ReportsService,\r\n private _toastr: ToastrService,\r\n ) { }\r\n\r\n ngOnInit() {\r\n this.getCambridgePaymentOrder(); \r\n }\r\n onPrint(){\r\n window.print();\r\n}\r\ngetCambridgePaymentOrder() {\r\n let transactionID = this._data.transactionID\r\n const request = {\r\n \"TranId\" : String(transactionID)\r\n }\r\n this._fuseSplashScreenService.show();\r\n this._reportsService.GetCambridgePaymentOrderDetails(request).subscribe((res:any)=> {\r\n if(res){\r\n this._fuseSplashScreenService.hide();\r\n this.cambridgePaymentDetails = res;\r\n this.dealDate = this.cambridgePaymentDetails.entryDate;\r\n this.dealNumber = this.cambridgePaymentDetails.ordNum;\r\n this.conversionCurrency = this.cambridgePaymentDetails.currency;\r\n this.currency = this.cambridgePaymentDetails.settlement_currency;\r\n this.estimateCostCurrency = this.cambridgePaymentDetails.estimateCostCurrency;\r\n this.EstimateCostAmount = parseFloat(this.cambridgePaymentDetails.estimateCostAmount).toFixed(2);\r\n this.currencyRate = parseFloat(this.cambridgePaymentDetails.exchange).toFixed(2);\r\n this.serviceCharge = parseFloat(this.cambridgePaymentDetails.settlement_amount).toFixed(2);\r\n this.serviceChargeCurrency = this.cambridgePaymentDetails.settlement_currency;\r\n this.totalCost = parseFloat(this.cambridgePaymentDetails.amount).toFixed(2);\r\n this.depositAmount = parseFloat(this.cambridgePaymentDetails.buyAmount).toFixed(2);\r\n this.depositCurrency = this.cambridgePaymentDetails.buy;\r\n let a:any = (parseInt(this.totalCost)- parseInt(this.currencyRate)-parseInt(this.serviceCharge));\r\n this.withdrawlAmount = parseFloat(a).toFixed(2);\r\n this.SellCurrency = this.cambridgePaymentDetails.sell;\r\n this.SellAmount = this.cambridgePaymentDetails.sellAmount;\r\n }else{\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error('Error');\r\n }\r\n },\r\n error => {\r\n this._fuseSplashScreenService.hide();\r\n this._toastr.error(error, 'Error');\r\n });\r\n \r\n\r\n}\r\n minimizeDialog() {\r\n let elements: any = document.getElementsByClassName(\"payout-receipt-details\");\r\n for (var i = 0; i < elements.length; i++) {\r\n elements[i].style.width = (this.hostWidth + 1 + 'px');\r\n elements[i].style.height = (this.hostHeight + 1 + 'px');\r\n }\r\n document.getElementById(\"sendpayoutdetail-content\").style.maxHeight = \"65vh\";\r\n document.getElementById(\"sendpayoutdetail-wrapper\").style.maxHeight = \"85vh\";\r\n this.IsDialogMax = !this.IsDialogMax;\r\n }\r\n maximizeDialog() {\r\n let elements: any = document.getElementsByClassName(\"payout-receipt-details\");\r\n for (var i = 0; i < elements.length; i++) {\r\n this.hostHeight = elements[i].clientHeight;\r\n this.hostWidth = elements[i].clientWidth;\r\n elements[i].style.width = (\"100%\");\r\n elements[i].style.height = (\"100%\");\r\n }\r\n document.getElementById(\"sendpayoutdetail-content\").style.maxHeight = \"100vh\";\r\n document.getElementById(\"sendpayoutdetail-wrapper\").style.maxHeight = \"100vh\";\r\n this.IsDialogMax = !this.IsDialogMax;\r\n }\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { RestService } from '../../../shared/rest.service';\r\nimport { request } from 'http';\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class ReportsService {\r\n\r\n constructor(private _restService: RestService) { }\r\n\r\n GetTransactionReport(request: any) {\r\n let _url = '/Report/GetTransactionReport';\r\n return this._restService.Post(_url, request);\r\n }\r\n GetScheduleTransactionsReport(request: any) {\r\n let _url = '/Report/GetScheduleTransactionsReport';\r\n return this._restService.Post(_url, request);\r\n }\r\n UpcomingScheduleTransactionsReport(request: any) {\r\n let _url = '/Report/UpcomingScheduleTransactionsReport';\r\n return this._restService.Post(_url, request);\r\n }\r\n ExecutedScheduleTransactionsReport(executedrequest: any) {\r\n let _url = '/Report/ExecutedScheduleTransactionsReport';\r\n return this._restService.Post(_url, executedrequest);\r\n }\r\n\r\n GetAPIUser(request: any) {\r\n let _url = '/Users/GetAPIUser' + request;\r\n return this._restService.Get(_url);\r\n }\r\n\r\n GetActivityLog(request: any) {\r\n let _url = '/ActivityLog/GetActivityLog';\r\n return this._restService.Post(_url, request);\r\n }\r\n GetActivityLogName(request: any) {\r\n let _url = '/ActivityLog/GetActivityLogName';\r\n return this._restService.Post(_url, request);\r\n }\r\n GetCustomerBalanceList(request: any) {\r\n let _url = '/Customer/GetCustomersWithBalance';\r\n return this._restService.Post(_url, request);\r\n }\r\n GetCambridgePaymentOrderDetails(request:any) {\r\n let _url = '/Report/GetCambridgePaymentOrderDetails';\r\n return this._restService.Post(_url, request);\r\n }\r\n GetACHTranscationList(request:any) {\r\n let _url = '/ScheduleTransaction/GetScheduleTransactionsCount';\r\n return this._restService.Post(_url, request);\r\n }\r\n GetSettingCompanyByCategoryKey(key:any,id:any) {\r\n let _url = '/Setting/GetSettingCompanyByCategoryKey?categoryKey=cambridgeschedule&companyId='+id;\r\n return this._restService.Get(_url);\r\n }\r\n GetTimezones(){\r\n let _url = '/Utils/GetTimeZones';\r\n return this._restService.Post(_url,'');\r\n }\r\n SaveUpdateFrequency(request){\r\n let _url = '/Cambridge/SaveUpdateCorpayFrequency';\r\n return this._restService.Post(_url,request);\r\n }\r\n GetActiveAccountsReport(request){\r\n let _url = '/Report/GetActiveAccountsReport'\r\n return this._restService.Post(_url, request)\r\n }\r\n GetNewEwalletSetupsReport(request){\r\n let _url = '/Report/GetNewEwalletSetupsReport'\r\n return this._restService.Post(_url, request)\r\n }\r\n GetSpendbackFeeReport(request){\r\n let _url = '/Report/GetSpendbackFeeReport'\r\n return this._restService.Post(_url, request)\r\n }\r\n GetCompanyDetail() {\r\n let _url = '/Company/GetCompanyDetail';\r\n return this._restService.Get(_url);\r\n}\r\n GetFeeReportByCompany(request){\r\n let _url = '/Report/GetFeeReportByCompany'\r\n return this._restService.Post(_url, request)\r\n }\r\n GetFeeReportDetailByCompany(request){\r\n let _url = '/Report/GetFeeReportDetailByCompany'\r\n return this._restService.Post(_url, request)\r\n }\r\n GetCustomerBalanceExportList() {\r\n let _url = '/Customer/GetExportFiles'\r\n return this._restService.Post(_url, {})\r\n }\r\n SaveUpdateScheduleDateTime(request){\r\n let _url = '/ScheduleTransaction/UpdateScheduledTransactionDate'\r\n return this._restService.Post(_url,request);\r\n }\r\n Getinactiveusers(request:any){\r\n let _url = `/Report/GetDormantAccountsByCompany?CompanyId=${request.CompanyId}&PointAccountId=${request.PointAccountId}&Months=${request.Months}`\r\n return this._restService.Get(_url);\r\n }\r\n ProcessCommissionPayoutByIDs(request){\r\n let _url = `/CommssionPayout/ProcessCommissionPayoutByIDs?${request}`\r\n return this._restService.Post(_url,null);\r\n }\r\n ExportUpcomingScheduleTransactionsReport(request){\r\n let _url = `/Report/ExportUpcomingScheduleTransactionsReport?companyId=${request.CompanyId}&pointAccountId=${request.PointAccountIDs}&search=${request.Search}&timeLineType=${request.TimeLineType}&from=${request.From}&to=${request.To}&payoutType=${request.payoutType}`\r\n return this._restService.Getblob(_url);\r\n }\r\n ExportExecutedScheduleTransactionsReport(request){\r\n let _url = `/Report/ExportExecutedScheduleTransactionsReport?companyId=${request.CompanyId}&pointAccountId=${request.PointAccountIDs}&search=${request.Search}&timeLineType=${request.TimeLineType}&from=${request.From}&to=${request.To}&payoutType=${request.payoutType}`\r\n return this._restService.Getblob(_url);\r\n }\r\n saveFile(blob, fileName) {\r\n if (window.navigator.msSaveOrOpenBlob) { \r\n navigator.msSaveBlob(blob, fileName);\r\n } else { \r\n var link = document.createElement('a');\r\n link.href = window.URL.createObjectURL(blob);\r\n link.download = fileName;\r\n link.click();\r\n window.URL.revokeObjectURL(link.href);\r\n }\r\n }\r\n GetCommissionPayoutmanualBatchList(request){\r\n let _url = `/CommssionPayout/GetCommissionPayoutmanualBatchList?${request}`\r\n return this._restService.Get(_url);\r\n }\r\n ProcessCommissionPayoutmanual(request){\r\n let _url = `/CommssionPayout/ProcessCommissionPayoutmanual?${request}`\r\n return this._restService.Post(_url,null);\r\n }\r\n GetCommissionPayoutmanualList(request){\r\n let _url = `/CommssionPayout/GetCommissionPayoutmanualList?${request}`\r\n return this._restService.Get(_url);\r\n }\r\n ProcessCommissionPayout(request){\r\n let _url = `/CommssionPayout/ProcessCommissionPayout?${request}`\r\n return this._restService.Post(_url,null);\r\n }\r\n GetCommissionPayoutBatchList(request){\r\n let _url = `/CommssionPayout/GetCommissionPayoutBatchList?${request}`\r\n return this._restService.Get(_url);\r\n }\r\n getCompanySettingActivityLog(request:any){\r\n let _url = `/ActivityLog/GetCompanySettingActivityLog`\r\n return this._restService.Post(_url,request);\r\n }\r\n GetCommissionPayoutList(request){\r\n let _url = `/CommssionPayout/GetCommissionPayoutList?${request}`\r\n return this._restService.Get(_url);\r\n }\r\n getReportDetails(request:any){\r\n let _url = `/Tax1099/GetRecipientReportDetails`\r\n return this._restService.Post(_url,request);\r\n }\r\n GetCompanyDetails() {\r\n let _url = '/Company/GetCompanyDetail';\r\n return this._restService.Get(_url);\r\n}\r\n exportTaxStatusReport(request:any){\r\n let _url = `/Tax1099/ExportRecipientReportDetails?CompanyId=${request.companyId}&Skip=${request.skip}&Take=${request.take}&search=${request.search}`\r\n return this._restService.Getblob(_url);\r\n }\r\n ExportDormatAccountsByCompany(request:any){\r\n let _url = `/Report/ExportDormantAccountsByCompany?CompanyId=${request.CompanyId}&PointAccountId=${request.PointAccountId}&Months=${request.Months}`\r\n return this._restService.Getblob(_url);\r\n\r\n }\r\n FindDuplicateTransfers(request){\r\n let _url = `/CustomerPointTransactions/FindDuplicateTransfers?companyId=${request.companyId}&startDate=${request.startDate}&endDate=${request.endDate}`;\r\n return this._restService.Get(_url);\r\n }\r\n GetSQSReport(request){\r\n let _url = `/Report/GetSQSReport`;\r\n return this._restService.Post(_url, request);\r\n }\r\n GetCardOrders(request){\r\n let _url = `/v1/CardOrder/GetCardOrders`;\r\n return this._restService.Post(_url, request);\r\n }\r\n UpdateCardOrders(request){\r\n let _url = `/v1/CardOrder/UpdateCardOrders`;\r\n return this._restService.Post(_url, request);\r\n }\r\n FindSuspiciousTransfers(request){\r\n let _url = `/Report/GetTransactionsAlertReport?fromDate=${request.fromDate}&transactionNumber=${request.transactionNumber}&mailSend=${request.mailSend}`;\r\n return this._restService.Get(_url);\r\n }\r\n GetDormantReport(request){\r\n let _url = `/Report/GetDormantReport?${request}`;\r\n return this._restService.Get(_url);\r\n }\r\n ExportDormantReport(request:any){\r\n let _url = `/Report/ExportDormantReport?${request}`\r\n return this._restService.Getblob(_url);\r\n }\r\n ExportFeeReportSummary(request:any){\r\n let _url = `/Report/ExportFeeReportSummary?${request}`\r\n return this._restService.Getblob(_url);\r\n }\r\n ExportFeeReport(request:any){\r\n let _url = `/Report/ExportFeeReport?${request}`\r\n return this._restService.Getblob(_url);\r\n }\r\n}\r\n","import { FuseNavigation } from '@fuse/types';\r\n\r\nexport const navigation: FuseNavigation[] = [\r\n {\r\n id: 'pages',\r\n title: 'Pages',\r\n type: 'group',\r\n icon: 'pages',\r\n role: '1',\r\n children: [\r\n {\r\n id: 'dashboards', title: 'Dashboard', translate: 'Dashboard', type: 'item', icon: 'dashboard', url: '/pages/dashboards/project'\r\n // children: [{ id: 'project', title: 'Project', translate: 'Project', type: 'item', url: '/pages/dashboards/project' },\r\n // ]\r\n },\r\n { id: 'company-management', title: 'Company', type: 'item', icon: 'business', url: '/pages/accounts/providers' },\r\n // { id: 'Users', title: 'Contacts', type: 'item', icon: 'group', url: '/pages/users' },\r\n { id: 'customers', title: 'Contacts', type: 'item', icon: 'people', url: '/pages/customers' },\r\n { id: 'Payout', title: 'Payout Transactions', type: 'item', icon: 'payment', url: '/pages/payout-report' },\r\n // { id: 'methods', title: 'Methods', translate: 'Methods', type: 'collapsable', icon: 'view_list', \r\n // children: [ \r\n // { id: 'API-Methods', title: 'API Methods', type: 'item', icon: '', url: '/pages/api-methods',},\r\n // { id: 'Version-Methods', title: 'Version Methods', type: 'item', icon: '', url: '/pages/version-method',},\r\n // { id: 'Company-Version', title: 'Company Version', type: 'item', icon: '', url: '/pages/company-version',},\r\n // ]},\r\n {\r\n id: 'manage-transactions', title: 'Manage Transactions',\r\n type: 'item', icon: 'transfer_within_a_station',\r\n url: '/pages/manage-transactions'\r\n },\r\n {\r\n id: 'reports', title: 'Reports', translate: 'Reports', type: 'collapsable', icon: 'grid_on',\r\n children: [\r\n // {id: 'transaction-report', title: 'Transaction Report', translate: 'Transaction Report', type: 'item', url: 'pages/reports/transaction-report'},\r\n { id: 'api-log-report', title: 'api log Report', translate: 'API Logs', type: 'item', url: 'pages/reports/api-log-report' },\r\n // {id: 'top-x-customer-report', title: 'Top X Customer Report', translate: 'Top X Customer Report', type: 'item', url: 'pages/reports/top-x-customer-report'}\r\n { id: 'customer-balance-report', title: 'Customer Balance', translate: 'Customer Balance', type: 'item', url: 'pages/reports/customer-balance-report' },\r\n { id: 'ach-transaction-report', title: 'ACH Transactions', translate: 'ACH Transactions', type: 'item', url: 'pages/reports/ach-transaction-report' },\r\n { id: 'ewallet-fees', title: 'eWallet Fees', type: 'item', url: 'pages/reports/ewallet-fees'},\r\n { id: 'duplicate-transaction-report', title: 'Duplicate Transaction Report', type: 'item', url: 'pages/reports/duplicate-transaction-report'},\r\n { id: 'ordered-card-report', title: 'Ordered Card Report', type: 'item', url: 'pages/reports/ordered-card-report'},\r\n { id: 'suspicious-transaction-report', title: 'Suspicious Transaction Report', type: 'item', url: 'pages/reports/suspicious-transaction-report'}\r\n ]\r\n },\r\n {\r\n id: 'Settings', title: 'Settings', translate: 'Settings', type: 'collapsable', icon: 'settings',\r\n children: [\r\n { id: 'Settings Category', title: 'Settings Category', type: 'item', icon: '', url: '/pages/settings-category' },\r\n { id: 'Settings', title: 'Settings', type: 'item', icon: '', url: '/pages/settings' },\r\n { id: 'Company Setting', title: 'Company Setting', type: 'item', icon: '', url: '/pages/company-setting' },\r\n { id: 'Fee Settings', title: 'Fee Settings', type: 'item', icon: '', url: '/pages/fee-settings' }\r\n ]\r\n }\r\n ]\r\n },\r\n\r\n {\r\n id: 'pages',\r\n title: 'Pages',\r\n type: 'group',\r\n icon: 'pages',\r\n role: '2',\r\n children: [\r\n {\r\n id: 'dashboards', title: 'Dashboard', translate: 'Dashboard', type: 'item', icon: 'dashboard', url: '/pages/dashboards/project'\r\n // children: [{ id: 'project', title: 'Project', translate: 'Project', type: 'item', url: '/pages/dashboards/project' },\r\n // ]\r\n },\r\n { id: 'customers', title: 'Contacts', type: 'item', icon: 'people', url: '/pages/customers' },\r\n // { id: 'Users', title: 'Users', type: 'item', icon: 'group', url: '/pages/users', },\r\n // { id: 'manage-transctions', title: 'Manage Transactions',\r\n // type: 'item', icon: 'transfer_within_a_station',\r\n // url: '/pages/manage-transctions'},\r\n\r\n {id: 'transactions', title: 'Transactions', translate: 'Transactions', type: 'collapsable', icon: 'transform',\r\n children: [\r\n { id: 'point-transactions', title: 'Point Transactions', type: 'item', url: '/pages/point-transactions' },\r\n { id: 'import-transactions', title: 'Import Transactions', type: 'item', url: '/pages/import' },\r\n { id: 'import-past-transactions', title: 'Import Past Transactions', type: 'item', url: '/pages/import-past-transactions'},\r\n { id: 'Payout', title: 'Payout Transactions', type: 'item', url: '/pages/payout-report' },\r\n { id: 'rellevate-transactions', title: 'Rellevate Transactions', type: 'item', url: '/pages/rellevate-transactions' },\r\n ]\r\n },\r\n \r\n {\r\n id: 'reports', title: 'Reports', translate: 'Reports', type: 'collapsable', icon: 'grid_on',\r\n children: [\r\n // {id: 'transaction-report', title: 'Transaction Report', translate: 'Transaction Report', type: 'item', url: 'pages/reports/transaction-report'},\r\n { id: 'api-log-report', title: 'api log Report', translate: 'API Logs', type: 'item', url: 'pages/reports/api-log-report' },\r\n { id: 'Schedule-transaction-report', title: 'Schedule Transaction Report', translate: ' Scheduled Transactions', type: 'item', url: 'pages/reports/company-report' },\r\n { id: 'customer-balance-report', title: 'Customer Balance', translate: 'Customer Balance', type: 'item', url: 'pages/reports/customer-balance-report' },\r\n // {id: 'top-x-customer-report', title: 'Top X Customer Report', translate: 'Top X Customer Report', type: 'item', url: 'pages/reports/top-x-customer-report'}\r\n //{ id: 'ewallet-fees', title: 'eWallet Fees', type: 'item', url: 'pages/reports/ewallet-fees'}\r\n { id: 'inactive-user-report', title: 'Inactive User Report', type: 'item', url: 'pages/reports/inactive-users'},\r\n { id: 'block-report', title: 'Block Report', type: 'item', url: 'pages/reports/block-report'},\r\n // { id: 'commission-payout-report', title: 'Commission Payout Report', type: 'item', url: 'pages/reports/commission-payout-report'},\r\n { id: 'bulk-commission-payout-report', title: 'Bulk Commission Payout', type: 'item', url: 'pages/reports/bulk-commission-payout-report'},\r\n // { id: 'company-setting-activity-log', title: 'Company Setting Activity Log', type: 'item', url: 'pages/reports/company-setting-activity-log'},\r\n { id: 'tax-status-report', title: 'Tax Status Report', type: 'item', url: 'pages/reports/tax-status-report'},\r\n { id: 'dormancy-report', title: 'Dormancy Report', type: 'item', url: 'pages/reports/dormancy-report'}\r\n ]\r\n },\r\n {\r\n id: 'manage', title: 'Manage', translate: 'Manage', type: 'collapsable', icon: 'widgets',\r\n children: [\r\n { id: 'Users', title: 'Users', type: 'item', url: '/pages/users', },\r\n { id: 'company-point-accounts', title: 'Wallet Types', type: 'item', url: '/pages/point-accounts' },\r\n ]\r\n },\r\n {\r\n id: 'Settings', title: 'Settings', translate: 'Settings', type: 'collapsable', icon: 'settings',\r\n children: [\r\n { id: 'Company Setting', title: 'Company Setting', type: 'item', icon: '', url: '/pages/company-setting' }\r\n ]\r\n }\r\n\r\n ]\r\n },\r\n\r\n {\r\n id: 'pages',\r\n title: 'Pages',\r\n type: 'group',\r\n icon: 'pages',\r\n role: '3',\r\n children: [\r\n {\r\n id: 'dashboards', title: 'Dashboard', translate: 'Dashboard', type: 'item', icon: 'dashboard', url: '/pages/dashboards/project'\r\n },\r\n { id: 'customers', title: 'Contacts', type: 'item', isPageEditable: true, icon: 'people', url: '/pages/customers' },\r\n { id: 'impersonation', title: 'Impersonation', type: 'none', url: ''},\r\n { id: 'manual-adjustment', title: 'Manual Adjustment', type: 'none', url: ''},\r\n {id: 'transactions', title: 'Transactions', translate: 'Transactions', type: 'collapsable', icon: 'transform',\r\n children: [\r\n { id: 'point-transactions', title: 'Point Transactions', type: 'item', isPageEditable: true, url: '/pages/point-transactions' },\r\n { id: 'import-transactions', title: 'Import Transactions', type: 'item', isPageEditable: true, url: '/pages/import' },\r\n { id: 'import-past-transactions', title: 'Import Past Transactions', type: 'item', url: '/pages/import-past-transactions'},\r\n { id: 'Payout', title: 'Payout Transactions', type: 'item', isPageEditable: true, url: '/pages/payout-report' },\r\n ]\r\n },\r\n \r\n {\r\n id: 'reports', title: 'Reports', translate: 'Reports', type: 'collapsable', icon: 'grid_on',\r\n children: [\r\n { id: 'api-log-report', title: 'api log Report', translate: 'API Logs', type: 'item', url: 'pages/reports/api-log-report' },\r\n { id: 'Schedule-transaction-report', title: 'Schedule Transaction Report', translate: ' Scheduled Transactions', type: 'item', isPageEditable: true, url: 'pages/reports/company-report' },\r\n { id: 'customer-balance-report', title: 'Customer Balance', translate: 'Customer Balance', type: 'item', isPageEditable: true, url: 'pages/reports/customer-balance-report' },\r\n { id: 'tax-status-report', title: 'Tax Status Report', type: 'item', url: 'pages/reports/tax-status-report'},\r\n //{ id: 'ewallet-fees', title: 'eWallet Fees', type: 'item', url: 'pages/reports/ewallet-fees'}\r\n { id: 'inactive-user-report', title: 'Inactive User Report', type: 'item', url: 'pages/reports/inactive-users'},\r\n\t\t { id: 'block-report', title: 'Block Report', type: 'item',isPageEditable: true, url: 'pages/reports/block-report'},\r\n { id: 'bulk-commission-payout-report', title: 'Bulk Commission Payout', isPageEditable: true, type: 'item', url: 'pages/reports/bulk-commission-payout-report'},\r\n { id: 'dormancy-report', title: 'Dormancy Report', type: 'item', url: 'pages/reports/dormancy-report'}\r\n ]\r\n },\r\n {\r\n id: 'manage', title: 'Manage', translate: 'Manage', type: 'collapsable', icon: 'widgets',\r\n children: [\r\n { id: 'Users', title: 'Users', type: 'item', isPageEditable: true, url: '/pages/users', },\r\n { id: 'company-point-accounts', title: 'Wallet Types', type: 'item', isPageEditable: true, url: '/pages/point-accounts' }\r\n ]\r\n },\r\n {\r\n id: 'Settings', title: 'Settings', translate: 'Settings', type: 'collapsable', icon: 'settings',\r\n children: [\r\n { id: 'Company Setting', title: 'Company Setting', type: 'item', isPageEditable: true, icon: '', url: '/pages/company-setting' }\r\n ]\r\n },\r\n {\r\n id: 'debitCardPortal', title: 'Debit Card Portal', translate: 'Debit Card Portal', type: 'collapsable', icon: 'payment',\r\n children : [\r\n { id: 'Portal', title: 'Portal', type: 'item', icon: 'account_box', url : \"https://pm-uat.readycash.com/\", externalUrl: true, openInNewTab: true},\r\n { id: 'Virtual Debit Card', title: 'Virtual Debit Card', type: 'item', isPageEditable: true, icon: 'credit_card', url: '/pages/virtual-debit-card' }\r\n ]\r\n }\r\n\r\n ]\r\n // children: [\r\n // //{id: 'dashboards', title: 'Dashboards',translate: 'Dashboards',type: 'collapsable', icon: 'dashboard',\r\n // // children: [ {id: 'project', title: 'Project', translate: 'Project', type: 'item', url: '/pages/dashboards/project' },\r\n // // ]},\r\n // { id: 'customers', title: 'Contacts', type: 'item', icon: 'people', url: '/pages/customers' },\r\n // { id: 'company-point-accounts', title: 'Point Accounts', type: 'item', icon: 'account_box', url: '/pages/point-accounts' },\r\n // {id: 'transactions', title: 'Transactions', translate: 'Transactions', type: 'collapsable', icon: 'transform',\r\n // children: [\r\n // { id: 'point-transactions', title: 'Point Transactions', type: 'item', url: '/pages/point-transactions' },\r\n // { id: 'import-transactions', title: 'Import Transactions', type: 'item', url: '/pages/import' },\r\n // { id: 'Payout', title: 'Payout Transactions', type: 'item', url: '/pages/payout-report' },\r\n // ]\r\n // },\r\n // // { id: 'Payout', title: 'Payout Transactions', type: 'item', icon: 'payment', url: '/pages/payout-report' },\r\n // {\r\n // id: 'reports', title: 'Reports', translate: 'Reports', type: 'collapsable', icon: 'grid_on',\r\n // children: [\r\n // //{id: 'transaction-report', title: 'Transaction Report', translate: 'Transaction Report', type: 'item', url: 'pages/reports/transaction-report'},\r\n // { id: 'api-log-report', title: 'api log Report', translate: 'API Logs', type: 'item', url: 'pages/reports/api-log-report' },\r\n // // {id: 'top-x-customer-report', title: 'Top X Customer Report', translate: 'Top X Customer Report', type: 'item', url: 'pages/reports/top-x-customer-report'}]\r\n // { id: 'customer-balance-report', title: 'Customer Balance', translate: 'Customer Balance', type: 'item', url: 'pages/reports/customer-balance-report' },\r\n // ]\r\n // },\r\n // ]\r\n },\r\n {\r\n id: 'pages',\r\n title: 'Pages',\r\n type: 'group',\r\n icon: 'pages',\r\n role: '6',\r\n children: [\r\n {\r\n id: 'dashboards', title: 'Dashboard', translate: 'Dashboard', type: 'item', icon: 'dashboard', url: '/pages/dashboards/project'\r\n // children: [{ id: 'project', title: 'Project', translate: 'Project', type: 'item', url: '/pages/dashboards/project' },\r\n // ]\r\n },\r\n { id: 'subaccount', title: 'Subaccount', type: 'item', icon: 'people', url: '/pages/accounts/companies' },\r\n // { id: 'Users', title: 'Users', type: 'item', icon: 'group', url: '/pages/users', },\r\n // { id: 'manage-transctions', title: 'Manage Transactions',\r\n // type: 'item', icon: 'transfer_within_a_station',\r\n // url: '/pages/manage-transctions'},\r\n\r\n {id: 'transactions', title: 'Transactions', translate: 'Transactions', type: 'collapsable', icon: 'transform',\r\n children: [\r\n { id: 'point-transactions', title: 'Point Transactions', type: 'item', url: '/pages/point-transactions' },\r\n { id: 'import-transactions', title: 'Import Transactions', type: 'item', url: '/pages/import' },\r\n { id: 'import-past-transactions', title: 'Import Past Transactions', type: 'item', url: '/pages/import-past-transactions'},\r\n { id: 'Payout', title: 'Payout Transactions', type: 'item', url: '/pages/payout-report' },\r\n { id: 'rellevate-transactions', title: 'Rellevate Transactions', type: 'item', url: '/pages/rellevate-transactions' },\r\n ]\r\n },\r\n\r\n {\r\n id: 'manage-transactions', title: 'Manage Transactions',\r\n type: 'item', icon: 'transfer_within_a_station',\r\n url: '/pages/manage-transactions'\r\n },\r\n {\r\n id: 'reports', title: 'Reports', translate: 'Reports', type: 'collapsable', icon: 'grid_on',\r\n children: [\r\n // {id: 'transaction-report', title: 'Transaction Report', translate: 'Transaction Report', type: 'item', url: 'pages/reports/transaction-report'},\r\n { id: 'api-log-report', title: 'api log Report', translate: 'API Logs', type: 'item', url: 'pages/reports/api-log-report' },\r\n { id: 'Schedule-transaction-report', title: 'Schedule Transaction Report', translate: ' Scheduled Transactions', type: 'item', url: 'pages/reports/company-report' },\r\n { id: 'customer-balance-report', title: 'Customer Balance', translate: 'Customer Balance', type: 'item', url: 'pages/reports/customer-balance-report' },\r\n // {id: 'top-x-customer-report', title: 'Top X Customer Report', translate: 'Top X Customer Report', type: 'item', url: 'pages/reports/top-x-customer-report'}\r\n { id: 'ach-transaction-report', title: 'ACH Transactions', translate: 'ACH Transactions', type: 'item', url: 'pages/reports/ach-transaction-report' },\r\n { id: 'ewallet-fees', title: 'eWallet Fees', type: 'item', url: 'pages/reports/ewallet-fees'},\r\n { id: 'inactive-user-report', title: 'Inactive User Report', type: 'item', url: 'pages/reports/inactive-users'},\r\n { id: 'block-report', title: 'Block Report', type: 'item', url: 'pages/reports/block-report'},\r\n { id: 'commission-payout-report', title: 'Commission Payout Report', type: 'item', url: 'pages/reports/commission-payout-report'},\r\n { id: 'bulk-commission-payout-report', title: 'Bulk Commission Payout', type: 'item', url: 'pages/reports/bulk-commission-payout-report'},\r\n // It is not move live yet\r\n // { id: 'white-list-customer-report', title: 'Customer White List Report', type: 'item', url: 'pages/reports/customer-white-list-report'},\r\n { id: 'company-setting-activity-log', title: 'Company Setting Activity Log', type: 'item', url: 'pages/reports/company-setting-activity-log'},\r\n { id: 'sqs-report', title: 'SQS Report', type: 'item', url: 'pages/reports/sqs-report'}\r\n ]\r\n },\r\n {\r\n id: 'manage', title: 'Manage', translate: 'Manage', type: 'collapsable', icon: 'widgets',\r\n children: [\r\n { id: 'Users', title: 'Users', type: 'item', url: '/pages/users', },\r\n { id: 'company-point-accounts', title: 'Wallet Types', type: 'item', url: '/pages/point-accounts' },\r\n // { id: 'company-bank-accounts', title: 'Bank Account', type: 'item', url: '/pages/bank-accounts' },\r\n ]\r\n },\r\n {\r\n id: 'Settings', title: 'Settings', translate: 'Settings', type: 'collapsable', icon: 'settings',\r\n children: [\r\n // { id: 'Company Setting', title: 'Company Setting', type: 'item', icon: '', url: '/pages/company-setting' },\r\n { id: 'Fee Settings', title: 'Fee Settings', type: 'item', icon: '', url: '/pages/fee-settings' }\r\n ]\r\n }\r\n\r\n ]\r\n }\r\n\r\n\r\n];","import { Injectable } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport {RestService} from '../../../src/app/shared/rest.service';\r\nimport {UserService} from './user.service';\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class AuthService {\r\n private verifyUserIntervalId: any = null;\r\n\r\n constructor(private _router: Router,private _restService:RestService,private _userService: UserService) { }\r\n\r\n sendToken(token: any) {\r\n token.loggedInDate=new Date();\r\n localStorage.setItem(\"LoggedInUser\",JSON.stringify(token))\r\n this.startVerifyUser();\r\n }\r\n sendAdminToken(token: any) {\r\n token.loggedInDate = new Date();\r\n localStorage.setItem(\"LoggedInAdmin\", JSON.stringify(token))\r\n }\r\n sendCompanyToken(token: any) {\r\n token.loggedInDate = new Date();\r\n localStorage.setItem(\"LoggedInCompany\", JSON.stringify(token))\r\n }\r\n // sendUserData(data: string){\r\n // localStorage.setItem(\"LoggedInUserData\",data)\r\n // }\r\n sendUserData(data: string): void {\r\n this._userService.setActiveUser(data);\r\n }\r\n\r\n setAdminBackToUrl(data: any) {\r\n window.localStorage.setItem('AdminBackToUrl', data);\r\n }\r\n getAdminBackToUrl() {\r\n return localStorage.getItem(\"AdminBackToUrl\");\r\n }\r\n setCompanyBackToUrl(data: any) {\r\n window.localStorage.setItem('CompanyBackToUrl', data);\r\n }\r\n getCompanyBackToUrl() {\r\n return localStorage.getItem(\"CompanyBackToUrl\");\r\n }\r\n isAuthorised(){\r\n if(this.getToken()){\r\n var token=JSON.parse(this.getToken());\r\n var loggedInDate=new Date(token.loggedInDate);\r\n loggedInDate.setSeconds(loggedInDate.getSeconds() + token.expires_in);\r\n if(loggedInDate < new Date()) return true;\r\n else return false;\r\n }\r\n return false;\r\n }\r\n\r\n getToken() {\r\n return localStorage.getItem(\"LoggedInUser\")\r\n }\r\n getAdminToken() {\r\n return localStorage.getItem(\"LoggedInAdmin\")\r\n }\r\n getCompanyToken() {\r\n return localStorage.getItem(\"LoggedInCompany\")\r\n }\r\n getUserData(){\r\n return localStorage.getItem(\"LoggedInUserData\")\r\n }\r\n\r\n\r\n isLoggedIn() {\r\n return this.getToken() !== null;\r\n }\r\n isAdminLoggedIn() {\r\n return this.getAdminToken() !== null;\r\n }\r\n isCompanyLoggedIn() {\r\n return this.getCompanyToken() !== null;\r\n }\r\n sendLanguageMenu(data: any){\r\n localStorage.setItem(\"LanguageMenuList\",data)\r\n }\r\n getLanguageMenu() {\r\n return JSON.parse(localStorage.getItem(\"LanguageMenuList\"));\r\n }\r\n\r\n sendDefaultCountryCode(data: any){\r\n localStorage.setItem(\"DefaultCountryCode\",data)\r\n }\r\n sendDefaultLanguageCountryCode(data: any){\r\n localStorage.setItem(\"DefaultLanguageCountryCode\",data)\r\n }\r\n logout() {\r\n this.stopVerifyUser();\r\n localStorage.removeItem(\"LoggedInUser\");\r\n localStorage.removeItem(\"LoggedInUserData\");\r\n localStorage.removeItem(\"LanguageMenuList\");\r\n localStorage.removeItem(\"DefaultCountryCode\");\r\n localStorage.removeItem(\"DefaultLanguageCountryCode\");\r\n localStorage.removeItem(\"isImpersonate\");\r\n localStorage.removeItem(\"superAdmin\");\r\n if(location.pathname != '/ForgotPassword'){\r\n this._router.navigate([\"login\"]);\r\n }\r\n }\r\n setCompanyLogo(data){\r\n var _url =\"/Company/SetCompanyLogo\";\r\n return this._restService.PostFile(_url,data);\r\n}\r\n\r\n sendCompanyProfileLogo(data: string): void {\r\n this._userService.setCompanyFavIcon(data);\r\n }\r\n\r\n startVerifyUser() {\r\n this.stopVerifyUser(); // Clear any existing interval to prevent duplicates\r\n if (this.isLoggedIn()) {\r\n this.verifyUserIntervalId = setInterval(() => {\r\n this.VerifyUser();\r\n }, 10000); // Call every 10 seconds\r\n }\r\n }\r\n\r\n stopVerifyUser() {\r\n if (this.verifyUserIntervalId) {\r\n clearInterval(this.verifyUserIntervalId);\r\n this.verifyUserIntervalId = null;\r\n }\r\n }\r\n\r\n VerifyUser() {\r\n this._restService.VerifyUser().subscribe((res: any) => {\r\n if (res == false) {\r\n this.logout();\r\n }\r\n })\r\n }\r\n\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { BASE_URL, API_URL } from '../constants';\r\nimport { HttpClient, HttpHeaders, HttpResponse } from '@angular/common/http';\r\nimport { Observable, forkJoin , of as observableOf} from 'rxjs';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { tap } from 'rxjs/operators';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { RestService } from './rest.service';\r\nimport * as _ from 'lodash';\r\nimport { AuthService } from './auth.service';\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class CustomTranslateService {\r\n C_responseList: any;\r\n L_responseList: any;\r\n CL_responseList: any;\r\n CL_MenuList: any;\r\n constructor(private _http: HttpClient,\r\n private route: ActivatedRoute,\r\n private _translateService: TranslateService,\r\n private _restService: RestService,\r\n private _auth: AuthService) { }\r\n\r\n\r\n\r\n public GetAllCountries() {\r\n var _url = \"/Country/GetAllCountries\";\r\n return this._restService.Get(_url);\r\n }\r\n\r\n public GetAllLanguages() {\r\n var _url = \"/Language/GetAllLanguages\";\r\n return this._restService.Get(_url);\r\n }\r\n public GetAllCountryLanguages() {\r\n var _url = \"/CountryLanguage/GetAllCompanyCountryLanguages\";\r\n return this._restService.Get(_url);\r\n }\r\n public GetMultipleSources(): Observable {\r\n let C_response = this.GetAllCountries();\r\n let L_response = this.GetAllLanguages();\r\n let CL_response = this.GetAllCountryLanguages();\r\n // Observable.forkJoin (RxJS 5) changes to just forkJoin() in RxJS 6\r\n return forkJoin([C_response, L_response, CL_response]);\r\n }\r\n public GetLanguageCodeCombination(countryId:string,callBackUpdateUIElements: CallableFunction) { \r\n //alert(countryId);\r\n this.CL_MenuList = [];\r\n this.GetMultipleSources().subscribe(responseList => {\r\n this.C_responseList = responseList[0].data;\r\n this.L_responseList = responseList[1].data;\r\n this.CL_responseList = responseList[2].data;\r\n this.CL_responseList.forEach((CL_obj: any) => { \r\n if(CL_obj.countryId == parseInt(countryId)){\r\n var temp_list = _.find(this.L_responseList, function (t) { return t.id == CL_obj.languageId });\r\n if (temp_list != undefined && temp_list != null) {\r\n this.CL_MenuList.push({\r\n LanguageName: temp_list.name,\r\n Code: CL_obj.languageCode\r\n })\r\n }\r\n } \r\n })\r\n //console.log(this.CL_MenuList); \r\n this._auth.sendLanguageMenu(JSON.stringify(this.CL_MenuList));\r\n callBackUpdateUIElements(this.CL_MenuList);\r\n }); \r\n }\r\n\r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot } from \r\n'@angular/router';\r\nimport { AuthService } from './auth.service';\r\nimport {Router} from '@angular/router';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class PreventLoggedInAccess implements CanActivate {\r\n\r\n constructor(\r\n private _auth: AuthService,\r\n private _route: Router)\r\n {}\r\n\r\n canActivate() {\r\n if(this._auth.isLoggedIn()){\r\n this._route.navigate(['/pages/dashboards/project']);\r\n return false;\r\n }\r\n else return true;\r\n }\r\n \r\n}\r\n","import { Injectable } from '@angular/core';\r\nimport { BASE_URL,API_URL, objectToParams,API_URL_FOR_BRANDING } from '../constants';\r\nimport { HttpClient, HttpHeaders, HttpResponse } from '@angular/common/http';\r\nimport { Observable } from 'rxjs';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { tap } from 'rxjs/operators';\r\nimport * as moment from 'moment';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class RestService {\r\n\r\n\r\n constructor(private _http: HttpClient, private route: ActivatedRoute) { }\r\n\r\n Delete(resultUrl: string){\r\n\r\n const apiUrl = BASE_URL;\r\n var url = apiUrl + resultUrl;\r\n var httpOptions = {\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'X-TimeZone': this.GetXTimeZone().toString(),\r\n 'Content-Type': 'application/json-patch+json; charset=UTF-8',\r\n })\r\n };\r\n\r\n return this._http.delete>(url, httpOptions).pipe();\r\n }\r\n\r\n\r\n Put(resultUrl: string, requestParameterData: any){\r\n\r\n const apiUrl = API_URL;\r\n var url = apiUrl + resultUrl;\r\n var httpOptions = {\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'X-TimeZone': this.GetXTimeZone().toString(),\r\n 'Content-Type': 'application/json',\r\n })\r\n };\r\n\r\n return this._http.put>(url, requestParameterData, httpOptions).pipe();\r\n }\r\n\r\n\r\n Get(resultUrl: string,isBranding:any = false, customHeader:any={}){\r\n var url = (isBranding ? API_URL_FOR_BRANDING : API_URL) + resultUrl;\r\n if(customHeader && customHeader.code){\r\n var httpOptions = {\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'X-TimeZone': this.GetXTimeZone().toString(),\r\n 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',\r\n 'x-reference-number': customHeader.refNumber,\r\n 'x-2fa-code':customHeader.code\r\n })\r\n };\r\n \r\n }else{\r\n var httpOptions = {\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'X-TimeZone': this.GetXTimeZone().toString(),\r\n 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',\r\n })\r\n };\r\n }\r\n \r\n return this._http.get>(url, httpOptions).pipe(tap());\r\n }\r\n\r\n\r\n Post(resultUrl: string, requestParameterData: any, timeout?: any,customHeader:any={}){\r\n const apiUrl = API_URL;\r\n var url = apiUrl + resultUrl;\r\n if(customHeader && customHeader.code){\r\n var httpOptions = {\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'X-TimeZone': this.GetXTimeZone().toString(),\r\n 'x-reference-number': customHeader.refNumber,\r\n 'x-2fa-code':customHeader.code\r\n })\r\n };\r\n \r\n }else{\r\n var httpOptions = {\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'X-TimeZone': this.GetXTimeZone().toString(),\r\n })\r\n };\r\n }\r\n\r\n return this._http.post>(url,requestParameterData, httpOptions).pipe(tap());\r\n }\r\n\r\n PostFile(resultUrl: string, requestParameterData: any, timeout?: any){\r\n const apiUrl = API_URL;\r\n var url = apiUrl + resultUrl;\r\n var httpOptions = {\r\n headers: new HttpHeaders({\r\n 'Content-Disposition': 'multipart/form-data',\r\n 'Accept': 'application/json'\r\n })\r\n };\r\n\r\n return this._http.post>(url,requestParameterData, httpOptions).pipe(tap());\r\n }\r\n\r\n Token(request) {\r\n var url = BASE_URL + '/Token';\r\n var httpOptions = {\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'\r\n })\r\n };\r\n\r\n return this._http.post>(url,request, httpOptions).pipe(tap());\r\n }\r\n\r\n GetUserProfile(){\r\n var url=\"/Users/GetUsersDetails\";\r\n return this.Get(url);\r\n }\r\n \r\n GetCompanyList() {\r\n var url=\"/Company/GetCompanyList\";\r\n return this.Get(url);\r\n }\r\n ForgotPassword(request){\r\n var url=\"/Common/ForgotPassword\";\r\n return this.Post(url,request);\r\n }\r\n\r\n VerifyForgotPassword(request){\r\n var url=\"/Common/VerifyForgotPassword\";\r\n return this.Post(url,request);\r\n }\r\n\r\n VerifyUser() {\r\n var url=\"/Users/VerifyUser\";\r\n return this.Get(url);\r\n }\r\n\r\n Getblob(resultUrl: string) {\r\n const apiUrl = API_URL;\r\n var url = apiUrl + resultUrl;\r\n var httpOptions = {\r\n responseType: 'blob' as 'json',\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'X-TimeZone': this.GetXTimeZone().toString(),\r\n 'Content-Type': 'application/json',\r\n })\r\n };\r\n\r\n return this._http.get>(url, httpOptions).pipe(tap());\r\n }\r\n Postblob(resultUrl: string, req:any) {\r\n const apiUrl = API_URL;\r\n var url = apiUrl + resultUrl;\r\n var httpOptions = {\r\n responseType: 'blob' as 'json',\r\n headers: new HttpHeaders({\r\n 'Accept': 'application/json',\r\n 'X-TimeZone': moment().utcOffset().toString(),\r\n 'Content-Type': 'application/json',\r\n })\r\n };\r\n\r\n return this._http.post>(url, req, httpOptions).pipe(tap());\r\n }\r\n\r\n GetXTimeZone(){\r\n var date = new Date();\r\n var utcOffset = moment(date).utcOffset();\r\n if(moment(date).isDST()){\r\n console.log('dst');\r\n utcOffset = utcOffset - 60;\r\n }else{\r\n console.log('non-dst');\r\n }\r\n console.log(utcOffset);\r\n return utcOffset;\r\n }\r\n\r\n GetBackGroundImage(){\r\n var url=\"/CompanyBranding/GetBackGroundImage\";\r\n return this.Get(url,true);\r\n }\r\n saveFile(blob, fileName) {\r\n if (window.navigator.msSaveOrOpenBlob) { \r\n navigator.msSaveBlob(blob, fileName);\r\n } else { \r\n var link = document.createElement('a');\r\n link.href = window.URL.createObjectURL(blob);\r\n link.download = fileName;\r\n link.click();\r\n window.URL.revokeObjectURL(link.href);\r\n }\r\n\r\n }\r\n\r\n getAdminSSOToken(req){\r\n var url=`/v2/users/AdminSSOToken?${req}`;\r\n return this.Get(url);\r\n }\r\n}\r\n","import {Injectable, EventEmitter} from '@angular/core';\r\n\r\n@Injectable({providedIn:'root'})\r\nexport class SharedService {\r\n pointAccountIDChanged = new EventEmitter();\r\n}","import { DOCUMENT } from '@angular/common';\r\nimport { Inject, Injectable } from '@angular/core';\r\nimport { Subject, BehaviorSubject, Observable } from 'rxjs';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class UserService {\r\n\r\n // Holds and pushes the value of the currently active company\r\n private activeUser$: Subject;\r\n\r\n // Computes the active company from local storage and store it as initial value\r\n constructor(@Inject(DOCUMENT) private document: any,) { \r\n const initialActiveUser = JSON.parse(window.localStorage.getItem('LoggedInUserData'));\r\n this.activeUser$ = new BehaviorSubject(initialActiveUser);\r\n }\r\n\r\n // Returns the observable (read-only) part of this subject\r\n getActiveUser$(): Observable {\r\n return this.activeUser$.asObservable();\r\n }\r\n\r\n // Stores the new company value in local storage and pushes it to the subject\r\n setActiveUser(data: string) {\r\n window.localStorage.setItem('LoggedInUserData', data);\r\n this.activeUser$.next(JSON.parse(data));\r\n }\r\n\r\n setCompanyFavIcon(data: string) {\r\n this.document.getElementById('appFavicon').setAttribute('href', (data));\r\n }\r\n}\r\n","// This file can be replaced during build by using the `fileReplacements` array.\r\n// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`.\r\n// The list of file replacements can be found in `angular.json`.\r\n\r\nexport const environment = {\r\n production: false,\r\n hmr : false\r\n};\r\n\r\n/*\r\n * For easier debugging in development mode, you can import the following file\r\n * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`.\r\n *\r\n * This import should be commented out in production mode because it will have a negative impact\r\n * on performance if an error is thrown.\r\n */\r\n// import 'zone.js/dist/zone-error'; // Included with Angular CLI.\r\n","import { NgModuleRef, ApplicationRef } from '@angular/core';\r\nimport { createNewHosts } from '@angularclass/hmr';\r\n\r\nexport const hmrBootstrap = (module: any, bootstrap: () => Promise>) => {\r\n let ngModule: NgModuleRef;\r\n module.hot.accept();\r\n bootstrap().then(mod => ngModule = mod);\r\n module.hot.dispose(() => {\r\n const appRef: ApplicationRef = ngModule.injector.get(ApplicationRef);\r\n const elements = appRef.components.map(c => c.location.nativeElement);\r\n const makeVisible = createNewHosts(elements);\r\n ngModule.destroy();\r\n makeVisible();\r\n });\r\n};\r\n","import { enableProdMode } from '@angular/core';\r\nimport { platformBrowserDynamic } from '@angular/platform-browser-dynamic';\r\n\r\nimport { AppModule } from './app/app.module';\r\nimport { environment } from './environments/environment';\r\nimport { hmrBootstrap } from 'hmr';\r\n\r\nif ( environment.production )\r\n{\r\n enableProdMode();\r\n}\r\n\r\nconst bootstrap = () => platformBrowserDynamic().bootstrapModule(AppModule);\r\n\r\nif ( environment.hmr )\r\n{\r\n if ( module['hot'] )\r\n {\r\n hmrBootstrap(module, bootstrap);\r\n }\r\n else\r\n {\r\n console.error('HMR is not enabled for webpack-dev-server!');\r\n console.log('Are you using the --hmr flag for ng serve?');\r\n }\r\n}\r\nelse\r\n{\r\n bootstrap().catch(err => console.error(err));\r\n}\r\n"],"sourceRoot":"webpack:///"}