From a7c05104af8da549d4dd82b2052d503b114a480b Mon Sep 17 00:00:00 2001 From: Chris Smith Date: Thu, 30 Apr 2026 13:14:01 +0200 Subject: [PATCH] flatten new-site/ to repo root and remove old hugo site MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Moves the Next.js app's contents from new-site/ to the repository root and deletes the previous Hugo site (assets/, content/, themes/, hugo.toml, etc.). Also retires the AWS Amplify config and old Netlify _redirects file — the new site deploys to Vercel. Updates STRATEGY.md path references to drop the new-site/ prefix. LICENSE preserved. Co-Authored-By: Claude Opus 4.7 (1M context) --- .gitignore | 58 +- .jshintrc | 59 - .markdownlint.json | 5 - .prettierrc | 13 - new-site/AGENTS.md => AGENTS.md | 0 new-site/CLAUDE.md => CLAUDE.md | 0 new-site/README.md => README.md | 0 new-site/STRATEGY.md => STRATEGY.md | 8 +- _redirects | 1 - amplify.yml | 29 - assets/images/avatar-sm.png | Bin 4005 -> 0 bytes assets/images/avatar.png | Bin 79057 -> 0 bytes assets/images/banner.png | Bin 80952 -> 0 bytes assets/images/call-to-action.png | Bin 19721 -> 0 bytes assets/images/favicon.png | Bin 21099 -> 0 bytes assets/images/image-placeholder.png | Bin 4881 -> 0 bytes assets/images/logo-darkmode.png | Bin 15830 -> 0 bytes assets/images/logo.png | Bin 18857 -> 0 bytes assets/images/no-search-found.png | Bin 8267 -> 0 bytes assets/images/og-image.png | Bin 107524 -> 0 bytes assets/images/service-1.png | Bin 11502 -> 0 bytes assets/images/service-2.png | Bin 19596 -> 0 bytes assets/images/service-3.png | Bin 16481 -> 0 bytes assets/scss/custom.scss | 1 - config/_default/languages.toml | 6 - config/_default/menus.en.toml | 24 - config/_default/module.toml | 87 - config/_default/params.toml | 101 - config/development/server.toml | 13 - content/english/_index.md | 12 - content/english/about/_index.md | 24 - content/english/authors/_index.md | 3 - content/english/blog/_index.md | 5 - content/english/blog/post-1.md | 23 - content/english/contact/_index.md | 6 - content/english/pages/privacy-policy.md | 42 - content/english/sections/call-to-action.md | 14 - content/english/sections/testimonial.md | 31 - data/social.json | 19 - data/theme.json | 44 - .../eslint.config.mjs => eslint.config.mjs | 0 go.mod | 31 - hugo.toml | 178 - i18n/en.yaml | 14 - .../mdx-components.tsx => mdx-components.tsx | 0 new-site/.env.local.example | 16 - new-site/.gitignore | 41 - new-site/package.json | 34 - new-site/next.config.ts => next.config.ts | 0 package.json | 61 +- new-site/pnpm-lock.yaml => pnpm-lock.yaml | 0 ...pnpm-workspace.yaml => pnpm-workspace.yaml | 0 postcss.config.js | 44 - .../postcss.config.mjs => postcss.config.mjs | 0 public/llms.txt | 34 + readme.md | 239 - scripts/clearModules.js | 14 - scripts/projectSetup.js | 116 - scripts/removeDarkmode.js | 69 - scripts/themeSetup.js | 125 - scripts/themeUpdate.js | 19 - {new-site/src => src}/app/about/page.tsx | 0 .../src => src}/app/blog/[slug]/page.tsx | 0 {new-site/src => src}/app/blog/page.tsx | 0 {new-site/src => src}/app/contact/page.tsx | 0 {new-site/src => src}/app/favicon.ico | Bin {new-site/src => src}/app/globals.css | 0 {new-site/src => src}/app/layout.tsx | 0 {new-site/src => src}/app/page.tsx | 0 {new-site/src => src}/app/robots.ts | 0 {new-site/src => src}/app/services/page.tsx | 0 {new-site/src => src}/app/sitemap.ts | 0 {new-site/src => src}/app/thank-you/page.tsx | 0 .../src => src}/app/work/[slug]/page.tsx | 0 {new-site/src => src}/app/work/page.tsx | 0 {new-site/src => src}/components/button.tsx | 0 .../src => src}/components/client-logos.tsx | 0 .../src => src}/components/contact-form.tsx | 0 .../src => src}/components/container.tsx | 0 .../src => src}/components/guarantees.tsx | 0 .../src => src}/components/how-i-work.tsx | 0 {new-site/src => src}/components/jsonld.tsx | 0 .../src => src}/components/pricing-teaser.tsx | 0 .../components/section-heading.tsx | 0 .../src => src}/components/site-footer.tsx | 0 .../src => src}/components/site-header.tsx | 0 .../src => src}/components/testimonials.tsx | 0 .../content/blog/how-to-hire-a-php-dev.mdx | 0 .../src => src}/content/blog/the-glue-job.mdx | 0 .../blog/three-pl-integration-checklist.mdx | 0 {new-site/src => src}/lib/case-studies.ts | 0 {new-site/src => src}/lib/cn.ts | 0 {new-site/src => src}/lib/jsonld.ts | 0 {new-site/src => src}/lib/posts.ts | 0 {new-site/src => src}/lib/pricing.ts | 0 {new-site/src => src}/lib/site.ts | 0 tailwind.config.js | 103 - theme.toml | 29 - themes/hugoplate/assets/js/main.js | 36 - .../assets/plugins/maps/google-map.js | 179 - .../assets/plugins/swiper/swiper-bundle.css | 667 - .../assets/plugins/swiper/swiper-bundle.js | 11853 ---------------- themes/hugoplate/assets/scss/base.scss | 59 - themes/hugoplate/assets/scss/buttons.scss | 15 - themes/hugoplate/assets/scss/components.scss | 74 - themes/hugoplate/assets/scss/custom.scss | 2 - themes/hugoplate/assets/scss/main.scss | 30 - .../assets/scss/module-overrides.scss | 53 - themes/hugoplate/assets/scss/navigation.scss | 87 - themes/hugoplate/assets/scss/utilities.scss | 20 - themes/hugoplate/layouts/404.en.html | 26 - themes/hugoplate/layouts/404.html | 26 - themes/hugoplate/layouts/_default/baseof.html | 53 - themes/hugoplate/layouts/_default/list.html | 20 - themes/hugoplate/layouts/_default/single.html | 16 - .../hugoplate/layouts/_default/taxonomy.html | 21 - themes/hugoplate/layouts/_default/terms.html | 41 - themes/hugoplate/layouts/about/list.html | 13 - themes/hugoplate/layouts/authors/list.html | 16 - themes/hugoplate/layouts/authors/single.html | 48 - themes/hugoplate/layouts/blog/list.html | 29 - themes/hugoplate/layouts/blog/single.html | 95 - themes/hugoplate/layouts/contact/list.html | 120 - themes/hugoplate/layouts/index.html | 139 - .../layouts/partials/call-to-action.html | 33 - .../partials/components/author-card.html | 30 - .../partials/components/blog-card.html | 37 - .../partials/components/breadcrumb.html | 30 - .../components/language-switcher.html | 28 - .../partials/components/pagination.html | 138 - .../partials/components/theme-switcher.html | 70 - .../components/tw-size-indicator.html | 9 - .../layouts/partials/essentials/footer.html | 57 - .../layouts/partials/essentials/head.html | 61 - .../layouts/partials/essentials/header.html | 139 - .../layouts/partials/essentials/script.html | 58 - .../layouts/partials/essentials/style.html | 82 - .../layouts/partials/page-header.html | 9 - .../layouts/partials/widgets/categories.html | 23 - .../layouts/partials/widgets/tags.html | 23 - .../partials/widgets/widget-wrapper.html | 3 - new-site/tsconfig.json => tsconfig.json | 0 142 files changed, 106 insertions(+), 16257 deletions(-) mode change 100755 => 100644 .gitignore delete mode 100644 .jshintrc delete mode 100755 .markdownlint.json delete mode 100755 .prettierrc rename new-site/AGENTS.md => AGENTS.md (100%) rename new-site/CLAUDE.md => CLAUDE.md (100%) rename new-site/README.md => README.md (100%) rename new-site/STRATEGY.md => STRATEGY.md (98%) delete mode 100644 _redirects delete mode 100644 amplify.yml delete mode 100644 assets/images/avatar-sm.png delete mode 100755 assets/images/avatar.png delete mode 100644 assets/images/banner.png delete mode 100755 assets/images/call-to-action.png delete mode 100644 assets/images/favicon.png delete mode 100755 assets/images/image-placeholder.png delete mode 100644 assets/images/logo-darkmode.png delete mode 100644 assets/images/logo.png delete mode 100755 assets/images/no-search-found.png delete mode 100644 assets/images/og-image.png delete mode 100755 assets/images/service-1.png delete mode 100755 assets/images/service-2.png delete mode 100755 assets/images/service-3.png delete mode 100755 assets/scss/custom.scss delete mode 100755 config/_default/languages.toml delete mode 100755 config/_default/menus.en.toml delete mode 100644 config/_default/module.toml delete mode 100755 config/_default/params.toml delete mode 100644 config/development/server.toml delete mode 100755 content/english/_index.md delete mode 100644 content/english/about/_index.md delete mode 100644 content/english/authors/_index.md delete mode 100755 content/english/blog/_index.md delete mode 100755 content/english/blog/post-1.md delete mode 100644 content/english/contact/_index.md delete mode 100644 content/english/pages/privacy-policy.md delete mode 100644 content/english/sections/call-to-action.md delete mode 100644 content/english/sections/testimonial.md delete mode 100644 data/social.json delete mode 100644 data/theme.json rename new-site/eslint.config.mjs => eslint.config.mjs (100%) delete mode 100644 go.mod delete mode 100755 hugo.toml delete mode 100755 i18n/en.yaml rename new-site/mdx-components.tsx => mdx-components.tsx (100%) delete mode 100644 new-site/.env.local.example delete mode 100644 new-site/.gitignore delete mode 100644 new-site/package.json rename new-site/next.config.ts => next.config.ts (100%) rename new-site/pnpm-lock.yaml => pnpm-lock.yaml (100%) rename new-site/pnpm-workspace.yaml => pnpm-workspace.yaml (100%) delete mode 100644 postcss.config.js rename new-site/postcss.config.mjs => postcss.config.mjs (100%) create mode 100644 public/llms.txt delete mode 100755 readme.md delete mode 100644 scripts/clearModules.js delete mode 100644 scripts/projectSetup.js delete mode 100644 scripts/removeDarkmode.js delete mode 100644 scripts/themeSetup.js delete mode 100644 scripts/themeUpdate.js rename {new-site/src => src}/app/about/page.tsx (100%) rename {new-site/src => src}/app/blog/[slug]/page.tsx (100%) rename {new-site/src => src}/app/blog/page.tsx (100%) rename {new-site/src => src}/app/contact/page.tsx (100%) rename {new-site/src => src}/app/favicon.ico (100%) rename {new-site/src => src}/app/globals.css (100%) rename {new-site/src => src}/app/layout.tsx (100%) rename {new-site/src => src}/app/page.tsx (100%) rename {new-site/src => src}/app/robots.ts (100%) rename {new-site/src => src}/app/services/page.tsx (100%) rename {new-site/src => src}/app/sitemap.ts (100%) rename {new-site/src => src}/app/thank-you/page.tsx (100%) rename {new-site/src => src}/app/work/[slug]/page.tsx (100%) rename {new-site/src => src}/app/work/page.tsx (100%) rename {new-site/src => src}/components/button.tsx (100%) rename {new-site/src => src}/components/client-logos.tsx (100%) rename {new-site/src => src}/components/contact-form.tsx (100%) rename {new-site/src => src}/components/container.tsx (100%) rename {new-site/src => src}/components/guarantees.tsx (100%) rename {new-site/src => src}/components/how-i-work.tsx (100%) rename {new-site/src => src}/components/jsonld.tsx (100%) rename {new-site/src => src}/components/pricing-teaser.tsx (100%) rename {new-site/src => src}/components/section-heading.tsx (100%) rename {new-site/src => src}/components/site-footer.tsx (100%) rename {new-site/src => src}/components/site-header.tsx (100%) rename {new-site/src => src}/components/testimonials.tsx (100%) rename {new-site/src => src}/content/blog/how-to-hire-a-php-dev.mdx (100%) rename {new-site/src => src}/content/blog/the-glue-job.mdx (100%) rename {new-site/src => src}/content/blog/three-pl-integration-checklist.mdx (100%) rename {new-site/src => src}/lib/case-studies.ts (100%) rename {new-site/src => src}/lib/cn.ts (100%) rename {new-site/src => src}/lib/jsonld.ts (100%) rename {new-site/src => src}/lib/posts.ts (100%) rename {new-site/src => src}/lib/pricing.ts (100%) rename {new-site/src => src}/lib/site.ts (100%) delete mode 100755 tailwind.config.js delete mode 100644 theme.toml delete mode 100755 themes/hugoplate/assets/js/main.js delete mode 100644 themes/hugoplate/assets/plugins/maps/google-map.js delete mode 100644 themes/hugoplate/assets/plugins/swiper/swiper-bundle.css delete mode 100644 themes/hugoplate/assets/plugins/swiper/swiper-bundle.js delete mode 100755 themes/hugoplate/assets/scss/base.scss delete mode 100755 themes/hugoplate/assets/scss/buttons.scss delete mode 100755 themes/hugoplate/assets/scss/components.scss delete mode 100644 themes/hugoplate/assets/scss/custom.scss delete mode 100755 themes/hugoplate/assets/scss/main.scss delete mode 100644 themes/hugoplate/assets/scss/module-overrides.scss delete mode 100755 themes/hugoplate/assets/scss/navigation.scss delete mode 100755 themes/hugoplate/assets/scss/utilities.scss delete mode 100755 themes/hugoplate/layouts/404.en.html delete mode 100755 themes/hugoplate/layouts/404.html delete mode 100755 themes/hugoplate/layouts/_default/baseof.html delete mode 100755 themes/hugoplate/layouts/_default/list.html delete mode 100755 themes/hugoplate/layouts/_default/single.html delete mode 100755 themes/hugoplate/layouts/_default/taxonomy.html delete mode 100755 themes/hugoplate/layouts/_default/terms.html delete mode 100644 themes/hugoplate/layouts/about/list.html delete mode 100644 themes/hugoplate/layouts/authors/list.html delete mode 100755 themes/hugoplate/layouts/authors/single.html delete mode 100644 themes/hugoplate/layouts/blog/list.html delete mode 100644 themes/hugoplate/layouts/blog/single.html delete mode 100755 themes/hugoplate/layouts/contact/list.html delete mode 100755 themes/hugoplate/layouts/index.html delete mode 100644 themes/hugoplate/layouts/partials/call-to-action.html delete mode 100755 themes/hugoplate/layouts/partials/components/author-card.html delete mode 100644 themes/hugoplate/layouts/partials/components/blog-card.html delete mode 100644 themes/hugoplate/layouts/partials/components/breadcrumb.html delete mode 100644 themes/hugoplate/layouts/partials/components/language-switcher.html delete mode 100755 themes/hugoplate/layouts/partials/components/pagination.html delete mode 100644 themes/hugoplate/layouts/partials/components/theme-switcher.html delete mode 100644 themes/hugoplate/layouts/partials/components/tw-size-indicator.html delete mode 100755 themes/hugoplate/layouts/partials/essentials/footer.html delete mode 100755 themes/hugoplate/layouts/partials/essentials/head.html delete mode 100755 themes/hugoplate/layouts/partials/essentials/header.html delete mode 100755 themes/hugoplate/layouts/partials/essentials/script.html delete mode 100755 themes/hugoplate/layouts/partials/essentials/style.html delete mode 100755 themes/hugoplate/layouts/partials/page-header.html delete mode 100755 themes/hugoplate/layouts/partials/widgets/categories.html delete mode 100755 themes/hugoplate/layouts/partials/widgets/tags.html delete mode 100755 themes/hugoplate/layouts/partials/widgets/widget-wrapper.html rename new-site/tsconfig.json => tsconfig.json (100%) diff --git a/.gitignore b/.gitignore old mode 100755 new mode 100644 index 40f1aa3..5ef6a52 --- a/.gitignore +++ b/.gitignore @@ -1,19 +1,41 @@ -Thumbs.db +# See https://help.github.com/articles/ignoring-files/ for more about ignoring files. + +# dependencies +/node_modules +/.pnp +.pnp.* +.yarn/* +!.yarn/patches +!.yarn/plugins +!.yarn/releases +!.yarn/versions + +# testing +/coverage + +# next.js +/.next/ +/out/ + +# production +/build + +# misc .DS_Store -.dist -.tmp -.lock -.sass-cache -npm-debug.log -node_modules -builds -package-lock.json -public -resources -.hugo_build.lock -jsconfig.json -hugo_stats.json -go.sum -yarn.lock -.idea -.vscode \ No newline at end of file +*.pem + +# debug +npm-debug.log* +yarn-debug.log* +yarn-error.log* +.pnpm-debug.log* + +# env files (can opt-in for committing if needed) +.env* + +# vercel +.vercel + +# typescript +*.tsbuildinfo +next-env.d.ts diff --git a/.jshintrc b/.jshintrc deleted file mode 100644 index 873eef9..0000000 --- a/.jshintrc +++ /dev/null @@ -1,59 +0,0 @@ -{ - "maxerr": 50, - "bitwise": true, - "camelcase": false, - "curly": true, - "eqeqeq": true, - "forin": true, - "freeze": true, - "immed": true, - "indent": 2, - "latedef": true, - "newcap": false, - "noarg": true, - "noempty": true, - "nonbsp": true, - "nonew": true, - "plusplus": false, - "undef": true, - "unused": false, - "strict": true, - "maxparams": false, - "maxdepth": 4, - "maxstatements": false, - "maxcomplexity": false, - "maxlen": 400, - "browser": true, - "devel": true, - "asi": false, - "boss": false, - "debug": false, - "eqnull": false, - "es3": false, - "es5": false, - "esversion": 12, - "moz": false, - "evil": true, - "expr": true, - "funcscope": false, - "globalstrict": false, - "iterator": false, - "lastsemic": false, - "laxbreak": false, - "laxcomma": false, - "loopfunc": true, - "multistr": true, - "noyield": false, - "notypeof": false, - "proto": false, - "scripturl": false, - "shadow": false, - "sub": false, - "supernew": false, - "validthis": false, - "globals": { - "jQuery": false, - "google": false, - "$": false - } -} diff --git a/.markdownlint.json b/.markdownlint.json deleted file mode 100755 index 7d41e3f..0000000 --- a/.markdownlint.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "MD033": false, - "MD034": false, - "MD013": false -} diff --git a/.prettierrc b/.prettierrc deleted file mode 100755 index ee30508..0000000 --- a/.prettierrc +++ /dev/null @@ -1,13 +0,0 @@ -{ - "plugins": ["prettier-plugin-go-template"], - "overrides": [ - { - "files": ["*.html"], - "options": { - "parser": "go-template", - "goTemplateBracketSpacing": true, - "bracketSameLine": true - } - } - ] -} diff --git a/new-site/AGENTS.md b/AGENTS.md similarity index 100% rename from new-site/AGENTS.md rename to AGENTS.md diff --git a/new-site/CLAUDE.md b/CLAUDE.md similarity index 100% rename from new-site/CLAUDE.md rename to CLAUDE.md diff --git a/new-site/README.md b/README.md similarity index 100% rename from new-site/README.md rename to README.md diff --git a/new-site/STRATEGY.md b/STRATEGY.md similarity index 98% rename from new-site/STRATEGY.md rename to STRATEGY.md index 3dd8875..195f82d 100644 --- a/new-site/STRATEGY.md +++ b/STRATEGY.md @@ -160,7 +160,7 @@ These are placeholders / wiring tasks I couldn't do without you: requirements — ask first. - **Source the assets.** Download proper SVGs from each brand's press kit / "About Us" media page, drop into - `new-site/public/logos/.svg`, then update + `public/logos/.svg`, then update `src/components/client-logos.tsx` to render `` for entries with a `logo` field. Style: grayscale by default, brighten on hover, max-height ~32px. @@ -304,7 +304,7 @@ The faster you can say "no" cleanly, the easier "yes" gets. blog/work registries (`src/app/sitemap.ts`) - **`/robots.txt`** — allows everything except `/thank-you`; points at the sitemap (`src/app/robots.ts`) -- **`/llms.txt`** at site root (`new-site/public/llms.txt`) — the +- **`/llms.txt`** at site root (`public/llms.txt`) — the emerging convention for telling LLM crawlers what to index. Update this when you add or rename pages. - **OG metadata** — title/description templates set in root layout. @@ -328,12 +328,12 @@ Four are wired and visible on Home (full section) and Services 3. One-business-day response 4. You own everything (full IP transfer, no subcontracting) -Edit them in `new-site/src/components/guarantees.tsx`. +Edit them in `src/components/guarantees.tsx`. ## "How I work" principles Five principles render on the About page (`HowIWork` component). -Edit in `new-site/src/components/how-i-work.tsx`. +Edit in `src/components/how-i-work.tsx`. --- diff --git a/_redirects b/_redirects deleted file mode 100644 index e6c1017..0000000 --- a/_redirects +++ /dev/null @@ -1 +0,0 @@ -/* /en/404.html 404 \ No newline at end of file diff --git a/amplify.yml b/amplify.yml deleted file mode 100644 index ce755f7..0000000 --- a/amplify.yml +++ /dev/null @@ -1,29 +0,0 @@ -version: 1 -frontend: - phases: - preBuild: - commands: - - yum install -y curl - - curl -LO "https://github.com/gohugoio/hugo/releases/download/v0.134.3/hugo_extended_0.134.3_Linux-64bit.tar.gz" - - tar -xvf hugo_extended_0.134.3_Linux-64bit.tar.gz - - mv hugo /usr/local/bin/ - - rm hugo_extended_0.134.3_Linux-64bit.tar.gz - - echo "HUGO 0.134.3 INSTALLED" - - curl -LO "https://dl.google.com/go/go1.22.2.linux-amd64.tar.gz" - - tar -C /usr/local -xzf go1.22.2.linux-amd64.tar.gz - - export PATH=$PATH:/usr/local/go/bin - - rm go1.22.2.linux-amd64.tar.gz - - echo "GO 1.22.2 INSTALLED" - - npm install - build: - commands: - - npm run project-setup - - npm run build - artifacts: - # IMPORTANT - Please verify your build output directory - baseDirectory: /public - files: - - "**/*" - cache: - paths: - - node_modules/**/* diff --git a/assets/images/avatar-sm.png b/assets/images/avatar-sm.png deleted file mode 100644 index e1699dc14a47a3b2726aa9a2b430865dda8a087f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4005 zcmV;W4_fevP)l(fwMt23Hy8`S_f>&z=*ekeV1>hA}UIBOom=)Npz>P7%r+rs|W(6aHM-ahl z^2k}5wvf8As;jF?!Y9HZS!zk$bvm;$vof>RXa#U~cGms;`E&34_wO5>PUjZC)cyJM zXAggPe{F58i`Qm9$M28$y)i#EfB*1nV}9-Y#*G{2o12?sT5_z>65{pi*98-?!9+Ze z#~!r+{@xLP|2hA?0_pee-79IyuoMJCLO*=?FaV+aZ$WdUF%lrrB@_Pg+O=!t?c29U zlsU2`xI*efx*#=2fb17HZ{9r0Rh?%?Fw`$d<$)VeI!Sc~pYs9#?ccd`=bSP^HUxuM ze%PgarB#cGRNudU|9~<;a)MWg*h_$c_T$Hoz0^b}BY0JborPH9k5XCS(FuP0_HFOm zw{K7R=@zw!s*j67p7Z|HH-^95maAoeIr@)3{@9Ccc}FFfrS>sD3@NPfWL%e5{5WFw z<=l4=-@JLV!NC%cy}|$9!lMb61j3lV4{G}vMM4yUMQWc@7 zf@mFR6qe?G3~6qi;6PG4A(j93_(nPJ_xs6w&XbdqEhgx1YEE_(X>N^R2~_OzU_2pD zh=KBgNqv@*)Ok2QKJKv;799KDZKB5c8lT<0dv}LgLMsGAC9_&PM4XuXQ1aj2vc!H_ zss~MoZc}9kCm3@UU+AId#g?>0#Ll7#(QT0&lwg^kU`)Brx0sK1a*6&lMFXNS4v%;o zjwld16bPrMr++iKhvZJ~KF_g#tqQpSuI203uYG>HPj2X93^A4z2tgzmC&YK&fy-x7 zM|fgE7EhkLN;7|Ez{b}LYKX=X>_aYNpYQO^RVNp~HR4*~4Y+&`V;Vw|8%eOtxrYuP zLD+DQ@62eCoSeYp^@Okgsmo`W=4dgqi4?HUT1<4esml$vqOH^inkq^VZX zn0M)l+*SZB=U{ksWo=yr6~R!=+Id%8p%God2^cdbc$+TPzHKPrQ!9?M6D;QWkQCq( z+_`dv`~epVNdTH-d8~IeuG6~h09MVg+%&5BAjb$5+`2DczCf+@s;_hKV4Pc$IsgNT zHD-^WKDHd%mE^_kx`S$sEJeop&w4 z9PEA<;zwctlKS!EN8I(8o4oSB#KrnoeoC#xBxB06scK-MfGsq#kdZ(Z;EqQ^93=wo@=u>W!8adL_(HWI)TBsK z67bj#NoQ3r}REK;%ksXtC%7@inK(0YDk{Oz@o-4(_5X>sU zI;p3U-h|{DBq3Q0s8Vt0*6a(HtY}%;_%B%?shtND5e{y{EK0iQo`axp*VF#3EyJs38De0BfTG?tIdz!HIRvnl8HUugT2hV;)xj zpGvT-_r9}zfvA8HMS}Lc1dW3(tO|!z<5yPji#lu@GKFF+YJGk_uRqOsO(mFBPC*u+ zCO5X`fFrBocM z2_uGvb&BL^v@p-Bb8un%V925<4WwmZ&vqQEq(>AO@|`yI+l?K{L;*Zm&PzH1PB0-@ zPO?_7Lp@V`Y}pRLI&>S;hJ2?+Ra?(7B$R4;dgDz97N5|DsM0HVU^{?qht{lmmKN(Z zSEVHu_%~lFj+t;eA(*ApdXnrbrpSJ%z45S6-=@(g=|{EK-JpwsH~6Nu-gssnR!J}% z``GC%5)-e5v`%Up*5B|gEAfTg)V1@l^v$LYd@GwF!*|0!6dC-R*7aS7`W|mch_e>6 z`CgGw*1ZW%!EJ|qIjf{V6;g(fPIkW~_}ZRR6KSqZj%Nz1VMpc;3|7vla{eQ`gqSe(Xc+pCP#&-bsjMv=>d21?SgSlg z?zlGdWNgS5w3lAw*T@rlOVo#C+)=2$Yyu(D04zz-n_w>o)m%ZX_JMZpD4gXUWds@E z6eQ&tSkz<{%%wAtormwb0W z$M#Uzg3opggjX{MBV5^|41r}jsdNl2&CqIlId40l&BWM`r<>!W44o>|C#8NIq=OscaKsoe6?@QRxbsn_lVhV&15K%~;dC0m;|s;Ye%&1%y`sGivVHA967LEMA92HVma-9b znUgwau55AEsm)Z4MT7C8=0jbnf+#5wDx^MS=__XA%YlI#1{;5E@r{i^MMv8G)MR5b zGTSlLJh3UkC`pv|yLG^VdP$KXR`Fvdb*p7k>j0Ji9AvWvdyuOAu(BJ_(e!xpMA;)N zs+tyJaZ?qPCrXOA-?2}loM}dfkXBkg8>R6Gh(&e3w6I5dyof^@l0jT>@8ogu+IK%Wcav%caWMd=%) zkYGs>%C|;5n9rx*)UDEPuYl##*=wKcbBKXcP(2z+vBy5TvjC}>Z(3UbENm7;~R&r&3= zk+1d4ce{4&-1~Duqtb;@1Emx@`^C6W>`zaQz~G|OZK`bq3^3rZW<77t0nd>yw8zU7 zcC46t7q)n=t8CCnao1%}TTgN)i}1LB)Z_vm%LJ6WJsZBJYI&Yc{S-R8le$F#wi)qH=E z;pN!jzE-$ui_f&1LEuCdscI>tMy;)iT-j`Eb6Lm*Oiq}C5r*b-hl`?KOzu++x$t{! zn$uccsBEh{Dc_v8r>(|FFsN(`pY3A%B48SE*yMR46g;-S6q(Cj%>%_(j5Uo|tpwx5 zUG}uCCS*$?bx--(^JU*TTu9y|MOSvgMzwHV#!jWVc)V2QtLnv7t-)oYHmyH0tLa4kGuYITjVa+u1X zn$;0Rr}PNSu^#1{i+}w8HUuflR7mX&_`1q1VrwC7Bb=91oe7rtW!oq4UO~`paB_zfu9xHqGnJ7C zyt?dQ&cqTJc{XrqV;h{@p*2$HVBEw`@ou9es>g?@a#fA0I>dvh` z7r-2gt>=+`(=gV&kLX}q9z|;e8^{6$?(U{ZgoO6i+G!0D zMQW>vN-*G?YU&CpJ{#frqJ#gD(}&l>;W2Mw`HK2J|Ace zfyZTPH*Bz!1kXa^-e&upYGajJAGgw!Wh4QU_XwIu0o?g2WSsmDH_F+EZrTiP00000 LNkvXXu0mjfiY%2t diff --git a/assets/images/avatar.png b/assets/images/avatar.png deleted file mode 100755 index 74f8c9a5d5c80822d412dc78af817b8a1bf3c0ec..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 79057 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

KVsm2r2N0x_5T@NsQ-OC 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

oj)GAUcMZ^CrDTm`v#?2~*BzfdZ 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 P*&6SChj7){u+;wohw#1g diff --git a/assets/images/favicon.png b/assets/images/favicon.png deleted file mode 100644 index 09fe59f5036bb97bdebc238322aaaa56002c5ce0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 21099 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 M07*qoM6N<$f?ARYhyVZp diff --git a/assets/images/image-placeholder.png b/assets/images/image-placeholder.png deleted file mode 100755 index a61a0c094250aba17ba1e399b8a570e47976613e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4881 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 diff --git a/assets/images/logo.png b/assets/images/logo.png deleted file mode 100644 index 41ad9e0bc57b54dced0d346477ceeefcf7154c10..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18857 zcmeHvbyQW~_U|U8OGKI@pwgX(E(Ii|LAtxUTe?BIq)R|rLO>A#0g-NLY3Y8;?~UKR z8oeLkPLFhWV;IW`6<1_VLaGSZSS!Otb|#e;?lzAwn8 zj6o27o|meo%S%Idn1hqOnWc>>%*E5e6lUsSX$C`QU zE~d;*=|Rse(`s($TOXkW5zOcs7u%)llo}(%fb`WhHiu*-9zr1SjbrTo!(B3e?U@i~32}q+ zuT%aXaWowwhpqjOe||rGXY?Zb?kmB~jf*h0Dr;-wm~7H;iqOLuSLY#tIG-cW&YBNX zM$8-Z$K}a&78-&U$KM7DinOeJ)^%E&ZP?+h3ym7|i{AbFrb1O4?HP`1*`AjDOhgXn zE5jR#iw^eD;@?=~&vY11)no}XZ6!B;GO`xZT=+$n+Xwpl++O1QK7f}huMy*yygRav zD7)~NgV`5`K4e(z{QUUrMk|28(bAMtYZKBPC}>&x@nVZ#MY>Qdxawh<>G!}&ZJtaf zwYQ^WjES1GHKd367d0$bsZSmb|Y(m>! zEVA%LjpF2j*ZxF1?){45iOS6M*@K^mmgT(rc6-98ljN0x9%oA^#)BND6J^6T^@^Fo zeTc#pEV{NQrUR2xrUPLjZnM6#r$P$CqFX--OS1iT&Pg7Y>U!F>d(G}nRxcjTHz?}d zonGA29muUtX;L}tzMbc$+`Z`|;NO%iH0P=mY8N<<)~}A_S{Npg z3eEDvpWWN;m$JVdZ7cC{<$|C2pX_d(lys!{&$K+%J`2yj@?P|tY@pzHzYyyyZ%D|E zKGt{C_l#Zd-N1Wh+gzKc4XxG#xT;1p0$v^^-lr*wg_4C-xw|%(%`;22<1A6Gg`T@V zyuEbWQaIW!rgkVzni`(QXtqa;b`Nd2s@fm9=x*=qtXb^IjC}SPu0*$cOO7g|pg=KD zeKaVfXsE+Y)gDbRKTAf@xxf!ybE;$2eA}WqbXDMo>(+S33B^{~TqpN=J&3e*mYa{h z$P14w#n3g+y!WJo4!h_ibLPNKfK>PC&6(#r_9kSxT%YxhHZ6vFu7?3#SbHsJlGz&f z0!`;WChQ)xI=efvXs0OaMqDmY5b4+t>ydvrV|H%JcaAG!Q$^7(saI(Kcw+pj=F2^1 zr2{X713udg&xu{0)7B0CaKqLtGW{NQ36Q75DHZhbzKK2E+ z#kw!Xsd4evtK`FS(dpi6*)l8isX|y*VR;Ymyla~FqIy&i^xgMj+l+VK7=}M$u1r=+ znNbO7-xtHh#K0bTB93bCyu@b*`2(NBx>35J!2Qba3qxwH!p1mXzw}>EY&}*PsU)oB z`cmZhOyH>X6wBo3_=iXA$>sEJopQ-b(UMD~?1P`;uEVNNA{;5|P zx5xYjEysZ-ZhIL9fnS~AL1?GNEfwmSQ--oxACGhqu%s)C@{peGshdkz;tUU!;m2r2 zjjcQujNr?wXzLgLHE4>O^mWzg^OEcj9JrQmIZpXZ`a7$<0ztn4wkNsxTnI_o`2|Ow zX>Z#&v|SKW8_*@Iw$MYI2nz=e7Nv29bozHKvGu|(YPkb~lcY$#y=~{gJeg-hco)tc ze2bJ~{<|BVhsKi3aFefiV`+IY`0?Ay>p0h-ri}i?>8%*r9)f&GccP`FD}QpcJ?m4c zS2%8YHjc!^3=a&6+Bdk}7)2oUTR~v7PpIWQQmaQTMg7abT{G4tn{9pzj9yI2ob5&n zgvcIYLpoHdlI0yccOr`h%Bct;me4qh7}gY&w(ZJ*!rr{@(Nm_jO4eYC?hqJ(-S@oa zN4wv*9DJw4L;bv}m!c+~H&iY^#H>VSa{QpEG6ik)-8b*zPH}WT_%6{>nB`WprtUej=!yO`NLOe7iY=LUfBx$NKC@u+O~|gC z)n{$ami3aRu-qlDADQ@~=6t=eiMy{1F2z)S;D@CoeC>Iq{f@O%u8GsfLG0nl#mERZ zwyp{G4#)niyWvoImoIi*vNIp@Lp}jo+xG9z)V`m&lazj?f#rVOG3bK52=%aHp%@#S z*rt#cjmHt;Ehy)&WPKAwxkFqMM1U7qNA>#J!%V!EAUj|{y2)cq$jTwry>&i-@VA%% z@k{B-&NXw^JmlS)(aMcH)cfsZ`V#frE9B8aCus(~{A@2n;jl-32H&K{4}@nPCKAS| zwEP;*+Eoah;`lKv9E?cnjNU#W>4`;69_=Ar$S}ACpH%)~_JNIG;uNCEr+z5DNTy20 z{FEyE*{e}>`ZyvE|KHjv@jXh9p1io>ro>|&LP0QC*mi!R;HAKKL~emx^k(GkpoZT^ z)apIh%_DM|go>pe&o{hQsNKQxjCN+iVRThQm6zq{EI1*QtGJ6JR@2c8quDBGA3RF0 zq<#~muq%9_8R6C7`FTmP^}fvgqs3c8pRd~a@MfvsUFhbQpG2|_D!)IQ${1w{OZIIP zP?%#GF|YkaKk!CpeUvEXi*%ak=N*MmESLhXXmBC1ih z)h}*_2OpKr<6k>jvhpL%Ze|8`lgjzGMJNZf9uVAr7VS;RCa_FQ{|qf5Gp5>@?npAW z%}I-i@JR0LIbpC-TuiGD9^6LBgZVSg^Uz0lb7<&aoaku9`B@`T#>Jz}#jZTxzw404 zOC9G(^sZqq$~;!p(?`BCKOQ|ByME^`h$xKek5!}}*=ubcSpIY!8KeETlk7)-j@>5l zJ$ee4pJtblJq#z7qNR1dl*q>@_E9Ro5NBP_LqZv65V;FfmAH+4bto~t4r5!YIB`|I z8;%T~jUb(8;sl~$L1s6k%t=*5yi(Uo;VkCK(Tlw_qHggojssq-JwoLUB@-K{%0ZO) zp60xwfW=csu+H+$!>;m)T+<_^DYp=BW$mF%1rziS{KL6dS*SfQKe1;91U&9uA%1Lb z;SfRs;X$U>{f&MDwV$Z9R(1N7M7P1CpDcwp`7`J6Ql<4A_YIV^>qpBduT1tN2&7-! zUyMFtFl1!oT<#=1NeeC1R$}(c%|pUwd1b(peEbQ> zO)14*_o@L}?h*kOQgUO!n)-seG%r3DEc*3*g~5JUVNF89QzaFZ9irgaV)E3p!j-@R zWW&YH7t><6LG-9W^fo5$^3qSGn$h%F9dm|;yU<^RaMF-;$xOS`R2LcxJ<9yQ~Ho9Q&sQLUshLw_=KKAnmmrqF&zZ=PVN}4SpQuY|X@(le&`z+7O z>)^s8!oeGf0Sn0}vtCprvXQNhm?OEOFhg_5Dtm3SJB3&J^9W8QH$%`%m0@0ZQssf0 z4g7gRz+C@D-R4$wOmIZnxkPy&R{~QpiCrG!oBLKFlYzP2x{of88$|uy_`Jcdmx=up zlIPLvA5tEi{^kJ_I?2b{?<2!09o@B$>M1nl1CihgGu`igA%=Myzc*Bf5U{n`jrk<{ zdJOkFM-B!5V9m)qW+1Idk0DU9-j_SeI7Fp5L#< zGT%&;pw8~|`F_67_BH?Xpf$Z$K9)opX4k8W9vQkDaX+@Z?wKZ07`#v9nm$$J*7~hO>U-=ZA)TIwy!Qo?sL#Lc=WZV+_a$&yH-~e;T&gopJ;(3W^BHh z2Yg48blKr#Ijvb2kNxF5GN;tj?sx`*STSAZIni$}LN5(Ir_rRM9hitk@x@TX3}9`C zT;9tRjV0VWhP}Dz4hA9VWb~vaBOxh0C`(H3aO5Or2pw{s?F==AMKnM1HgT4=9<_Ys zqBqF3K=mLb8NnShT-ni*sIs=(xbPQEB4yCDVRFf5#1Vmoq_P;M5C;JaXq@fs%-h0< zm+^$xAMxI^ndjDx3cP~FELN0uW?|E;#XmPq3G!}T5)9XLGotRmCxcix(8Otyb;n+e zbV%PMr%k#q;f@;(I|UuvqvNRguoGzu+10=cFq=ju<7;GJMSj5KDEx_B_pTs@mglur zNc_9b`rTgKdv6i&v1=X{_8*6g$c9Z@{4V`~yX+Tn(cX`Y^0`X+BUOS8En#B%Fr9G^ z&ixy*p@2vpyk5yff-IAXH&_JS^hrdH-zmiiNQ-T^YVq?`SPA6vs3SRUl8ovoR@F2S z7f}VMH#Y}kMBMrj5#AWiAs$PFm%S6@lbn0>RRXI=+jVNJXL>=8ePIyM^(hyFhIvEt z#dm=`S|&8Zpf^$8jF_SfgNlhAk8i(pQPy%gCeV>yBvkbYmDed-`#ktz%PUBs7t{gO z`f6GZCQ(gMIAMLwN^r9-!XgogG4Af|dMb@WqKoZhi?nRbY?2?|{>yPPcj)s_R3AOn zE;Fp^X=J0gy#&)RiE0tDhUOcCHynEbh~Drr@y5XTed{6Qmwp84EvvFxk{t$bg%$3O<&GzFVJJKe z!#5ToF+U9p<*^ZcGy`A%?R!3r6`1$i;vHEz(V5tLVdqgQs%#Ie$HnKf_EOd{AyQbh zCT#DPL%v+2K8lW?MNdc1Lc~u|B73Re{S6+D4l{Fl+>H>uyxV{&mX$l(YT_28B+WTU z^JTEP&`3w{3o_s8>@+ zjs^Pqh<>}erxA-L9v#3z67$R#BCW8Rb!7cX-YslwsTa@D=%D;FFe>f|JNwngao#~? z3Q~U`SOP47?=&&!!S^Sh@^yP7h&as<(8Yt4tUb))V{k>IGHG3GKkx=@E$f_BDpF!>_$V zTvQWXnZu_K4#(2#n=5$Iq?CL_$FR;``^5)r@h|Z1kc9ijEq)0=8CX8xTgXRI~TrzQ-9a|smBG83$ye2Zq6J+0L+@Ioy&tI^ z{|xi(GEOL}EeaWA;e1XylizjHkhFF*NrWCh8NSxFf4b3$SDoNpuv!!jK?ot15)w)> z5)%K=YJftM<(nWR-6Kl=NnfXk`a!rGp6eH-Z0!R~#~%!Y`QoJyv|ZU+jxjU1Xz5vE zgRDP(jQdm`993V9Qym05NBH^c=i5!{$G5EX?_VD-HB;^H3GFQ)+&&8}Gn*vNvr0`+ zcoJe`r-s%+9r7pyzo)rZ&R2m@<$zrO?BMW(O}0_cst8AXrtdla40Ea|UI z*_@d2FdihX+`9{2oX-gDN9UzahFbM)u8fh<_7I0!ZT+cc-Hwpa1d%kfXZ39%&fK?? zv)adKn~SI{)w3BN?!DTBkQ7@@q+<#5wpa-R&NwfN$?-Z+ye8)sw6FMlA&wtvzfk%3 zke@{*x9=V9<$PPX6&m}se{cJN)1)F}1wYW#JS>5BrYSE6H@3HBF*LC^GG+0wbpYBL z1PO|GI2amRo4UY^OwBFrgsAu1I;mlnCPLI2-12Pl4icsomeO8MrYc?vs>WW{#{4GK zBElGg9&lj5*3`ui=3#4N=M47{qW;S+9K8N>nUxy$R}&X&A!w}bt$X=r5c>LNr<4c>?Sqkpyz^78*Q zZ|D4XF93hAdKfyeva_(U+S;=I>mAN6Qf|P=-#hewyu(=)NRX^AO`Yvsos3PT+)V9U zX#UlNiSa-0cW`yG`D-{P#;m3`rnaD|Gk7ZdzdiD~jJ(o6@A%^ab4y!?zwQFg{vgeX>4R-XvX$0rey4#T@3AvP5+nz z##tZ>MYs|~XY4W$;m>9#K**n=9 zg6XuhH8eM6b+9x4>luF>4i{6B5u)Z``CHS!t|-|Ux|o3*gs9~#?OZ+nr>Ux?t*MHO z;U90Z^RjXBvhi_n^6+x%``fQJmVYfJ80@b_ z0XH=M+Yp=$-AqmX>L;-Ex3`Qf4DHNKLH782xc=k1<^LfRjCpxE_}MwQnb}NvjG4LE zz$-&TBMxRhGgA&u4qk44Gak-=x9)6j=HhPXWGZG3{0Mvn!t*a*!RY>)DEfbI?QUWE zXBL3NnAtg)|96M6{(Zo#e{#k@Ml8tszxhP)uLl2;WWarYy9SaM$c3!`Ooo5=*`KuY z|MBDRbMgQ23BdG!AMzjh_rLD?ue<&u5Bx`s{~KNZb=QC7f&ZxSf1~UFnY%FlhfbN= z0Tkp8$WqRyeRn{#P>o(ZmxS*A{L5=ENdi~U9i+9KAqeySpDzR`Ba0YZyyqe#FLiGN zi;NH-Z$vO;9)e(yjHH;V$IPy;rwjRb`o4y>hO35#y;YfxRaL5qp$-wMF@YQbOf-P) zO}vCr_bL|c)2En7NSv$jBpi+egECL-7ia}3B{YM34h%GNWMJ!tJjTYx^&SZ!Cc9Q; zrY9Zh?z?LHaU~P)wbiN`ZHPJx_sJ<-HRfA&UH5N%XKy-cAa#q-fBh6z78j17(rU1J zurM+b;O^!ouA%YJ#my~f$SgQb-;ZQ_dwZHmY2u=b>fwOo+euq4|$T@1mkBgPQ5Vz+XjSD5D*F10qg>cyV`FTBf|Ys>A5qAIU{7;=Pp8wrUkPtyIge~@ zZL#ERbe3;>v5@0DM7?(}B`hrLIF(uFe5EhWxX`5Nyq@ecg69wBsE^tCs?{%`Qr6D?^#YBx1@lFG<3iCx<# z-8KF<*6kU$!@^fUYQ=b@fALiVmek)hGJnp)?drtwiMt!S-nZOa!Mx#3_qJu?l~ANS9CPIqVJug)i$Izp#*-9ikBmpmyw za>B*)+3vImr9|;0{jYYLHm;hl_SzEq`(lHHBp0?$yVps4 zdHJY#e*EV4_6s(w!YdzP-@aIiOA^ek^z`(Gbh-6dRfYxyJmd;m89y;RCh|TIG69Cf zCiPl$gcxl6{OCzZNl};0m%l2gis;H8LQcp54W9b#=W#hhQnP z*=hYIc3|pHppoQ$6Tu)@9(i9NU8FcidX^JBI}YmVOg$Z)nzA4vCT?~xF#jtkdDP1xa-*1wqL>E98dHv%D z;nRV-#DO&!X^c2^0u;Mq;O6G$bhbC|BuE+VA@~h5=pYxudu8Rb-@JnJlJFCyni}hb zt1muS3$KtxwNf9Y4anO~*R9Q)aHO~H)D4{H-t3sCbomKEuO7=JQV-M>lry|8;2S#n zz$BAcZK=(YAf5H62g4hfX?k9krGSiISDr+LO(XgL!{E2GUANv&-{SI0Db zS5~gw<#_E1O`$*syY~K>GDR=9rIhDr2Y$l|r6v)&w1DAeUoS7x(UZGy)W5Xvr@E6H4-M%EfA_8&9)ZQ>iz;8nyWmlHG-F+}OD|IEd1R)V zYU*QRvP|l+62luw#r)C0;Q=K2;ziWGK1VcUM3~IWmBW=jRv!?O*!#OF8hY%4lu@6S zZm;(5K~P4q%0qo0M}KZ8nYRD?;^N(>Nj>jfeFZZ;>BJChGM-h0rMtmz--I3dDBQ`< z!Ppry-d9a>?M80ocvn|@*!cMPh-J2WpMCS!YqFyt#6WqIo{ms5mYzaOUqcreYdCe+ z?RY&2vWLhw6Au4Q_kF#BV>lFmD{_set)tVYqod=G1BF3Y;XRXn=gZ*_H=OtfH+`(F zt-&-Jm!1m|V%%7Gd0keIjw+uK7^BzM*F#V*_|S$l+YEccI&JOk{h0_Nt_K=zXT>|u zKd~NjVgzt=b62~-cfXi$4D1yu(TRd6gaQUw+L(NIrr7C;qSTNL61Hb|Pc@$;r6WN4 zp|=_-RG7$!OD^z=*3Q$@)97(4l!|eT0=k^v0ZFtGKgP%L$KSicvkmH}6)t&cWr8Ha zai%NPwpPdbM}e?a55c3ETq=C%MOwV zuvG^>xvPg#qh~8rcOD;|V`F0QBP6@^P@qIA-(%&21@Haw8$S`?^lT#ZO}DmmMZ^H- zCkQ#xv^>Qx%XAv;=4Twr2}YuCuQx&wF7>2lQRa$%p?Y(~4c z_V!K(2M3oz#XlZsrwyPelq4N_2-d!Yau|^Kw=3&89_qT_`+r7w*VyPL1NrSa=aN}j zTMIaC6{X=cy?-ysYd81C+RExX91bU%4!Anoe`uLOq?(C z?u%uP4-yg*8kw1CT_wUAs58b1m&izZJD~3R^|1jT`Kjtysv&V6-LGVSPC|_7zP`RY z2Fkca7cfh0A~+B{`&(*82I;`nekZFD@u@OO7+93G<>hc}o1+<3hS1D(DyD%*5Yo%f zseHM-;RqH@vmn3tke&;0lZ|Yji1U$GPlXkfA~6jJztYfn4p!?+obX^|D8rE09DGy_ ztigHM*y0&$^>2yMkQXd1EJX2;)2U1drJ}5)Q)&BqK%x%@%UQwB$_gI1;_-d3`t`Fy zhXLlM_j?QN0_qq)3*0LSrfnMIYL=ZgT9T^*QmK)>p&sWlv!VB4-sx`*!?Vb}Z=S&-5CN5cC zHk5vnRDu+6^s8>%O6WE0HT^qR-5UB%Tqr<8-*-Ggp+r764fguO*cMibP+LB-;MGoj z+^SQ{+?*gaq15>4$w?Itl7VssybwA+owZK_3%uYO7d5!5XwiLlrfAr9J<{1<$t_19 z-CMK4N{u#i=ow=JzSOA7XF@h9<;|kEk$o#9ww9L4k*DFsmaB7FESVhXSZ>Fg%J$s0 z=t1u+GS)Q+i;UX(`}=zy>Uk{JsHrso*g}*@iv)mz`_4kUci>w!wFh6Xyf(7k>Ey@W zjUkA(&Fj4%ife3W*aEoub-xcEXL@v>0ZZA!f*x1yFxf3?m?3}XB2^`7!2J9?Zislk znC_%2d7li_Tv=1IZ&&E&-0}*<8Rsx6R;aifM|$PvV+(tGk;gP3L>}4N+8!6nXW9Vw zH0+Wso_|K<9@#jOvfp0{gKA4@gWN;D)sd%4T<;Xs@}L3&X5Vm0aBqStnnxs{a_r2{-$<=HQNeuzG@ zu8>YP3kM=<@1>Oq1Me9n6Ly~kS!F{*!(AAe zorn8yj?g|vkOLb*M0CddFzEF6KX?JtJPX-{kDM+DCjFTEI2c!WQ!rilZg2l~FZbu+ zxht}mroR7;E5Pa&ENRY?h00EDZt57wh^$CmXRgw2p}$kgf~QCuJ6 zjI(-$tLEg1r{#`Yn^>wT=R30-KmXUoTY_SE0fukz4*<64a(s1kbt7?gx?6!75KyrB zA?a(hwzf7AAO4f4PhGWAi>x4v`e`(+)C3i^k9f#|1w*&?cc=D0A9fss;vy``CarUY z8FKT^IUt=Jk11k4o&+8L+dck0CpaBK6;F+>d(i&<%QK`Acf zz$(mkgtAlyVA(vrJeylvj*4<}s`KVtq*Y)gE&WoW>m_^`RY2F}NIt^Fyv*0p73#m= zerA=)YmZ}{k;+kzq@%6<3+!$jcfJM&U0;uU3?fjtV^^A0F+@3^jm^znFMp09yDMvI zI`hTq!9sYw!k0&f;k5v&x>`L^T7YI_LWZd!t8b_Js zU1r~bDiW(Mh3_6eJm`jEKi=iv8}9O^-_p#CkT_p0GFIkN$pge zJ!e#UW{J;kGu6H2)!3njpcQHtU_s8Zo$ju#V({#+`%e|#I5{`X3ay`beR^qTj4CRI zhY?v|0-$+G&bNL?K5|SWp&<*F&rY{jVc2BH;`w+YKIaFC1S3`rh+=qAjhYVRX+o64 zj0w_j%MWrX1l*X;0o8Q)QfbSQ7Hq?_O+rcOmV)@Mv$K;sZ9q%zhq}Vpdjuo{xT#iS zO5FW{x<8ao>$x&lv)|3-Vm9D3sert+&D-&2_nTxf4a^XSp=0CXGMZ;$Z#uOE7&7eB zAal#X3*rBNWqv;R!l1}t_pBQzek|{mspQ{QO5Q zPEG{&wzeppi>&V(8_o7xx2rGI9?2xqPxd*^Idq!cT%IhCj*f-^s8>iADNQSGJKs8f zF=ZV00D^GH`2ql~u|~lyr5kXPPJHXh{=s=eL2}YH6JL`*_C@>If_Fq5Qoy*)?U7)o z0p;c8rOT%-*K*4l>Y;9|fFcCkfqVx(a)4r^Vq#*((<`&hf?%Xy-?Bf$LpDO~YHVzj zvTFEbgrJrB(DG@5w22tuC=#w<9wdq(Z2aB^;^F3g)ZX51!H`l;2QVY;;rAD;^V47p zihjE{jWCZ1NN{~nc(5+edqfu*)BLkfdA2B{ccD7WEg~J{jRiDH9ETyuGn6Y>ENquVTULPf!<8cU&6{(x z78)}X6J)>ym=8UCH0Ys$B)I|G@U1N=IlP~T&A_3}1$5|8DQ99g$iniFL+K{>AmB>A zL(>mv)GN64?e?uQP}iVdHo0C$!Lvcm;Vd^+(t)}M6t9Ym)iFe+lttCl=A{u+<7`J! znM!EWngHCU+S=c`myurp?Pb>*Hy+ z42i=~1FnIf5m)q*{w1Ll%>z|x8K>VSgL&Bk?s}~tW6)$2$Gk}7Dx;GP+_*p&!|MiW z(R(F2WM2D)EQgj?p@2$1*lXJtzKBL#0!!Jz$OzFyOV2HyLw>Az-mY%|K~oIn6C0Ls zG&HlYAdHU@NC@p&Pk_UFCb-3A2Fv-5KgUZ~4^znypg#pdSbh*s** zZ^2I1bh+Ex;!L}lqu%?9tHZ<)Kt_Q*%K_r~?{+l1Ex4>eg3+sbNGOIkXjJe|12B`%Kj!gGe))pN z&cX3}NVd~^uVsT8P(OQO1P8l8W4_pX2nH#mo>Iym0MTOa8>t1DnKoUHCGky0F}huo zcb6Pujtx&p0UaA3-)krU398=P+jG0}=|G0a1q*5OdX`Hq3eRu+Hg|S>$od=`G-<+C znvHykqYFykelo%zpp7g;mQ*IBi{y}_SmtBdb%7VUwduz8t(df6e06*!vE}PXey^}F zsxXN-Oh$?Dfj{UUQRR=Z`1h@cCafL@AMYhttxMyDpvY~16WEvheIck8gCUC-@pOP>6V!f%L+pi-5$)@(gx#kEEkImH5 zA0lmtN0$e9VCa6!2BieOj*7}rr>ib5HxCc$lP6Cy=InSs)iJGtzg-#LkU$F(l~guq z*JBk^R=w)#3YZjq;{bS35Wd9iAff}%;@E(p+#x&3GF6PAk4q67x&909pkc5rKvX^l zVi#`#1tp|0987%5El-wY%CCYWDnAAz$7!=`UPk2|KKdiXE;1cUr>-d@ixD9JAVM|j z+CILc1>l_%q15BT(bB28xhw#5UNWQvrKgijH9H!ErLJXVZ{MeY8lYbBAjLFY8zZ2A z&dgLRM}rKA4S^e;m9Koc69ce%-oQIRFk$)7A#`x2$WFrr1QGzXn(tCB3F%oj7S0`J zs~I(`_aq5()c0IVL5nOPj9n=WY^AFxpRsns6>!_(!-1k2pR%;963hZkJr2MF;nOMO z+wlsGN!q0TTpTPcrr%#LeS}-;>yHK#18{|o<2k|T7#;@#IpX6)l}@|CON0SQ=4BV% z$w5eZjH`M6Gdkk#?rzfk`}ehIzKOu$k#j(AqlDg=5{EIYKP4@dSIN%KZt1*UV_oYL z8{U4M4A2KvJdfkiTznadC4$09gHaW@aYo_xouZ9y}@hRN268 zN5SxwW_4sMUtb~O`I74Gi~>4se#p6Ht^h(MlmZ*;6Gw9Yf}kYn&yGIdcYK~d56@62 zc}hx3dJYs7vcU%VF)nvdh`9JwQ8SU8iR0|n*-6B`*H=f1hw_rL1`zH9l-1N6Ovy3bQ)^+Otn zrIPwLzcfJiyCraixN0uROwl%5S-#f2qPv$j8rCpwH4Zd1nl`uH%kZ`81ReW!wa)9` z14&?`B!?zQOHWEc`bjXIZgtz$9spGVZNEjnSVoZDf>X%FoF7F>kJ7$WQ}bUAeR#}a zo?g}@Opdbw80({_@VSmcvA*u)W6nu;WyB1Gc-ZT#dAm5kQB3Q# z>f~<3LBQ@Whf{s-S!T1YTk3%vevWJCr(n|-mN^4VU_gutDg}z$tExKj^mu5Zumk;m zij$L*u*R0^?ZoPBqYHatTi4R^NU;2V59r@=+8^bMvR3GtHj}2o7?*_eOn%7y0DJP>@{F z553wO5~PuV-XHeTlO<1plY^t~OAeqa#pN|j13)X6uV+ks@h2y0KTf1&c9@Tgi_3g= zLG0m+{dg&>F#5x<@`}om-&l4{Iv@~=37CL_2Gkbvev?Fc*3Q5Jy7QacNKO}L;Z0yOlY~!>IgAWEkw~g=LtDu}+LFPNL8gnJW$|gG(L~om*VWZk+eY0oe$pq7d4PM_`OPta3t^c< z-TkXV>Wl~#Ws&NDr1nO4fYQeoAX-!~cq@~N8JmbnQYWaCM}fTr7HL#7xy@aFAp|lk zpkc}x#R(kHF90J~W}EEO9Q5 zu{}0N9-ZG21ej;LPROKWmcOTJNJh?b?v1{WTx*dhlPC!!LUN{ojB+>fz8H%Pvt~=x zXqz(Rt|apK>`_l3sTb8~X^-VJZNwS8Q6*nDQqkRrPV zW+VjY-JobNh*6sA-3nq{CQ(l4Wn@7B0J4Y$13$j7cP_8zT{A)ItsJX9rgIcM9}26F6|7D?F{lCpus;@ zruq%9cG{*ywPru!Y0d~fvWyN>D*OE~oeH|hipItXtNQ7$lZAVS9+yLx3-#v11!tOs zTcHp29ByvUI`x-A*qu7Srt=ZNm$Xj6?RpiF0tVc=ub1wLzyPk{Sfokn=gOArOsRVm z^bv*}EH>3(owjw-d9!P;lJ?3;1}s@h2=;=A9?rv~J~=%dvF^lQH@9SGVL_KiM+&%4 z8#ceIuC8t-$pN=~uz0=!c6d(?vrZ%4s0ATdylNT6C!kn*15`B)VE@DKuZ%MQE*B*w z1dR7i6Jdm+5CGkYM4e&DQ%|vEOgkOh3xz@5CL|Ys@<){slK;MgN6v!?F87RX2E_KQ=ML?T~#Zq zP$DZic06gKPRNeUEMQ2y1DF)hGszZO(O*rk-k#}P-iT&RIuU6Q2=yx2cEJ|2?^p&*ML41fDp zz07A9_+Gc(EJj@U$Gr!{$@lvlCE`x`H?qcp3+UKh7n6U0Go7_^Sb{M_J$xd zt3PJ}I39rMx(E=?wO6LDnYX*Am73(N!+exHWF|jTK4`aodu;@e}vVF^0I zASJrD?;9GVhK0`N-qOmj0mKB9%#rWkIV>8qaZAhLZGhcZMJKFEDPNa1G>nfZr%2QK zfLJ=U;fYG#Ljn?g;H+Jnd|6&WA)qemYqKrR8@j-UB6~YKAujML0M`Q~@FaO02xJQA z*1f#FhbvuZI~Q@s3CnEl?99NP@Ab16y-FKWkCX*8&arJ?^Kl%_KwUf3m8M}n!G#_5 ztk4ypN9?s6(ULI|J8SC~8lWi45K({z3J>?NdR(+p)39VPL&c@JwK0Z|Fd0yQR7*xH zBR-&NQ`^$Q52{~{uhOykDl9V~C^^tK3>O=_ii(s}`=I*=NG0Fh=@Fr>t}dujr)kfu zWbA?~`N6B(A$va>+l3FFUzZ);LIw#FfJJN25;&&VcMFimCKTD2C=+5=pn_eEQrM^2 z1q%x>@JybvKvB`l9;(}evXE{j9h8#`AGMSrP`{i4G{nB9aj{5sY5rw9VVi!6+H{LHX%i2)sfX#&lysjqzaYa4l0&@WxB0x{W~v;*cFZP@)@;mK@6bThgXACCWT%SS>Qt*_=QV;!$p^O zF4AMWswuCg#{Q$936Sh2fKtyc@@38GF%!{?OF7h~I@>OAq+~@!MdgKFZoi2^*_nH8 zG;$?T0GB*&28t`0TsJ6zR=x4^11qLkaWW4m2;~gy5AVxXKue|tbd4B6u&|zGX?Q0#+qQ<`p$WQz5;V*AhC$hvS$4m+ww8@*rw(|k%nWp&E7X`ZP3 z$NGn(Z&$Dc=?{H%JHLKUEtWsVi)0`Uqcn6@Ao>AAA;cOyRUAHlo1+| zQs(K)G$1=|EmyDFu4KTVMC(M+_M+#5p{jPSqr5@@M9$)xuO;2mNKae}TDVn(kDHBZ}9K`Xr zv$wa8{$#ZAyij@KZD~@%O({4xLo9}OC7nnPUx7dp&(sERHP8jl4CIv0Y|((uRc*IE zCXIOs(iRB?1&aLG2&k}3SY5UMjARrBMfkg$u0W(lP?OHH%rGKGwc#O~vf(-KYUgxj zU43PR`25$eUv(Eg3p%f&`C^g643F;Ev5-nY<(sKny$zbF-G`TY4aLJ$nyia~vS2$+zoH@wT;7gZy2G=d#Ss5V z%T2SoKp6G~IN9H=ZGKqzu=jo;m|>DIlB$Y|D=NCkI%F{=x<~@SVI5Vq$6#08#m2@a zYMWnpXEsDC1ZpDXyJue+Yjyyg?GcdN)F}THyxs=(5Bg47hPQnP`C~(FLyXt5(_D|GK-E}WPKz5)af z&Z&Un`LQJMGO|S@4rH}$fq!N3=Ull7hAS6is<0TD<2 zeeTIu!R%PUY*%`$}-3+Sq=I5 z2tc6^1)Z|6vkMcs*;4EUirdtd%Q_I?4fs-Zn(RzHau(yIY2lz~z7|8qOGFp>GCVBI zV0WfL3kdrlTt5Ezp?bR^a(A%=m_$>hU@zd03&OdiMkE{Qv8xV*D-Z@qmAQ-$lls|AGmUky4PX7B>j`UkQR?l>h($ diff --git a/assets/images/no-search-found.png b/assets/images/no-search-found.png deleted file mode 100755 index 1e1e6e16149baa3d78d891a3b10fc7d87b942abf..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8267 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 diff --git a/assets/images/og-image.png b/assets/images/og-image.png deleted file mode 100644 index e31ac0e264c7e69020590de056be3c73f60e4909..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 107524 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≷ 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 Lr!W+UUlRWd^A_Zu diff --git a/assets/images/service-1.png b/assets/images/service-1.png deleted file mode 100755 index 5842791a2e1215f1c20b8075cdf2956ea8e7343b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 11502 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�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 UuAG>^L*S2!g1UUAtohsj3j%NHc>n+a diff --git a/assets/scss/custom.scss b/assets/scss/custom.scss deleted file mode 100755 index 9685904..0000000 --- a/assets/scss/custom.scss +++ /dev/null @@ -1 +0,0 @@ -// Add your own custom styles here diff --git a/config/_default/languages.toml b/config/_default/languages.toml deleted file mode 100755 index f39ff9d..0000000 --- a/config/_default/languages.toml +++ /dev/null @@ -1,6 +0,0 @@ -################ English language ################## -[en] -languageName = "En" -languageCode = "en-us" -contentDir = "content/english" -weight = 1 diff --git a/config/_default/menus.en.toml b/config/_default/menus.en.toml deleted file mode 100755 index c7c68f3..0000000 --- a/config/_default/menus.en.toml +++ /dev/null @@ -1,24 +0,0 @@ -############# English navigation ############## - -# main menu -[[main]] -name = "Home" -url = "/" -weight = 1 - -[[main]] -name = "About" -url = "about/" -weight = 2 - - -# footer menu -[[footer]] -name = "About" -url = "about/" -weight = 1 - -[[footer]] -name = "Privacy Policy" -url = "privacy-policy/" -weight = 3 diff --git a/config/_default/module.toml b/config/_default/module.toml deleted file mode 100644 index 970d2d6..0000000 --- a/config/_default/module.toml +++ /dev/null @@ -1,87 +0,0 @@ -[hugoVersion] -extended = true -min = "0.134.3" - -# [[imports]] -# path = "github.com/zeon-studio/hugoplate" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/search" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/pwa" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/images" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/videos" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/icons/font-awesome" - -# [[imports]] -# path = "github.com/gethugothemes/hugo-modules/icons/themify-icons" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/gzip-caching" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/adsense" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/accordion" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/table-of-contents" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/tab" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/modal" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/gallery-slider" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/components/preloader" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/components/social-share" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/components/cookie-consent" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/components/announcement" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/components/custom-script" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/components/render-link" - -# [[imports]] -# path = "github.com/gethugothemes/hugo-modules/components/valine-comment" - -# [[imports]] -# path = "github.com/gethugothemes/hugo-modules/components/crisp-chat" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/shortcodes/button" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/shortcodes/notice" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/seo-tools/basic-seo" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/seo-tools/site-verifications" - -[[imports]] -path = "github.com/gethugothemes/hugo-modules/seo-tools/google-tag-manager" - -[[imports]] -path = "github.com/hugomods/mermaid" diff --git a/config/_default/params.toml b/config/_default/params.toml deleted file mode 100755 index e48f5af..0000000 --- a/config/_default/params.toml +++ /dev/null @@ -1,101 +0,0 @@ -#################### default parameters ################################ -# favicon module: https://github.com/gethugothemes/hugo-modules/tree/master/images#favicon-implementation -favicon = "images/favicon.png" -# logo module: https://github.com/gethugothemes/hugo-modules/tree/master/images#logo-implementation -logo = "images/logo.png" -logo_darkmode = "images/logo-darkmode.png" -# use `px` or `x` with logo_width, example: "100px". -# Note: logo_width is not work with .svg file -logo_width = "160px" -logo_height = "32px" -# if logo_webp set false, will not generate WEBP version of logo | default is true -logo_webp = true -# logo text will only show when logo is missing. -logo_text = "Hugoplate" -# navbar fixed to top -navbar_fixed = true -# theme-mode -theme_switcher = true -theme_default = "system" # available options [light/dark/system] -# Main Sections -mainSections = ["blog"] -# contact form action -contact_form_action = "https://formspree.io/f/myyrgrdd" # contact form works with [https://airform.io/] or [https://formspree.io] -# google tag manager, see https://developers.google.com/tag-manager/ -google_tag_manager = "" # example: G-XXXXXXXXXX -google_adsense = "" # example: ca-pub-xxxxxxxxxxxxxxxx -# custom script on header, example: custom_script= "" -custom_script = "" -# copyright -copyright = "© 2024 Five Devs, LLC" - -# Preloader -# preloader module: https://github.com/gethugothemes/hugo-modules/tree/master/components/preloader -[preloader] -enable = false -preloader = "" # use jpg, png, svg or gif format. - -# Navigation button -[navigation_button] -enable = true -label = "get a quote" -link = "contact" - -# search -# search module: https://github.com/gethugothemes/hugo-modules/tree/master/search -[search] -enable = false -primary_color = "#121212" -include_sections = ["blog"] -show_image = true -show_description = true -show_tags = true -show_categories = true - - -# seo meta data for OpenGraph / Twitter Card -# seo module: https://github.com/gethugothemes/hugo-modules/tree/master/seo-tools/basic-seo -[metadata] -keywords = ["Boilerplate", "Hugo"] -description = "Hugo & Tailwindcss Starter" -author = "zeon.studio" -image = "images/og-image.png" - - -# site verifications -# verification module: https://github.com/gethugothemes/hugo-modules/tree/master/seo-tools/site-verifications -[site_verification] -google = "" # Your verification code -bing = "" # Your verification code -baidu = "" # Your verification code -facebook = "" # Your verification code -mastodon = "" # Your verification code - -# cookies -# cookies module: https://github.com/gethugothemes/hugo-modules/tree/master/components/cookie-consent -[cookies] -enable = false -expire_days = 60 -content = "This site uses cookies. By continuing to use this website, you agree to their use." -button = "I Accept" - -######################## sidebar widgets ######################### -[widgets] -sidebar = ["categories", "tags"] - - -# google map -[google_map] -enable = false -map_api_key = "AIzaSyCcABaamniA6OL5YvYSpB3pFMNrXwXnLwU" -map_latitude = "51.5223477" -map_longitude = "-0.1622023" -map_marker = "images/marker.png" - - -# Subscription -[subscription] -enable = false -# mailchimp subsciption -mailchimp_form_action = "https://gmail.us4.list-manage.com/subscribe/post?u=463ee871f45d2d93748e77cad&id=a0a2c6d074" # replace this url with yours -mailchimp_form_name = "b_463ee871f45d2d93748e77cad_a0a2c6d074" diff --git a/config/development/server.toml b/config/development/server.toml deleted file mode 100644 index 49e5756..0000000 --- a/config/development/server.toml +++ /dev/null @@ -1,13 +0,0 @@ -# defaultContentLanguageInSubdir must be true for this to work. - -# Other languages redirects -# [[redirects]] -# from = '/fr/**' -# to = '/fr/404.html' -# status = 404 - -# Default language must be last. -[[redirects]] -from = '/**' -to = '/en/404.html' -status = 404 diff --git a/content/english/_index.md b/content/english/_index.md deleted file mode 100755 index d1eb26f..0000000 --- a/content/english/_index.md +++ /dev/null @@ -1,12 +0,0 @@ ---- -# Banner -banner: - title: "PHP Experts Helping Small Shops or Large Fortune 500 Companies" - content: "Five Devs specializes in software development. We fix small issues and tackle large projects to help you save valuable time." - image: "/images/banner.png" - button: - enable: true - label: "Let's Talk!" - link: "/contact" - ---- diff --git a/content/english/about/_index.md b/content/english/about/_index.md deleted file mode 100644 index 61a0592..0000000 --- a/content/english/about/_index.md +++ /dev/null @@ -1,24 +0,0 @@ ---- -title: "👋 I'm Chris!" -meta_title: "About" -description: "this is meta description" -image: "/images/avatar.png" -draft: false ---- - -I have been doing software development **since 2010**. I started working with PHP with local businesses and joined -multiple teams. I started **Five Devs, LLC** to help small and large businesses streamline their operations. If you have -a project that is just at the idea stage or an existing problem on a large application - I can help! - -### 📬 Sending a letter? - -Prefer to do things the old fashioned way? Sure thing! Just no fax 📠 - -```php -/** -Five Devs, LLC -1887 Whitney Mesa Dr. Pmb 7325 -Henderson, NV 89014 -USA -*/ -``` \ No newline at end of file diff --git a/content/english/authors/_index.md b/content/english/authors/_index.md deleted file mode 100644 index 62eae44..0000000 --- a/content/english/authors/_index.md +++ /dev/null @@ -1,3 +0,0 @@ ---- -title: "Authors" ---- diff --git a/content/english/blog/_index.md b/content/english/blog/_index.md deleted file mode 100755 index 17564a2..0000000 --- a/content/english/blog/_index.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -title: "Blog Posts" -meta_title: "" -description: "this is meta description" ---- diff --git a/content/english/blog/post-1.md b/content/english/blog/post-1.md deleted file mode 100755 index 68280a6..0000000 --- a/content/english/blog/post-1.md +++ /dev/null @@ -1,23 +0,0 @@ ---- -title: "How to build an Application with modern Technology" -meta_title: "" -description: "this is meta description" -date: 2022-04-04T05:00:00Z -image: "/images/image-placeholder.png" -categories: ["Application", "Data"] -author: "John Doe" -tags: ["nextjs", "tailwind"] -draft: false ---- - -Nemo vel ad consectetur namut rutrum ex, venenatis sollicitudin urna. Aliquam erat volutpat. Integer eu ipsum sem. Ut bibendum lacus vestibulum maximus suscipit. Quisque vitae nibh iaculis neque blandit euismod. - -Lorem ipsum dolor sit amet consectetur adipisicing elit. Nemo vel ad consectetur ut aperiam. Itaque eligendi natus aperiam? Excepturi repellendus consequatur quibusdam optio expedita praesentium est adipisci dolorem ut eius! - -## Creative Design - -Nam ut rutrum ex, venenatis sollicitudin urna. Aliquam erat volutpat. Integer eu ipsum sem. Ut bibendum lacus vestibulum maximus suscipit. Quisque vitae nibh iaculis neque blandit euismod. - -> Lorem ipsum dolor sit amet consectetur adipisicing elit. Nemo vel ad consectetur ut aperiam. Itaque eligendi natus aperiam? Excepturi repellendus consequatur quibusdam optio expedita praesentium est adipisci dolorem ut eius! - -Lorem ipsum dolor sit amet consectetur adipisicing elit. Nemo vel ad consectetur ut aperiam. Itaque eligendi natus aperiam? Excepturi repellendus consequatur quibusdam optio expedita praesentium est adipisci dolorem ut eius! diff --git a/content/english/contact/_index.md b/content/english/contact/_index.md deleted file mode 100644 index bd6b9f6..0000000 --- a/content/english/contact/_index.md +++ /dev/null @@ -1,6 +0,0 @@ ---- -title: "Contact" -meta_title: "" -description: "this is meta description" -draft: false ---- diff --git a/content/english/pages/privacy-policy.md b/content/english/pages/privacy-policy.md deleted file mode 100644 index 1f664a3..0000000 --- a/content/english/pages/privacy-policy.md +++ /dev/null @@ -1,42 +0,0 @@ ---- -title: "Privacy Policy" -# meta title -meta_title: "" -# meta description -description: "This is our company privacy policy" -# save as draft -draft: false ---- - - -Five Devs, LLC takes your privacy seriously. To better protect your privacy we provide this privacy policy notice explaining the way your personal information is collected and used. - -## Collection of Routine Information - -This website track basic information about their visitors. This information includes, but is not limited to, IP addresses, browser details, timestamps and referring pages. None of this information can personally identify specific visitors to this website. The information is tracked for routine administration and maintenance purposes. We use Amazon Amplify for site hosting if you're super curious and want to check out their privacy policies. - -## Cookies - -We don't use cookies. They are tasty though. - -## Advertisement and Other Third Parties - -We don't use advertising or have third party tracking. The pages are just HTML pages rendered by Amazon Amplify when updated on GitHub. - -## Links to Third Party Websites - -We have included links on this website for your use and reference. We are not responsible for the privacy policies on these websites. You should be aware that the privacy policies of these websites may differ from our own. - -## Security - -The security of your personal information is important to us, but remember that no method of transmission over the Internet, or method of electronic storage, is 100% secure. While we strive to use commercially acceptable means to protect your personal information, we cannot guarantee its absolute security. - -## Changes To This Privacy Policy - -This Privacy Policy is effective as of June 27, 2024 and will remain in effect except with respect to any changes in its provisions in the future, which will be in effect immediately after being posted on this page. - -We reserve the right to update or change our Privacy Policy at any time and you should check this Privacy Policy periodically. If we make any material changes to this Privacy Policy, we will notify you by placing a prominent notice on our website. - -## Contact Information - -For any questions or concerns regarding the privacy policy, please send us an email using the contact form on our website or by mailing to a letter to our address. diff --git a/content/english/sections/call-to-action.md b/content/english/sections/call-to-action.md deleted file mode 100644 index efda148..0000000 --- a/content/english/sections/call-to-action.md +++ /dev/null @@ -1,14 +0,0 @@ ---- -enable: true -title: "Ready to build your next project with Hugo?" -image: "/images/call-to-action.png" -description: "Experience the future of web development with Hugoplate and Hugo. Build lightning-fast static sites with ease and flexibility." -button: - enable: true - label: "Get Started Now" - link: "https://github.com/zeon-studio/hugoplate" - -# don't create a separate page -_build: - render: "never" ---- diff --git a/content/english/sections/testimonial.md b/content/english/sections/testimonial.md deleted file mode 100644 index 1d97238..0000000 --- a/content/english/sections/testimonial.md +++ /dev/null @@ -1,31 +0,0 @@ ---- -enable: true -title: "What Others Are Saying About Five Devs" -description: "Don't just take our word for it - hear from some of our satisfied users! Check out some of our testimonials below to see what others are saying about Hugoplate." - -# Testimonials -testimonials: - - name: "Emil Boschert" - designation: "Pritikin Foods" - avatar: "/images/avatar-sm.png" - content: "I have worked together with Chris and Five Devs for several years now on our shipping and order parsing process. They are vital for our e-commerce site and our 3PL." - - - name: "Katie Allen" - designation: "Fortune Fulfillment" - avatar: "/images/avatar-sm.png" - content: "I have been working with this Five Devs on multiple customer accounts for several years. Chris makes the set-up process flow so much easier!" - - - name: "Tom Deppe" - designation: "HD Financial" - avatar: "/images/avatar-sm.png" - content: "Five Devs is an integral part of my business. Their tech support keeps us up and running. Promptly returns phone calls and is a pleasure to work with." - - - name: "Timothy Dorcas" - designation: "Americold" - avatar: "/images/avatar-sm.png" - content: "I cannot say enough good things about the team at Five Devs. They are solution oriented, customer focused, and consistently deliver at a high level. Highly recommended." - -# don't create a separate page -_build: - render: "never" ---- diff --git a/data/social.json b/data/social.json deleted file mode 100644 index 06c2e92..0000000 --- a/data/social.json +++ /dev/null @@ -1,19 +0,0 @@ -{ - "main": [ - { - "name": "twitter", - "icon": "fab fa-x-twitter", - "link": "https://twitter.com/cgsmith105" - }, - { - "name": "github", - "icon": "fab fa-github", - "link": "https://github.com/cgsmith/fivedevs.com" - }, - { - "name": "linkedin", - "icon": "fab fa-linkedin", - "link": "https://www.linkedin.com/in/phpguy" - } - ] -} diff --git a/data/theme.json b/data/theme.json deleted file mode 100644 index c838223..0000000 --- a/data/theme.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "colors": { - "default": { - "theme_color": { - "primary": "#121212", - "body": "#fff", - "border": "#eaeaea", - "theme_light": "#f6f6f6", - "theme_dark": "" - }, - "text_color": { - "default": "#444444", - "dark": "#040404", - "light": "#717171" - } - }, - "darkmode": { - "theme_color": { - "primary": "#fff", - "body": "#1c1c1c", - "border": "#3E3E3E", - "theme_light": "#222222", - "theme_dark": "" - }, - "text_color": { - "default": "#B4AFB6", - "dark": "#fff", - "light": "#B4AFB6" - } - } - }, - "fonts": { - "font_family": { - "primary": "Heebo:wght@400;600", - "primary_type": "sans-serif", - "secondary": "Signika:wght@500;700", - "secondary_type": "sans-serif" - }, - "font_size": { - "base": "16", - "scale": "1.250" - } - } -} diff --git a/new-site/eslint.config.mjs b/eslint.config.mjs similarity index 100% rename from new-site/eslint.config.mjs rename to eslint.config.mjs diff --git a/go.mod b/go.mod deleted file mode 100644 index 85e38cf..0000000 --- a/go.mod +++ /dev/null @@ -1,31 +0,0 @@ -module hugoplate.netlify.app - -go 1.21 - -require ( - github.com/gethugothemes/hugo-modules/accordion v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/adsense v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/components/announcement v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/components/cookie-consent v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/components/custom-script v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/components/preloader v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/components/render-link v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/components/social-share v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/gallery-slider v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/gzip-caching v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/icons/font-awesome v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/images v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/modal v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/pwa v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/search v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/seo-tools/basic-seo v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/seo-tools/google-tag-manager v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/seo-tools/site-verifications v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/shortcodes/button v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/shortcodes/notice v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/tab v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/table-of-contents v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/gethugothemes/hugo-modules/videos v0.0.0-20240925042433-d2b5d05977e8 // indirect - github.com/hugomods/mermaid v0.1.4 // indirect - github.com/zeon-studio/hugoplate v0.0.0-20240925044951-fe74d0e62893 // indirect -) diff --git a/hugo.toml b/hugo.toml deleted file mode 100755 index dc4971e..0000000 --- a/hugo.toml +++ /dev/null @@ -1,178 +0,0 @@ -######################## default configuration #################### -# The base URL of your site (required). This will be prepended to all relative URLs. -baseURL = "/" -# Title of your website (required). -title = "Five Devs" -# Your theme name -theme = "hugoplate" -# Default time zone for time stamps; use any valid tz database name: https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List -timeZone = "America/Chicago" -# post excerpt -summaryLength = 10 # see https://gohugo.io/content-management/excerpts/ -# disable language -disableLanguages = [ -] # example: ["fr"] for disable french language. see https://gohugo.io/content-management/multilingual/ -hasCJKLanguage = false # If hasCJKLanguage true, auto-detect Chinese/Japanese/Korean Languages in the content. see: https://gohugo.io/getting-started/configuration/#hascjklanguage -# default language -defaultContentLanguage = 'en' -# defaultContentLanguageInSubdir need to be true if you want to use the language code as a subdirectory and language specific 404 page -defaultContentLanguageInSubdir = false - -########################### Services ############################# -[services] -[services.googleAnalytics] -ID = 'G-MEASUREMENT_ID' # see https://gohugo.io/templates/internal/#configure-google-analytics - -[services.disqus] -shortname = 'themefisher-template' # we use disqus to show comments in blog posts . To install disqus please follow this tutorial https://portfolio.peter-baumgartner.net/2017/09/10/how-to-install-disqus-on-hugo/ - -########################## Permalinks ############################ -[permalinks.page] -"pages" = "/:slugorfilename/" - - -########################## Pagination ############################ -[pagination] -disableAliases = false -pagerSize = 10 -path = 'page' - - -############################# Modules ############################ -[module] -[[module.mounts]] -source = "assets" -target = "assets" - -[[module.mounts]] -source = "hugo_stats.json" -target = "assets/watching/hugo_stats.json" - -############################# Build ############################## -[build] -noJSConfigInAssets = false -useResourceCacheWhen = 'fallback' -[build.buildStats] -enable = true -[[build.cachebusters]] -source = 'assets/watching/hugo_stats\.json' -target = 'style\.css' -[[build.cachebusters]] -source = '(postcss|tailwind)\.config\.js' -target = 'css' -[[build.cachebusters]] -source = 'assets/.*\.(js|ts|jsx|tsx)' -target = 'js' -[[build.cachebusters]] -source = 'assets/.*\.(css|scss|sass)' -target = 'css' -[[build.cachebusters]] -source = 'data/.*\.(.*)$' -target = 'css' -[[build.cachebusters]] -source = 'assets/.*\.(.*)$' -target = '$1' - - -############################# Outputs ############################ -[outputs] -home = ["HTML", "RSS", "WebAppManifest", "SearchIndex"] - -############################# Imaging ############################ -[imaging] -# See https://github.com/disintegration/imaging -# Default JPEG or WebP quality setting. Default is 75. -quality = 80 -resampleFilter = "Lanczos" - -############################ Caches ############################## -[caches] -[caches.images] -dir = ":resourceDir/_gen" -maxAge = "720h" - -[caches.assets] -dir = ":resourceDir/_gen" -maxAge = "720h" - - -############################ Markup ############################## -[markup] -[markup.goldmark.renderer] -unsafe = true - -[markup.highlight] -style = 'monokai' # see https://xyproto.github.io/splash/docs/all.html - -[markup.tableOfContents] -startLevel = 2 -endLevel = 5 -ordered = true - - -########################### Media types ########################### -[mediaTypes] -[mediaTypes."application/manifest+json"] -suffixes = ["webmanifest"] - - -########################### Output Format ########################## -[outputFormats] -[outputFormats.WebAppManifest] -mediaType = "application/manifest+json" -rel = "manifest" - -[outputFormats.SearchIndex] -mediaType = "application/json" -baseName = "searchindex" -isPlainText = true -notAlternative = true - - -############################# Plugins ############################## - -# CSS Plugins -[[params.plugins.css]] -link = "plugins/swiper/swiper-bundle.css" -lazy = true -[[params.plugins.css]] -link = "plugins/glightbox/glightbox.css" -lazy = true -[[params.plugins.css]] -link = "plugins/font-awesome/v6/brands.css" -lazy = true -[[params.plugins.css]] -link = "plugins/font-awesome/v6/solid.css" -lazy = true -[[params.plugins.css]] -link = "plugins/font-awesome/v6/icons.css" -lazy = true - -# JS Plugins -[[params.plugins.js]] -link = "js/search.js" -lazy = false -[[params.plugins.js]] -link = "plugins/swiper/swiper-bundle.js" -lazy = false -[[params.plugins.js]] -link = "plugins/cookie.js" -lazy = false -[[params.plugins.js]] -link = "plugins/glightbox/glightbox.js" -lazy = true -[[params.plugins.js]] -link = "js/gallery-slider.js" -lazy = true -[[params.plugins.js]] -link = "js/accordion.js" -lazy = true -[[params.plugins.js]] -link = "js/tab.js" -lazy = true -[[params.plugins.js]] -link = "js/modal.js" -lazy = true -[[params.plugins.js]] -link = "plugins/youtube-lite.js" -lazy = true diff --git a/i18n/en.yaml b/i18n/en.yaml deleted file mode 100755 index 4e6722f..0000000 --- a/i18n/en.yaml +++ /dev/null @@ -1,14 +0,0 @@ -home: Home -read_more: Read More -send: Send -related_posts: Related Posts -categories: Categories -tags: Tags -toc: Table of Contents -share: Share -search_input_placeholder: Search Post... -search_no_results: No results for -search_initial_message: Type something to search.. -search_navigate: to navigate -search_select: to select -search_close: to close diff --git a/new-site/mdx-components.tsx b/mdx-components.tsx similarity index 100% rename from new-site/mdx-components.tsx rename to mdx-components.tsx diff --git a/new-site/.env.local.example b/new-site/.env.local.example deleted file mode 100644 index 921f60a..0000000 --- a/new-site/.env.local.example +++ /dev/null @@ -1,16 +0,0 @@ -# Stripe Payment Link URLs. -# Create each Payment Link in your Stripe Dashboard: -# Dashboard -> Payment Links -> + New -# Then paste the resulting URL (looks like https://buy.stripe.com/abc123) -# into the matching variable below. -# -# When the website-redesign-launch sale is active (see -# src/lib/pricing.ts), each Payment Link should be configured at the -# sale price (50% of the regular price shown on the site). When you -# end the sale, swap each URL to a Payment Link priced at the regular -# amount. - -NEXT_PUBLIC_STRIPE_RETAINER= -NEXT_PUBLIC_STRIPE_BLOCK_5= -NEXT_PUBLIC_STRIPE_BLOCK_10= -NEXT_PUBLIC_STRIPE_BLOCK_20= diff --git a/new-site/.gitignore b/new-site/.gitignore deleted file mode 100644 index 5ef6a52..0000000 --- a/new-site/.gitignore +++ /dev/null @@ -1,41 +0,0 @@ -# See https://help.github.com/articles/ignoring-files/ for more about ignoring files. - -# dependencies -/node_modules -/.pnp -.pnp.* -.yarn/* -!.yarn/patches -!.yarn/plugins -!.yarn/releases -!.yarn/versions - -# testing -/coverage - -# next.js -/.next/ -/out/ - -# production -/build - -# misc -.DS_Store -*.pem - -# debug -npm-debug.log* -yarn-debug.log* -yarn-error.log* -.pnpm-debug.log* - -# env files (can opt-in for committing if needed) -.env* - -# vercel -.vercel - -# typescript -*.tsbuildinfo -next-env.d.ts diff --git a/new-site/package.json b/new-site/package.json deleted file mode 100644 index 7682d3c..0000000 --- a/new-site/package.json +++ /dev/null @@ -1,34 +0,0 @@ -{ - "name": "new-site", - "version": "0.1.0", - "private": true, - "scripts": { - "dev": "next dev", - "build": "next build", - "start": "next start", - "lint": "eslint" - }, - "dependencies": { - "@mdx-js/loader": "^3.1.1", - "@mdx-js/react": "^3.1.1", - "@next/mdx": "^16.2.4", - "@types/mdx": "^2.0.13", - "@vercel/analytics": "^2.0.1", - "gray-matter": "^4.0.3", - "next": "16.2.4", - "react": "19.2.4", - "react-dom": "19.2.4", - "remark-gfm": "^4.0.1" - }, - "devDependencies": { - "@tailwindcss/postcss": "^4", - "@tailwindcss/typography": "^0.5.19", - "@types/node": "^20", - "@types/react": "^19", - "@types/react-dom": "^19", - "eslint": "^9", - "eslint-config-next": "16.2.4", - "tailwindcss": "^4", - "typescript": "^5" - } -} diff --git a/new-site/next.config.ts b/next.config.ts similarity index 100% rename from new-site/next.config.ts rename to next.config.ts diff --git a/package.json b/package.json index 6fcc13e..7682d3c 100644 --- a/package.json +++ b/package.json @@ -1,39 +1,34 @@ { - "name": "hugoplate", - "description": "hugo tailwindcss boilerplate", - "version": "1.17.0", - "license": "MIT", - "author": "zeon.studio", + "name": "new-site", + "version": "0.1.0", + "private": true, "scripts": { - "dev": "hugo server", - "build": "hugo --gc --minify --templateMetrics --templateMetricsHints --forceSyncStatic", - "preview": "hugo server --disableFastRender --navigateToChanged --templateMetrics --templateMetricsHints --watch --forceSyncStatic -e production --minify", - "dev:example": "cd exampleSite && hugo server", - "build:example": "cd exampleSite && hugo --gc --minify --templateMetrics --templateMetricsHints --forceSyncStatic", - "preview:example": "cd exampleSite && hugo server --disableFastRender --navigateToChanged --templateMetrics --templateMetricsHints --watch --forceSyncStatic -e production --minify", - "update-modules": "node ./scripts/clearModules.js && hugo mod clean --all && hugo mod get -u ./... && hugo mod tidy", - "remove-darkmode": "node ./scripts/removeDarkmode.js && yarn format", - "project-setup": "node ./scripts/projectSetup.js", - "theme-setup": "node ./scripts/themeSetup.js", - "update-theme": "node ./scripts/themeUpdate.js", - "format": "prettier -w ." + "dev": "next dev", + "build": "next build", + "start": "next start", + "lint": "eslint" + }, + "dependencies": { + "@mdx-js/loader": "^3.1.1", + "@mdx-js/react": "^3.1.1", + "@next/mdx": "^16.2.4", + "@types/mdx": "^2.0.13", + "@vercel/analytics": "^2.0.1", + "gray-matter": "^4.0.3", + "next": "16.2.4", + "react": "19.2.4", + "react-dom": "19.2.4", + "remark-gfm": "^4.0.1" }, "devDependencies": { - "@tailwindcss/forms": "^0.5.9", - "@tailwindcss/typography": "^0.5.15", - "autoprefixer": "^10.4.20", - "postcss": "^8.4.47", - "postcss-cli": "^11.0.0", - "prettier": "^3.3.3", - "prettier-plugin-go-template": "0.0.15", - "prettier-plugin-tailwindcss": "^0.6.8", - "tailwind-bootstrap-grid": "^5.1.0", - "tailwindcss": "^3.4.13" - }, - "postcss": { - "plugins": { - "tailwindcss": {}, - "autoprefixer": {} - } + "@tailwindcss/postcss": "^4", + "@tailwindcss/typography": "^0.5.19", + "@types/node": "^20", + "@types/react": "^19", + "@types/react-dom": "^19", + "eslint": "^9", + "eslint-config-next": "16.2.4", + "tailwindcss": "^4", + "typescript": "^5" } } diff --git a/new-site/pnpm-lock.yaml b/pnpm-lock.yaml similarity index 100% rename from new-site/pnpm-lock.yaml rename to pnpm-lock.yaml diff --git a/new-site/pnpm-workspace.yaml b/pnpm-workspace.yaml similarity index 100% rename from new-site/pnpm-workspace.yaml rename to pnpm-workspace.yaml diff --git a/postcss.config.js b/postcss.config.js deleted file mode 100644 index bab806f..0000000 --- a/postcss.config.js +++ /dev/null @@ -1,44 +0,0 @@ -const purgecss = { - content: ["./hugo_stats.json"], - defaultExtractor: (content) => { - const elements = JSON.parse(content).htmlElements; - return [ - ...(elements.tags || []), - ...(elements.classes || []), - ...(elements.ids || []), - ]; - }, - safelist: [ - /^swiper-/, - /^lb-/, - /^gl/, - /^go/, - /^gc/, - /^gs/, - /^gi/, - /^gz/, - /^gprev/, - /^gnext/, - /^desc/, - /^zoom/, - /^search/, - /^:is/, - /dark/, - /show/, - /dragging/, - /fullscreen/, - /loaded/, - /visible/, - /current/, - /active/, - ], -}; - -module.exports = { - plugins: { - tailwindcss: {}, - "@fullhuman/postcss-purgecss": - process.env.HUGO_ENVIRONMENT === "production" ? purgecss : false, - autoprefixer: process.env.HUGO_ENVIRONMENT === "production" ? {} : false, - }, -}; diff --git a/new-site/postcss.config.mjs b/postcss.config.mjs similarity index 100% rename from new-site/postcss.config.mjs rename to postcss.config.mjs diff --git a/public/llms.txt b/public/llms.txt new file mode 100644 index 0000000..f1d1752 --- /dev/null +++ b/public/llms.txt @@ -0,0 +1,34 @@ +# Five Devs + +> Senior PHP help for the unglamorous, mission-critical glue between your store, your warehouse, and your books. Fifteen years of e-commerce and 3PL/logistics integration work. + +Five Devs is the freelance PHP practice of Chris Smith, operating as Five Devs, LLC out of Henderson, Nevada. Engagements are structured as monthly retainers, time blocks (5/10/20 hours), or fixed-price project sprints, primarily for companies running e-commerce, third-party logistics (3PL), or operational tooling on PHP-based stacks. + +Long-term clients have included Pritikin Foods, Americold, Fortune Fulfillment, HD Financial, Butcher Box, Perfect Bar, Vanderose Farms, Potawatomi Business Development, and PERC Engage. + +## Pages + +- [Home](https://fivedevs.com/): Service overview and positioning +- [About](https://fivedevs.com/about): Background, principles, and how Chris works +- [Services](https://fivedevs.com/services): Engagement options, pricing, and self-serve checkout +- [Work](https://fivedevs.com/work): Selected client engagements and case studies +- [Contact](https://fivedevs.com/contact): Book an intro call or send a message + +## Writing + +- [Why I take 'glue work' seriously (and you should too)](https://fivedevs.com/blog/the-glue-job): On the integration code that quietly keeps small businesses shipping +- [How to hire a senior PHP developer (without getting burned)](https://fivedevs.com/blog/how-to-hire-a-php-dev): Practical buyer's guide for non-technical founders +- [A pre-launch checklist for connecting your store to a 3PL](https://fivedevs.com/blog/three-pl-integration-checklist): Twelve things to verify before flipping the switch on a new fulfillment integration + +## Case studies + +- [Pritikin Foods](https://fivedevs.com/work/pritikin-foods): Multi-year e-commerce + 3PL shipping and order parsing pipeline +- [Americold](https://fivedevs.com/work/americold): Senior PHP work on customer-facing logistics tooling for one of the largest cold-chain warehousing networks in the US + +## Contact + +- Email: chris@fivedevs.com +- LinkedIn: https://www.linkedin.com/in/phpguy +- GitHub: https://github.com/cgsmith +- Twitter / X: https://twitter.com/cgsmith105 +- Languages: English, German diff --git a/readme.md b/readme.md deleted file mode 100755 index 27abcd2..0000000 --- a/readme.md +++ /dev/null @@ -1,239 +0,0 @@ -

Hugo + Tailwind CSS Starter and Boilerplate

- -

Hugoplate is a free starter template built with Hugo, and TailwindCSS, providing everything you need to jumpstart your Hugo project and save valuable time.

- -

Made with ♥ by Zeon Studio

-

If you find this project useful, please give it a ⭐ to show your support.

- -

👀 Demo | Page Speed (95+)🚀 -

- -

- - - - - - license - - - - code size - - - - contributors - -

- -## 🎁 What's Included - -We have included almost everything you need to start your Hugo project. Let's see what's included in this template: - -### 📌 Key Features - -- 👥 Multi-Authors -- 🎯 Similar Posts Suggestion -- 🔍 Search Functionality -- 🌑 Dark Mode -- 🏷️ Tags & Categories -- 🔗 Netlify setting pre-configured -- 📞 Support contact form -- 📱 Fully responsive -- 📝 Write and update content in Markdown -- 💬 Disqus Comment -- 🔳 Syntax Highlighting - -### 📄 15+ Pre-designed Pages - -- 🏠 Homepage -- 👤 About -- 📞 Contact -- 👥 Authors -- 👤 Author Single -- 📝 Blog -- 📝 Blog Single -- 🚫 Custom 404 -- 💡 Elements -- 📄 Privacy Policy -- 🏷️ Tags -- 🏷️ Tag Single -- 🗂️ Categories -- 🗂️ Category Single -- 🔍 Search - -### 📦 Tech Stack - -- [Hugo](https://gohugo.io/) -- [Tailwind CSS](https://tailwindcss.com/) -- [PostCSS](https://postcss.org/) -- [PurgeCSS](https://purgecss.com/) -- [AutoPrefixer](https://autoprefixer.github.io/) -- [Hugo Modules](https://gohugo.io/hugo-modules/) by [Gethugothemes](https://gethugothemes.com/hugo-modules) -- [Markdown](https://markdownguide.org/) -- [Prettier](https://prettier.io/) -- [Jshint](https://jshint.com/) -- [Netlify](https://www.netlify.com/) -- [Vercel](https://vercel.com/) -- [Github Actions](https://github.com/features/actions) -- [Gitlab Ci](https://docs.gitlab.com/ee/ci/) -- [AWS Amplify](https://aws.amazon.com/amplify/) - ---- - -## 🚀 Getting Started - -First you need to [clone](https://github.com/zeon-studio/hugoplate) or [download](https://github.com/zeon-studio/hugoplate/archive/refs/heads/main.zip) the template repository, and then let's get started with the following process: - -### ⚙️ Prerequisites - -To start using this template, you need to have some prerequisites installed on your machine. - -- [Hugo Extended v0.124+](https://gohugo.io/installation/) -- [Node v20+](https://nodejs.org/en/download/) -- [Go v1.22+](https://go.dev/doc/install) - -### 👉 Project Setup - -We build this custom script to make your project setup easier. It will create a new Hugo theme folder, and clone the Hugoplate theme into it. Then move the exampleSite folder into the root directory. So that you can start your Hugo server without going into the exampleSite folder. Use the following command to setup your project. - -```bash -npm run project-setup -``` - -### 👉 Install Dependencies - -Install all the dependencies using the following command. - -```bash -npm install -``` - -### 👉 Development Command - -Start the development server using the following command. - -```bash -npm run dev -``` - -### 🎬 Still Confused? Watch a Quick Video - -https://github.com/zeon-studio/hugoplate/assets/58769763/c260c0ae-91be-42ce-b8db-aa7f11f777bd - ---- - -## 📝 Customization - -This template has been designed with a lot of customization options in mind. You can customize almost anything you want, including: - -### 👉 Site Config - -You can change the site title, base URL, language, theme, plugins, and more from the `hugo.toml` file. - -### 👉 Site Params - -You can customize all the parameters from the `config/_default/params.toml` file. This includes the logo, favicon, search, SEO metadata, and more. - -### 👉 Colors and Fonts - -You can change the colors and fonts from the `data/theme.json` file. This includes the primary color, secondary color, font family, and font size. - -### 👉 Social Links - -You can change the social links from the `data/social.json` file. Add your social links here, and they will automatically be displayed on the site. - ---- - -## 🛠 Advanced Usage - -We have added some custom scripts to make your life easier. You can use these scripts to help you with your development. - -### 👉 Update Theme - -If you want to update the theme, then you can use the following command. It will update the theme to the latest version. - -```bash -npm run update-theme -``` - -> **Note:** This command will work after running `project-setup` script. - -### 👉 Update Modules - -We have added a lot of modules to this template. You can update all the modules using the following command. - -```bash -npm run update-modules -``` - -### 👉 Remove Dark Mode - -If you want to remove dark mode from your project, you can use the following command to remove dark mode from your project. - -```bash -npm run remove-darkmode -``` - -> **Note:** This command will work before running `project-setup` script. If you already run the `project-setup` command, then you have to run `npm run theme-setup` first, and then you can run this command. afterward, you can run `npm run project-setup` again. - ---- - -## 🚀 Build And Deploy - -After you finish your development, you can build or deploy your project almost everywhere. Let's see the process: - -### 👉 Build Command - -To build your project locally, you can use the following command. It will purge all the unused CSS and minify all the files. - -```bash -npm run build -``` - -### 👉 Deploy Site - -We have provided 5 different deploy platform configurations with this template, so you can deploy easily. - -- [Netlify](https://www.netlify.com/) -- [Vercel](https://vercel.com/) -- [Github Actions](https://github.com/features/actions) -- [Gitlab Ci](https://docs.gitlab.com/ee/ci/) -- [AWS Amplify](https://aws.amazon.com/amplify/) - -And if you want to Host some other hosting platforms. then you can build your project, and you will get a `public` folder. that you can copy and paste on your hosting platform. - -> **Note:** You must change the `baseURL` in the `hugo.toml` file. Otherwise, your site will not work properly. - ---- - -## 🔒 Guide to Staying Compliant - -### 🐞 Reporting Issues - -We use GitHub Issues as the official bug tracker for this Template. Please Search [existing issues](https://github.com/zeon-studio/hugoplate/issues). It’s possible someone has already reported the same problem. -If your problem or idea has not been addressed yet, feel free to [open a new issue](https://github.com/zeon-studio/hugoplate/issues). - -### 📝 License - -Copyright (c) 2023 - Present, Designed & Developed by [Zeon Studio](https://zeon.studio/) - -**Code License:** Released under the [MIT](https://github.com/zeon-studio/hugoplate/blob/main/LICENSE) license. - -**Image license:** The images are only for demonstration purposes. They have their license, we don't have permission to share those images. - ---- - -## 🖼️ Showcase - -List of some projects people are building with **Hugoplate**! - -| [![Open Neuromorphic](https://tinyurl.com/hp7avtje)](https://open-neuromorphic.org/) | [![AI Models](https://tinyurl.com/mu4p7dhb)](https://aimodels.org/) | [![Hugobricks](https://tinyurl.com/4x3uwhm9)](https://www.hugobricks.preview.usecue.com/) | [![ONO LLC](https://tinyurl.com/2fbjzwzn)](https://ono.day/) -|:---:|:---:|:---:|:---:| -| **Open Neuromorphic** | **AI Models** | **Hugobricks** | **ONO LLC** | - ---- - -## 💻 Need Customization? - -If you need a custom theme, theme customization, or complete website development services from scratch you can [Hire Us](https://zeon.studio/estimate-project). diff --git a/scripts/clearModules.js b/scripts/clearModules.js deleted file mode 100644 index 1b9c74a..0000000 --- a/scripts/clearModules.js +++ /dev/null @@ -1,14 +0,0 @@ -const fs = require("fs"); - -const clearModules = (filePath) => { - if (fs.existsSync(filePath)) { - let fileContent = fs.readFileSync(filePath, "utf8"); - fileContent = fileContent.replace(/require\s*\([\s\S]*?\)/, ""); - fs.writeFileSync(filePath, fileContent, "utf8"); - } else { - console.log("File does not exist."); - } -}; - -clearModules("go.mod"); -clearModules("exampleSite/go.mod"); diff --git a/scripts/projectSetup.js b/scripts/projectSetup.js deleted file mode 100644 index 3ab7306..0000000 --- a/scripts/projectSetup.js +++ /dev/null @@ -1,116 +0,0 @@ -const fs = require("fs"); -const path = require("path"); - -const toggleComment = ({ filepath, regex }) => { - let updatedContent = fs.readFileSync(filepath, "utf8"); - const match = updatedContent.match(regex); - - if (match) { - const matchedContent = match[0]; - const hasComment = matchedContent.startsWith("# "); - if (hasComment) { - updatedContent = updatedContent.replace( - regex, - matchedContent.replace("# ", ""), - ); - fs.writeFileSync(filepath, updatedContent, "utf8"); - } else { - const hasBreakline = matchedContent.includes("\n"); - if (hasBreakline) { - const content = matchedContent - .split("\n") - .map((line) => "# " + line) - .join("\n"); - updatedContent = updatedContent.replace(regex, content); - fs.writeFileSync(filepath, updatedContent, "utf8"); - } - } - } -}; - -const getFolderName = (rootfolder) => { - const configPath = path.join(rootfolder, "exampleSite/hugo.toml"); - const getConfig = fs.readFileSync(configPath, "utf8"); - const match = getConfig.match(/theme\s*=\s*\[?"([^"\]]+)"\]?/); - let selectedTheme = null; - if (match && match[1]) { - selectedTheme = match[1]; - } - return selectedTheme; -}; - -const deleteFolder = (folderPath) => { - if (fs.existsSync(folderPath)) { - fs.rmSync(folderPath, { recursive: true, force: true }); - } -}; - -const createNewfolder = (rootfolder, folderName) => { - const newFolder = path.join(rootfolder, folderName); - fs.mkdirSync(newFolder, { recursive: true }); - return newFolder; -}; - -const iterateFilesAndFolders = (rootFolder, { destinationRoot }) => { - const directory = path.join(rootFolder); - const items = fs.readdirSync(directory, { withFileTypes: true }); - items.forEach((item) => { - if (item.isDirectory()) { - createNewfolder(destinationRoot, item.name); - iterateFilesAndFolders(path.join(directory, item.name), { - currentFolder: item.name, - destinationRoot: path.join(destinationRoot, item.name), - }); - } else { - const sourceFile = path.join(directory, item.name); - const destinationFile = path.join(destinationRoot, item.name); - fs.renameSync(sourceFile, destinationFile); - } - }); -}; - -const setupProject = () => { - const rootfolder = path.join(__dirname, "../"); - if (!fs.existsSync(path.join(rootfolder, "themes"))) { - // remove this part if you don't using theme demo as a module - [ - { - filepath: path.join(rootfolder, "exampleSite/hugo.toml"), - regex: /^.*theme\s*=\s*("[^"\]]+"|\S+)/m, - }, - { - filepath: path.join( - rootfolder, - "exampleSite/config/_default/module.toml", - ), - regex: /\[\[imports\]\]\s*\r?\npath = "([^"]+)"/, - }, - ].forEach(toggleComment); - - const folderList = ["layouts", "assets", "static"]; - const folderName = getFolderName(rootfolder); - const newfolderName = createNewfolder( - path.join(rootfolder, "themes"), - folderName, - ); - - folderList.forEach((folder) => { - const source = path.join(rootfolder, folder); - const destination = path.join(newfolderName, folder); - if (fs.existsSync(source)) { - fs.mkdirSync(destination, { recursive: true }); - iterateFilesAndFolders(source, { - currentFolder: folder, - destinationRoot: destination, - }); - deleteFolder(source); - } - }); - - const exampleSite = path.join(rootfolder, "exampleSite"); - iterateFilesAndFolders(exampleSite, { destinationRoot: rootfolder }); - deleteFolder(exampleSite); - } -}; - -setupProject(); diff --git a/scripts/removeDarkmode.js b/scripts/removeDarkmode.js deleted file mode 100644 index cb1b863..0000000 --- a/scripts/removeDarkmode.js +++ /dev/null @@ -1,69 +0,0 @@ -const fs = require("fs"); -const path = require("path"); - -const rootDirs = ["assets/scss", "layouts"]; -const configFiles = [ - { - filePath: "exampleSite/tailwind.config.js", - patterns: ["darkmode:\\s*{[^}]*},", 'darkMode:\\s*"class",'], - }, - { - filePath: "exampleSite/data/theme.json", - patterns: ["colors.darkmode"], - }, -]; - -rootDirs.forEach(removeDarkModeFromPages); -configFiles.forEach(removeDarkMode); - -function removeDarkModeFromFiles(filePath, regexPatterns) { - const fileContent = fs.readFileSync(filePath, "utf8"); - let updatedContent = fileContent; - regexPatterns.forEach((pattern) => { - const regex = new RegExp(pattern, "g"); - updatedContent = updatedContent.replace(regex, ""); - }); - fs.writeFileSync(filePath, updatedContent, "utf8"); -} - -function removeDarkModeFromPages(directoryPath) { - const files = fs.readdirSync(directoryPath); - - files.forEach((file) => { - const filePath = path.join(directoryPath, file); - const stats = fs.statSync(filePath); - if (stats.isDirectory()) { - removeDarkModeFromPages(filePath); - } else if (stats.isFile()) { - removeDarkModeFromFiles(filePath, [ - '(?:(?!["])\\S)*dark:(?:(?![,;"])\\S)*', - "@apply?(\\s)*;", - ]); - } - }); -} - -function removeDarkMode(configFile) { - const { filePath, patterns } = configFile; - if (filePath === "exampleSite/tailwind.config.js") { - removeDarkModeFromFiles(filePath, patterns); - } else { - const contentFile = JSON.parse(fs.readFileSync(filePath, "utf8")); - patterns.forEach((pattern) => deleteNestedProperty(contentFile, pattern)); - fs.writeFileSync(filePath, JSON.stringify(contentFile)); - } -} - -function deleteNestedProperty(obj, propertyPath) { - const properties = propertyPath.split("."); - let currentObj = obj; - for (let i = 0; i < properties.length - 1; i++) { - const property = properties[i]; - if (currentObj.hasOwnProperty(property)) { - currentObj = currentObj[property]; - } else { - return; // Property not found, no need to continue - } - } - delete currentObj[properties[properties.length - 1]]; -} diff --git a/scripts/themeSetup.js b/scripts/themeSetup.js deleted file mode 100644 index 0d21aad..0000000 --- a/scripts/themeSetup.js +++ /dev/null @@ -1,125 +0,0 @@ -const fs = require("fs"); -const path = require("path"); - -const toggleComment = ({ filepath, regex }) => { - let updatedContent = fs.readFileSync(filepath, "utf8"); - const match = updatedContent.match(regex); - - if (match) { - const matchedContent = match[0]; - const hasComment = matchedContent.startsWith("# "); - if (hasComment) { - const hasBreakline = matchedContent.includes("\n"); - if (hasBreakline) { - updatedContent = updatedContent.replace( - regex, - matchedContent.replace(/# /gm, ""), - ); - fs.writeFileSync(filepath, updatedContent, "utf8"); - } - } else { - updatedContent = updatedContent.replace(regex, "# " + matchedContent); - fs.writeFileSync(filepath, updatedContent, "utf8"); - } - } -}; - -const createNewfolder = (rootfolder, folderName) => { - const newFolder = path.join(rootfolder, folderName); - fs.mkdirSync(newFolder, { recursive: true }); - return newFolder; -}; - -const deleteFolder = (folderPath) => { - if (fs.existsSync(folderPath)) { - fs.rmSync(folderPath, { recursive: true, force: true }); - } -}; - -const getFolderName = (rootfolder) => { - const configPath = path.join(rootfolder, "exampleSite/hugo.toml"); - const getConfig = fs.readFileSync(configPath, "utf8"); - const match = getConfig.match(/theme\s*=\s*\[?"([^"\]]+)"\]?/); - let selectedTheme = null; - if (match && match[1]) { - selectedTheme = match[1]; - } - return selectedTheme; -}; - -const iterateFilesAndFolders = (rootFolder, { destinationRoot }) => { - const directory = path.join(rootFolder); - const items = fs.readdirSync(directory, { withFileTypes: true }); - items.forEach((item) => { - if (item.isDirectory()) { - createNewfolder(destinationRoot, item.name); - iterateFilesAndFolders(path.join(directory, item.name), { - currentFolder: item.name, - destinationRoot: path.join(destinationRoot, item.name), - }); - } else { - const sourceFile = path.join(directory, item.name); - const destinationFile = path.join(destinationRoot, item.name); - fs.renameSync(sourceFile, destinationFile); - } - }); -}; - -const setupTheme = () => { - const rootFolder = path.join(__dirname, "../"); - - if (!fs.existsSync(path.join(rootFolder, "exampleSite"))) { - // remove this part if you don't using theme demo as a module - [ - { - filepath: path.join(rootFolder, "config/_default/module.toml"), - regex: /# \[\[imports\]\]\s*\r?\n# path = "([^"]+)"/, - }, - { - filepath: path.join(rootFolder, "hugo.toml"), - regex: /^.*theme\s*=\s*("[^"\]]+"|\S+)/m, - }, - ].forEach(toggleComment); - - const includesFiles = [ - "tailwind.config.js", - "postcss.config.js", - "go.mod", - "hugo.toml", - "assets", - "config", - "data", - "content", - "i18n", - "static", - ]; - - const folder = createNewfolder(rootFolder, "exampleSite"); - - fs.readdirSync(rootFolder, { withFileTypes: true }).forEach((file) => { - if (includesFiles.includes(file.name)) { - if (file.isDirectory()) { - const destination = path.join(rootFolder, "exampleSite", file.name); - fs.mkdirSync(destination, { recursive: true }); - iterateFilesAndFolders(path.join(rootFolder, file.name), { - destinationRoot: destination, - }); - deleteFolder(path.join(rootFolder, file.name)); - } else { - fs.renameSync( - path.join(rootFolder, file.name), - path.join(folder, file.name), - ); - } - } - }); - - const themes = path.join(rootFolder, "themes"); - iterateFilesAndFolders(path.join(themes, getFolderName(rootFolder)), { - destinationRoot: rootFolder, - }); - deleteFolder(themes); - } -}; - -setupTheme(); diff --git a/scripts/themeUpdate.js b/scripts/themeUpdate.js deleted file mode 100644 index 742cd20..0000000 --- a/scripts/themeUpdate.js +++ /dev/null @@ -1,19 +0,0 @@ -const { exec } = require("child_process"); - -const repositoryUrl = "https://github.com/zeon-studio/hugoplate"; -const localDirectory = "./themes/hugoplate"; -const foldersToFetch = ["assets", "layouts"]; -const foldersToSkip = ["exampleSite"]; - -const fetchFolder = (folder) => { - exec( - `curl -L ${repositoryUrl}/tarball/main | tar -xz --strip-components=1 --directory=${localDirectory} --exclude=$(curl -sL ${repositoryUrl}/tarball/main | tar -tz | grep -E "/(${foldersToSkip.join( - "|", - )})/") */${folder}`, - ); -}; - -// Fetch each specified folder -foldersToFetch.forEach((folder) => { - fetchFolder(folder); -}); diff --git a/new-site/src/app/about/page.tsx b/src/app/about/page.tsx similarity index 100% rename from new-site/src/app/about/page.tsx rename to src/app/about/page.tsx diff --git a/new-site/src/app/blog/[slug]/page.tsx b/src/app/blog/[slug]/page.tsx similarity index 100% rename from new-site/src/app/blog/[slug]/page.tsx rename to src/app/blog/[slug]/page.tsx diff --git a/new-site/src/app/blog/page.tsx b/src/app/blog/page.tsx similarity index 100% rename from new-site/src/app/blog/page.tsx rename to src/app/blog/page.tsx diff --git a/new-site/src/app/contact/page.tsx b/src/app/contact/page.tsx similarity index 100% rename from new-site/src/app/contact/page.tsx rename to src/app/contact/page.tsx diff --git a/new-site/src/app/favicon.ico b/src/app/favicon.ico similarity index 100% rename from new-site/src/app/favicon.ico rename to src/app/favicon.ico diff --git a/new-site/src/app/globals.css b/src/app/globals.css similarity index 100% rename from new-site/src/app/globals.css rename to src/app/globals.css diff --git a/new-site/src/app/layout.tsx b/src/app/layout.tsx similarity index 100% rename from new-site/src/app/layout.tsx rename to src/app/layout.tsx diff --git a/new-site/src/app/page.tsx b/src/app/page.tsx similarity index 100% rename from new-site/src/app/page.tsx rename to src/app/page.tsx diff --git a/new-site/src/app/robots.ts b/src/app/robots.ts similarity index 100% rename from new-site/src/app/robots.ts rename to src/app/robots.ts diff --git a/new-site/src/app/services/page.tsx b/src/app/services/page.tsx similarity index 100% rename from new-site/src/app/services/page.tsx rename to src/app/services/page.tsx diff --git a/new-site/src/app/sitemap.ts b/src/app/sitemap.ts similarity index 100% rename from new-site/src/app/sitemap.ts rename to src/app/sitemap.ts diff --git a/new-site/src/app/thank-you/page.tsx b/src/app/thank-you/page.tsx similarity index 100% rename from new-site/src/app/thank-you/page.tsx rename to src/app/thank-you/page.tsx diff --git a/new-site/src/app/work/[slug]/page.tsx b/src/app/work/[slug]/page.tsx similarity index 100% rename from new-site/src/app/work/[slug]/page.tsx rename to src/app/work/[slug]/page.tsx diff --git a/new-site/src/app/work/page.tsx b/src/app/work/page.tsx similarity index 100% rename from new-site/src/app/work/page.tsx rename to src/app/work/page.tsx diff --git a/new-site/src/components/button.tsx b/src/components/button.tsx similarity index 100% rename from new-site/src/components/button.tsx rename to src/components/button.tsx diff --git a/new-site/src/components/client-logos.tsx b/src/components/client-logos.tsx similarity index 100% rename from new-site/src/components/client-logos.tsx rename to src/components/client-logos.tsx diff --git a/new-site/src/components/contact-form.tsx b/src/components/contact-form.tsx similarity index 100% rename from new-site/src/components/contact-form.tsx rename to src/components/contact-form.tsx diff --git a/new-site/src/components/container.tsx b/src/components/container.tsx similarity index 100% rename from new-site/src/components/container.tsx rename to src/components/container.tsx diff --git a/new-site/src/components/guarantees.tsx b/src/components/guarantees.tsx similarity index 100% rename from new-site/src/components/guarantees.tsx rename to src/components/guarantees.tsx diff --git a/new-site/src/components/how-i-work.tsx b/src/components/how-i-work.tsx similarity index 100% rename from new-site/src/components/how-i-work.tsx rename to src/components/how-i-work.tsx diff --git a/new-site/src/components/jsonld.tsx b/src/components/jsonld.tsx similarity index 100% rename from new-site/src/components/jsonld.tsx rename to src/components/jsonld.tsx diff --git a/new-site/src/components/pricing-teaser.tsx b/src/components/pricing-teaser.tsx similarity index 100% rename from new-site/src/components/pricing-teaser.tsx rename to src/components/pricing-teaser.tsx diff --git a/new-site/src/components/section-heading.tsx b/src/components/section-heading.tsx similarity index 100% rename from new-site/src/components/section-heading.tsx rename to src/components/section-heading.tsx diff --git a/new-site/src/components/site-footer.tsx b/src/components/site-footer.tsx similarity index 100% rename from new-site/src/components/site-footer.tsx rename to src/components/site-footer.tsx diff --git a/new-site/src/components/site-header.tsx b/src/components/site-header.tsx similarity index 100% rename from new-site/src/components/site-header.tsx rename to src/components/site-header.tsx diff --git a/new-site/src/components/testimonials.tsx b/src/components/testimonials.tsx similarity index 100% rename from new-site/src/components/testimonials.tsx rename to src/components/testimonials.tsx diff --git a/new-site/src/content/blog/how-to-hire-a-php-dev.mdx b/src/content/blog/how-to-hire-a-php-dev.mdx similarity index 100% rename from new-site/src/content/blog/how-to-hire-a-php-dev.mdx rename to src/content/blog/how-to-hire-a-php-dev.mdx diff --git a/new-site/src/content/blog/the-glue-job.mdx b/src/content/blog/the-glue-job.mdx similarity index 100% rename from new-site/src/content/blog/the-glue-job.mdx rename to src/content/blog/the-glue-job.mdx diff --git a/new-site/src/content/blog/three-pl-integration-checklist.mdx b/src/content/blog/three-pl-integration-checklist.mdx similarity index 100% rename from new-site/src/content/blog/three-pl-integration-checklist.mdx rename to src/content/blog/three-pl-integration-checklist.mdx diff --git a/new-site/src/lib/case-studies.ts b/src/lib/case-studies.ts similarity index 100% rename from new-site/src/lib/case-studies.ts rename to src/lib/case-studies.ts diff --git a/new-site/src/lib/cn.ts b/src/lib/cn.ts similarity index 100% rename from new-site/src/lib/cn.ts rename to src/lib/cn.ts diff --git a/new-site/src/lib/jsonld.ts b/src/lib/jsonld.ts similarity index 100% rename from new-site/src/lib/jsonld.ts rename to src/lib/jsonld.ts diff --git a/new-site/src/lib/posts.ts b/src/lib/posts.ts similarity index 100% rename from new-site/src/lib/posts.ts rename to src/lib/posts.ts diff --git a/new-site/src/lib/pricing.ts b/src/lib/pricing.ts similarity index 100% rename from new-site/src/lib/pricing.ts rename to src/lib/pricing.ts diff --git a/new-site/src/lib/site.ts b/src/lib/site.ts similarity index 100% rename from new-site/src/lib/site.ts rename to src/lib/site.ts diff --git a/tailwind.config.js b/tailwind.config.js deleted file mode 100755 index c8754a7..0000000 --- a/tailwind.config.js +++ /dev/null @@ -1,103 +0,0 @@ -const fs = require("fs"); -const path = require("path"); -const themePath = path.join(__dirname, "data/theme.json"); -const themeRead = fs.readFileSync(themePath, "utf8"); -const theme = JSON.parse(themeRead); - -let font_base = Number(theme.fonts.font_size.base.replace("px", "")); -let font_scale = Number(theme.fonts.font_size.scale); -let h6 = font_scale; -let h5 = h6 * font_scale; -let h4 = h5 * font_scale; -let h3 = h4 * font_scale; -let h2 = h3 * font_scale; -let h1 = h2 * font_scale; -let fontPrimary, fontPrimaryType, fontSecondary, fontSecondaryType; -if (theme.fonts.font_family.primary) { - fontPrimary = theme.fonts.font_family.primary - .replace(/\+/g, " ") - .replace(/:[ital,]*[ital@]*[wght@]*[0-9,;.]+/gi, ""); - fontPrimaryType = theme.fonts.font_family.primary_type; -} -if (theme.fonts.font_family.secondary) { - fontSecondary = theme.fonts.font_family.secondary - .replace(/\+/g, " ") - .replace(/:[ital,]*[ital@]*[wght@]*[0-9,;.]+/gi, ""); - fontSecondaryType = theme.fonts.font_family.secondary_type; -} - -/** @type {import('tailwindcss').Config} */ -module.exports = { - content: ["./hugo_stats.json"], - safelist: [{ pattern: /^swiper-/ }], - darkMode: "class", - theme: { - screens: { - sm: "540px", - md: "768px", - lg: "1024px", - xl: "1280px", - "2xl": "1536px", - }, - container: { - center: true, - padding: "2rem", - }, - extend: { - colors: { - text: theme.colors.default.text_color.default, - light: theme.colors.default.text_color.light, - dark: theme.colors.default.text_color.dark, - primary: theme.colors.default.theme_color.primary, - secondary: theme.colors.default.theme_color.secondary, - body: theme.colors.default.theme_color.body, - border: theme.colors.default.theme_color.border, - "theme-light": theme.colors.default.theme_color.theme_light, - "theme-dark": theme.colors.default.theme_color.theme_dark, - darkmode: { - text: theme.colors.darkmode.text_color.default, - light: theme.colors.darkmode.text_color.light, - dark: theme.colors.darkmode.text_color.dark, - primary: theme.colors.darkmode.theme_color.primary, - secondary: theme.colors.darkmode.theme_color.secondary, - body: theme.colors.darkmode.theme_color.body, - border: theme.colors.darkmode.theme_color.border, - "theme-light": theme.colors.darkmode.theme_color.theme_light, - "theme-dark": theme.colors.darkmode.theme_color.theme_dark, - }, - }, - fontSize: { - base: font_base + "px", - "base-sm": font_base * 0.8 + "px", - h1: h1 + "rem", - "h1-sm": h1 * 0.9 + "rem", - h2: h2 + "rem", - "h2-sm": h2 * 0.9 + "rem", - h3: h3 + "rem", - "h3-sm": h3 * 0.9 + "rem", - h4: h4 + "rem", - h5: h5 + "rem", - h6: h6 + "rem", - }, - fontFamily: { - primary: [fontPrimary, fontPrimaryType], - secondary: [fontSecondary, fontSecondaryType], - }, - }, - }, - plugins: [ - require("@tailwindcss/typography"), - require("@tailwindcss/forms"), - require("tailwind-bootstrap-grid")({ - generateContainer: false, - gridGutterWidth: "2rem", - gridGutters: { - 1: "0.25rem", - 2: "0.5rem", - 3: "1rem", - 4: "1.5rem", - 5: "3rem", - }, - }), - ], -}; diff --git a/theme.toml b/theme.toml deleted file mode 100644 index 959881d..0000000 --- a/theme.toml +++ /dev/null @@ -1,29 +0,0 @@ -name = "Five Devs" -license = "MIT" -licenselink = "https://github.com/zeon-studio/hugoplate/blob/main/LICENSE" -description = "Hugoplate is a free starter template built with Hugo, and TailwindCSS, providing everything you need to jumpstart your Hugo project and save valuable time." -homepage = "https://github.com/zeon-studio/hugoplate" -demosite = "https://zeon.studio/preview?project=hugoplate" -min_version = "0.134.3" - -tags = [ - "blog", - "responsive", - "minimal", - "personal", - "light", - "dark", - "multilingual", - "landing", - "contact", - "dark mode", - "tailwindcss", -] - -features = [ - "Multi-Authors", - "Search", - "Multilingual", - "Dark Mode", - "Taxonomies", -] diff --git a/themes/hugoplate/assets/js/main.js b/themes/hugoplate/assets/js/main.js deleted file mode 100755 index 73fa884..0000000 --- a/themes/hugoplate/assets/js/main.js +++ /dev/null @@ -1,36 +0,0 @@ -// main script -(function () { - "use strict"; - - // Dropdown Menu Toggler For Mobile - // ---------------------------------------- - const dropdownMenuToggler = document.querySelectorAll( - ".nav-dropdown > .nav-link", - ); - - dropdownMenuToggler.forEach((toggler) => { - toggler?.addEventListener("click", (e) => { - e.target.parentElement.classList.toggle("active"); - }); - }); - - // Testimonial Slider - // ---------------------------------------- - new Swiper(".testimonial-slider", { - spaceBetween: 24, - loop: true, - pagination: { - el: ".testimonial-slider-pagination", - type: "bullets", - clickable: true, - }, - breakpoints: { - 768: { - slidesPerView: 2, - }, - 992: { - slidesPerView: 3, - }, - }, - }); -})(); diff --git a/themes/hugoplate/assets/plugins/maps/google-map.js b/themes/hugoplate/assets/plugins/maps/google-map.js deleted file mode 100644 index 884b5b1..0000000 --- a/themes/hugoplate/assets/plugins/maps/google-map.js +++ /dev/null @@ -1,179 +0,0 @@ -/*!*************************************************** - * Google Map - *****************************************************/ - -window.marker = null; - -function initialize() { - var map, - mapId = document.getElementById("map"); - var latitude = mapId.getAttribute("data-latitude"); - var longitude = mapId.getAttribute("data-longitude"); - var mapMarker = mapId.getAttribute("data-marker"); - var mapMarkerName = mapId.getAttribute("data-marker-name"); - var nottingham = new google.maps.LatLng(latitude, longitude); - var style = [ - { - featureType: "administrative", - elementType: "all", - stylers: [ - { - saturation: "-100", - }, - ], - }, - { - featureType: "administrative.province", - elementType: "all", - stylers: [ - { - visibility: "off", - }, - ], - }, - { - featureType: "landscape", - elementType: "all", - stylers: [ - { - saturation: -100, - }, - { - lightness: 65, - }, - { - visibility: "on", - }, - ], - }, - { - featureType: "poi", - elementType: "all", - stylers: [ - { - saturation: -100, - }, - { - lightness: "50", - }, - { - visibility: "simplified", - }, - ], - }, - { - featureType: "road", - elementType: "all", - stylers: [ - { - saturation: "-100", - }, - ], - }, - { - featureType: "road.highway", - elementType: "all", - stylers: [ - { - visibility: "simplified", - }, - ], - }, - { - featureType: "road.arterial", - elementType: "all", - stylers: [ - { - lightness: "30", - }, - ], - }, - { - featureType: "road.local", - elementType: "all", - stylers: [ - { - lightness: "40", - }, - ], - }, - { - featureType: "transit", - elementType: "all", - stylers: [ - { - saturation: -100, - }, - { - visibility: "simplified", - }, - ], - }, - { - featureType: "water", - elementType: "geometry", - stylers: [ - { - hue: "#ffff00", - }, - { - lightness: -25, - }, - { - saturation: -97, - }, - ], - }, - { - featureType: "water", - elementType: "labels", - stylers: [ - { - lightness: -25, - }, - { - saturation: -100, - }, - ], - }, - ]; - var mapOptions = { - center: nottingham, - mapTypeId: google.maps.MapTypeId.ROADMAP, - backgroundColor: "#000", - zoom: 15, - panControl: !1, - zoomControl: !0, - mapTypeControl: !1, - scaleControl: !1, - streetViewControl: !1, - overviewMapControl: !1, - zoomControlOptions: { - style: google.maps.ZoomControlStyle.LARGE, - }, - }; - map = new google.maps.Map(document.getElementById("map"), mapOptions); - var mapType = new google.maps.StyledMapType(style, { - name: "Grayscale", - }); - map.mapTypes.set("grey", mapType); - map.setMapTypeId("grey"); - var marker_image = mapMarker; - var pinIcon = new google.maps.MarkerImage( - marker_image, - null, - null, - null, - new google.maps.Size(30, 50), - ); - marker = new google.maps.Marker({ - position: nottingham, - map: map, - icon: pinIcon, - title: mapMarkerName, - }); -} -var map = document.getElementById("map"); -if (map != null) { - google.maps.event.addDomListener(window, "load", initialize); -} diff --git a/themes/hugoplate/assets/plugins/swiper/swiper-bundle.css b/themes/hugoplate/assets/plugins/swiper/swiper-bundle.css deleted file mode 100644 index 6f0c194..0000000 --- a/themes/hugoplate/assets/plugins/swiper/swiper-bundle.css +++ /dev/null @@ -1,667 +0,0 @@ -/** - * Swiper 8.0.7 - * Most modern mobile touch slider and framework with hardware accelerated transitions - * https://swiperjs.com - * - * Copyright 2014-2022 Vladimir Kharlampidi - * - * Released under the MIT License - * - * Released on: March 4, 2022 - */ - -@font-face { - font-family: "swiper-icons"; - src: url("data:application/font-woff;charset=utf-8;base64, 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"); - font-weight: 400; - font-style: normal; -} -:root { - --swiper-theme-color: #007aff; -} -.swiper { - margin-left: auto; - margin-right: auto; - position: relative; - overflow: hidden; - list-style: none; - padding: 0; - /* Fix of Webkit flickering */ - z-index: 1; -} -.swiper-vertical > .swiper-wrapper { - flex-direction: column; -} -.swiper-wrapper { - position: relative; - width: 100%; - height: 100%; - z-index: 1; - display: flex; - transition-property: transform; - box-sizing: content-box; -} -.swiper-android .swiper-slide, -.swiper-wrapper { - transform: translate3d(0px, 0, 0); -} -.swiper-pointer-events { - touch-action: pan-y; -} -.swiper-pointer-events.swiper-vertical { - touch-action: pan-x; -} -.swiper-slide { - flex-shrink: 0; - width: 100%; - height: 100%; - position: relative; - transition-property: transform; -} -.swiper-slide-invisible-blank { - visibility: hidden; -} -/* Auto Height */ -.swiper-autoheight, -.swiper-autoheight .swiper-slide { - height: auto; -} -.swiper-autoheight .swiper-wrapper { - align-items: flex-start; - transition-property: transform, height; -} -.swiper-backface-hidden .swiper-slide { - transform: translateZ(0); - -webkit-backface-visibility: hidden; - backface-visibility: hidden; -} -/* 3D Effects */ -.swiper-3d, -.swiper-3d.swiper-css-mode .swiper-wrapper { - perspective: 1200px; -} -.swiper-3d .swiper-wrapper, -.swiper-3d .swiper-slide, -.swiper-3d .swiper-slide-shadow, -.swiper-3d .swiper-slide-shadow-left, -.swiper-3d .swiper-slide-shadow-right, -.swiper-3d .swiper-slide-shadow-top, -.swiper-3d .swiper-slide-shadow-bottom, -.swiper-3d .swiper-cube-shadow { - transform-style: preserve-3d; -} -.swiper-3d .swiper-slide-shadow, -.swiper-3d .swiper-slide-shadow-left, -.swiper-3d .swiper-slide-shadow-right, -.swiper-3d .swiper-slide-shadow-top, -.swiper-3d .swiper-slide-shadow-bottom { - position: absolute; - left: 0; - top: 0; - width: 100%; - height: 100%; - pointer-events: none; - z-index: 10; -} -.swiper-3d .swiper-slide-shadow { - background: rgba(0, 0, 0, 0.15); -} -.swiper-3d .swiper-slide-shadow-left { - background-image: linear-gradient( - to left, - rgba(0, 0, 0, 0.5), - rgba(0, 0, 0, 0) - ); -} -.swiper-3d .swiper-slide-shadow-right { - background-image: linear-gradient( - to right, - rgba(0, 0, 0, 0.5), - rgba(0, 0, 0, 0) - ); -} -.swiper-3d .swiper-slide-shadow-top { - background-image: linear-gradient( - to top, - rgba(0, 0, 0, 0.5), - rgba(0, 0, 0, 0) - ); -} -.swiper-3d .swiper-slide-shadow-bottom { - background-image: linear-gradient( - to bottom, - rgba(0, 0, 0, 0.5), - rgba(0, 0, 0, 0) - ); -} -/* CSS Mode */ -.swiper-css-mode > .swiper-wrapper { - overflow: auto; - scrollbar-width: none; - /* For Firefox */ - -ms-overflow-style: none; - /* For Internet Explorer and Edge */ -} -.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar { - display: none; -} -.swiper-css-mode > .swiper-wrapper > .swiper-slide { - scroll-snap-align: start start; -} -.swiper-horizontal.swiper-css-mode > .swiper-wrapper { - scroll-snap-type: x mandatory; -} -.swiper-vertical.swiper-css-mode > .swiper-wrapper { - scroll-snap-type: y mandatory; -} -.swiper-centered > .swiper-wrapper::before { - content: ""; - flex-shrink: 0; - order: 9999; -} -.swiper-centered.swiper-horizontal - > .swiper-wrapper - > .swiper-slide:first-child { - margin-inline-start: var(--swiper-centered-offset-before); -} -.swiper-centered.swiper-horizontal > .swiper-wrapper::before { - height: 100%; - min-height: 1px; - width: var(--swiper-centered-offset-after); -} -.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child { - margin-block-start: var(--swiper-centered-offset-before); -} -.swiper-centered.swiper-vertical > .swiper-wrapper::before { - width: 100%; - min-width: 1px; - height: var(--swiper-centered-offset-after); -} -.swiper-centered > .swiper-wrapper > .swiper-slide { - scroll-snap-align: center center; -} -.swiper-virtual .swiper-slide { - -webkit-backface-visibility: hidden; - transform: translateZ(0); -} -.swiper-virtual.swiper-css-mode .swiper-wrapper::after { - content: ""; - position: absolute; - left: 0; - top: 0; - pointer-events: none; -} -.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after { - height: 1px; - width: var(--swiper-virtual-size); -} -.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after { - width: 1px; - height: var(--swiper-virtual-size); -} -:root { - --swiper-navigation-size: 44px; - /* - --swiper-navigation-color: var(--swiper-theme-color); - */ -} -.swiper-button-prev, -.swiper-button-next { - position: absolute; - top: 50%; - width: calc(var(--swiper-navigation-size) / 44 * 27); - height: var(--swiper-navigation-size); - margin-top: calc(0px - (var(--swiper-navigation-size) / 2)); - z-index: 10; - cursor: pointer; - display: flex; - align-items: center; - justify-content: center; - color: var(--swiper-navigation-color, var(--swiper-theme-color)); -} -.swiper-button-prev.swiper-button-disabled, -.swiper-button-next.swiper-button-disabled { - opacity: 0.35; - cursor: auto; - pointer-events: none; -} -.swiper-button-prev:after, -.swiper-button-next:after { - font-family: swiper-icons; - font-size: var(--swiper-navigation-size); - text-transform: none !important; - letter-spacing: 0; - text-transform: none; - font-variant: initial; - line-height: 1; -} -.swiper-button-prev, -.swiper-rtl .swiper-button-next { - left: 10px; - right: auto; -} -.swiper-button-prev:after, -.swiper-rtl .swiper-button-next:after { - content: "prev"; -} -.swiper-button-next, -.swiper-rtl .swiper-button-prev { - right: 10px; - left: auto; -} -.swiper-button-next:after, -.swiper-rtl .swiper-button-prev:after { - content: "next"; -} -.swiper-button-lock { - display: none; -} -:root { - /* - --swiper-pagination-color: var(--swiper-theme-color); - --swiper-pagination-bullet-size: 8px; - --swiper-pagination-bullet-width: 8px; - --swiper-pagination-bullet-height: 8px; - --swiper-pagination-bullet-inactive-color: #000; - --swiper-pagination-bullet-inactive-opacity: 0.2; - --swiper-pagination-bullet-opacity: 1; - --swiper-pagination-bullet-horizontal-gap: 4px; - --swiper-pagination-bullet-vertical-gap: 6px; - */ -} -.swiper-pagination { - position: absolute; - text-align: center; - transition: 300ms opacity; - transform: translate3d(0, 0, 0); - z-index: 10; -} -.swiper-pagination.swiper-pagination-hidden { - opacity: 0; -} -/* Common Styles */ -.swiper-pagination-fraction, -.swiper-pagination-custom, -.swiper-horizontal > .swiper-pagination-bullets, -.swiper-pagination-bullets.swiper-pagination-horizontal { - bottom: 10px; - left: 0; - width: 100%; -} -/* Bullets */ -.swiper-pagination-bullets-dynamic { - overflow: hidden; - font-size: 0; -} -.swiper-pagination-bullets-dynamic .swiper-pagination-bullet { - transform: scale(0.33); - position: relative; -} -.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active { - transform: scale(1); -} -.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main { - transform: scale(1); -} -.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev { - transform: scale(0.66); -} -.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev { - transform: scale(0.33); -} -.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next { - transform: scale(0.66); -} -.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next { - transform: scale(0.33); -} -.swiper-pagination-bullet { - width: var( - --swiper-pagination-bullet-width, - var(--swiper-pagination-bullet-size, 8px) - ); - height: var( - --swiper-pagination-bullet-height, - var(--swiper-pagination-bullet-size, 8px) - ); - display: inline-block; - border-radius: 50%; - background: var(--swiper-pagination-bullet-inactive-color, #000); - opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2); -} -button.swiper-pagination-bullet { - border: none; - margin: 0; - padding: 0; - box-shadow: none; - -webkit-appearance: none; - appearance: none; -} -.swiper-pagination-clickable .swiper-pagination-bullet { - cursor: pointer; -} -.swiper-pagination-bullet:only-child { - display: none !important; -} -.swiper-pagination-bullet-active { - opacity: var(--swiper-pagination-bullet-opacity, 1); - background: var(--swiper-pagination-color, var(--swiper-theme-color)); -} -.swiper-vertical > .swiper-pagination-bullets, -.swiper-pagination-vertical.swiper-pagination-bullets { - right: 10px; - top: 50%; - transform: translate3d(0px, -50%, 0); -} -.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet, -.swiper-pagination-vertical.swiper-pagination-bullets - .swiper-pagination-bullet { - margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0; - display: block; -} -.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, -.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic { - top: 50%; - transform: translateY(-50%); - width: 8px; -} -.swiper-vertical - > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic - .swiper-pagination-bullet, -.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic - .swiper-pagination-bullet { - display: inline-block; - transition: - 200ms transform, - 200ms top; -} -.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, -.swiper-pagination-horizontal.swiper-pagination-bullets - .swiper-pagination-bullet { - margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px); -} -.swiper-horizontal - > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, -.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic { - left: 50%; - transform: translateX(-50%); - white-space: nowrap; -} -.swiper-horizontal - > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic - .swiper-pagination-bullet, -.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic - .swiper-pagination-bullet { - transition: - 200ms transform, - 200ms left; -} -.swiper-horizontal.swiper-rtl - > .swiper-pagination-bullets-dynamic - .swiper-pagination-bullet { - transition: - 200ms transform, - 200ms right; -} -/* Progress */ -.swiper-pagination-progressbar { - background: rgba(0, 0, 0, 0.25); - position: absolute; -} -.swiper-pagination-progressbar .swiper-pagination-progressbar-fill { - background: var(--swiper-pagination-color, var(--swiper-theme-color)); - position: absolute; - left: 0; - top: 0; - width: 100%; - height: 100%; - transform: scale(0); - transform-origin: left top; -} -.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill { - transform-origin: right top; -} -.swiper-horizontal > .swiper-pagination-progressbar, -.swiper-pagination-progressbar.swiper-pagination-horizontal, -.swiper-vertical - > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, -.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite { - width: 100%; - height: 4px; - left: 0; - top: 0; -} -.swiper-vertical > .swiper-pagination-progressbar, -.swiper-pagination-progressbar.swiper-pagination-vertical, -.swiper-horizontal - > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, -.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite { - width: 4px; - height: 100%; - left: 0; - top: 0; -} -.swiper-pagination-lock { - display: none; -} -/* Scrollbar */ -.swiper-scrollbar { - border-radius: 10px; - position: relative; - -ms-touch-action: none; - background: rgba(0, 0, 0, 0.1); -} -.swiper-horizontal > .swiper-scrollbar { - position: absolute; - left: 1%; - bottom: 3px; - z-index: 50; - height: 5px; - width: 98%; -} -.swiper-vertical > .swiper-scrollbar { - position: absolute; - right: 3px; - top: 1%; - z-index: 50; - width: 5px; - height: 98%; -} -.swiper-scrollbar-drag { - height: 100%; - width: 100%; - position: relative; - background: rgba(0, 0, 0, 0.5); - border-radius: 10px; - left: 0; - top: 0; -} -.swiper-scrollbar-cursor-drag { - cursor: move; -} -.swiper-scrollbar-lock { - display: none; -} -.swiper-zoom-container { - width: 100%; - height: 100%; - display: flex; - justify-content: center; - align-items: center; - text-align: center; -} -.swiper-zoom-container > img, -.swiper-zoom-container > svg, -.swiper-zoom-container > canvas { - max-width: 100%; - max-height: 100%; - object-fit: contain; -} -.swiper-slide-zoomed { - cursor: move; -} -/* Preloader */ -:root { - /* - --swiper-preloader-color: var(--swiper-theme-color); - */ -} -.swiper-lazy-preloader { - width: 42px; - height: 42px; - position: absolute; - left: 50%; - top: 50%; - margin-left: -21px; - margin-top: -21px; - z-index: 10; - transform-origin: 50%; - box-sizing: border-box; - border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color)); - border-radius: 50%; - border-top-color: transparent; -} -.swiper-slide-visible .swiper-lazy-preloader { - animation: swiper-preloader-spin 1s infinite linear; -} -.swiper-lazy-preloader-white { - --swiper-preloader-color: #fff; -} -.swiper-lazy-preloader-black { - --swiper-preloader-color: #000; -} -@keyframes swiper-preloader-spin { - 100% { - transform: rotate(360deg); - } -} -/* a11y */ -.swiper .swiper-notification { - position: absolute; - left: 0; - top: 0; - pointer-events: none; - opacity: 0; - z-index: -1000; -} -.swiper-free-mode > .swiper-wrapper { - transition-timing-function: ease-out; - margin: 0 auto; -} -.swiper-grid > .swiper-wrapper { - flex-wrap: wrap; -} -.swiper-grid-column > .swiper-wrapper { - flex-wrap: wrap; - flex-direction: column; -} -.swiper-fade.swiper-free-mode .swiper-slide { - transition-timing-function: ease-out; -} -.swiper-fade .swiper-slide { - pointer-events: none; - transition-property: opacity; -} -.swiper-fade .swiper-slide .swiper-slide { - pointer-events: none; -} -.swiper-fade .swiper-slide-active, -.swiper-fade .swiper-slide-active .swiper-slide-active { - pointer-events: auto; -} -.swiper-cube { - overflow: visible; -} -.swiper-cube .swiper-slide { - pointer-events: none; - -webkit-backface-visibility: hidden; - backface-visibility: hidden; - z-index: 1; - visibility: hidden; - transform-origin: 0 0; - width: 100%; - height: 100%; -} -.swiper-cube .swiper-slide .swiper-slide { - pointer-events: none; -} -.swiper-cube.swiper-rtl .swiper-slide { - transform-origin: 100% 0; -} -.swiper-cube .swiper-slide-active, -.swiper-cube .swiper-slide-active .swiper-slide-active { - pointer-events: auto; -} -.swiper-cube .swiper-slide-active, -.swiper-cube .swiper-slide-next, -.swiper-cube .swiper-slide-prev, -.swiper-cube .swiper-slide-next + .swiper-slide { - pointer-events: auto; - visibility: visible; -} -.swiper-cube .swiper-slide-shadow-top, -.swiper-cube .swiper-slide-shadow-bottom, -.swiper-cube .swiper-slide-shadow-left, -.swiper-cube .swiper-slide-shadow-right { - z-index: 0; - -webkit-backface-visibility: hidden; - backface-visibility: hidden; -} -.swiper-cube .swiper-cube-shadow { - position: absolute; - left: 0; - bottom: 0px; - width: 100%; - height: 100%; - opacity: 0.6; - z-index: 0; -} -.swiper-cube .swiper-cube-shadow:before { - content: ""; - background: #000; - position: absolute; - left: 0; - top: 0; - bottom: 0; - right: 0; - filter: blur(50px); -} -.swiper-flip { - overflow: visible; -} -.swiper-flip .swiper-slide { - pointer-events: none; - -webkit-backface-visibility: hidden; - backface-visibility: hidden; - z-index: 1; -} -.swiper-flip .swiper-slide .swiper-slide { - pointer-events: none; -} -.swiper-flip .swiper-slide-active, -.swiper-flip .swiper-slide-active .swiper-slide-active { - pointer-events: auto; -} -.swiper-flip .swiper-slide-shadow-top, -.swiper-flip .swiper-slide-shadow-bottom, -.swiper-flip .swiper-slide-shadow-left, -.swiper-flip .swiper-slide-shadow-right { - z-index: 0; - -webkit-backface-visibility: hidden; - backface-visibility: hidden; -} -.swiper-creative .swiper-slide { - -webkit-backface-visibility: hidden; - backface-visibility: hidden; - overflow: hidden; - transition-property: transform, opacity, height; -} -.swiper-cards { - overflow: visible; -} -.swiper-cards .swiper-slide { - transform-origin: center bottom; - -webkit-backface-visibility: hidden; - backface-visibility: hidden; - overflow: hidden; -} diff --git a/themes/hugoplate/assets/plugins/swiper/swiper-bundle.js b/themes/hugoplate/assets/plugins/swiper/swiper-bundle.js deleted file mode 100644 index 9c90ea5..0000000 --- a/themes/hugoplate/assets/plugins/swiper/swiper-bundle.js +++ /dev/null @@ -1,11853 +0,0 @@ -/** - * Swiper 8.0.7 - * Most modern mobile touch slider and framework with hardware accelerated transitions - * https://swiperjs.com - * - * Copyright 2014-2022 Vladimir Kharlampidi - * - * Released under the MIT License - * - * Released on: March 4, 2022 - */ - -(function (global, factory) { - typeof exports === "object" && typeof module !== "undefined" - ? (module.exports = factory()) - : typeof define === "function" && define.amd - ? define(factory) - : ((global = - typeof globalThis !== "undefined" ? globalThis : global || self), - (global.Swiper = factory())); -})(this, function () { - "use strict"; - - /** - * SSR Window 4.0.2 - * Better handling for window object in SSR environment - * https://github.com/nolimits4web/ssr-window - * - * Copyright 2021, Vladimir Kharlampidi - * - * Licensed under MIT - * - * Released on: December 13, 2021 - */ - - /* eslint-disable no-param-reassign */ - function isObject$1(obj) { - return ( - obj !== null && - typeof obj === "object" && - "constructor" in obj && - obj.constructor === Object - ); - } - - function extend$1(target, src) { - if (target === void 0) { - target = {}; - } - - if (src === void 0) { - src = {}; - } - - Object.keys(src).forEach((key) => { - if (typeof target[key] === "undefined") target[key] = src[key]; - else if ( - isObject$1(src[key]) && - isObject$1(target[key]) && - Object.keys(src[key]).length > 0 - ) { - extend$1(target[key], src[key]); - } - }); - } - - const ssrDocument = { - body: {}, - - addEventListener() {}, - - removeEventListener() {}, - - activeElement: { - blur() {}, - - nodeName: "", - }, - - querySelector() { - return null; - }, - - querySelectorAll() { - return []; - }, - - getElementById() { - return null; - }, - - createEvent() { - return { - initEvent() {}, - }; - }, - - createElement() { - return { - children: [], - childNodes: [], - style: {}, - - setAttribute() {}, - - getElementsByTagName() { - return []; - }, - }; - }, - - createElementNS() { - return {}; - }, - - importNode() { - return null; - }, - - location: { - hash: "", - host: "", - hostname: "", - href: "", - origin: "", - pathname: "", - protocol: "", - search: "", - }, - }; - - function getDocument() { - const doc = typeof document !== "undefined" ? document : {}; - extend$1(doc, ssrDocument); - return doc; - } - - const ssrWindow = { - document: ssrDocument, - navigator: { - userAgent: "", - }, - location: { - hash: "", - host: "", - hostname: "", - href: "", - origin: "", - pathname: "", - protocol: "", - search: "", - }, - history: { - replaceState() {}, - - pushState() {}, - - go() {}, - - back() {}, - }, - CustomEvent: function CustomEvent() { - return this; - }, - - addEventListener() {}, - - removeEventListener() {}, - - getComputedStyle() { - return { - getPropertyValue() { - return ""; - }, - }; - }, - - Image() {}, - - Date() {}, - - screen: {}, - - setTimeout() {}, - - clearTimeout() {}, - - matchMedia() { - return {}; - }, - - requestAnimationFrame(callback) { - if (typeof setTimeout === "undefined") { - callback(); - return null; - } - - return setTimeout(callback, 0); - }, - - cancelAnimationFrame(id) { - if (typeof setTimeout === "undefined") { - return; - } - - clearTimeout(id); - }, - }; - - function getWindow() { - const win = typeof window !== "undefined" ? window : {}; - extend$1(win, ssrWindow); - return win; - } - - /** - * Dom7 4.0.4 - * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API - * https://framework7.io/docs/dom7.html - * - * Copyright 2022, Vladimir Kharlampidi - * - * Licensed under MIT - * - * Released on: January 11, 2022 - */ - /* eslint-disable no-proto */ - - function makeReactive(obj) { - const proto = obj.__proto__; - Object.defineProperty(obj, "__proto__", { - get() { - return proto; - }, - - set(value) { - proto.__proto__ = value; - }, - }); - } - - class Dom7 extends Array { - constructor(items) { - if (typeof items === "number") { - super(items); - } else { - super(...(items || [])); - makeReactive(this); - } - } - } - - function arrayFlat(arr) { - if (arr === void 0) { - arr = []; - } - - const res = []; - arr.forEach((el) => { - if (Array.isArray(el)) { - res.push(...arrayFlat(el)); - } else { - res.push(el); - } - }); - return res; - } - - function arrayFilter(arr, callback) { - return Array.prototype.filter.call(arr, callback); - } - - function arrayUnique(arr) { - const uniqueArray = []; - - for (let i = 0; i < arr.length; i += 1) { - if (uniqueArray.indexOf(arr[i]) === -1) uniqueArray.push(arr[i]); - } - - return uniqueArray; - } - - function qsa(selector, context) { - if (typeof selector !== "string") { - return [selector]; - } - - const a = []; - const res = context.querySelectorAll(selector); - - for (let i = 0; i < res.length; i += 1) { - a.push(res[i]); - } - - return a; - } - - function $(selector, context) { - const window = getWindow(); - const document = getDocument(); - let arr = []; - - if (!context && selector instanceof Dom7) { - return selector; - } - - if (!selector) { - return new Dom7(arr); - } - - if (typeof selector === "string") { - const html = selector.trim(); - - if (html.indexOf("<") >= 0 && html.indexOf(">") >= 0) { - let toCreate = "div"; - if (html.indexOf(" c.split(" "))); - this.forEach((el) => { - el.classList.add(...classNames); - }); - return this; - } - - function removeClass() { - for ( - var _len2 = arguments.length, classes = new Array(_len2), _key2 = 0; - _key2 < _len2; - _key2++ - ) { - classes[_key2] = arguments[_key2]; - } - - const classNames = arrayFlat(classes.map((c) => c.split(" "))); - this.forEach((el) => { - el.classList.remove(...classNames); - }); - return this; - } - - function toggleClass() { - for ( - var _len3 = arguments.length, classes = new Array(_len3), _key3 = 0; - _key3 < _len3; - _key3++ - ) { - classes[_key3] = arguments[_key3]; - } - - const classNames = arrayFlat(classes.map((c) => c.split(" "))); - this.forEach((el) => { - classNames.forEach((className) => { - el.classList.toggle(className); - }); - }); - } - - function hasClass() { - for ( - var _len4 = arguments.length, classes = new Array(_len4), _key4 = 0; - _key4 < _len4; - _key4++ - ) { - classes[_key4] = arguments[_key4]; - } - - const classNames = arrayFlat(classes.map((c) => c.split(" "))); - return ( - arrayFilter(this, (el) => { - return ( - classNames.filter((className) => el.classList.contains(className)) - .length > 0 - ); - }).length > 0 - ); - } - - function attr(attrs, value) { - if (arguments.length === 1 && typeof attrs === "string") { - // Get attr - if (this[0]) return this[0].getAttribute(attrs); - return undefined; - } // Set attrs - - for (let i = 0; i < this.length; i += 1) { - if (arguments.length === 2) { - // String - this[i].setAttribute(attrs, value); - } else { - // Object - for (const attrName in attrs) { - this[i][attrName] = attrs[attrName]; - this[i].setAttribute(attrName, attrs[attrName]); - } - } - } - - return this; - } - - function removeAttr(attr) { - for (let i = 0; i < this.length; i += 1) { - this[i].removeAttribute(attr); - } - - return this; - } - - function transform(transform) { - for (let i = 0; i < this.length; i += 1) { - this[i].style.transform = transform; - } - - return this; - } - - function transition$1(duration) { - for (let i = 0; i < this.length; i += 1) { - this[i].style.transitionDuration = - typeof duration !== "string" ? `${duration}ms` : duration; - } - - return this; - } - - function on() { - for ( - var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; - _key5 < _len5; - _key5++ - ) { - args[_key5] = arguments[_key5]; - } - - let [eventType, targetSelector, listener, capture] = args; - - if (typeof args[1] === "function") { - [eventType, listener, capture] = args; - targetSelector = undefined; - } - - if (!capture) capture = false; - - function handleLiveEvent(e) { - const target = e.target; - if (!target) return; - const eventData = e.target.dom7EventData || []; - - if (eventData.indexOf(e) < 0) { - eventData.unshift(e); - } - - if ($(target).is(targetSelector)) listener.apply(target, eventData); - else { - const parents = $(target).parents(); // eslint-disable-line - - for (let k = 0; k < parents.length; k += 1) { - if ($(parents[k]).is(targetSelector)) - listener.apply(parents[k], eventData); - } - } - } - - function handleEvent(e) { - const eventData = e && e.target ? e.target.dom7EventData || [] : []; - - if (eventData.indexOf(e) < 0) { - eventData.unshift(e); - } - - listener.apply(this, eventData); - } - - const events = eventType.split(" "); - let j; - - for (let i = 0; i < this.length; i += 1) { - const el = this[i]; - - if (!targetSelector) { - for (j = 0; j < events.length; j += 1) { - const event = events[j]; - if (!el.dom7Listeners) el.dom7Listeners = {}; - if (!el.dom7Listeners[event]) el.dom7Listeners[event] = []; - el.dom7Listeners[event].push({ - listener, - proxyListener: handleEvent, - }); - el.addEventListener(event, handleEvent, capture); - } - } else { - // Live events - for (j = 0; j < events.length; j += 1) { - const event = events[j]; - if (!el.dom7LiveListeners) el.dom7LiveListeners = {}; - if (!el.dom7LiveListeners[event]) el.dom7LiveListeners[event] = []; - el.dom7LiveListeners[event].push({ - listener, - proxyListener: handleLiveEvent, - }); - el.addEventListener(event, handleLiveEvent, capture); - } - } - } - - return this; - } - - function off() { - for ( - var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; - _key6 < _len6; - _key6++ - ) { - args[_key6] = arguments[_key6]; - } - - let [eventType, targetSelector, listener, capture] = args; - - if (typeof args[1] === "function") { - [eventType, listener, capture] = args; - targetSelector = undefined; - } - - if (!capture) capture = false; - const events = eventType.split(" "); - - for (let i = 0; i < events.length; i += 1) { - const event = events[i]; - - for (let j = 0; j < this.length; j += 1) { - const el = this[j]; - let handlers; - - if (!targetSelector && el.dom7Listeners) { - handlers = el.dom7Listeners[event]; - } else if (targetSelector && el.dom7LiveListeners) { - handlers = el.dom7LiveListeners[event]; - } - - if (handlers && handlers.length) { - for (let k = handlers.length - 1; k >= 0; k -= 1) { - const handler = handlers[k]; - - if (listener && handler.listener === listener) { - el.removeEventListener(event, handler.proxyListener, capture); - handlers.splice(k, 1); - } else if ( - listener && - handler.listener && - handler.listener.dom7proxy && - handler.listener.dom7proxy === listener - ) { - el.removeEventListener(event, handler.proxyListener, capture); - handlers.splice(k, 1); - } else if (!listener) { - el.removeEventListener(event, handler.proxyListener, capture); - handlers.splice(k, 1); - } - } - } - } - } - - return this; - } - - function trigger() { - const window = getWindow(); - - for ( - var _len9 = arguments.length, args = new Array(_len9), _key9 = 0; - _key9 < _len9; - _key9++ - ) { - args[_key9] = arguments[_key9]; - } - - const events = args[0].split(" "); - const eventData = args[1]; - - for (let i = 0; i < events.length; i += 1) { - const event = events[i]; - - for (let j = 0; j < this.length; j += 1) { - const el = this[j]; - - if (window.CustomEvent) { - const evt = new window.CustomEvent(event, { - detail: eventData, - bubbles: true, - cancelable: true, - }); - el.dom7EventData = args.filter((data, dataIndex) => dataIndex > 0); - el.dispatchEvent(evt); - el.dom7EventData = []; - delete el.dom7EventData; - } - } - } - - return this; - } - - function transitionEnd$1(callback) { - const dom = this; - - function fireCallBack(e) { - if (e.target !== this) return; - callback.call(this, e); - dom.off("transitionend", fireCallBack); - } - - if (callback) { - dom.on("transitionend", fireCallBack); - } - - return this; - } - - function outerWidth(includeMargins) { - if (this.length > 0) { - if (includeMargins) { - const styles = this.styles(); - return ( - this[0].offsetWidth + - parseFloat(styles.getPropertyValue("margin-right")) + - parseFloat(styles.getPropertyValue("margin-left")) - ); - } - - return this[0].offsetWidth; - } - - return null; - } - - function outerHeight(includeMargins) { - if (this.length > 0) { - if (includeMargins) { - const styles = this.styles(); - return ( - this[0].offsetHeight + - parseFloat(styles.getPropertyValue("margin-top")) + - parseFloat(styles.getPropertyValue("margin-bottom")) - ); - } - - return this[0].offsetHeight; - } - - return null; - } - - function offset() { - if (this.length > 0) { - const window = getWindow(); - const document = getDocument(); - const el = this[0]; - const box = el.getBoundingClientRect(); - const body = document.body; - const clientTop = el.clientTop || body.clientTop || 0; - const clientLeft = el.clientLeft || body.clientLeft || 0; - const scrollTop = el === window ? window.scrollY : el.scrollTop; - const scrollLeft = el === window ? window.scrollX : el.scrollLeft; - return { - top: box.top + scrollTop - clientTop, - left: box.left + scrollLeft - clientLeft, - }; - } - - return null; - } - - function styles() { - const window = getWindow(); - if (this[0]) return window.getComputedStyle(this[0], null); - return {}; - } - - function css(props, value) { - const window = getWindow(); - let i; - - if (arguments.length === 1) { - if (typeof props === "string") { - // .css('width') - if (this[0]) - return window.getComputedStyle(this[0], null).getPropertyValue(props); - } else { - // .css({ width: '100px' }) - for (i = 0; i < this.length; i += 1) { - for (const prop in props) { - this[i].style[prop] = props[prop]; - } - } - - return this; - } - } - - if (arguments.length === 2 && typeof props === "string") { - // .css('width', '100px') - for (i = 0; i < this.length; i += 1) { - this[i].style[props] = value; - } - - return this; - } - - return this; - } - - function each(callback) { - if (!callback) return this; - this.forEach((el, index) => { - callback.apply(el, [el, index]); - }); - return this; - } - - function filter(callback) { - const result = arrayFilter(this, callback); - return $(result); - } - - function html(html) { - if (typeof html === "undefined") { - return this[0] ? this[0].innerHTML : null; - } - - for (let i = 0; i < this.length; i += 1) { - this[i].innerHTML = html; - } - - return this; - } - - function text(text) { - if (typeof text === "undefined") { - return this[0] ? this[0].textContent.trim() : null; - } - - for (let i = 0; i < this.length; i += 1) { - this[i].textContent = text; - } - - return this; - } - - function is(selector) { - const window = getWindow(); - const document = getDocument(); - const el = this[0]; - let compareWith; - let i; - if (!el || typeof selector === "undefined") return false; - - if (typeof selector === "string") { - if (el.matches) return el.matches(selector); - if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector); - if (el.msMatchesSelector) return el.msMatchesSelector(selector); - compareWith = $(selector); - - for (i = 0; i < compareWith.length; i += 1) { - if (compareWith[i] === el) return true; - } - - return false; - } - - if (selector === document) { - return el === document; - } - - if (selector === window) { - return el === window; - } - - if (selector.nodeType || selector instanceof Dom7) { - compareWith = selector.nodeType ? [selector] : selector; - - for (i = 0; i < compareWith.length; i += 1) { - if (compareWith[i] === el) return true; - } - - return false; - } - - return false; - } - - function index() { - let child = this[0]; - let i; - - if (child) { - i = 0; // eslint-disable-next-line - - while ((child = child.previousSibling) !== null) { - if (child.nodeType === 1) i += 1; - } - - return i; - } - - return undefined; - } - - function eq(index) { - if (typeof index === "undefined") return this; - const length = this.length; - - if (index > length - 1) { - return $([]); - } - - if (index < 0) { - const returnIndex = length + index; - if (returnIndex < 0) return $([]); - return $([this[returnIndex]]); - } - - return $([this[index]]); - } - - function append() { - let newChild; - const document = getDocument(); - - for (let k = 0; k < arguments.length; k += 1) { - newChild = k < 0 || arguments.length <= k ? undefined : arguments[k]; - - for (let i = 0; i < this.length; i += 1) { - if (typeof newChild === "string") { - const tempDiv = document.createElement("div"); - tempDiv.innerHTML = newChild; - - while (tempDiv.firstChild) { - this[i].appendChild(tempDiv.firstChild); - } - } else if (newChild instanceof Dom7) { - for (let j = 0; j < newChild.length; j += 1) { - this[i].appendChild(newChild[j]); - } - } else { - this[i].appendChild(newChild); - } - } - } - - return this; - } - - function prepend(newChild) { - const document = getDocument(); - let i; - let j; - - for (i = 0; i < this.length; i += 1) { - if (typeof newChild === "string") { - const tempDiv = document.createElement("div"); - tempDiv.innerHTML = newChild; - - for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) { - this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]); - } - } else if (newChild instanceof Dom7) { - for (j = 0; j < newChild.length; j += 1) { - this[i].insertBefore(newChild[j], this[i].childNodes[0]); - } - } else { - this[i].insertBefore(newChild, this[i].childNodes[0]); - } - } - - return this; - } - - function next(selector) { - if (this.length > 0) { - if (selector) { - if ( - this[0].nextElementSibling && - $(this[0].nextElementSibling).is(selector) - ) { - return $([this[0].nextElementSibling]); - } - - return $([]); - } - - if (this[0].nextElementSibling) return $([this[0].nextElementSibling]); - return $([]); - } - - return $([]); - } - - function nextAll(selector) { - const nextEls = []; - let el = this[0]; - if (!el) return $([]); - - while (el.nextElementSibling) { - const next = el.nextElementSibling; // eslint-disable-line - - if (selector) { - if ($(next).is(selector)) nextEls.push(next); - } else nextEls.push(next); - - el = next; - } - - return $(nextEls); - } - - function prev(selector) { - if (this.length > 0) { - const el = this[0]; - - if (selector) { - if ( - el.previousElementSibling && - $(el.previousElementSibling).is(selector) - ) { - return $([el.previousElementSibling]); - } - - return $([]); - } - - if (el.previousElementSibling) return $([el.previousElementSibling]); - return $([]); - } - - return $([]); - } - - function prevAll(selector) { - const prevEls = []; - let el = this[0]; - if (!el) return $([]); - - while (el.previousElementSibling) { - const prev = el.previousElementSibling; // eslint-disable-line - - if (selector) { - if ($(prev).is(selector)) prevEls.push(prev); - } else prevEls.push(prev); - - el = prev; - } - - return $(prevEls); - } - - function parent(selector) { - const parents = []; // eslint-disable-line - - for (let i = 0; i < this.length; i += 1) { - if (this[i].parentNode !== null) { - if (selector) { - if ($(this[i].parentNode).is(selector)) - parents.push(this[i].parentNode); - } else { - parents.push(this[i].parentNode); - } - } - } - - return $(parents); - } - - function parents(selector) { - const parents = []; // eslint-disable-line - - for (let i = 0; i < this.length; i += 1) { - let parent = this[i].parentNode; // eslint-disable-line - - while (parent) { - if (selector) { - if ($(parent).is(selector)) parents.push(parent); - } else { - parents.push(parent); - } - - parent = parent.parentNode; - } - } - - return $(parents); - } - - function closest(selector) { - let closest = this; // eslint-disable-line - - if (typeof selector === "undefined") { - return $([]); - } - - if (!closest.is(selector)) { - closest = closest.parents(selector).eq(0); - } - - return closest; - } - - function find(selector) { - const foundElements = []; - - for (let i = 0; i < this.length; i += 1) { - const found = this[i].querySelectorAll(selector); - - for (let j = 0; j < found.length; j += 1) { - foundElements.push(found[j]); - } - } - - return $(foundElements); - } - - function children(selector) { - const children = []; // eslint-disable-line - - for (let i = 0; i < this.length; i += 1) { - const childNodes = this[i].children; - - for (let j = 0; j < childNodes.length; j += 1) { - if (!selector || $(childNodes[j]).is(selector)) { - children.push(childNodes[j]); - } - } - } - - return $(children); - } - - function remove() { - for (let i = 0; i < this.length; i += 1) { - if (this[i].parentNode) this[i].parentNode.removeChild(this[i]); - } - - return this; - } - - const Methods = { - addClass, - removeClass, - hasClass, - toggleClass, - attr, - removeAttr, - transform, - transition: transition$1, - on, - off, - trigger, - transitionEnd: transitionEnd$1, - outerWidth, - outerHeight, - styles, - offset, - css, - each, - html, - text, - is, - index, - eq, - append, - prepend, - next, - nextAll, - prev, - prevAll, - parent, - parents, - closest, - find, - children, - filter, - remove, - }; - Object.keys(Methods).forEach((methodName) => { - Object.defineProperty($.fn, methodName, { - value: Methods[methodName], - writable: true, - }); - }); - - function deleteProps(obj) { - const object = obj; - Object.keys(object).forEach((key) => { - try { - object[key] = null; - } catch (e) { - // no getter for object - } - - try { - delete object[key]; - } catch (e) { - // something got wrong - } - }); - } - - function nextTick(callback, delay) { - if (delay === void 0) { - delay = 0; - } - - return setTimeout(callback, delay); - } - - function now() { - return Date.now(); - } - - function getComputedStyle$1(el) { - const window = getWindow(); - let style; - - if (window.getComputedStyle) { - style = window.getComputedStyle(el, null); - } - - if (!style && el.currentStyle) { - style = el.currentStyle; - } - - if (!style) { - style = el.style; - } - - return style; - } - - function getTranslate(el, axis) { - if (axis === void 0) { - axis = "x"; - } - - const window = getWindow(); - let matrix; - let curTransform; - let transformMatrix; - const curStyle = getComputedStyle$1(el); - - if (window.WebKitCSSMatrix) { - curTransform = curStyle.transform || curStyle.webkitTransform; - - if (curTransform.split(",").length > 6) { - curTransform = curTransform - .split(", ") - .map((a) => a.replace(",", ".")) - .join(", "); - } // Some old versions of Webkit choke when 'none' is passed; pass - // empty string instead in this case - - transformMatrix = new window.WebKitCSSMatrix( - curTransform === "none" ? "" : curTransform, - ); - } else { - transformMatrix = - curStyle.MozTransform || - curStyle.OTransform || - curStyle.MsTransform || - curStyle.msTransform || - curStyle.transform || - curStyle - .getPropertyValue("transform") - .replace("translate(", "matrix(1, 0, 0, 1,"); - matrix = transformMatrix.toString().split(","); - } - - if (axis === "x") { - // Latest Chrome and webkits Fix - if (window.WebKitCSSMatrix) - curTransform = transformMatrix.m41; // Crazy IE10 Matrix - else if (matrix.length === 16) - curTransform = parseFloat(matrix[12]); // Normal Browsers - else curTransform = parseFloat(matrix[4]); - } - - if (axis === "y") { - // Latest Chrome and webkits Fix - if (window.WebKitCSSMatrix) - curTransform = transformMatrix.m42; // Crazy IE10 Matrix - else if (matrix.length === 16) - curTransform = parseFloat(matrix[13]); // Normal Browsers - else curTransform = parseFloat(matrix[5]); - } - - return curTransform || 0; - } - - function isObject(o) { - return ( - typeof o === "object" && - o !== null && - o.constructor && - Object.prototype.toString.call(o).slice(8, -1) === "Object" - ); - } - - function isNode(node) { - // eslint-disable-next-line - if ( - typeof window !== "undefined" && - typeof window.HTMLElement !== "undefined" - ) { - return node instanceof HTMLElement; - } - - return node && (node.nodeType === 1 || node.nodeType === 11); - } - - function extend() { - const to = Object(arguments.length <= 0 ? undefined : arguments[0]); - const noExtend = ["__proto__", "constructor", "prototype"]; - - for (let i = 1; i < arguments.length; i += 1) { - const nextSource = - i < 0 || arguments.length <= i ? undefined : arguments[i]; - - if ( - nextSource !== undefined && - nextSource !== null && - !isNode(nextSource) - ) { - const keysArray = Object.keys(Object(nextSource)).filter( - (key) => noExtend.indexOf(key) < 0, - ); - - for ( - let nextIndex = 0, len = keysArray.length; - nextIndex < len; - nextIndex += 1 - ) { - const nextKey = keysArray[nextIndex]; - const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey); - - if (desc !== undefined && desc.enumerable) { - if (isObject(to[nextKey]) && isObject(nextSource[nextKey])) { - if (nextSource[nextKey].__swiper__) { - to[nextKey] = nextSource[nextKey]; - } else { - extend(to[nextKey], nextSource[nextKey]); - } - } else if ( - !isObject(to[nextKey]) && - isObject(nextSource[nextKey]) - ) { - to[nextKey] = {}; - - if (nextSource[nextKey].__swiper__) { - to[nextKey] = nextSource[nextKey]; - } else { - extend(to[nextKey], nextSource[nextKey]); - } - } else { - to[nextKey] = nextSource[nextKey]; - } - } - } - } - } - - return to; - } - - function setCSSProperty(el, varName, varValue) { - el.style.setProperty(varName, varValue); - } - - function animateCSSModeScroll(_ref) { - let { swiper, targetPosition, side } = _ref; - const window = getWindow(); - const startPosition = -swiper.translate; - let startTime = null; - let time; - const duration = swiper.params.speed; - swiper.wrapperEl.style.scrollSnapType = "none"; - window.cancelAnimationFrame(swiper.cssModeFrameID); - const dir = targetPosition > startPosition ? "next" : "prev"; - - const isOutOfBound = (current, target) => { - return ( - (dir === "next" && current >= target) || - (dir === "prev" && current <= target) - ); - }; - - const animate = () => { - time = new Date().getTime(); - - if (startTime === null) { - startTime = time; - } - - const progress = Math.max(Math.min((time - startTime) / duration, 1), 0); - const easeProgress = 0.5 - Math.cos(progress * Math.PI) / 2; - let currentPosition = - startPosition + easeProgress * (targetPosition - startPosition); - - if (isOutOfBound(currentPosition, targetPosition)) { - currentPosition = targetPosition; - } - - swiper.wrapperEl.scrollTo({ - [side]: currentPosition, - }); - - if (isOutOfBound(currentPosition, targetPosition)) { - swiper.wrapperEl.style.overflow = "hidden"; - swiper.wrapperEl.style.scrollSnapType = ""; - setTimeout(() => { - swiper.wrapperEl.style.overflow = ""; - swiper.wrapperEl.scrollTo({ - [side]: currentPosition, - }); - }); - window.cancelAnimationFrame(swiper.cssModeFrameID); - return; - } - - swiper.cssModeFrameID = window.requestAnimationFrame(animate); - }; - - animate(); - } - - let support; - - function calcSupport() { - const window = getWindow(); - const document = getDocument(); - return { - smoothScroll: - document.documentElement && - "scrollBehavior" in document.documentElement.style, - touch: !!( - "ontouchstart" in window || - (window.DocumentTouch && document instanceof window.DocumentTouch) - ), - passiveListener: (function checkPassiveListener() { - let supportsPassive = false; - - try { - const opts = Object.defineProperty({}, "passive", { - // eslint-disable-next-line - get() { - supportsPassive = true; - }, - }); - window.addEventListener("testPassiveListener", null, opts); - } catch (e) { - // No support - } - - return supportsPassive; - })(), - gestures: (function checkGestures() { - return "ongesturestart" in window; - })(), - }; - } - - function getSupport() { - if (!support) { - support = calcSupport(); - } - - return support; - } - - let deviceCached; - - function calcDevice(_temp) { - let { userAgent } = _temp === void 0 ? {} : _temp; - const support = getSupport(); - const window = getWindow(); - const platform = window.navigator.platform; - const ua = userAgent || window.navigator.userAgent; - const device = { - ios: false, - android: false, - }; - const screenWidth = window.screen.width; - const screenHeight = window.screen.height; - const android = ua.match(/(Android);?[\s\/]+([\d.]+)?/); // eslint-disable-line - - let ipad = ua.match(/(iPad).*OS\s([\d_]+)/); - const ipod = ua.match(/(iPod)(.*OS\s([\d_]+))?/); - const iphone = !ipad && ua.match(/(iPhone\sOS|iOS)\s([\d_]+)/); - const windows = platform === "Win32"; - let macos = platform === "MacIntel"; // iPadOs 13 fix - - const iPadScreens = [ - "1024x1366", - "1366x1024", - "834x1194", - "1194x834", - "834x1112", - "1112x834", - "768x1024", - "1024x768", - "820x1180", - "1180x820", - "810x1080", - "1080x810", - ]; - - if ( - !ipad && - macos && - support.touch && - iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0 - ) { - ipad = ua.match(/(Version)\/([\d.]+)/); - if (!ipad) ipad = [0, 1, "13_0_0"]; - macos = false; - } // Android - - if (android && !windows) { - device.os = "android"; - device.android = true; - } - - if (ipad || iphone || ipod) { - device.os = "ios"; - device.ios = true; - } // Export object - - return device; - } - - function getDevice(overrides) { - if (overrides === void 0) { - overrides = {}; - } - - if (!deviceCached) { - deviceCached = calcDevice(overrides); - } - - return deviceCached; - } - - let browser; - - function calcBrowser() { - const window = getWindow(); - - function isSafari() { - const ua = window.navigator.userAgent.toLowerCase(); - return ( - ua.indexOf("safari") >= 0 && - ua.indexOf("chrome") < 0 && - ua.indexOf("android") < 0 - ); - } - - return { - isSafari: isSafari(), - isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test( - window.navigator.userAgent, - ), - }; - } - - function getBrowser() { - if (!browser) { - browser = calcBrowser(); - } - - return browser; - } - - function Resize(_ref) { - let { swiper, on, emit } = _ref; - const window = getWindow(); - let observer = null; - let animationFrame = null; - - const resizeHandler = () => { - if (!swiper || swiper.destroyed || !swiper.initialized) return; - emit("beforeResize"); - emit("resize"); - }; - - const createObserver = () => { - if (!swiper || swiper.destroyed || !swiper.initialized) return; - observer = new ResizeObserver((entries) => { - animationFrame = window.requestAnimationFrame(() => { - const { width, height } = swiper; - let newWidth = width; - let newHeight = height; - entries.forEach((_ref2) => { - let { contentBoxSize, contentRect, target } = _ref2; - if (target && target !== swiper.el) return; - newWidth = contentRect - ? contentRect.width - : (contentBoxSize[0] || contentBoxSize).inlineSize; - newHeight = contentRect - ? contentRect.height - : (contentBoxSize[0] || contentBoxSize).blockSize; - }); - - if (newWidth !== width || newHeight !== height) { - resizeHandler(); - } - }); - }); - observer.observe(swiper.el); - }; - - const removeObserver = () => { - if (animationFrame) { - window.cancelAnimationFrame(animationFrame); - } - - if (observer && observer.unobserve && swiper.el) { - observer.unobserve(swiper.el); - observer = null; - } - }; - - const orientationChangeHandler = () => { - if (!swiper || swiper.destroyed || !swiper.initialized) return; - emit("orientationchange"); - }; - - on("init", () => { - if ( - swiper.params.resizeObserver && - typeof window.ResizeObserver !== "undefined" - ) { - createObserver(); - return; - } - - window.addEventListener("resize", resizeHandler); - window.addEventListener("orientationchange", orientationChangeHandler); - }); - on("destroy", () => { - removeObserver(); - window.removeEventListener("resize", resizeHandler); - window.removeEventListener("orientationchange", orientationChangeHandler); - }); - } - - function Observer(_ref) { - let { swiper, extendParams, on, emit } = _ref; - const observers = []; - const window = getWindow(); - - const attach = function (target, options) { - if (options === void 0) { - options = {}; - } - - const ObserverFunc = - window.MutationObserver || window.WebkitMutationObserver; - const observer = new ObserverFunc((mutations) => { - // The observerUpdate event should only be triggered - // once despite the number of mutations. Additional - // triggers are redundant and are very costly - if (mutations.length === 1) { - emit("observerUpdate", mutations[0]); - return; - } - - const observerUpdate = function observerUpdate() { - emit("observerUpdate", mutations[0]); - }; - - if (window.requestAnimationFrame) { - window.requestAnimationFrame(observerUpdate); - } else { - window.setTimeout(observerUpdate, 0); - } - }); - observer.observe(target, { - attributes: - typeof options.attributes === "undefined" ? true : options.attributes, - childList: - typeof options.childList === "undefined" ? true : options.childList, - characterData: - typeof options.characterData === "undefined" - ? true - : options.characterData, - }); - observers.push(observer); - }; - - const init = () => { - if (!swiper.params.observer) return; - - if (swiper.params.observeParents) { - const containerParents = swiper.$el.parents(); - - for (let i = 0; i < containerParents.length; i += 1) { - attach(containerParents[i]); - } - } // Observe container - - attach(swiper.$el[0], { - childList: swiper.params.observeSlideChildren, - }); // Observe wrapper - - attach(swiper.$wrapperEl[0], { - attributes: false, - }); - }; - - const destroy = () => { - observers.forEach((observer) => { - observer.disconnect(); - }); - observers.splice(0, observers.length); - }; - - extendParams({ - observer: false, - observeParents: false, - observeSlideChildren: false, - }); - on("init", init); - on("destroy", destroy); - } - - /* eslint-disable no-underscore-dangle */ - var eventsEmitter = { - on(events, handler, priority) { - const self = this; - if (typeof handler !== "function") return self; - const method = priority ? "unshift" : "push"; - events.split(" ").forEach((event) => { - if (!self.eventsListeners[event]) self.eventsListeners[event] = []; - self.eventsListeners[event][method](handler); - }); - return self; - }, - - once(events, handler, priority) { - const self = this; - if (typeof handler !== "function") return self; - - function onceHandler() { - self.off(events, onceHandler); - - if (onceHandler.__emitterProxy) { - delete onceHandler.__emitterProxy; - } - - for ( - var _len = arguments.length, args = new Array(_len), _key = 0; - _key < _len; - _key++ - ) { - args[_key] = arguments[_key]; - } - - handler.apply(self, args); - } - - onceHandler.__emitterProxy = handler; - return self.on(events, onceHandler, priority); - }, - - onAny(handler, priority) { - const self = this; - if (typeof handler !== "function") return self; - const method = priority ? "unshift" : "push"; - - if (self.eventsAnyListeners.indexOf(handler) < 0) { - self.eventsAnyListeners[method](handler); - } - - return self; - }, - - offAny(handler) { - const self = this; - if (!self.eventsAnyListeners) return self; - const index = self.eventsAnyListeners.indexOf(handler); - - if (index >= 0) { - self.eventsAnyListeners.splice(index, 1); - } - - return self; - }, - - off(events, handler) { - const self = this; - if (!self.eventsListeners) return self; - events.split(" ").forEach((event) => { - if (typeof handler === "undefined") { - self.eventsListeners[event] = []; - } else if (self.eventsListeners[event]) { - self.eventsListeners[event].forEach((eventHandler, index) => { - if ( - eventHandler === handler || - (eventHandler.__emitterProxy && - eventHandler.__emitterProxy === handler) - ) { - self.eventsListeners[event].splice(index, 1); - } - }); - } - }); - return self; - }, - - emit() { - const self = this; - if (!self.eventsListeners) return self; - let events; - let data; - let context; - - for ( - var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; - _key2 < _len2; - _key2++ - ) { - args[_key2] = arguments[_key2]; - } - - if (typeof args[0] === "string" || Array.isArray(args[0])) { - events = args[0]; - data = args.slice(1, args.length); - context = self; - } else { - events = args[0].events; - data = args[0].data; - context = args[0].context || self; - } - - data.unshift(context); - const eventsArray = Array.isArray(events) ? events : events.split(" "); - eventsArray.forEach((event) => { - if (self.eventsAnyListeners && self.eventsAnyListeners.length) { - self.eventsAnyListeners.forEach((eventHandler) => { - eventHandler.apply(context, [event, ...data]); - }); - } - - if (self.eventsListeners && self.eventsListeners[event]) { - self.eventsListeners[event].forEach((eventHandler) => { - eventHandler.apply(context, data); - }); - } - }); - return self; - }, - }; - - function updateSize() { - const swiper = this; - let width; - let height; - const $el = swiper.$el; - - if ( - typeof swiper.params.width !== "undefined" && - swiper.params.width !== null - ) { - width = swiper.params.width; - } else { - width = $el[0].clientWidth; - } - - if ( - typeof swiper.params.height !== "undefined" && - swiper.params.height !== null - ) { - height = swiper.params.height; - } else { - height = $el[0].clientHeight; - } - - if ( - (width === 0 && swiper.isHorizontal()) || - (height === 0 && swiper.isVertical()) - ) { - return; - } // Subtract paddings - - width = - width - - parseInt($el.css("padding-left") || 0, 10) - - parseInt($el.css("padding-right") || 0, 10); - height = - height - - parseInt($el.css("padding-top") || 0, 10) - - parseInt($el.css("padding-bottom") || 0, 10); - if (Number.isNaN(width)) width = 0; - if (Number.isNaN(height)) height = 0; - Object.assign(swiper, { - width, - height, - size: swiper.isHorizontal() ? width : height, - }); - } - - function updateSlides() { - const swiper = this; - - function getDirectionLabel(property) { - if (swiper.isHorizontal()) { - return property; - } // prettier-ignore - - return { - width: "height", - "margin-top": "margin-left", - "margin-bottom ": "margin-right", - "margin-left": "margin-top", - "margin-right": "margin-bottom", - "padding-left": "padding-top", - "padding-right": "padding-bottom", - marginRight: "marginBottom", - }[property]; - } - - function getDirectionPropertyValue(node, label) { - return parseFloat(node.getPropertyValue(getDirectionLabel(label)) || 0); - } - - const params = swiper.params; - const { - $wrapperEl, - size: swiperSize, - rtlTranslate: rtl, - wrongRTL, - } = swiper; - const isVirtual = swiper.virtual && params.virtual.enabled; - const previousSlidesLength = isVirtual - ? swiper.virtual.slides.length - : swiper.slides.length; - const slides = $wrapperEl.children(`.${swiper.params.slideClass}`); - const slidesLength = isVirtual - ? swiper.virtual.slides.length - : slides.length; - let snapGrid = []; - const slidesGrid = []; - const slidesSizesGrid = []; - let offsetBefore = params.slidesOffsetBefore; - - if (typeof offsetBefore === "function") { - offsetBefore = params.slidesOffsetBefore.call(swiper); - } - - let offsetAfter = params.slidesOffsetAfter; - - if (typeof offsetAfter === "function") { - offsetAfter = params.slidesOffsetAfter.call(swiper); - } - - const previousSnapGridLength = swiper.snapGrid.length; - const previousSlidesGridLength = swiper.slidesGrid.length; - let spaceBetween = params.spaceBetween; - let slidePosition = -offsetBefore; - let prevSlideSize = 0; - let index = 0; - - if (typeof swiperSize === "undefined") { - return; - } - - if (typeof spaceBetween === "string" && spaceBetween.indexOf("%") >= 0) { - spaceBetween = - (parseFloat(spaceBetween.replace("%", "")) / 100) * swiperSize; - } - - swiper.virtualSize = -spaceBetween; // reset margins - - if (rtl) - slides.css({ - marginLeft: "", - marginBottom: "", - marginTop: "", - }); - else - slides.css({ - marginRight: "", - marginBottom: "", - marginTop: "", - }); // reset cssMode offsets - - if (params.centeredSlides && params.cssMode) { - setCSSProperty(swiper.wrapperEl, "--swiper-centered-offset-before", ""); - setCSSProperty(swiper.wrapperEl, "--swiper-centered-offset-after", ""); - } - - const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid; - - if (gridEnabled) { - swiper.grid.initSlides(slidesLength); - } // Calc slides - - let slideSize; - const shouldResetSlideSize = - params.slidesPerView === "auto" && - params.breakpoints && - Object.keys(params.breakpoints).filter((key) => { - return typeof params.breakpoints[key].slidesPerView !== "undefined"; - }).length > 0; - - for (let i = 0; i < slidesLength; i += 1) { - slideSize = 0; - const slide = slides.eq(i); - - if (gridEnabled) { - swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel); - } - - if (slide.css("display") === "none") continue; // eslint-disable-line - - if (params.slidesPerView === "auto") { - if (shouldResetSlideSize) { - slides[i].style[getDirectionLabel("width")] = ``; - } - - const slideStyles = getComputedStyle(slide[0]); - const currentTransform = slide[0].style.transform; - const currentWebKitTransform = slide[0].style.webkitTransform; - - if (currentTransform) { - slide[0].style.transform = "none"; - } - - if (currentWebKitTransform) { - slide[0].style.webkitTransform = "none"; - } - - if (params.roundLengths) { - slideSize = swiper.isHorizontal() - ? slide.outerWidth(true) - : slide.outerHeight(true); - } else { - // eslint-disable-next-line - const width = getDirectionPropertyValue(slideStyles, "width"); - const paddingLeft = getDirectionPropertyValue( - slideStyles, - "padding-left", - ); - const paddingRight = getDirectionPropertyValue( - slideStyles, - "padding-right", - ); - const marginLeft = getDirectionPropertyValue( - slideStyles, - "margin-left", - ); - const marginRight = getDirectionPropertyValue( - slideStyles, - "margin-right", - ); - const boxSizing = slideStyles.getPropertyValue("box-sizing"); - - if (boxSizing && boxSizing === "border-box") { - slideSize = width + marginLeft + marginRight; - } else { - const { clientWidth, offsetWidth } = slide[0]; - slideSize = - width + - paddingLeft + - paddingRight + - marginLeft + - marginRight + - (offsetWidth - clientWidth); - } - } - - if (currentTransform) { - slide[0].style.transform = currentTransform; - } - - if (currentWebKitTransform) { - slide[0].style.webkitTransform = currentWebKitTransform; - } - - if (params.roundLengths) slideSize = Math.floor(slideSize); - } else { - slideSize = - (swiperSize - (params.slidesPerView - 1) * spaceBetween) / - params.slidesPerView; - if (params.roundLengths) slideSize = Math.floor(slideSize); - - if (slides[i]) { - slides[i].style[getDirectionLabel("width")] = `${slideSize}px`; - } - } - - if (slides[i]) { - slides[i].swiperSlideSize = slideSize; - } - - slidesSizesGrid.push(slideSize); - - if (params.centeredSlides) { - slidePosition = - slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween; - if (prevSlideSize === 0 && i !== 0) - slidePosition = slidePosition - swiperSize / 2 - spaceBetween; - if (i === 0) - slidePosition = slidePosition - swiperSize / 2 - spaceBetween; - if (Math.abs(slidePosition) < 1 / 1000) slidePosition = 0; - if (params.roundLengths) slidePosition = Math.floor(slidePosition); - if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition); - slidesGrid.push(slidePosition); - } else { - if (params.roundLengths) slidePosition = Math.floor(slidePosition); - if ( - (index - Math.min(swiper.params.slidesPerGroupSkip, index)) % - swiper.params.slidesPerGroup === - 0 - ) - snapGrid.push(slidePosition); - slidesGrid.push(slidePosition); - slidePosition = slidePosition + slideSize + spaceBetween; - } - - swiper.virtualSize += slideSize + spaceBetween; - prevSlideSize = slideSize; - index += 1; - } - - swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter; - - if ( - rtl && - wrongRTL && - (params.effect === "slide" || params.effect === "coverflow") - ) { - $wrapperEl.css({ - width: `${swiper.virtualSize + params.spaceBetween}px`, - }); - } - - if (params.setWrapperSize) { - $wrapperEl.css({ - [getDirectionLabel("width")]: `${ - swiper.virtualSize + params.spaceBetween - }px`, - }); - } - - if (gridEnabled) { - swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel); - } // Remove last grid elements depending on width - - if (!params.centeredSlides) { - const newSlidesGrid = []; - - for (let i = 0; i < snapGrid.length; i += 1) { - let slidesGridItem = snapGrid[i]; - if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem); - - if (snapGrid[i] <= swiper.virtualSize - swiperSize) { - newSlidesGrid.push(slidesGridItem); - } - } - - snapGrid = newSlidesGrid; - - if ( - Math.floor(swiper.virtualSize - swiperSize) - - Math.floor(snapGrid[snapGrid.length - 1]) > - 1 - ) { - snapGrid.push(swiper.virtualSize - swiperSize); - } - } - - if (snapGrid.length === 0) snapGrid = [0]; - - if (params.spaceBetween !== 0) { - const key = - swiper.isHorizontal() && rtl - ? "marginLeft" - : getDirectionLabel("marginRight"); - slides - .filter((_, slideIndex) => { - if (!params.cssMode) return true; - - if (slideIndex === slides.length - 1) { - return false; - } - - return true; - }) - .css({ - [key]: `${spaceBetween}px`, - }); - } - - if (params.centeredSlides && params.centeredSlidesBounds) { - let allSlidesSize = 0; - slidesSizesGrid.forEach((slideSizeValue) => { - allSlidesSize += - slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0); - }); - allSlidesSize -= params.spaceBetween; - const maxSnap = allSlidesSize - swiperSize; - snapGrid = snapGrid.map((snap) => { - if (snap < 0) return -offsetBefore; - if (snap > maxSnap) return maxSnap + offsetAfter; - return snap; - }); - } - - if (params.centerInsufficientSlides) { - let allSlidesSize = 0; - slidesSizesGrid.forEach((slideSizeValue) => { - allSlidesSize += - slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0); - }); - allSlidesSize -= params.spaceBetween; - - if (allSlidesSize < swiperSize) { - const allSlidesOffset = (swiperSize - allSlidesSize) / 2; - snapGrid.forEach((snap, snapIndex) => { - snapGrid[snapIndex] = snap - allSlidesOffset; - }); - slidesGrid.forEach((snap, snapIndex) => { - slidesGrid[snapIndex] = snap + allSlidesOffset; - }); - } - } - - Object.assign(swiper, { - slides, - snapGrid, - slidesGrid, - slidesSizesGrid, - }); - - if ( - params.centeredSlides && - params.cssMode && - !params.centeredSlidesBounds - ) { - setCSSProperty( - swiper.wrapperEl, - "--swiper-centered-offset-before", - `${-snapGrid[0]}px`, - ); - setCSSProperty( - swiper.wrapperEl, - "--swiper-centered-offset-after", - `${ - swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2 - }px`, - ); - const addToSnapGrid = -swiper.snapGrid[0]; - const addToSlidesGrid = -swiper.slidesGrid[0]; - swiper.snapGrid = swiper.snapGrid.map((v) => v + addToSnapGrid); - swiper.slidesGrid = swiper.slidesGrid.map((v) => v + addToSlidesGrid); - } - - if (slidesLength !== previousSlidesLength) { - swiper.emit("slidesLengthChange"); - } - - if (snapGrid.length !== previousSnapGridLength) { - if (swiper.params.watchOverflow) swiper.checkOverflow(); - swiper.emit("snapGridLengthChange"); - } - - if (slidesGrid.length !== previousSlidesGridLength) { - swiper.emit("slidesGridLengthChange"); - } - - if (params.watchSlidesProgress) { - swiper.updateSlidesOffset(); - } - - if ( - !isVirtual && - !params.cssMode && - (params.effect === "slide" || params.effect === "fade") - ) { - const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`; - const hasClassBackfaceClassAdded = - swiper.$el.hasClass(backFaceHiddenClass); - - if (slidesLength <= params.maxBackfaceHiddenSlides) { - if (!hasClassBackfaceClassAdded) - swiper.$el.addClass(backFaceHiddenClass); - } else if (hasClassBackfaceClassAdded) { - swiper.$el.removeClass(backFaceHiddenClass); - } - } - } - - function updateAutoHeight(speed) { - const swiper = this; - const activeSlides = []; - const isVirtual = swiper.virtual && swiper.params.virtual.enabled; - let newHeight = 0; - let i; - - if (typeof speed === "number") { - swiper.setTransition(speed); - } else if (speed === true) { - swiper.setTransition(swiper.params.speed); - } - - const getSlideByIndex = (index) => { - if (isVirtual) { - return swiper.slides.filter( - (el) => - parseInt(el.getAttribute("data-swiper-slide-index"), 10) === index, - )[0]; - } - - return swiper.slides.eq(index)[0]; - }; // Find slides currently in view - - if ( - swiper.params.slidesPerView !== "auto" && - swiper.params.slidesPerView > 1 - ) { - if (swiper.params.centeredSlides) { - swiper.visibleSlides.each((slide) => { - activeSlides.push(slide); - }); - } else { - for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) { - const index = swiper.activeIndex + i; - if (index > swiper.slides.length && !isVirtual) break; - activeSlides.push(getSlideByIndex(index)); - } - } - } else { - activeSlides.push(getSlideByIndex(swiper.activeIndex)); - } // Find new height from highest slide in view - - for (i = 0; i < activeSlides.length; i += 1) { - if (typeof activeSlides[i] !== "undefined") { - const height = activeSlides[i].offsetHeight; - newHeight = height > newHeight ? height : newHeight; - } - } // Update Height - - if (newHeight || newHeight === 0) - swiper.$wrapperEl.css("height", `${newHeight}px`); - } - - function updateSlidesOffset() { - const swiper = this; - const slides = swiper.slides; - - for (let i = 0; i < slides.length; i += 1) { - slides[i].swiperSlideOffset = swiper.isHorizontal() - ? slides[i].offsetLeft - : slides[i].offsetTop; - } - } - - function updateSlidesProgress(translate) { - if (translate === void 0) { - translate = (this && this.translate) || 0; - } - - const swiper = this; - const params = swiper.params; - const { slides, rtlTranslate: rtl, snapGrid } = swiper; - if (slides.length === 0) return; - if (typeof slides[0].swiperSlideOffset === "undefined") - swiper.updateSlidesOffset(); - let offsetCenter = -translate; - if (rtl) offsetCenter = translate; // Visible Slides - - slides.removeClass(params.slideVisibleClass); - swiper.visibleSlidesIndexes = []; - swiper.visibleSlides = []; - - for (let i = 0; i < slides.length; i += 1) { - const slide = slides[i]; - let slideOffset = slide.swiperSlideOffset; - - if (params.cssMode && params.centeredSlides) { - slideOffset -= slides[0].swiperSlideOffset; - } - - const slideProgress = - (offsetCenter + - (params.centeredSlides ? swiper.minTranslate() : 0) - - slideOffset) / - (slide.swiperSlideSize + params.spaceBetween); - const originalSlideProgress = - (offsetCenter - - snapGrid[0] + - (params.centeredSlides ? swiper.minTranslate() : 0) - - slideOffset) / - (slide.swiperSlideSize + params.spaceBetween); - const slideBefore = -(offsetCenter - slideOffset); - const slideAfter = slideBefore + swiper.slidesSizesGrid[i]; - const isVisible = - (slideBefore >= 0 && slideBefore < swiper.size - 1) || - (slideAfter > 1 && slideAfter <= swiper.size) || - (slideBefore <= 0 && slideAfter >= swiper.size); - - if (isVisible) { - swiper.visibleSlides.push(slide); - swiper.visibleSlidesIndexes.push(i); - slides.eq(i).addClass(params.slideVisibleClass); - } - - slide.progress = rtl ? -slideProgress : slideProgress; - slide.originalProgress = rtl - ? -originalSlideProgress - : originalSlideProgress; - } - - swiper.visibleSlides = $(swiper.visibleSlides); - } - - function updateProgress(translate) { - const swiper = this; - - if (typeof translate === "undefined") { - const multiplier = swiper.rtlTranslate ? -1 : 1; // eslint-disable-next-line - - translate = - (swiper && swiper.translate && swiper.translate * multiplier) || 0; - } - - const params = swiper.params; - const translatesDiff = swiper.maxTranslate() - swiper.minTranslate(); - let { progress, isBeginning, isEnd } = swiper; - const wasBeginning = isBeginning; - const wasEnd = isEnd; - - if (translatesDiff === 0) { - progress = 0; - isBeginning = true; - isEnd = true; - } else { - progress = (translate - swiper.minTranslate()) / translatesDiff; - isBeginning = progress <= 0; - isEnd = progress >= 1; - } - - Object.assign(swiper, { - progress, - isBeginning, - isEnd, - }); - if ( - params.watchSlidesProgress || - (params.centeredSlides && params.autoHeight) - ) - swiper.updateSlidesProgress(translate); - - if (isBeginning && !wasBeginning) { - swiper.emit("reachBeginning toEdge"); - } - - if (isEnd && !wasEnd) { - swiper.emit("reachEnd toEdge"); - } - - if ((wasBeginning && !isBeginning) || (wasEnd && !isEnd)) { - swiper.emit("fromEdge"); - } - - swiper.emit("progress", progress); - } - - function updateSlidesClasses() { - const swiper = this; - const { slides, params, $wrapperEl, activeIndex, realIndex } = swiper; - const isVirtual = swiper.virtual && params.virtual.enabled; - slides.removeClass( - `${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`, - ); - let activeSlide; - - if (isVirtual) { - activeSlide = swiper.$wrapperEl.find( - `.${params.slideClass}[data-swiper-slide-index="${activeIndex}"]`, - ); - } else { - activeSlide = slides.eq(activeIndex); - } // Active classes - - activeSlide.addClass(params.slideActiveClass); - - if (params.loop) { - // Duplicate to all looped slides - if (activeSlide.hasClass(params.slideDuplicateClass)) { - $wrapperEl - .children( - `.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index="${realIndex}"]`, - ) - .addClass(params.slideDuplicateActiveClass); - } else { - $wrapperEl - .children( - `.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index="${realIndex}"]`, - ) - .addClass(params.slideDuplicateActiveClass); - } - } // Next Slide - - let nextSlide = activeSlide - .nextAll(`.${params.slideClass}`) - .eq(0) - .addClass(params.slideNextClass); - - if (params.loop && nextSlide.length === 0) { - nextSlide = slides.eq(0); - nextSlide.addClass(params.slideNextClass); - } // Prev Slide - - let prevSlide = activeSlide - .prevAll(`.${params.slideClass}`) - .eq(0) - .addClass(params.slidePrevClass); - - if (params.loop && prevSlide.length === 0) { - prevSlide = slides.eq(-1); - prevSlide.addClass(params.slidePrevClass); - } - - if (params.loop) { - // Duplicate to all looped slides - if (nextSlide.hasClass(params.slideDuplicateClass)) { - $wrapperEl - .children( - `.${params.slideClass}:not(.${ - params.slideDuplicateClass - })[data-swiper-slide-index="${nextSlide.attr( - "data-swiper-slide-index", - )}"]`, - ) - .addClass(params.slideDuplicateNextClass); - } else { - $wrapperEl - .children( - `.${params.slideClass}.${ - params.slideDuplicateClass - }[data-swiper-slide-index="${nextSlide.attr( - "data-swiper-slide-index", - )}"]`, - ) - .addClass(params.slideDuplicateNextClass); - } - - if (prevSlide.hasClass(params.slideDuplicateClass)) { - $wrapperEl - .children( - `.${params.slideClass}:not(.${ - params.slideDuplicateClass - })[data-swiper-slide-index="${prevSlide.attr( - "data-swiper-slide-index", - )}"]`, - ) - .addClass(params.slideDuplicatePrevClass); - } else { - $wrapperEl - .children( - `.${params.slideClass}.${ - params.slideDuplicateClass - }[data-swiper-slide-index="${prevSlide.attr( - "data-swiper-slide-index", - )}"]`, - ) - .addClass(params.slideDuplicatePrevClass); - } - } - - swiper.emitSlidesClasses(); - } - - function updateActiveIndex(newActiveIndex) { - const swiper = this; - const translate = swiper.rtlTranslate - ? swiper.translate - : -swiper.translate; - const { - slidesGrid, - snapGrid, - params, - activeIndex: previousIndex, - realIndex: previousRealIndex, - snapIndex: previousSnapIndex, - } = swiper; - let activeIndex = newActiveIndex; - let snapIndex; - - if (typeof activeIndex === "undefined") { - for (let i = 0; i < slidesGrid.length; i += 1) { - if (typeof slidesGrid[i + 1] !== "undefined") { - if ( - translate >= slidesGrid[i] && - translate < - slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2 - ) { - activeIndex = i; - } else if ( - translate >= slidesGrid[i] && - translate < slidesGrid[i + 1] - ) { - activeIndex = i + 1; - } - } else if (translate >= slidesGrid[i]) { - activeIndex = i; - } - } // Normalize slideIndex - - if (params.normalizeSlideIndex) { - if (activeIndex < 0 || typeof activeIndex === "undefined") - activeIndex = 0; - } - } - - if (snapGrid.indexOf(translate) >= 0) { - snapIndex = snapGrid.indexOf(translate); - } else { - const skip = Math.min(params.slidesPerGroupSkip, activeIndex); - snapIndex = - skip + Math.floor((activeIndex - skip) / params.slidesPerGroup); - } - - if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1; - - if (activeIndex === previousIndex) { - if (snapIndex !== previousSnapIndex) { - swiper.snapIndex = snapIndex; - swiper.emit("snapIndexChange"); - } - - return; - } // Get real index - - const realIndex = parseInt( - swiper.slides.eq(activeIndex).attr("data-swiper-slide-index") || - activeIndex, - 10, - ); - Object.assign(swiper, { - snapIndex, - realIndex, - previousIndex, - activeIndex, - }); - swiper.emit("activeIndexChange"); - swiper.emit("snapIndexChange"); - - if (previousRealIndex !== realIndex) { - swiper.emit("realIndexChange"); - } - - if (swiper.initialized || swiper.params.runCallbacksOnInit) { - swiper.emit("slideChange"); - } - } - - function updateClickedSlide(e) { - const swiper = this; - const params = swiper.params; - const slide = $(e).closest(`.${params.slideClass}`)[0]; - let slideFound = false; - let slideIndex; - - if (slide) { - for (let i = 0; i < swiper.slides.length; i += 1) { - if (swiper.slides[i] === slide) { - slideFound = true; - slideIndex = i; - break; - } - } - } - - if (slide && slideFound) { - swiper.clickedSlide = slide; - - if (swiper.virtual && swiper.params.virtual.enabled) { - swiper.clickedIndex = parseInt( - $(slide).attr("data-swiper-slide-index"), - 10, - ); - } else { - swiper.clickedIndex = slideIndex; - } - } else { - swiper.clickedSlide = undefined; - swiper.clickedIndex = undefined; - return; - } - - if ( - params.slideToClickedSlide && - swiper.clickedIndex !== undefined && - swiper.clickedIndex !== swiper.activeIndex - ) { - swiper.slideToClickedSlide(); - } - } - - var update = { - updateSize, - updateSlides, - updateAutoHeight, - updateSlidesOffset, - updateSlidesProgress, - updateProgress, - updateSlidesClasses, - updateActiveIndex, - updateClickedSlide, - }; - - function getSwiperTranslate(axis) { - if (axis === void 0) { - axis = this.isHorizontal() ? "x" : "y"; - } - - const swiper = this; - const { params, rtlTranslate: rtl, translate, $wrapperEl } = swiper; - - if (params.virtualTranslate) { - return rtl ? -translate : translate; - } - - if (params.cssMode) { - return translate; - } - - let currentTranslate = getTranslate($wrapperEl[0], axis); - if (rtl) currentTranslate = -currentTranslate; - return currentTranslate || 0; - } - - function setTranslate(translate, byController) { - const swiper = this; - const { - rtlTranslate: rtl, - params, - $wrapperEl, - wrapperEl, - progress, - } = swiper; - let x = 0; - let y = 0; - const z = 0; - - if (swiper.isHorizontal()) { - x = rtl ? -translate : translate; - } else { - y = translate; - } - - if (params.roundLengths) { - x = Math.floor(x); - y = Math.floor(y); - } - - if (params.cssMode) { - wrapperEl[swiper.isHorizontal() ? "scrollLeft" : "scrollTop"] = - swiper.isHorizontal() ? -x : -y; - } else if (!params.virtualTranslate) { - $wrapperEl.transform(`translate3d(${x}px, ${y}px, ${z}px)`); - } - - swiper.previousTranslate = swiper.translate; - swiper.translate = swiper.isHorizontal() ? x : y; // Check if we need to update progress - - let newProgress; - const translatesDiff = swiper.maxTranslate() - swiper.minTranslate(); - - if (translatesDiff === 0) { - newProgress = 0; - } else { - newProgress = (translate - swiper.minTranslate()) / translatesDiff; - } - - if (newProgress !== progress) { - swiper.updateProgress(translate); - } - - swiper.emit("setTranslate", swiper.translate, byController); - } - - function minTranslate() { - return -this.snapGrid[0]; - } - - function maxTranslate() { - return -this.snapGrid[this.snapGrid.length - 1]; - } - - function translateTo( - translate, - speed, - runCallbacks, - translateBounds, - internal, - ) { - if (translate === void 0) { - translate = 0; - } - - if (speed === void 0) { - speed = this.params.speed; - } - - if (runCallbacks === void 0) { - runCallbacks = true; - } - - if (translateBounds === void 0) { - translateBounds = true; - } - - const swiper = this; - const { params, wrapperEl } = swiper; - - if (swiper.animating && params.preventInteractionOnTransition) { - return false; - } - - const minTranslate = swiper.minTranslate(); - const maxTranslate = swiper.maxTranslate(); - let newTranslate; - if (translateBounds && translate > minTranslate) - newTranslate = minTranslate; - else if (translateBounds && translate < maxTranslate) - newTranslate = maxTranslate; - else newTranslate = translate; // Update progress - - swiper.updateProgress(newTranslate); - - if (params.cssMode) { - const isH = swiper.isHorizontal(); - - if (speed === 0) { - wrapperEl[isH ? "scrollLeft" : "scrollTop"] = -newTranslate; - } else { - if (!swiper.support.smoothScroll) { - animateCSSModeScroll({ - swiper, - targetPosition: -newTranslate, - side: isH ? "left" : "top", - }); - return true; - } - - wrapperEl.scrollTo({ - [isH ? "left" : "top"]: -newTranslate, - behavior: "smooth", - }); - } - - return true; - } - - if (speed === 0) { - swiper.setTransition(0); - swiper.setTranslate(newTranslate); - - if (runCallbacks) { - swiper.emit("beforeTransitionStart", speed, internal); - swiper.emit("transitionEnd"); - } - } else { - swiper.setTransition(speed); - swiper.setTranslate(newTranslate); - - if (runCallbacks) { - swiper.emit("beforeTransitionStart", speed, internal); - swiper.emit("transitionStart"); - } - - if (!swiper.animating) { - swiper.animating = true; - - if (!swiper.onTranslateToWrapperTransitionEnd) { - swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) { - if (!swiper || swiper.destroyed) return; - if (e.target !== this) return; - swiper.$wrapperEl[0].removeEventListener( - "transitionend", - swiper.onTranslateToWrapperTransitionEnd, - ); - swiper.$wrapperEl[0].removeEventListener( - "webkitTransitionEnd", - swiper.onTranslateToWrapperTransitionEnd, - ); - swiper.onTranslateToWrapperTransitionEnd = null; - delete swiper.onTranslateToWrapperTransitionEnd; - - if (runCallbacks) { - swiper.emit("transitionEnd"); - } - }; - } - - swiper.$wrapperEl[0].addEventListener( - "transitionend", - swiper.onTranslateToWrapperTransitionEnd, - ); - swiper.$wrapperEl[0].addEventListener( - "webkitTransitionEnd", - swiper.onTranslateToWrapperTransitionEnd, - ); - } - } - - return true; - } - - var translate = { - getTranslate: getSwiperTranslate, - setTranslate, - minTranslate, - maxTranslate, - translateTo, - }; - - function setTransition(duration, byController) { - const swiper = this; - - if (!swiper.params.cssMode) { - swiper.$wrapperEl.transition(duration); - } - - swiper.emit("setTransition", duration, byController); - } - - function transitionEmit(_ref) { - let { swiper, runCallbacks, direction, step } = _ref; - const { activeIndex, previousIndex } = swiper; - let dir = direction; - - if (!dir) { - if (activeIndex > previousIndex) dir = "next"; - else if (activeIndex < previousIndex) dir = "prev"; - else dir = "reset"; - } - - swiper.emit(`transition${step}`); - - if (runCallbacks && activeIndex !== previousIndex) { - if (dir === "reset") { - swiper.emit(`slideResetTransition${step}`); - return; - } - - swiper.emit(`slideChangeTransition${step}`); - - if (dir === "next") { - swiper.emit(`slideNextTransition${step}`); - } else { - swiper.emit(`slidePrevTransition${step}`); - } - } - } - - function transitionStart(runCallbacks, direction) { - if (runCallbacks === void 0) { - runCallbacks = true; - } - - const swiper = this; - const { params } = swiper; - if (params.cssMode) return; - - if (params.autoHeight) { - swiper.updateAutoHeight(); - } - - transitionEmit({ - swiper, - runCallbacks, - direction, - step: "Start", - }); - } - - function transitionEnd(runCallbacks, direction) { - if (runCallbacks === void 0) { - runCallbacks = true; - } - - const swiper = this; - const { params } = swiper; - swiper.animating = false; - if (params.cssMode) return; - swiper.setTransition(0); - transitionEmit({ - swiper, - runCallbacks, - direction, - step: "End", - }); - } - - var transition = { - setTransition, - transitionStart, - transitionEnd, - }; - - function slideTo(index, speed, runCallbacks, internal, initial) { - if (index === void 0) { - index = 0; - } - - if (speed === void 0) { - speed = this.params.speed; - } - - if (runCallbacks === void 0) { - runCallbacks = true; - } - - if (typeof index !== "number" && typeof index !== "string") { - throw new Error( - `The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`, - ); - } - - if (typeof index === "string") { - /** - * The `index` argument converted from `string` to `number`. - * @type {number} - */ - const indexAsNumber = parseInt(index, 10); - /** - * Determines whether the `index` argument is a valid `number` - * after being converted from the `string` type. - * @type {boolean} - */ - - const isValidNumber = isFinite(indexAsNumber); - - if (!isValidNumber) { - throw new Error( - `The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`, - ); - } // Knowing that the converted `index` is a valid number, - // we can update the original argument's value. - - index = indexAsNumber; - } - - const swiper = this; - let slideIndex = index; - if (slideIndex < 0) slideIndex = 0; - const { - params, - snapGrid, - slidesGrid, - previousIndex, - activeIndex, - rtlTranslate: rtl, - wrapperEl, - enabled, - } = swiper; - - if ( - (swiper.animating && params.preventInteractionOnTransition) || - (!enabled && !internal && !initial) - ) { - return false; - } - - const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex); - let snapIndex = - skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup); - if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1; - - if ( - (activeIndex || params.initialSlide || 0) === (previousIndex || 0) && - runCallbacks - ) { - swiper.emit("beforeSlideChangeStart"); - } - - const translate = -snapGrid[snapIndex]; // Update progress - - swiper.updateProgress(translate); // Normalize slideIndex - - if (params.normalizeSlideIndex) { - for (let i = 0; i < slidesGrid.length; i += 1) { - const normalizedTranslate = -Math.floor(translate * 100); - const normalizedGrid = Math.floor(slidesGrid[i] * 100); - const normalizedGridNext = Math.floor(slidesGrid[i + 1] * 100); - - if (typeof slidesGrid[i + 1] !== "undefined") { - if ( - normalizedTranslate >= normalizedGrid && - normalizedTranslate < - normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2 - ) { - slideIndex = i; - } else if ( - normalizedTranslate >= normalizedGrid && - normalizedTranslate < normalizedGridNext - ) { - slideIndex = i + 1; - } - } else if (normalizedTranslate >= normalizedGrid) { - slideIndex = i; - } - } - } // Directions locks - - if (swiper.initialized && slideIndex !== activeIndex) { - if ( - !swiper.allowSlideNext && - translate < swiper.translate && - translate < swiper.minTranslate() - ) { - return false; - } - - if ( - !swiper.allowSlidePrev && - translate > swiper.translate && - translate > swiper.maxTranslate() - ) { - if ((activeIndex || 0) !== slideIndex) return false; - } - } - - let direction; - if (slideIndex > activeIndex) direction = "next"; - else if (slideIndex < activeIndex) direction = "prev"; - else direction = "reset"; // Update Index - - if ( - (rtl && -translate === swiper.translate) || - (!rtl && translate === swiper.translate) - ) { - swiper.updateActiveIndex(slideIndex); // Update Height - - if (params.autoHeight) { - swiper.updateAutoHeight(); - } - - swiper.updateSlidesClasses(); - - if (params.effect !== "slide") { - swiper.setTranslate(translate); - } - - if (direction !== "reset") { - swiper.transitionStart(runCallbacks, direction); - swiper.transitionEnd(runCallbacks, direction); - } - - return false; - } - - if (params.cssMode) { - const isH = swiper.isHorizontal(); - const t = rtl ? translate : -translate; - - if (speed === 0) { - const isVirtual = swiper.virtual && swiper.params.virtual.enabled; - - if (isVirtual) { - swiper.wrapperEl.style.scrollSnapType = "none"; - swiper._immediateVirtual = true; - } - - wrapperEl[isH ? "scrollLeft" : "scrollTop"] = t; - - if (isVirtual) { - requestAnimationFrame(() => { - swiper.wrapperEl.style.scrollSnapType = ""; - swiper._swiperImmediateVirtual = false; - }); - } - } else { - if (!swiper.support.smoothScroll) { - animateCSSModeScroll({ - swiper, - targetPosition: t, - side: isH ? "left" : "top", - }); - return true; - } - - wrapperEl.scrollTo({ - [isH ? "left" : "top"]: t, - behavior: "smooth", - }); - } - - return true; - } - - swiper.setTransition(speed); - swiper.setTranslate(translate); - swiper.updateActiveIndex(slideIndex); - swiper.updateSlidesClasses(); - swiper.emit("beforeTransitionStart", speed, internal); - swiper.transitionStart(runCallbacks, direction); - - if (speed === 0) { - swiper.transitionEnd(runCallbacks, direction); - } else if (!swiper.animating) { - swiper.animating = true; - - if (!swiper.onSlideToWrapperTransitionEnd) { - swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) { - if (!swiper || swiper.destroyed) return; - if (e.target !== this) return; - swiper.$wrapperEl[0].removeEventListener( - "transitionend", - swiper.onSlideToWrapperTransitionEnd, - ); - swiper.$wrapperEl[0].removeEventListener( - "webkitTransitionEnd", - swiper.onSlideToWrapperTransitionEnd, - ); - swiper.onSlideToWrapperTransitionEnd = null; - delete swiper.onSlideToWrapperTransitionEnd; - swiper.transitionEnd(runCallbacks, direction); - }; - } - - swiper.$wrapperEl[0].addEventListener( - "transitionend", - swiper.onSlideToWrapperTransitionEnd, - ); - swiper.$wrapperEl[0].addEventListener( - "webkitTransitionEnd", - swiper.onSlideToWrapperTransitionEnd, - ); - } - - return true; - } - - function slideToLoop(index, speed, runCallbacks, internal) { - if (index === void 0) { - index = 0; - } - - if (speed === void 0) { - speed = this.params.speed; - } - - if (runCallbacks === void 0) { - runCallbacks = true; - } - - const swiper = this; - let newIndex = index; - - if (swiper.params.loop) { - newIndex += swiper.loopedSlides; - } - - return swiper.slideTo(newIndex, speed, runCallbacks, internal); - } - - /* eslint no-unused-vars: "off" */ - function slideNext(speed, runCallbacks, internal) { - if (speed === void 0) { - speed = this.params.speed; - } - - if (runCallbacks === void 0) { - runCallbacks = true; - } - - const swiper = this; - const { animating, enabled, params } = swiper; - if (!enabled) return swiper; - let perGroup = params.slidesPerGroup; - - if ( - params.slidesPerView === "auto" && - params.slidesPerGroup === 1 && - params.slidesPerGroupAuto - ) { - perGroup = Math.max(swiper.slidesPerViewDynamic("current", true), 1); - } - - const increment = - swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup; - - if (params.loop) { - if (animating && params.loopPreventsSlide) return false; - swiper.loopFix(); // eslint-disable-next-line - - swiper._clientLeft = swiper.$wrapperEl[0].clientLeft; - } - - if (params.rewind && swiper.isEnd) { - return swiper.slideTo(0, speed, runCallbacks, internal); - } - - return swiper.slideTo( - swiper.activeIndex + increment, - speed, - runCallbacks, - internal, - ); - } - - /* eslint no-unused-vars: "off" */ - function slidePrev(speed, runCallbacks, internal) { - if (speed === void 0) { - speed = this.params.speed; - } - - if (runCallbacks === void 0) { - runCallbacks = true; - } - - const swiper = this; - const { params, animating, snapGrid, slidesGrid, rtlTranslate, enabled } = - swiper; - if (!enabled) return swiper; - - if (params.loop) { - if (animating && params.loopPreventsSlide) return false; - swiper.loopFix(); // eslint-disable-next-line - - swiper._clientLeft = swiper.$wrapperEl[0].clientLeft; - } - - const translate = rtlTranslate ? swiper.translate : -swiper.translate; - - function normalize(val) { - if (val < 0) return -Math.floor(Math.abs(val)); - return Math.floor(val); - } - - const normalizedTranslate = normalize(translate); - const normalizedSnapGrid = snapGrid.map((val) => normalize(val)); - let prevSnap = - snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1]; - - if (typeof prevSnap === "undefined" && params.cssMode) { - let prevSnapIndex; - snapGrid.forEach((snap, snapIndex) => { - if (normalizedTranslate >= snap) { - // prevSnap = snap; - prevSnapIndex = snapIndex; - } - }); - - if (typeof prevSnapIndex !== "undefined") { - prevSnap = - snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex]; - } - } - - let prevIndex = 0; - - if (typeof prevSnap !== "undefined") { - prevIndex = slidesGrid.indexOf(prevSnap); - if (prevIndex < 0) prevIndex = swiper.activeIndex - 1; - - if ( - params.slidesPerView === "auto" && - params.slidesPerGroup === 1 && - params.slidesPerGroupAuto - ) { - prevIndex = - prevIndex - swiper.slidesPerViewDynamic("previous", true) + 1; - prevIndex = Math.max(prevIndex, 0); - } - } - - if (params.rewind && swiper.isBeginning) { - const lastIndex = - swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual - ? swiper.virtual.slides.length - 1 - : swiper.slides.length - 1; - return swiper.slideTo(lastIndex, speed, runCallbacks, internal); - } - - return swiper.slideTo(prevIndex, speed, runCallbacks, internal); - } - - /* eslint no-unused-vars: "off" */ - function slideReset(speed, runCallbacks, internal) { - if (speed === void 0) { - speed = this.params.speed; - } - - if (runCallbacks === void 0) { - runCallbacks = true; - } - - const swiper = this; - return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal); - } - - /* eslint no-unused-vars: "off" */ - function slideToClosest(speed, runCallbacks, internal, threshold) { - if (speed === void 0) { - speed = this.params.speed; - } - - if (runCallbacks === void 0) { - runCallbacks = true; - } - - if (threshold === void 0) { - threshold = 0.5; - } - - const swiper = this; - let index = swiper.activeIndex; - const skip = Math.min(swiper.params.slidesPerGroupSkip, index); - const snapIndex = - skip + Math.floor((index - skip) / swiper.params.slidesPerGroup); - const translate = swiper.rtlTranslate - ? swiper.translate - : -swiper.translate; - - if (translate >= swiper.snapGrid[snapIndex]) { - // The current translate is on or after the current snap index, so the choice - // is between the current index and the one after it. - const currentSnap = swiper.snapGrid[snapIndex]; - const nextSnap = swiper.snapGrid[snapIndex + 1]; - - if (translate - currentSnap > (nextSnap - currentSnap) * threshold) { - index += swiper.params.slidesPerGroup; - } - } else { - // The current translate is before the current snap index, so the choice - // is between the current index and the one before it. - const prevSnap = swiper.snapGrid[snapIndex - 1]; - const currentSnap = swiper.snapGrid[snapIndex]; - - if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) { - index -= swiper.params.slidesPerGroup; - } - } - - index = Math.max(index, 0); - index = Math.min(index, swiper.slidesGrid.length - 1); - return swiper.slideTo(index, speed, runCallbacks, internal); - } - - function slideToClickedSlide() { - const swiper = this; - const { params, $wrapperEl } = swiper; - const slidesPerView = - params.slidesPerView === "auto" - ? swiper.slidesPerViewDynamic() - : params.slidesPerView; - let slideToIndex = swiper.clickedIndex; - let realIndex; - - if (params.loop) { - if (swiper.animating) return; - realIndex = parseInt( - $(swiper.clickedSlide).attr("data-swiper-slide-index"), - 10, - ); - - if (params.centeredSlides) { - if ( - slideToIndex < swiper.loopedSlides - slidesPerView / 2 || - slideToIndex > - swiper.slides.length - swiper.loopedSlides + slidesPerView / 2 - ) { - swiper.loopFix(); - slideToIndex = $wrapperEl - .children( - `.${params.slideClass}[data-swiper-slide-index="${realIndex}"]:not(.${params.slideDuplicateClass})`, - ) - .eq(0) - .index(); - nextTick(() => { - swiper.slideTo(slideToIndex); - }); - } else { - swiper.slideTo(slideToIndex); - } - } else if (slideToIndex > swiper.slides.length - slidesPerView) { - swiper.loopFix(); - slideToIndex = $wrapperEl - .children( - `.${params.slideClass}[data-swiper-slide-index="${realIndex}"]:not(.${params.slideDuplicateClass})`, - ) - .eq(0) - .index(); - nextTick(() => { - swiper.slideTo(slideToIndex); - }); - } else { - swiper.slideTo(slideToIndex); - } - } else { - swiper.slideTo(slideToIndex); - } - } - - var slide = { - slideTo, - slideToLoop, - slideNext, - slidePrev, - slideReset, - slideToClosest, - slideToClickedSlide, - }; - - function loopCreate() { - const swiper = this; - const document = getDocument(); - const { params, $wrapperEl } = swiper; // Remove duplicated slides - - const $selector = - $wrapperEl.children().length > 0 - ? $($wrapperEl.children()[0].parentNode) - : $wrapperEl; - $selector - .children(`.${params.slideClass}.${params.slideDuplicateClass}`) - .remove(); - let slides = $selector.children(`.${params.slideClass}`); - - if (params.loopFillGroupWithBlank) { - const blankSlidesNum = - params.slidesPerGroup - (slides.length % params.slidesPerGroup); - - if (blankSlidesNum !== params.slidesPerGroup) { - for (let i = 0; i < blankSlidesNum; i += 1) { - const blankNode = $(document.createElement("div")).addClass( - `${params.slideClass} ${params.slideBlankClass}`, - ); - $selector.append(blankNode); - } - - slides = $selector.children(`.${params.slideClass}`); - } - } - - if (params.slidesPerView === "auto" && !params.loopedSlides) - params.loopedSlides = slides.length; - swiper.loopedSlides = Math.ceil( - parseFloat(params.loopedSlides || params.slidesPerView, 10), - ); - swiper.loopedSlides += params.loopAdditionalSlides; - - if (swiper.loopedSlides > slides.length) { - swiper.loopedSlides = slides.length; - } - - const prependSlides = []; - const appendSlides = []; - slides.each((el, index) => { - const slide = $(el); - - if (index < swiper.loopedSlides) { - appendSlides.push(el); - } - - if ( - index < slides.length && - index >= slides.length - swiper.loopedSlides - ) { - prependSlides.push(el); - } - - slide.attr("data-swiper-slide-index", index); - }); - - for (let i = 0; i < appendSlides.length; i += 1) { - $selector.append( - $(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass), - ); - } - - for (let i = prependSlides.length - 1; i >= 0; i -= 1) { - $selector.prepend( - $(prependSlides[i].cloneNode(true)).addClass( - params.slideDuplicateClass, - ), - ); - } - } - - function loopFix() { - const swiper = this; - swiper.emit("beforeLoopFix"); - const { - activeIndex, - slides, - loopedSlides, - allowSlidePrev, - allowSlideNext, - snapGrid, - rtlTranslate: rtl, - } = swiper; - let newIndex; - swiper.allowSlidePrev = true; - swiper.allowSlideNext = true; - const snapTranslate = -snapGrid[activeIndex]; - const diff = snapTranslate - swiper.getTranslate(); // Fix For Negative Oversliding - - if (activeIndex < loopedSlides) { - newIndex = slides.length - loopedSlides * 3 + activeIndex; - newIndex += loopedSlides; - const slideChanged = swiper.slideTo(newIndex, 0, false, true); - - if (slideChanged && diff !== 0) { - swiper.setTranslate( - (rtl ? -swiper.translate : swiper.translate) - diff, - ); - } - } else if (activeIndex >= slides.length - loopedSlides) { - // Fix For Positive Oversliding - newIndex = -slides.length + activeIndex + loopedSlides; - newIndex += loopedSlides; - const slideChanged = swiper.slideTo(newIndex, 0, false, true); - - if (slideChanged && diff !== 0) { - swiper.setTranslate( - (rtl ? -swiper.translate : swiper.translate) - diff, - ); - } - } - - swiper.allowSlidePrev = allowSlidePrev; - swiper.allowSlideNext = allowSlideNext; - swiper.emit("loopFix"); - } - - function loopDestroy() { - const swiper = this; - const { $wrapperEl, params, slides } = swiper; - $wrapperEl - .children( - `.${params.slideClass}.${params.slideDuplicateClass},.${params.slideClass}.${params.slideBlankClass}`, - ) - .remove(); - slides.removeAttr("data-swiper-slide-index"); - } - - var loop = { - loopCreate, - loopFix, - loopDestroy, - }; - - function setGrabCursor(moving) { - const swiper = this; - if ( - swiper.support.touch || - !swiper.params.simulateTouch || - (swiper.params.watchOverflow && swiper.isLocked) || - swiper.params.cssMode - ) - return; - const el = - swiper.params.touchEventsTarget === "container" - ? swiper.el - : swiper.wrapperEl; - el.style.cursor = "move"; - el.style.cursor = moving ? "-webkit-grabbing" : "-webkit-grab"; - el.style.cursor = moving ? "-moz-grabbin" : "-moz-grab"; - el.style.cursor = moving ? "grabbing" : "grab"; - } - - function unsetGrabCursor() { - const swiper = this; - - if ( - swiper.support.touch || - (swiper.params.watchOverflow && swiper.isLocked) || - swiper.params.cssMode - ) { - return; - } - - swiper[ - swiper.params.touchEventsTarget === "container" ? "el" : "wrapperEl" - ].style.cursor = ""; - } - - var grabCursor = { - setGrabCursor, - unsetGrabCursor, - }; - - function closestElement(selector, base) { - if (base === void 0) { - base = this; - } - - function __closestFrom(el) { - if (!el || el === getDocument() || el === getWindow()) return null; - if (el.assignedSlot) el = el.assignedSlot; - const found = el.closest(selector); - return found || __closestFrom(el.getRootNode().host); - } - - return __closestFrom(base); - } - - function onTouchStart(event) { - const swiper = this; - const document = getDocument(); - const window = getWindow(); - const data = swiper.touchEventsData; - const { params, touches, enabled } = swiper; - if (!enabled) return; - - if (swiper.animating && params.preventInteractionOnTransition) { - return; - } - - if (!swiper.animating && params.cssMode && params.loop) { - swiper.loopFix(); - } - - let e = event; - if (e.originalEvent) e = e.originalEvent; - let $targetEl = $(e.target); - - if (params.touchEventsTarget === "wrapper") { - if (!$targetEl.closest(swiper.wrapperEl).length) return; - } - - data.isTouchEvent = e.type === "touchstart"; - if (!data.isTouchEvent && "which" in e && e.which === 3) return; - if (!data.isTouchEvent && "button" in e && e.button > 0) return; - if (data.isTouched && data.isMoved) return; // change target el for shadow root component - - const swipingClassHasValue = - !!params.noSwipingClass && params.noSwipingClass !== ""; - - if ( - swipingClassHasValue && - e.target && - e.target.shadowRoot && - event.path && - event.path[0] - ) { - $targetEl = $(event.path[0]); - } - - const noSwipingSelector = params.noSwipingSelector - ? params.noSwipingSelector - : `.${params.noSwipingClass}`; - const isTargetShadow = !!(e.target && e.target.shadowRoot); // use closestElement for shadow root element to get the actual closest for nested shadow root element - - if ( - params.noSwiping && - (isTargetShadow - ? closestElement(noSwipingSelector, e.target) - : $targetEl.closest(noSwipingSelector)[0]) - ) { - swiper.allowClick = true; - return; - } - - if (params.swipeHandler) { - if (!$targetEl.closest(params.swipeHandler)[0]) return; - } - - touches.currentX = - e.type === "touchstart" ? e.targetTouches[0].pageX : e.pageX; - touches.currentY = - e.type === "touchstart" ? e.targetTouches[0].pageY : e.pageY; - const startX = touches.currentX; - const startY = touches.currentY; // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore - - const edgeSwipeDetection = - params.edgeSwipeDetection || params.iOSEdgeSwipeDetection; - const edgeSwipeThreshold = - params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold; - - if ( - edgeSwipeDetection && - (startX <= edgeSwipeThreshold || - startX >= window.innerWidth - edgeSwipeThreshold) - ) { - if (edgeSwipeDetection === "prevent") { - event.preventDefault(); - } else { - return; - } - } - - Object.assign(data, { - isTouched: true, - isMoved: false, - allowTouchCallbacks: true, - isScrolling: undefined, - startMoving: undefined, - }); - touches.startX = startX; - touches.startY = startY; - data.touchStartTime = now(); - swiper.allowClick = true; - swiper.updateSize(); - swiper.swipeDirection = undefined; - if (params.threshold > 0) data.allowThresholdMove = false; - - if (e.type !== "touchstart") { - let preventDefault = true; - - if ($targetEl.is(data.focusableElements)) { - preventDefault = false; - - if ($targetEl[0].nodeName === "SELECT") { - data.isTouched = false; - } - } - - if ( - document.activeElement && - $(document.activeElement).is(data.focusableElements) && - document.activeElement !== $targetEl[0] - ) { - document.activeElement.blur(); - } - - const shouldPreventDefault = - preventDefault && - swiper.allowTouchMove && - params.touchStartPreventDefault; - - if ( - (params.touchStartForcePreventDefault || shouldPreventDefault) && - !$targetEl[0].isContentEditable - ) { - e.preventDefault(); - } - } - - if ( - swiper.params.freeMode && - swiper.params.freeMode.enabled && - swiper.freeMode && - swiper.animating && - !params.cssMode - ) { - swiper.freeMode.onTouchStart(); - } - - swiper.emit("touchStart", e); - } - - function onTouchMove(event) { - const document = getDocument(); - const swiper = this; - const data = swiper.touchEventsData; - const { params, touches, rtlTranslate: rtl, enabled } = swiper; - if (!enabled) return; - let e = event; - if (e.originalEvent) e = e.originalEvent; - - if (!data.isTouched) { - if (data.startMoving && data.isScrolling) { - swiper.emit("touchMoveOpposite", e); - } - - return; - } - - if (data.isTouchEvent && e.type !== "touchmove") return; - const targetTouch = - e.type === "touchmove" && - e.targetTouches && - (e.targetTouches[0] || e.changedTouches[0]); - const pageX = e.type === "touchmove" ? targetTouch.pageX : e.pageX; - const pageY = e.type === "touchmove" ? targetTouch.pageY : e.pageY; - - if (e.preventedByNestedSwiper) { - touches.startX = pageX; - touches.startY = pageY; - return; - } - - if (!swiper.allowTouchMove) { - if (!$(e.target).is(data.focusableElements)) { - swiper.allowClick = false; - } - - if (data.isTouched) { - Object.assign(touches, { - startX: pageX, - startY: pageY, - currentX: pageX, - currentY: pageY, - }); - data.touchStartTime = now(); - } - - return; - } - - if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) { - if (swiper.isVertical()) { - // Vertical - if ( - (pageY < touches.startY && - swiper.translate <= swiper.maxTranslate()) || - (pageY > touches.startY && swiper.translate >= swiper.minTranslate()) - ) { - data.isTouched = false; - data.isMoved = false; - return; - } - } else if ( - (pageX < touches.startX && swiper.translate <= swiper.maxTranslate()) || - (pageX > touches.startX && swiper.translate >= swiper.minTranslate()) - ) { - return; - } - } - - if (data.isTouchEvent && document.activeElement) { - if ( - e.target === document.activeElement && - $(e.target).is(data.focusableElements) - ) { - data.isMoved = true; - swiper.allowClick = false; - return; - } - } - - if (data.allowTouchCallbacks) { - swiper.emit("touchMove", e); - } - - if (e.targetTouches && e.targetTouches.length > 1) return; - touches.currentX = pageX; - touches.currentY = pageY; - const diffX = touches.currentX - touches.startX; - const diffY = touches.currentY - touches.startY; - if ( - swiper.params.threshold && - Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold - ) - return; - - if (typeof data.isScrolling === "undefined") { - let touchAngle; - - if ( - (swiper.isHorizontal() && touches.currentY === touches.startY) || - (swiper.isVertical() && touches.currentX === touches.startX) - ) { - data.isScrolling = false; - } else { - // eslint-disable-next-line - if (diffX * diffX + diffY * diffY >= 25) { - touchAngle = - (Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180) / Math.PI; - data.isScrolling = swiper.isHorizontal() - ? touchAngle > params.touchAngle - : 90 - touchAngle > params.touchAngle; - } - } - } - - if (data.isScrolling) { - swiper.emit("touchMoveOpposite", e); - } - - if (typeof data.startMoving === "undefined") { - if ( - touches.currentX !== touches.startX || - touches.currentY !== touches.startY - ) { - data.startMoving = true; - } - } - - if (data.isScrolling) { - data.isTouched = false; - return; - } - - if (!data.startMoving) { - return; - } - - swiper.allowClick = false; - - if (!params.cssMode && e.cancelable) { - e.preventDefault(); - } - - if (params.touchMoveStopPropagation && !params.nested) { - e.stopPropagation(); - } - - if (!data.isMoved) { - if (params.loop && !params.cssMode) { - swiper.loopFix(); - } - - data.startTranslate = swiper.getTranslate(); - swiper.setTransition(0); - - if (swiper.animating) { - swiper.$wrapperEl.trigger("webkitTransitionEnd transitionend"); - } - - data.allowMomentumBounce = false; // Grab Cursor - - if ( - params.grabCursor && - (swiper.allowSlideNext === true || swiper.allowSlidePrev === true) - ) { - swiper.setGrabCursor(true); - } - - swiper.emit("sliderFirstMove", e); - } - - swiper.emit("sliderMove", e); - data.isMoved = true; - let diff = swiper.isHorizontal() ? diffX : diffY; - touches.diff = diff; - diff *= params.touchRatio; - if (rtl) diff = -diff; - swiper.swipeDirection = diff > 0 ? "prev" : "next"; - data.currentTranslate = diff + data.startTranslate; - let disableParentSwiper = true; - let resistanceRatio = params.resistanceRatio; - - if (params.touchReleaseOnEdges) { - resistanceRatio = 0; - } - - if (diff > 0 && data.currentTranslate > swiper.minTranslate()) { - disableParentSwiper = false; - if (params.resistance) - data.currentTranslate = - swiper.minTranslate() - - 1 + - (-swiper.minTranslate() + data.startTranslate + diff) ** - resistanceRatio; - } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) { - disableParentSwiper = false; - if (params.resistance) - data.currentTranslate = - swiper.maxTranslate() + - 1 - - (swiper.maxTranslate() - data.startTranslate - diff) ** - resistanceRatio; - } - - if (disableParentSwiper) { - e.preventedByNestedSwiper = true; - } // Directions locks - - if ( - !swiper.allowSlideNext && - swiper.swipeDirection === "next" && - data.currentTranslate < data.startTranslate - ) { - data.currentTranslate = data.startTranslate; - } - - if ( - !swiper.allowSlidePrev && - swiper.swipeDirection === "prev" && - data.currentTranslate > data.startTranslate - ) { - data.currentTranslate = data.startTranslate; - } - - if (!swiper.allowSlidePrev && !swiper.allowSlideNext) { - data.currentTranslate = data.startTranslate; - } // Threshold - - if (params.threshold > 0) { - if (Math.abs(diff) > params.threshold || data.allowThresholdMove) { - if (!data.allowThresholdMove) { - data.allowThresholdMove = true; - touches.startX = touches.currentX; - touches.startY = touches.currentY; - data.currentTranslate = data.startTranslate; - touches.diff = swiper.isHorizontal() - ? touches.currentX - touches.startX - : touches.currentY - touches.startY; - return; - } - } else { - data.currentTranslate = data.startTranslate; - return; - } - } - - if (!params.followFinger || params.cssMode) return; // Update active index in free mode - - if ( - (params.freeMode && params.freeMode.enabled && swiper.freeMode) || - params.watchSlidesProgress - ) { - swiper.updateActiveIndex(); - swiper.updateSlidesClasses(); - } - - if (swiper.params.freeMode && params.freeMode.enabled && swiper.freeMode) { - swiper.freeMode.onTouchMove(); - } // Update progress - - swiper.updateProgress(data.currentTranslate); // Update translate - - swiper.setTranslate(data.currentTranslate); - } - - function onTouchEnd(event) { - const swiper = this; - const data = swiper.touchEventsData; - const { params, touches, rtlTranslate: rtl, slidesGrid, enabled } = swiper; - if (!enabled) return; - let e = event; - if (e.originalEvent) e = e.originalEvent; - - if (data.allowTouchCallbacks) { - swiper.emit("touchEnd", e); - } - - data.allowTouchCallbacks = false; - - if (!data.isTouched) { - if (data.isMoved && params.grabCursor) { - swiper.setGrabCursor(false); - } - - data.isMoved = false; - data.startMoving = false; - return; - } // Return Grab Cursor - - if ( - params.grabCursor && - data.isMoved && - data.isTouched && - (swiper.allowSlideNext === true || swiper.allowSlidePrev === true) - ) { - swiper.setGrabCursor(false); - } // Time diff - - const touchEndTime = now(); - const timeDiff = touchEndTime - data.touchStartTime; // Tap, doubleTap, Click - - if (swiper.allowClick) { - const pathTree = e.path || (e.composedPath && e.composedPath()); - swiper.updateClickedSlide((pathTree && pathTree[0]) || e.target); - swiper.emit("tap click", e); - - if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) { - swiper.emit("doubleTap doubleClick", e); - } - } - - data.lastClickTime = now(); - nextTick(() => { - if (!swiper.destroyed) swiper.allowClick = true; - }); - - if ( - !data.isTouched || - !data.isMoved || - !swiper.swipeDirection || - touches.diff === 0 || - data.currentTranslate === data.startTranslate - ) { - data.isTouched = false; - data.isMoved = false; - data.startMoving = false; - return; - } - - data.isTouched = false; - data.isMoved = false; - data.startMoving = false; - let currentPos; - - if (params.followFinger) { - currentPos = rtl ? swiper.translate : -swiper.translate; - } else { - currentPos = -data.currentTranslate; - } - - if (params.cssMode) { - return; - } - - if (swiper.params.freeMode && params.freeMode.enabled) { - swiper.freeMode.onTouchEnd({ - currentPos, - }); - return; - } // Find current slide - - let stopIndex = 0; - let groupSize = swiper.slidesSizesGrid[0]; - - for ( - let i = 0; - i < slidesGrid.length; - i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup - ) { - const increment = - i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup; - - if (typeof slidesGrid[i + increment] !== "undefined") { - if ( - currentPos >= slidesGrid[i] && - currentPos < slidesGrid[i + increment] - ) { - stopIndex = i; - groupSize = slidesGrid[i + increment] - slidesGrid[i]; - } - } else if (currentPos >= slidesGrid[i]) { - stopIndex = i; - groupSize = - slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2]; - } - } - - let rewindFirstIndex = null; - let rewindLastIndex = null; - - if (params.rewind) { - if (swiper.isBeginning) { - rewindLastIndex = - swiper.params.virtual && - swiper.params.virtual.enabled && - swiper.virtual - ? swiper.virtual.slides.length - 1 - : swiper.slides.length - 1; - } else if (swiper.isEnd) { - rewindFirstIndex = 0; - } - } // Find current slide size - - const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize; - const increment = - stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup; - - if (timeDiff > params.longSwipesMs) { - // Long touches - if (!params.longSwipes) { - swiper.slideTo(swiper.activeIndex); - return; - } - - if (swiper.swipeDirection === "next") { - if (ratio >= params.longSwipesRatio) - swiper.slideTo( - params.rewind && swiper.isEnd - ? rewindFirstIndex - : stopIndex + increment, - ); - else swiper.slideTo(stopIndex); - } - - if (swiper.swipeDirection === "prev") { - if (ratio > 1 - params.longSwipesRatio) { - swiper.slideTo(stopIndex + increment); - } else if ( - rewindLastIndex !== null && - ratio < 0 && - Math.abs(ratio) > params.longSwipesRatio - ) { - swiper.slideTo(rewindLastIndex); - } else { - swiper.slideTo(stopIndex); - } - } - } else { - // Short swipes - if (!params.shortSwipes) { - swiper.slideTo(swiper.activeIndex); - return; - } - - const isNavButtonTarget = - swiper.navigation && - (e.target === swiper.navigation.nextEl || - e.target === swiper.navigation.prevEl); - - if (!isNavButtonTarget) { - if (swiper.swipeDirection === "next") { - swiper.slideTo( - rewindFirstIndex !== null - ? rewindFirstIndex - : stopIndex + increment, - ); - } - - if (swiper.swipeDirection === "prev") { - swiper.slideTo( - rewindLastIndex !== null ? rewindLastIndex : stopIndex, - ); - } - } else if (e.target === swiper.navigation.nextEl) { - swiper.slideTo(stopIndex + increment); - } else { - swiper.slideTo(stopIndex); - } - } - } - - function onResize() { - const swiper = this; - const { params, el } = swiper; - if (el && el.offsetWidth === 0) return; // Breakpoints - - if (params.breakpoints) { - swiper.setBreakpoint(); - } // Save locks - - const { allowSlideNext, allowSlidePrev, snapGrid } = swiper; // Disable locks on resize - - swiper.allowSlideNext = true; - swiper.allowSlidePrev = true; - swiper.updateSize(); - swiper.updateSlides(); - swiper.updateSlidesClasses(); - - if ( - (params.slidesPerView === "auto" || params.slidesPerView > 1) && - swiper.isEnd && - !swiper.isBeginning && - !swiper.params.centeredSlides - ) { - swiper.slideTo(swiper.slides.length - 1, 0, false, true); - } else { - swiper.slideTo(swiper.activeIndex, 0, false, true); - } - - if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) { - swiper.autoplay.run(); - } // Return locks after resize - - swiper.allowSlidePrev = allowSlidePrev; - swiper.allowSlideNext = allowSlideNext; - - if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) { - swiper.checkOverflow(); - } - } - - function onClick(e) { - const swiper = this; - if (!swiper.enabled) return; - - if (!swiper.allowClick) { - if (swiper.params.preventClicks) e.preventDefault(); - - if (swiper.params.preventClicksPropagation && swiper.animating) { - e.stopPropagation(); - e.stopImmediatePropagation(); - } - } - } - - function onScroll() { - const swiper = this; - const { wrapperEl, rtlTranslate, enabled } = swiper; - if (!enabled) return; - swiper.previousTranslate = swiper.translate; - - if (swiper.isHorizontal()) { - swiper.translate = -wrapperEl.scrollLeft; - } else { - swiper.translate = -wrapperEl.scrollTop; - } // eslint-disable-next-line - - if (swiper.translate === -0) swiper.translate = 0; - swiper.updateActiveIndex(); - swiper.updateSlidesClasses(); - let newProgress; - const translatesDiff = swiper.maxTranslate() - swiper.minTranslate(); - - if (translatesDiff === 0) { - newProgress = 0; - } else { - newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff; - } - - if (newProgress !== swiper.progress) { - swiper.updateProgress( - rtlTranslate ? -swiper.translate : swiper.translate, - ); - } - - swiper.emit("setTranslate", swiper.translate, false); - } - - let dummyEventAttached = false; - - function dummyEventListener() {} - - const events = (swiper, method) => { - const document = getDocument(); - const { params, touchEvents, el, wrapperEl, device, support } = swiper; - const capture = !!params.nested; - const domMethod = - method === "on" ? "addEventListener" : "removeEventListener"; - const swiperMethod = method; // Touch Events - - if (!support.touch) { - el[domMethod](touchEvents.start, swiper.onTouchStart, false); - document[domMethod](touchEvents.move, swiper.onTouchMove, capture); - document[domMethod](touchEvents.end, swiper.onTouchEnd, false); - } else { - const passiveListener = - touchEvents.start === "touchstart" && - support.passiveListener && - params.passiveListeners - ? { - passive: true, - capture: false, - } - : false; - el[domMethod](touchEvents.start, swiper.onTouchStart, passiveListener); - el[domMethod]( - touchEvents.move, - swiper.onTouchMove, - support.passiveListener - ? { - passive: false, - capture, - } - : capture, - ); - el[domMethod](touchEvents.end, swiper.onTouchEnd, passiveListener); - - if (touchEvents.cancel) { - el[domMethod](touchEvents.cancel, swiper.onTouchEnd, passiveListener); - } - } // Prevent Links Clicks - - if (params.preventClicks || params.preventClicksPropagation) { - el[domMethod]("click", swiper.onClick, true); - } - - if (params.cssMode) { - wrapperEl[domMethod]("scroll", swiper.onScroll); - } // Resize handler - - if (params.updateOnWindowResize) { - swiper[swiperMethod]( - device.ios || device.android - ? "resize orientationchange observerUpdate" - : "resize observerUpdate", - onResize, - true, - ); - } else { - swiper[swiperMethod]("observerUpdate", onResize, true); - } - }; - - function attachEvents() { - const swiper = this; - const document = getDocument(); - const { params, support } = swiper; - swiper.onTouchStart = onTouchStart.bind(swiper); - swiper.onTouchMove = onTouchMove.bind(swiper); - swiper.onTouchEnd = onTouchEnd.bind(swiper); - - if (params.cssMode) { - swiper.onScroll = onScroll.bind(swiper); - } - - swiper.onClick = onClick.bind(swiper); - - if (support.touch && !dummyEventAttached) { - document.addEventListener("touchstart", dummyEventListener); - dummyEventAttached = true; - } - - events(swiper, "on"); - } - - function detachEvents() { - const swiper = this; - events(swiper, "off"); - } - - var events$1 = { - attachEvents, - detachEvents, - }; - - const isGridEnabled = (swiper, params) => { - return swiper.grid && params.grid && params.grid.rows > 1; - }; - - function setBreakpoint() { - const swiper = this; - const { activeIndex, initialized, loopedSlides = 0, params, $el } = swiper; - const breakpoints = params.breakpoints; - if (!breakpoints || (breakpoints && Object.keys(breakpoints).length === 0)) - return; // Get breakpoint for window width and update parameters - - const breakpoint = swiper.getBreakpoint( - breakpoints, - swiper.params.breakpointsBase, - swiper.el, - ); - if (!breakpoint || swiper.currentBreakpoint === breakpoint) return; - const breakpointOnlyParams = - breakpoint in breakpoints ? breakpoints[breakpoint] : undefined; - const breakpointParams = breakpointOnlyParams || swiper.originalParams; - const wasMultiRow = isGridEnabled(swiper, params); - const isMultiRow = isGridEnabled(swiper, breakpointParams); - const wasEnabled = params.enabled; - - if (wasMultiRow && !isMultiRow) { - $el.removeClass( - `${params.containerModifierClass}grid ${params.containerModifierClass}grid-column`, - ); - swiper.emitContainerClasses(); - } else if (!wasMultiRow && isMultiRow) { - $el.addClass(`${params.containerModifierClass}grid`); - - if ( - (breakpointParams.grid.fill && - breakpointParams.grid.fill === "column") || - (!breakpointParams.grid.fill && params.grid.fill === "column") - ) { - $el.addClass(`${params.containerModifierClass}grid-column`); - } - - swiper.emitContainerClasses(); - } - - const directionChanged = - breakpointParams.direction && - breakpointParams.direction !== params.direction; - const needsReLoop = - params.loop && - (breakpointParams.slidesPerView !== params.slidesPerView || - directionChanged); - - if (directionChanged && initialized) { - swiper.changeDirection(); - } - - extend(swiper.params, breakpointParams); - const isEnabled = swiper.params.enabled; - Object.assign(swiper, { - allowTouchMove: swiper.params.allowTouchMove, - allowSlideNext: swiper.params.allowSlideNext, - allowSlidePrev: swiper.params.allowSlidePrev, - }); - - if (wasEnabled && !isEnabled) { - swiper.disable(); - } else if (!wasEnabled && isEnabled) { - swiper.enable(); - } - - swiper.currentBreakpoint = breakpoint; - swiper.emit("_beforeBreakpoint", breakpointParams); - - if (needsReLoop && initialized) { - swiper.loopDestroy(); - swiper.loopCreate(); - swiper.updateSlides(); - swiper.slideTo( - activeIndex - loopedSlides + swiper.loopedSlides, - 0, - false, - ); - } - - swiper.emit("breakpoint", breakpointParams); - } - - function getBreakpoint(breakpoints, base, containerEl) { - if (base === void 0) { - base = "window"; - } - - if (!breakpoints || (base === "container" && !containerEl)) - return undefined; - let breakpoint = false; - const window = getWindow(); - const currentHeight = - base === "window" ? window.innerHeight : containerEl.clientHeight; - const points = Object.keys(breakpoints).map((point) => { - if (typeof point === "string" && point.indexOf("@") === 0) { - const minRatio = parseFloat(point.substr(1)); - const value = currentHeight * minRatio; - return { - value, - point, - }; - } - - return { - value: point, - point, - }; - }); - points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10)); - - for (let i = 0; i < points.length; i += 1) { - const { point, value } = points[i]; - - if (base === "window") { - if (window.matchMedia(`(min-width: ${value}px)`).matches) { - breakpoint = point; - } - } else if (value <= containerEl.clientWidth) { - breakpoint = point; - } - } - - return breakpoint || "max"; - } - - var breakpoints = { - setBreakpoint, - getBreakpoint, - }; - - function prepareClasses(entries, prefix) { - const resultClasses = []; - entries.forEach((item) => { - if (typeof item === "object") { - Object.keys(item).forEach((classNames) => { - if (item[classNames]) { - resultClasses.push(prefix + classNames); - } - }); - } else if (typeof item === "string") { - resultClasses.push(prefix + item); - } - }); - return resultClasses; - } - - function addClasses() { - const swiper = this; - const { - classNames, - params, - rtl, - $el, - device, - support - } = swiper; // prettier-ignore - - const suffixes = prepareClasses( - [ - "initialized", - params.direction, - { - "pointer-events": !support.touch, - }, - { - "free-mode": swiper.params.freeMode && params.freeMode.enabled, - }, - { - autoheight: params.autoHeight, - }, - { - rtl: rtl, - }, - { - grid: params.grid && params.grid.rows > 1, - }, - { - "grid-column": - params.grid && - params.grid.rows > 1 && - params.grid.fill === "column", - }, - { - android: device.android, - }, - { - ios: device.ios, - }, - { - "css-mode": params.cssMode, - }, - { - centered: params.cssMode && params.centeredSlides, - }, - ], - params.containerModifierClass, - ); - classNames.push(...suffixes); - $el.addClass([...classNames].join(" ")); - swiper.emitContainerClasses(); - } - - function removeClasses() { - const swiper = this; - const { $el, classNames } = swiper; - $el.removeClass(classNames.join(" ")); - swiper.emitContainerClasses(); - } - - var classes = { - addClasses, - removeClasses, - }; - - function loadImage(imageEl, src, srcset, sizes, checkForComplete, callback) { - const window = getWindow(); - let image; - - function onReady() { - if (callback) callback(); - } - - const isPicture = $(imageEl).parent("picture")[0]; - - if (!isPicture && (!imageEl.complete || !checkForComplete)) { - if (src) { - image = new window.Image(); - image.onload = onReady; - image.onerror = onReady; - - if (sizes) { - image.sizes = sizes; - } - - if (srcset) { - image.srcset = srcset; - } - - if (src) { - image.src = src; - } - } else { - onReady(); - } - } else { - // image already loaded... - onReady(); - } - } - - function preloadImages() { - const swiper = this; - swiper.imagesToLoad = swiper.$el.find("img"); - - function onReady() { - if ( - typeof swiper === "undefined" || - swiper === null || - !swiper || - swiper.destroyed - ) - return; - if (swiper.imagesLoaded !== undefined) swiper.imagesLoaded += 1; - - if (swiper.imagesLoaded === swiper.imagesToLoad.length) { - if (swiper.params.updateOnImagesReady) swiper.update(); - swiper.emit("imagesReady"); - } - } - - for (let i = 0; i < swiper.imagesToLoad.length; i += 1) { - const imageEl = swiper.imagesToLoad[i]; - swiper.loadImage( - imageEl, - imageEl.currentSrc || imageEl.getAttribute("src"), - imageEl.srcset || imageEl.getAttribute("srcset"), - imageEl.sizes || imageEl.getAttribute("sizes"), - true, - onReady, - ); - } - } - - var images = { - loadImage, - preloadImages, - }; - - function checkOverflow() { - const swiper = this; - const { isLocked: wasLocked, params } = swiper; - const { slidesOffsetBefore } = params; - - if (slidesOffsetBefore) { - const lastSlideIndex = swiper.slides.length - 1; - const lastSlideRightEdge = - swiper.slidesGrid[lastSlideIndex] + - swiper.slidesSizesGrid[lastSlideIndex] + - slidesOffsetBefore * 2; - swiper.isLocked = swiper.size > lastSlideRightEdge; - } else { - swiper.isLocked = swiper.snapGrid.length === 1; - } - - if (params.allowSlideNext === true) { - swiper.allowSlideNext = !swiper.isLocked; - } - - if (params.allowSlidePrev === true) { - swiper.allowSlidePrev = !swiper.isLocked; - } - - if (wasLocked && wasLocked !== swiper.isLocked) { - swiper.isEnd = false; - } - - if (wasLocked !== swiper.isLocked) { - swiper.emit(swiper.isLocked ? "lock" : "unlock"); - } - } - - var checkOverflow$1 = { - checkOverflow, - }; - - var defaults = { - init: true, - direction: "horizontal", - touchEventsTarget: "wrapper", - initialSlide: 0, - speed: 300, - cssMode: false, - updateOnWindowResize: true, - resizeObserver: true, - nested: false, - createElements: false, - enabled: true, - focusableElements: "input, select, option, textarea, button, video, label", - // Overrides - width: null, - height: null, - // - preventInteractionOnTransition: false, - // ssr - userAgent: null, - url: null, - // To support iOS's swipe-to-go-back gesture (when being used in-app). - edgeSwipeDetection: false, - edgeSwipeThreshold: 20, - // Autoheight - autoHeight: false, - // Set wrapper width - setWrapperSize: false, - // Virtual Translate - virtualTranslate: false, - // Effects - effect: "slide", - // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip' - // Breakpoints - breakpoints: undefined, - breakpointsBase: "window", - // Slides grid - spaceBetween: 0, - slidesPerView: 1, - slidesPerGroup: 1, - slidesPerGroupSkip: 0, - slidesPerGroupAuto: false, - centeredSlides: false, - centeredSlidesBounds: false, - slidesOffsetBefore: 0, - // in px - slidesOffsetAfter: 0, - // in px - normalizeSlideIndex: true, - centerInsufficientSlides: false, - // Disable swiper and hide navigation when container not overflow - watchOverflow: true, - // Round length - roundLengths: false, - // Touches - touchRatio: 1, - touchAngle: 45, - simulateTouch: true, - shortSwipes: true, - longSwipes: true, - longSwipesRatio: 0.5, - longSwipesMs: 300, - followFinger: true, - allowTouchMove: true, - threshold: 0, - touchMoveStopPropagation: false, - touchStartPreventDefault: true, - touchStartForcePreventDefault: false, - touchReleaseOnEdges: false, - // Unique Navigation Elements - uniqueNavElements: true, - // Resistance - resistance: true, - resistanceRatio: 0.85, - // Progress - watchSlidesProgress: false, - // Cursor - grabCursor: false, - // Clicks - preventClicks: true, - preventClicksPropagation: true, - slideToClickedSlide: false, - // Images - preloadImages: true, - updateOnImagesReady: true, - // loop - loop: false, - loopAdditionalSlides: 0, - loopedSlides: null, - loopFillGroupWithBlank: false, - loopPreventsSlide: true, - // rewind - rewind: false, - // Swiping/no swiping - allowSlidePrev: true, - allowSlideNext: true, - swipeHandler: null, - // '.swipe-handler', - noSwiping: true, - noSwipingClass: "swiper-no-swiping", - noSwipingSelector: null, - // Passive Listeners - passiveListeners: true, - maxBackfaceHiddenSlides: 10, - // NS - containerModifierClass: "swiper-", - // NEW - slideClass: "swiper-slide", - slideBlankClass: "swiper-slide-invisible-blank", - slideActiveClass: "swiper-slide-active", - slideDuplicateActiveClass: "swiper-slide-duplicate-active", - slideVisibleClass: "swiper-slide-visible", - slideDuplicateClass: "swiper-slide-duplicate", - slideNextClass: "swiper-slide-next", - slideDuplicateNextClass: "swiper-slide-duplicate-next", - slidePrevClass: "swiper-slide-prev", - slideDuplicatePrevClass: "swiper-slide-duplicate-prev", - wrapperClass: "swiper-wrapper", - // Callbacks - runCallbacksOnInit: true, - // Internals - _emitClasses: false, - }; - - function moduleExtendParams(params, allModulesParams) { - return function extendParams(obj) { - if (obj === void 0) { - obj = {}; - } - - const moduleParamName = Object.keys(obj)[0]; - const moduleParams = obj[moduleParamName]; - - if (typeof moduleParams !== "object" || moduleParams === null) { - extend(allModulesParams, obj); - return; - } - - if ( - ["navigation", "pagination", "scrollbar"].indexOf(moduleParamName) >= - 0 && - params[moduleParamName] === true - ) { - params[moduleParamName] = { - auto: true, - }; - } - - if (!(moduleParamName in params && "enabled" in moduleParams)) { - extend(allModulesParams, obj); - return; - } - - if (params[moduleParamName] === true) { - params[moduleParamName] = { - enabled: true, - }; - } - - if ( - typeof params[moduleParamName] === "object" && - !("enabled" in params[moduleParamName]) - ) { - params[moduleParamName].enabled = true; - } - - if (!params[moduleParamName]) - params[moduleParamName] = { - enabled: false, - }; - extend(allModulesParams, obj); - }; - } - - /* eslint no-param-reassign: "off" */ - const prototypes = { - eventsEmitter, - update, - translate, - transition, - slide, - loop, - grabCursor, - events: events$1, - breakpoints, - checkOverflow: checkOverflow$1, - classes, - images, - }; - const extendedDefaults = {}; - - class Swiper { - constructor() { - let el; - let params; - - for ( - var _len = arguments.length, args = new Array(_len), _key = 0; - _key < _len; - _key++ - ) { - args[_key] = arguments[_key]; - } - - if ( - args.length === 1 && - args[0].constructor && - Object.prototype.toString.call(args[0]).slice(8, -1) === "Object" - ) { - params = args[0]; - } else { - [el, params] = args; - } - - if (!params) params = {}; - params = extend({}, params); - if (el && !params.el) params.el = el; - - if (params.el && $(params.el).length > 1) { - const swipers = []; - $(params.el).each((containerEl) => { - const newParams = extend({}, params, { - el: containerEl, - }); - swipers.push(new Swiper(newParams)); - }); - return swipers; - } // Swiper Instance - - const swiper = this; - swiper.__swiper__ = true; - swiper.support = getSupport(); - swiper.device = getDevice({ - userAgent: params.userAgent, - }); - swiper.browser = getBrowser(); - swiper.eventsListeners = {}; - swiper.eventsAnyListeners = []; - swiper.modules = [...swiper.__modules__]; - - if (params.modules && Array.isArray(params.modules)) { - swiper.modules.push(...params.modules); - } - - const allModulesParams = {}; - swiper.modules.forEach((mod) => { - mod({ - swiper, - extendParams: moduleExtendParams(params, allModulesParams), - on: swiper.on.bind(swiper), - once: swiper.once.bind(swiper), - off: swiper.off.bind(swiper), - emit: swiper.emit.bind(swiper), - }); - }); // Extend defaults with modules params - - const swiperParams = extend({}, defaults, allModulesParams); // Extend defaults with passed params - - swiper.params = extend({}, swiperParams, extendedDefaults, params); - swiper.originalParams = extend({}, swiper.params); - swiper.passedParams = extend({}, params); // add event listeners - - if (swiper.params && swiper.params.on) { - Object.keys(swiper.params.on).forEach((eventName) => { - swiper.on(eventName, swiper.params.on[eventName]); - }); - } - - if (swiper.params && swiper.params.onAny) { - swiper.onAny(swiper.params.onAny); - } // Save Dom lib - - swiper.$ = $; // Extend Swiper - - Object.assign(swiper, { - enabled: swiper.params.enabled, - el, - // Classes - classNames: [], - // Slides - slides: $(), - slidesGrid: [], - snapGrid: [], - slidesSizesGrid: [], - - // isDirection - isHorizontal() { - return swiper.params.direction === "horizontal"; - }, - - isVertical() { - return swiper.params.direction === "vertical"; - }, - - // Indexes - activeIndex: 0, - realIndex: 0, - // - isBeginning: true, - isEnd: false, - // Props - translate: 0, - previousTranslate: 0, - progress: 0, - velocity: 0, - animating: false, - // Locks - allowSlideNext: swiper.params.allowSlideNext, - allowSlidePrev: swiper.params.allowSlidePrev, - // Touch Events - touchEvents: (function touchEvents() { - const touch = ["touchstart", "touchmove", "touchend", "touchcancel"]; - const desktop = ["pointerdown", "pointermove", "pointerup"]; - swiper.touchEventsTouch = { - start: touch[0], - move: touch[1], - end: touch[2], - cancel: touch[3], - }; - swiper.touchEventsDesktop = { - start: desktop[0], - move: desktop[1], - end: desktop[2], - }; - return swiper.support.touch || !swiper.params.simulateTouch - ? swiper.touchEventsTouch - : swiper.touchEventsDesktop; - })(), - touchEventsData: { - isTouched: undefined, - isMoved: undefined, - allowTouchCallbacks: undefined, - touchStartTime: undefined, - isScrolling: undefined, - currentTranslate: undefined, - startTranslate: undefined, - allowThresholdMove: undefined, - // Form elements to match - focusableElements: swiper.params.focusableElements, - // Last click time - lastClickTime: now(), - clickTimeout: undefined, - // Velocities - velocities: [], - allowMomentumBounce: undefined, - isTouchEvent: undefined, - startMoving: undefined, - }, - // Clicks - allowClick: true, - // Touches - allowTouchMove: swiper.params.allowTouchMove, - touches: { - startX: 0, - startY: 0, - currentX: 0, - currentY: 0, - diff: 0, - }, - // Images - imagesToLoad: [], - imagesLoaded: 0, - }); - swiper.emit("_swiper"); // Init - - if (swiper.params.init) { - swiper.init(); - } // Return app instance - - return swiper; - } - - enable() { - const swiper = this; - if (swiper.enabled) return; - swiper.enabled = true; - - if (swiper.params.grabCursor) { - swiper.setGrabCursor(); - } - - swiper.emit("enable"); - } - - disable() { - const swiper = this; - if (!swiper.enabled) return; - swiper.enabled = false; - - if (swiper.params.grabCursor) { - swiper.unsetGrabCursor(); - } - - swiper.emit("disable"); - } - - setProgress(progress, speed) { - const swiper = this; - progress = Math.min(Math.max(progress, 0), 1); - const min = swiper.minTranslate(); - const max = swiper.maxTranslate(); - const current = (max - min) * progress + min; - swiper.translateTo(current, typeof speed === "undefined" ? 0 : speed); - swiper.updateActiveIndex(); - swiper.updateSlidesClasses(); - } - - emitContainerClasses() { - const swiper = this; - if (!swiper.params._emitClasses || !swiper.el) return; - const cls = swiper.el.className.split(" ").filter((className) => { - return ( - className.indexOf("swiper") === 0 || - className.indexOf(swiper.params.containerModifierClass) === 0 - ); - }); - swiper.emit("_containerClasses", cls.join(" ")); - } - - getSlideClasses(slideEl) { - const swiper = this; - return slideEl.className - .split(" ") - .filter((className) => { - return ( - className.indexOf("swiper-slide") === 0 || - className.indexOf(swiper.params.slideClass) === 0 - ); - }) - .join(" "); - } - - emitSlidesClasses() { - const swiper = this; - if (!swiper.params._emitClasses || !swiper.el) return; - const updates = []; - swiper.slides.each((slideEl) => { - const classNames = swiper.getSlideClasses(slideEl); - updates.push({ - slideEl, - classNames, - }); - swiper.emit("_slideClass", slideEl, classNames); - }); - swiper.emit("_slideClasses", updates); - } - - slidesPerViewDynamic(view, exact) { - if (view === void 0) { - view = "current"; - } - - if (exact === void 0) { - exact = false; - } - - const swiper = this; - const { - params, - slides, - slidesGrid, - slidesSizesGrid, - size: swiperSize, - activeIndex, - } = swiper; - let spv = 1; - - if (params.centeredSlides) { - let slideSize = slides[activeIndex].swiperSlideSize; - let breakLoop; - - for (let i = activeIndex + 1; i < slides.length; i += 1) { - if (slides[i] && !breakLoop) { - slideSize += slides[i].swiperSlideSize; - spv += 1; - if (slideSize > swiperSize) breakLoop = true; - } - } - - for (let i = activeIndex - 1; i >= 0; i -= 1) { - if (slides[i] && !breakLoop) { - slideSize += slides[i].swiperSlideSize; - spv += 1; - if (slideSize > swiperSize) breakLoop = true; - } - } - } else { - // eslint-disable-next-line - if (view === "current") { - for (let i = activeIndex + 1; i < slides.length; i += 1) { - const slideInView = exact - ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < - swiperSize - : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize; - - if (slideInView) { - spv += 1; - } - } - } else { - // previous - for (let i = activeIndex - 1; i >= 0; i -= 1) { - const slideInView = - slidesGrid[activeIndex] - slidesGrid[i] < swiperSize; - - if (slideInView) { - spv += 1; - } - } - } - } - - return spv; - } - - update() { - const swiper = this; - if (!swiper || swiper.destroyed) return; - const { snapGrid, params } = swiper; // Breakpoints - - if (params.breakpoints) { - swiper.setBreakpoint(); - } - - swiper.updateSize(); - swiper.updateSlides(); - swiper.updateProgress(); - swiper.updateSlidesClasses(); - - function setTranslate() { - const translateValue = swiper.rtlTranslate - ? swiper.translate * -1 - : swiper.translate; - const newTranslate = Math.min( - Math.max(translateValue, swiper.maxTranslate()), - swiper.minTranslate(), - ); - swiper.setTranslate(newTranslate); - swiper.updateActiveIndex(); - swiper.updateSlidesClasses(); - } - - let translated; - - if (swiper.params.freeMode && swiper.params.freeMode.enabled) { - setTranslate(); - - if (swiper.params.autoHeight) { - swiper.updateAutoHeight(); - } - } else { - if ( - (swiper.params.slidesPerView === "auto" || - swiper.params.slidesPerView > 1) && - swiper.isEnd && - !swiper.params.centeredSlides - ) { - translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true); - } else { - translated = swiper.slideTo(swiper.activeIndex, 0, false, true); - } - - if (!translated) { - setTranslate(); - } - } - - if (params.watchOverflow && snapGrid !== swiper.snapGrid) { - swiper.checkOverflow(); - } - - swiper.emit("update"); - } - - changeDirection(newDirection, needUpdate) { - if (needUpdate === void 0) { - needUpdate = true; - } - - const swiper = this; - const currentDirection = swiper.params.direction; - - if (!newDirection) { - // eslint-disable-next-line - newDirection = - currentDirection === "horizontal" ? "vertical" : "horizontal"; - } - - if ( - newDirection === currentDirection || - (newDirection !== "horizontal" && newDirection !== "vertical") - ) { - return swiper; - } - - swiper.$el - .removeClass( - `${swiper.params.containerModifierClass}${currentDirection}`, - ) - .addClass(`${swiper.params.containerModifierClass}${newDirection}`); - swiper.emitContainerClasses(); - swiper.params.direction = newDirection; - swiper.slides.each((slideEl) => { - if (newDirection === "vertical") { - slideEl.style.width = ""; - } else { - slideEl.style.height = ""; - } - }); - swiper.emit("changeDirection"); - if (needUpdate) swiper.update(); - return swiper; - } - - mount(el) { - const swiper = this; - if (swiper.mounted) return true; // Find el - - const $el = $(el || swiper.params.el); - el = $el[0]; - - if (!el) { - return false; - } - - el.swiper = swiper; - - const getWrapperSelector = () => { - return `.${(swiper.params.wrapperClass || "") - .trim() - .split(" ") - .join(".")}`; - }; - - const getWrapper = () => { - if (el && el.shadowRoot && el.shadowRoot.querySelector) { - const res = $(el.shadowRoot.querySelector(getWrapperSelector())); // Children needs to return slot items - - res.children = (options) => $el.children(options); - - return res; - } - - return $el.children(getWrapperSelector()); - }; // Find Wrapper - - let $wrapperEl = getWrapper(); - - if ($wrapperEl.length === 0 && swiper.params.createElements) { - const document = getDocument(); - const wrapper = document.createElement("div"); - $wrapperEl = $(wrapper); - wrapper.className = swiper.params.wrapperClass; - $el.append(wrapper); - $el.children(`.${swiper.params.slideClass}`).each((slideEl) => { - $wrapperEl.append(slideEl); - }); - } - - Object.assign(swiper, { - $el, - el, - $wrapperEl, - wrapperEl: $wrapperEl[0], - mounted: true, - // RTL - rtl: el.dir.toLowerCase() === "rtl" || $el.css("direction") === "rtl", - rtlTranslate: - swiper.params.direction === "horizontal" && - (el.dir.toLowerCase() === "rtl" || $el.css("direction") === "rtl"), - wrongRTL: $wrapperEl.css("display") === "-webkit-box", - }); - return true; - } - - init(el) { - const swiper = this; - if (swiper.initialized) return swiper; - const mounted = swiper.mount(el); - if (mounted === false) return swiper; - swiper.emit("beforeInit"); // Set breakpoint - - if (swiper.params.breakpoints) { - swiper.setBreakpoint(); - } // Add Classes - - swiper.addClasses(); // Create loop - - if (swiper.params.loop) { - swiper.loopCreate(); - } // Update size - - swiper.updateSize(); // Update slides - - swiper.updateSlides(); - - if (swiper.params.watchOverflow) { - swiper.checkOverflow(); - } // Set Grab Cursor - - if (swiper.params.grabCursor && swiper.enabled) { - swiper.setGrabCursor(); - } - - if (swiper.params.preloadImages) { - swiper.preloadImages(); - } // Slide To Initial Slide - - if (swiper.params.loop) { - swiper.slideTo( - swiper.params.initialSlide + swiper.loopedSlides, - 0, - swiper.params.runCallbacksOnInit, - false, - true, - ); - } else { - swiper.slideTo( - swiper.params.initialSlide, - 0, - swiper.params.runCallbacksOnInit, - false, - true, - ); - } // Attach events - - swiper.attachEvents(); // Init Flag - - swiper.initialized = true; // Emit - - swiper.emit("init"); - swiper.emit("afterInit"); - return swiper; - } - - destroy(deleteInstance, cleanStyles) { - if (deleteInstance === void 0) { - deleteInstance = true; - } - - if (cleanStyles === void 0) { - cleanStyles = true; - } - - const swiper = this; - const { params, $el, $wrapperEl, slides } = swiper; - - if (typeof swiper.params === "undefined" || swiper.destroyed) { - return null; - } - - swiper.emit("beforeDestroy"); // Init Flag - - swiper.initialized = false; // Detach events - - swiper.detachEvents(); // Destroy loop - - if (params.loop) { - swiper.loopDestroy(); - } // Cleanup styles - - if (cleanStyles) { - swiper.removeClasses(); - $el.removeAttr("style"); - $wrapperEl.removeAttr("style"); - - if (slides && slides.length) { - slides - .removeClass( - [ - params.slideVisibleClass, - params.slideActiveClass, - params.slideNextClass, - params.slidePrevClass, - ].join(" "), - ) - .removeAttr("style") - .removeAttr("data-swiper-slide-index"); - } - } - - swiper.emit("destroy"); // Detach emitter events - - Object.keys(swiper.eventsListeners).forEach((eventName) => { - swiper.off(eventName); - }); - - if (deleteInstance !== false) { - swiper.$el[0].swiper = null; - deleteProps(swiper); - } - - swiper.destroyed = true; - return null; - } - - static extendDefaults(newDefaults) { - extend(extendedDefaults, newDefaults); - } - - static get extendedDefaults() { - return extendedDefaults; - } - - static get defaults() { - return defaults; - } - - static installModule(mod) { - if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = []; - const modules = Swiper.prototype.__modules__; - - if (typeof mod === "function" && modules.indexOf(mod) < 0) { - modules.push(mod); - } - } - - static use(module) { - if (Array.isArray(module)) { - module.forEach((m) => Swiper.installModule(m)); - return Swiper; - } - - Swiper.installModule(module); - return Swiper; - } - } - - Object.keys(prototypes).forEach((prototypeGroup) => { - Object.keys(prototypes[prototypeGroup]).forEach((protoMethod) => { - Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod]; - }); - }); - Swiper.use([Resize, Observer]); - - function Virtual(_ref) { - let { swiper, extendParams, on, emit } = _ref; - extendParams({ - virtual: { - enabled: false, - slides: [], - cache: true, - renderSlide: null, - renderExternal: null, - renderExternalUpdate: true, - addSlidesBefore: 0, - addSlidesAfter: 0, - }, - }); - let cssModeTimeout; - swiper.virtual = { - cache: {}, - from: undefined, - to: undefined, - slides: [], - offset: 0, - slidesGrid: [], - }; - - function renderSlide(slide, index) { - const params = swiper.params.virtual; - - if (params.cache && swiper.virtual.cache[index]) { - return swiper.virtual.cache[index]; - } - - const $slideEl = params.renderSlide - ? $(params.renderSlide.call(swiper, slide, index)) - : $( - `
${slide}
`, - ); - if (!$slideEl.attr("data-swiper-slide-index")) - $slideEl.attr("data-swiper-slide-index", index); - if (params.cache) swiper.virtual.cache[index] = $slideEl; - return $slideEl; - } - - function update(force) { - const { slidesPerView, slidesPerGroup, centeredSlides } = swiper.params; - const { addSlidesBefore, addSlidesAfter } = swiper.params.virtual; - const { - from: previousFrom, - to: previousTo, - slides, - slidesGrid: previousSlidesGrid, - offset: previousOffset, - } = swiper.virtual; - - if (!swiper.params.cssMode) { - swiper.updateActiveIndex(); - } - - const activeIndex = swiper.activeIndex || 0; - let offsetProp; - if (swiper.rtlTranslate) offsetProp = "right"; - else offsetProp = swiper.isHorizontal() ? "left" : "top"; - let slidesAfter; - let slidesBefore; - - if (centeredSlides) { - slidesAfter = - Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter; - slidesBefore = - Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore; - } else { - slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesAfter; - slidesBefore = slidesPerGroup + addSlidesBefore; - } - - const from = Math.max((activeIndex || 0) - slidesBefore, 0); - const to = Math.min((activeIndex || 0) + slidesAfter, slides.length - 1); - const offset = - (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0); - Object.assign(swiper.virtual, { - from, - to, - offset, - slidesGrid: swiper.slidesGrid, - }); - - function onRendered() { - swiper.updateSlides(); - swiper.updateProgress(); - swiper.updateSlidesClasses(); - - if (swiper.lazy && swiper.params.lazy.enabled) { - swiper.lazy.load(); - } - - emit("virtualUpdate"); - } - - if (previousFrom === from && previousTo === to && !force) { - if ( - swiper.slidesGrid !== previousSlidesGrid && - offset !== previousOffset - ) { - swiper.slides.css(offsetProp, `${offset}px`); - } - - swiper.updateProgress(); - emit("virtualUpdate"); - return; - } - - if (swiper.params.virtual.renderExternal) { - swiper.params.virtual.renderExternal.call(swiper, { - offset, - from, - to, - slides: (function getSlides() { - const slidesToRender = []; - - for (let i = from; i <= to; i += 1) { - slidesToRender.push(slides[i]); - } - - return slidesToRender; - })(), - }); - - if (swiper.params.virtual.renderExternalUpdate) { - onRendered(); - } else { - emit("virtualUpdate"); - } - - return; - } - - const prependIndexes = []; - const appendIndexes = []; - - if (force) { - swiper.$wrapperEl.find(`.${swiper.params.slideClass}`).remove(); - } else { - for (let i = previousFrom; i <= previousTo; i += 1) { - if (i < from || i > to) { - swiper.$wrapperEl - .find( - `.${swiper.params.slideClass}[data-swiper-slide-index="${i}"]`, - ) - .remove(); - } - } - } - - for (let i = 0; i < slides.length; i += 1) { - if (i >= from && i <= to) { - if (typeof previousTo === "undefined" || force) { - appendIndexes.push(i); - } else { - if (i > previousTo) appendIndexes.push(i); - if (i < previousFrom) prependIndexes.push(i); - } - } - } - - appendIndexes.forEach((index) => { - swiper.$wrapperEl.append(renderSlide(slides[index], index)); - }); - prependIndexes - .sort((a, b) => b - a) - .forEach((index) => { - swiper.$wrapperEl.prepend(renderSlide(slides[index], index)); - }); - swiper.$wrapperEl - .children(".swiper-slide") - .css(offsetProp, `${offset}px`); - onRendered(); - } - - function appendSlide(slides) { - if (typeof slides === "object" && "length" in slides) { - for (let i = 0; i < slides.length; i += 1) { - if (slides[i]) swiper.virtual.slides.push(slides[i]); - } - } else { - swiper.virtual.slides.push(slides); - } - - update(true); - } - - function prependSlide(slides) { - const activeIndex = swiper.activeIndex; - let newActiveIndex = activeIndex + 1; - let numberOfNewSlides = 1; - - if (Array.isArray(slides)) { - for (let i = 0; i < slides.length; i += 1) { - if (slides[i]) swiper.virtual.slides.unshift(slides[i]); - } - - newActiveIndex = activeIndex + slides.length; - numberOfNewSlides = slides.length; - } else { - swiper.virtual.slides.unshift(slides); - } - - if (swiper.params.virtual.cache) { - const cache = swiper.virtual.cache; - const newCache = {}; - Object.keys(cache).forEach((cachedIndex) => { - const $cachedEl = cache[cachedIndex]; - const cachedElIndex = $cachedEl.attr("data-swiper-slide-index"); - - if (cachedElIndex) { - $cachedEl.attr( - "data-swiper-slide-index", - parseInt(cachedElIndex, 10) + numberOfNewSlides, - ); - } - - newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = $cachedEl; - }); - swiper.virtual.cache = newCache; - } - - update(true); - swiper.slideTo(newActiveIndex, 0); - } - - function removeSlide(slidesIndexes) { - if (typeof slidesIndexes === "undefined" || slidesIndexes === null) - return; - let activeIndex = swiper.activeIndex; - - if (Array.isArray(slidesIndexes)) { - for (let i = slidesIndexes.length - 1; i >= 0; i -= 1) { - swiper.virtual.slides.splice(slidesIndexes[i], 1); - - if (swiper.params.virtual.cache) { - delete swiper.virtual.cache[slidesIndexes[i]]; - } - - if (slidesIndexes[i] < activeIndex) activeIndex -= 1; - activeIndex = Math.max(activeIndex, 0); - } - } else { - swiper.virtual.slides.splice(slidesIndexes, 1); - - if (swiper.params.virtual.cache) { - delete swiper.virtual.cache[slidesIndexes]; - } - - if (slidesIndexes < activeIndex) activeIndex -= 1; - activeIndex = Math.max(activeIndex, 0); - } - - update(true); - swiper.slideTo(activeIndex, 0); - } - - function removeAllSlides() { - swiper.virtual.slides = []; - - if (swiper.params.virtual.cache) { - swiper.virtual.cache = {}; - } - - update(true); - swiper.slideTo(0, 0); - } - - on("beforeInit", () => { - if (!swiper.params.virtual.enabled) return; - swiper.virtual.slides = swiper.params.virtual.slides; - swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`); - swiper.params.watchSlidesProgress = true; - swiper.originalParams.watchSlidesProgress = true; - - if (!swiper.params.initialSlide) { - update(); - } - }); - on("setTranslate", () => { - if (!swiper.params.virtual.enabled) return; - - if (swiper.params.cssMode && !swiper._immediateVirtual) { - clearTimeout(cssModeTimeout); - cssModeTimeout = setTimeout(() => { - update(); - }, 100); - } else { - update(); - } - }); - on("init update resize", () => { - if (!swiper.params.virtual.enabled) return; - - if (swiper.params.cssMode) { - setCSSProperty( - swiper.wrapperEl, - "--swiper-virtual-size", - `${swiper.virtualSize}px`, - ); - } - }); - Object.assign(swiper.virtual, { - appendSlide, - prependSlide, - removeSlide, - removeAllSlides, - update, - }); - } - - /* eslint-disable consistent-return */ - function Keyboard(_ref) { - let { swiper, extendParams, on, emit } = _ref; - const document = getDocument(); - const window = getWindow(); - swiper.keyboard = { - enabled: false, - }; - extendParams({ - keyboard: { - enabled: false, - onlyInViewport: true, - pageUpDown: true, - }, - }); - - function handle(event) { - if (!swiper.enabled) return; - const { rtlTranslate: rtl } = swiper; - let e = event; - if (e.originalEvent) e = e.originalEvent; // jquery fix - - const kc = e.keyCode || e.charCode; - const pageUpDown = swiper.params.keyboard.pageUpDown; - const isPageUp = pageUpDown && kc === 33; - const isPageDown = pageUpDown && kc === 34; - const isArrowLeft = kc === 37; - const isArrowRight = kc === 39; - const isArrowUp = kc === 38; - const isArrowDown = kc === 40; // Directions locks - - if ( - !swiper.allowSlideNext && - ((swiper.isHorizontal() && isArrowRight) || - (swiper.isVertical() && isArrowDown) || - isPageDown) - ) { - return false; - } - - if ( - !swiper.allowSlidePrev && - ((swiper.isHorizontal() && isArrowLeft) || - (swiper.isVertical() && isArrowUp) || - isPageUp) - ) { - return false; - } - - if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) { - return undefined; - } - - if ( - document.activeElement && - document.activeElement.nodeName && - (document.activeElement.nodeName.toLowerCase() === "input" || - document.activeElement.nodeName.toLowerCase() === "textarea") - ) { - return undefined; - } - - if ( - swiper.params.keyboard.onlyInViewport && - (isPageUp || - isPageDown || - isArrowLeft || - isArrowRight || - isArrowUp || - isArrowDown) - ) { - let inView = false; // Check that swiper should be inside of visible area of window - - if ( - swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0 && - swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length === 0 - ) { - return undefined; - } - - const $el = swiper.$el; - const swiperWidth = $el[0].clientWidth; - const swiperHeight = $el[0].clientHeight; - const windowWidth = window.innerWidth; - const windowHeight = window.innerHeight; - const swiperOffset = swiper.$el.offset(); - if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft; - const swiperCoord = [ - [swiperOffset.left, swiperOffset.top], - [swiperOffset.left + swiperWidth, swiperOffset.top], - [swiperOffset.left, swiperOffset.top + swiperHeight], - [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight], - ]; - - for (let i = 0; i < swiperCoord.length; i += 1) { - const point = swiperCoord[i]; - - if ( - point[0] >= 0 && - point[0] <= windowWidth && - point[1] >= 0 && - point[1] <= windowHeight - ) { - if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line - - inView = true; - } - } - - if (!inView) return undefined; - } - - if (swiper.isHorizontal()) { - if (isPageUp || isPageDown || isArrowLeft || isArrowRight) { - if (e.preventDefault) e.preventDefault(); - else e.returnValue = false; - } - - if ( - ((isPageDown || isArrowRight) && !rtl) || - ((isPageUp || isArrowLeft) && rtl) - ) - swiper.slideNext(); - if ( - ((isPageUp || isArrowLeft) && !rtl) || - ((isPageDown || isArrowRight) && rtl) - ) - swiper.slidePrev(); - } else { - if (isPageUp || isPageDown || isArrowUp || isArrowDown) { - if (e.preventDefault) e.preventDefault(); - else e.returnValue = false; - } - - if (isPageDown || isArrowDown) swiper.slideNext(); - if (isPageUp || isArrowUp) swiper.slidePrev(); - } - - emit("keyPress", kc); - return undefined; - } - - function enable() { - if (swiper.keyboard.enabled) return; - $(document).on("keydown", handle); - swiper.keyboard.enabled = true; - } - - function disable() { - if (!swiper.keyboard.enabled) return; - $(document).off("keydown", handle); - swiper.keyboard.enabled = false; - } - - on("init", () => { - if (swiper.params.keyboard.enabled) { - enable(); - } - }); - on("destroy", () => { - if (swiper.keyboard.enabled) { - disable(); - } - }); - Object.assign(swiper.keyboard, { - enable, - disable, - }); - } - - /* eslint-disable consistent-return */ - function Mousewheel(_ref) { - let { swiper, extendParams, on, emit } = _ref; - const window = getWindow(); - extendParams({ - mousewheel: { - enabled: false, - releaseOnEdges: false, - invert: false, - forceToAxis: false, - sensitivity: 1, - eventsTarget: "container", - thresholdDelta: null, - thresholdTime: null, - }, - }); - swiper.mousewheel = { - enabled: false, - }; - let timeout; - let lastScrollTime = now(); - let lastEventBeforeSnap; - const recentWheelEvents = []; - - function normalize(e) { - // Reasonable defaults - const PIXEL_STEP = 10; - const LINE_HEIGHT = 40; - const PAGE_HEIGHT = 800; - let sX = 0; - let sY = 0; // spinX, spinY - - let pX = 0; - let pY = 0; // pixelX, pixelY - // Legacy - - if ("detail" in e) { - sY = e.detail; - } - - if ("wheelDelta" in e) { - sY = -e.wheelDelta / 120; - } - - if ("wheelDeltaY" in e) { - sY = -e.wheelDeltaY / 120; - } - - if ("wheelDeltaX" in e) { - sX = -e.wheelDeltaX / 120; - } // side scrolling on FF with DOMMouseScroll - - if ("axis" in e && e.axis === e.HORIZONTAL_AXIS) { - sX = sY; - sY = 0; - } - - pX = sX * PIXEL_STEP; - pY = sY * PIXEL_STEP; - - if ("deltaY" in e) { - pY = e.deltaY; - } - - if ("deltaX" in e) { - pX = e.deltaX; - } - - if (e.shiftKey && !pX) { - // if user scrolls with shift he wants horizontal scroll - pX = pY; - pY = 0; - } - - if ((pX || pY) && e.deltaMode) { - if (e.deltaMode === 1) { - // delta in LINE units - pX *= LINE_HEIGHT; - pY *= LINE_HEIGHT; - } else { - // delta in PAGE units - pX *= PAGE_HEIGHT; - pY *= PAGE_HEIGHT; - } - } // Fall-back if spin cannot be determined - - if (pX && !sX) { - sX = pX < 1 ? -1 : 1; - } - - if (pY && !sY) { - sY = pY < 1 ? -1 : 1; - } - - return { - spinX: sX, - spinY: sY, - pixelX: pX, - pixelY: pY, - }; - } - - function handleMouseEnter() { - if (!swiper.enabled) return; - swiper.mouseEntered = true; - } - - function handleMouseLeave() { - if (!swiper.enabled) return; - swiper.mouseEntered = false; - } - - function animateSlider(newEvent) { - if ( - swiper.params.mousewheel.thresholdDelta && - newEvent.delta < swiper.params.mousewheel.thresholdDelta - ) { - // Prevent if delta of wheel scroll delta is below configured threshold - return false; - } - - if ( - swiper.params.mousewheel.thresholdTime && - now() - lastScrollTime < swiper.params.mousewheel.thresholdTime - ) { - // Prevent if time between scrolls is below configured threshold - return false; - } // If the movement is NOT big enough and - // if the last time the user scrolled was too close to the current one (avoid continuously triggering the slider): - // Don't go any further (avoid insignificant scroll movement). - - if (newEvent.delta >= 6 && now() - lastScrollTime < 60) { - // Return false as a default - return true; - } // If user is scrolling towards the end: - // If the slider hasn't hit the latest slide or - // if the slider is a loop and - // if the slider isn't moving right now: - // Go to next slide and - // emit a scroll event. - // Else (the user is scrolling towards the beginning) and - // if the slider hasn't hit the first slide or - // if the slider is a loop and - // if the slider isn't moving right now: - // Go to prev slide and - // emit a scroll event. - - if (newEvent.direction < 0) { - if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) { - swiper.slideNext(); - emit("scroll", newEvent.raw); - } - } else if ( - (!swiper.isBeginning || swiper.params.loop) && - !swiper.animating - ) { - swiper.slidePrev(); - emit("scroll", newEvent.raw); - } // If you got here is because an animation has been triggered so store the current time - - lastScrollTime = new window.Date().getTime(); // Return false as a default - - return false; - } - - function releaseScroll(newEvent) { - const params = swiper.params.mousewheel; - - if (newEvent.direction < 0) { - if (swiper.isEnd && !swiper.params.loop && params.releaseOnEdges) { - // Return true to animate scroll on edges - return true; - } - } else if ( - swiper.isBeginning && - !swiper.params.loop && - params.releaseOnEdges - ) { - // Return true to animate scroll on edges - return true; - } - - return false; - } - - function handle(event) { - let e = event; - let disableParentSwiper = true; - if (!swiper.enabled) return; - const params = swiper.params.mousewheel; - - if (swiper.params.cssMode) { - e.preventDefault(); - } - - let target = swiper.$el; - - if (swiper.params.mousewheel.eventsTarget !== "container") { - target = $(swiper.params.mousewheel.eventsTarget); - } - - if ( - !swiper.mouseEntered && - !target[0].contains(e.target) && - !params.releaseOnEdges - ) - return true; - if (e.originalEvent) e = e.originalEvent; // jquery fix - - let delta = 0; - const rtlFactor = swiper.rtlTranslate ? -1 : 1; - const data = normalize(e); - - if (params.forceToAxis) { - if (swiper.isHorizontal()) { - if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) - delta = -data.pixelX * rtlFactor; - else return true; - } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) - delta = -data.pixelY; - else return true; - } else { - delta = - Math.abs(data.pixelX) > Math.abs(data.pixelY) - ? -data.pixelX * rtlFactor - : -data.pixelY; - } - - if (delta === 0) return true; - if (params.invert) delta = -delta; // Get the scroll positions - - let positions = swiper.getTranslate() + delta * params.sensitivity; - if (positions >= swiper.minTranslate()) positions = swiper.minTranslate(); - if (positions <= swiper.maxTranslate()) positions = swiper.maxTranslate(); // When loop is true: - // the disableParentSwiper will be true. - // When loop is false: - // if the scroll positions is not on edge, - // then the disableParentSwiper will be true. - // if the scroll on edge positions, - // then the disableParentSwiper will be false. - - disableParentSwiper = swiper.params.loop - ? true - : !( - positions === swiper.minTranslate() || - positions === swiper.maxTranslate() - ); - if (disableParentSwiper && swiper.params.nested) e.stopPropagation(); - - if (!swiper.params.freeMode || !swiper.params.freeMode.enabled) { - // Register the new event in a variable which stores the relevant data - const newEvent = { - time: now(), - delta: Math.abs(delta), - direction: Math.sign(delta), - raw: event, - }; // Keep the most recent events - - if (recentWheelEvents.length >= 2) { - recentWheelEvents.shift(); // only store the last N events - } - - const prevEvent = recentWheelEvents.length - ? recentWheelEvents[recentWheelEvents.length - 1] - : undefined; - recentWheelEvents.push(newEvent); // If there is at least one previous recorded event: - // If direction has changed or - // if the scroll is quicker than the previous one: - // Animate the slider. - // Else (this is the first time the wheel is moved): - // Animate the slider. - - if (prevEvent) { - if ( - newEvent.direction !== prevEvent.direction || - newEvent.delta > prevEvent.delta || - newEvent.time > prevEvent.time + 150 - ) { - animateSlider(newEvent); - } - } else { - animateSlider(newEvent); - } // If it's time to release the scroll: - // Return now so you don't hit the preventDefault. - - if (releaseScroll(newEvent)) { - return true; - } - } else { - // Freemode or scrollContainer: - // If we recently snapped after a momentum scroll, then ignore wheel events - // to give time for the deceleration to finish. Stop ignoring after 500 msecs - // or if it's a new scroll (larger delta or inverse sign as last event before - // an end-of-momentum snap). - const newEvent = { - time: now(), - delta: Math.abs(delta), - direction: Math.sign(delta), - }; - const ignoreWheelEvents = - lastEventBeforeSnap && - newEvent.time < lastEventBeforeSnap.time + 500 && - newEvent.delta <= lastEventBeforeSnap.delta && - newEvent.direction === lastEventBeforeSnap.direction; - - if (!ignoreWheelEvents) { - lastEventBeforeSnap = undefined; - - if (swiper.params.loop) { - swiper.loopFix(); - } - - let position = swiper.getTranslate() + delta * params.sensitivity; - const wasBeginning = swiper.isBeginning; - const wasEnd = swiper.isEnd; - if (position >= swiper.minTranslate()) - position = swiper.minTranslate(); - if (position <= swiper.maxTranslate()) - position = swiper.maxTranslate(); - swiper.setTransition(0); - swiper.setTranslate(position); - swiper.updateProgress(); - swiper.updateActiveIndex(); - swiper.updateSlidesClasses(); - - if ( - (!wasBeginning && swiper.isBeginning) || - (!wasEnd && swiper.isEnd) - ) { - swiper.updateSlidesClasses(); - } - - if (swiper.params.freeMode.sticky) { - // When wheel scrolling starts with sticky (aka snap) enabled, then detect - // the end of a momentum scroll by storing recent (N=15?) wheel events. - // 1. do all N events have decreasing or same (absolute value) delta? - // 2. did all N events arrive in the last M (M=500?) msecs? - // 3. does the earliest event have an (absolute value) delta that's - // at least P (P=1?) larger than the most recent event's delta? - // 4. does the latest event have a delta that's smaller than Q (Q=6?) pixels? - // If 1-4 are "yes" then we're near the end of a momentum scroll deceleration. - // Snap immediately and ignore remaining wheel events in this scroll. - // See comment above for "remaining wheel events in this scroll" determination. - // If 1-4 aren't satisfied, then wait to snap until 500ms after the last event. - clearTimeout(timeout); - timeout = undefined; - - if (recentWheelEvents.length >= 15) { - recentWheelEvents.shift(); // only store the last N events - } - - const prevEvent = recentWheelEvents.length - ? recentWheelEvents[recentWheelEvents.length - 1] - : undefined; - const firstEvent = recentWheelEvents[0]; - recentWheelEvents.push(newEvent); - - if ( - prevEvent && - (newEvent.delta > prevEvent.delta || - newEvent.direction !== prevEvent.direction) - ) { - // Increasing or reverse-sign delta means the user started scrolling again. Clear the wheel event log. - recentWheelEvents.splice(0); - } else if ( - recentWheelEvents.length >= 15 && - newEvent.time - firstEvent.time < 500 && - firstEvent.delta - newEvent.delta >= 1 && - newEvent.delta <= 6 - ) { - // We're at the end of the deceleration of a momentum scroll, so there's no need - // to wait for more events. Snap ASAP on the next tick. - // Also, because there's some remaining momentum we'll bias the snap in the - // direction of the ongoing scroll because it's better UX for the scroll to snap - // in the same direction as the scroll instead of reversing to snap. Therefore, - // if it's already scrolled more than 20% in the current direction, keep going. - const snapToThreshold = delta > 0 ? 0.8 : 0.2; - lastEventBeforeSnap = newEvent; - recentWheelEvents.splice(0); - timeout = nextTick(() => { - swiper.slideToClosest( - swiper.params.speed, - true, - undefined, - snapToThreshold, - ); - }, 0); // no delay; move on next tick - } - - if (!timeout) { - // if we get here, then we haven't detected the end of a momentum scroll, so - // we'll consider a scroll "complete" when there haven't been any wheel events - // for 500ms. - timeout = nextTick(() => { - const snapToThreshold = 0.5; - lastEventBeforeSnap = newEvent; - recentWheelEvents.splice(0); - swiper.slideToClosest( - swiper.params.speed, - true, - undefined, - snapToThreshold, - ); - }, 500); - } - } // Emit event - - if (!ignoreWheelEvents) emit("scroll", e); // Stop autoplay - - if ( - swiper.params.autoplay && - swiper.params.autoplayDisableOnInteraction - ) - swiper.autoplay.stop(); // Return page scroll on edge positions - - if ( - position === swiper.minTranslate() || - position === swiper.maxTranslate() - ) - return true; - } - } - - if (e.preventDefault) e.preventDefault(); - else e.returnValue = false; - return false; - } - - function events(method) { - let target = swiper.$el; - - if (swiper.params.mousewheel.eventsTarget !== "container") { - target = $(swiper.params.mousewheel.eventsTarget); - } - - target[method]("mouseenter", handleMouseEnter); - target[method]("mouseleave", handleMouseLeave); - target[method]("wheel", handle); - } - - function enable() { - if (swiper.params.cssMode) { - swiper.wrapperEl.removeEventListener("wheel", handle); - return true; - } - - if (swiper.mousewheel.enabled) return false; - events("on"); - swiper.mousewheel.enabled = true; - return true; - } - - function disable() { - if (swiper.params.cssMode) { - swiper.wrapperEl.addEventListener(event, handle); - return true; - } - - if (!swiper.mousewheel.enabled) return false; - events("off"); - swiper.mousewheel.enabled = false; - return true; - } - - on("init", () => { - if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) { - disable(); - } - - if (swiper.params.mousewheel.enabled) enable(); - }); - on("destroy", () => { - if (swiper.params.cssMode) { - enable(); - } - - if (swiper.mousewheel.enabled) disable(); - }); - Object.assign(swiper.mousewheel, { - enable, - disable, - }); - } - - function createElementIfNotDefined( - swiper, - originalParams, - params, - checkProps, - ) { - const document = getDocument(); - - if (swiper.params.createElements) { - Object.keys(checkProps).forEach((key) => { - if (!params[key] && params.auto === true) { - let element = swiper.$el.children(`.${checkProps[key]}`)[0]; - - if (!element) { - element = document.createElement("div"); - element.className = checkProps[key]; - swiper.$el.append(element); - } - - params[key] = element; - originalParams[key] = element; - } - }); - } - - return params; - } - - function Navigation(_ref) { - let { swiper, extendParams, on, emit } = _ref; - extendParams({ - navigation: { - nextEl: null, - prevEl: null, - hideOnClick: false, - disabledClass: "swiper-button-disabled", - hiddenClass: "swiper-button-hidden", - lockClass: "swiper-button-lock", - }, - }); - swiper.navigation = { - nextEl: null, - $nextEl: null, - prevEl: null, - $prevEl: null, - }; - - function getEl(el) { - let $el; - - if (el) { - $el = $(el); - - if ( - swiper.params.uniqueNavElements && - typeof el === "string" && - $el.length > 1 && - swiper.$el.find(el).length === 1 - ) { - $el = swiper.$el.find(el); - } - } - - return $el; - } - - function toggleEl($el, disabled) { - const params = swiper.params.navigation; - - if ($el && $el.length > 0) { - $el[disabled ? "addClass" : "removeClass"](params.disabledClass); - if ($el[0] && $el[0].tagName === "BUTTON") $el[0].disabled = disabled; - - if (swiper.params.watchOverflow && swiper.enabled) { - $el[swiper.isLocked ? "addClass" : "removeClass"](params.lockClass); - } - } - } - - function update() { - // Update Navigation Buttons - if (swiper.params.loop) return; - const { $nextEl, $prevEl } = swiper.navigation; - toggleEl($prevEl, swiper.isBeginning && !swiper.params.rewind); - toggleEl($nextEl, swiper.isEnd && !swiper.params.rewind); - } - - function onPrevClick(e) { - e.preventDefault(); - if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) - return; - swiper.slidePrev(); - } - - function onNextClick(e) { - e.preventDefault(); - if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return; - swiper.slideNext(); - } - - function init() { - const params = swiper.params.navigation; - swiper.params.navigation = createElementIfNotDefined( - swiper, - swiper.originalParams.navigation, - swiper.params.navigation, - { - nextEl: "swiper-button-next", - prevEl: "swiper-button-prev", - }, - ); - if (!(params.nextEl || params.prevEl)) return; - const $nextEl = getEl(params.nextEl); - const $prevEl = getEl(params.prevEl); - - if ($nextEl && $nextEl.length > 0) { - $nextEl.on("click", onNextClick); - } - - if ($prevEl && $prevEl.length > 0) { - $prevEl.on("click", onPrevClick); - } - - Object.assign(swiper.navigation, { - $nextEl, - nextEl: $nextEl && $nextEl[0], - $prevEl, - prevEl: $prevEl && $prevEl[0], - }); - - if (!swiper.enabled) { - if ($nextEl) $nextEl.addClass(params.lockClass); - if ($prevEl) $prevEl.addClass(params.lockClass); - } - } - - function destroy() { - const { $nextEl, $prevEl } = swiper.navigation; - - if ($nextEl && $nextEl.length) { - $nextEl.off("click", onNextClick); - $nextEl.removeClass(swiper.params.navigation.disabledClass); - } - - if ($prevEl && $prevEl.length) { - $prevEl.off("click", onPrevClick); - $prevEl.removeClass(swiper.params.navigation.disabledClass); - } - } - - on("init", () => { - init(); - update(); - }); - on("toEdge fromEdge lock unlock", () => { - update(); - }); - on("destroy", () => { - destroy(); - }); - on("enable disable", () => { - const { $nextEl, $prevEl } = swiper.navigation; - - if ($nextEl) { - $nextEl[swiper.enabled ? "removeClass" : "addClass"]( - swiper.params.navigation.lockClass, - ); - } - - if ($prevEl) { - $prevEl[swiper.enabled ? "removeClass" : "addClass"]( - swiper.params.navigation.lockClass, - ); - } - }); - on("click", (_s, e) => { - const { $nextEl, $prevEl } = swiper.navigation; - const targetEl = e.target; - - if ( - swiper.params.navigation.hideOnClick && - !$(targetEl).is($prevEl) && - !$(targetEl).is($nextEl) - ) { - if ( - swiper.pagination && - swiper.params.pagination && - swiper.params.pagination.clickable && - (swiper.pagination.el === targetEl || - swiper.pagination.el.contains(targetEl)) - ) - return; - let isHidden; - - if ($nextEl) { - isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass); - } else if ($prevEl) { - isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass); - } - - if (isHidden === true) { - emit("navigationShow"); - } else { - emit("navigationHide"); - } - - if ($nextEl) { - $nextEl.toggleClass(swiper.params.navigation.hiddenClass); - } - - if ($prevEl) { - $prevEl.toggleClass(swiper.params.navigation.hiddenClass); - } - } - }); - Object.assign(swiper.navigation, { - update, - init, - destroy, - }); - } - - function classesToSelector(classes) { - if (classes === void 0) { - classes = ""; - } - - return `.${classes - .trim() - .replace(/([\.:!\/])/g, "\\$1") // eslint-disable-line - .replace(/ /g, ".")}`; - } - - function Pagination(_ref) { - let { swiper, extendParams, on, emit } = _ref; - const pfx = "swiper-pagination"; - extendParams({ - pagination: { - el: null, - bulletElement: "span", - clickable: false, - hideOnClick: false, - renderBullet: null, - renderProgressbar: null, - renderFraction: null, - renderCustom: null, - progressbarOpposite: false, - type: "bullets", - // 'bullets' or 'progressbar' or 'fraction' or 'custom' - dynamicBullets: false, - dynamicMainBullets: 1, - formatFractionCurrent: (number) => number, - formatFractionTotal: (number) => number, - bulletClass: `${pfx}-bullet`, - bulletActiveClass: `${pfx}-bullet-active`, - modifierClass: `${pfx}-`, - currentClass: `${pfx}-current`, - totalClass: `${pfx}-total`, - hiddenClass: `${pfx}-hidden`, - progressbarFillClass: `${pfx}-progressbar-fill`, - progressbarOppositeClass: `${pfx}-progressbar-opposite`, - clickableClass: `${pfx}-clickable`, - lockClass: `${pfx}-lock`, - horizontalClass: `${pfx}-horizontal`, - verticalClass: `${pfx}-vertical`, - }, - }); - swiper.pagination = { - el: null, - $el: null, - bullets: [], - }; - let bulletSize; - let dynamicBulletIndex = 0; - - function isPaginationDisabled() { - return ( - !swiper.params.pagination.el || - !swiper.pagination.el || - !swiper.pagination.$el || - swiper.pagination.$el.length === 0 - ); - } - - function setSideBullets($bulletEl, position) { - const { bulletActiveClass } = swiper.params.pagination; - $bulletEl[position]() - .addClass(`${bulletActiveClass}-${position}`) - [position]() - .addClass(`${bulletActiveClass}-${position}-${position}`); - } - - function update() { - // Render || Update Pagination bullets/items - const rtl = swiper.rtl; - const params = swiper.params.pagination; - if (isPaginationDisabled()) return; - const slidesLength = - swiper.virtual && swiper.params.virtual.enabled - ? swiper.virtual.slides.length - : swiper.slides.length; - const $el = swiper.pagination.$el; // Current/Total - - let current; - const total = swiper.params.loop - ? Math.ceil( - (slidesLength - swiper.loopedSlides * 2) / - swiper.params.slidesPerGroup, - ) - : swiper.snapGrid.length; - - if (swiper.params.loop) { - current = Math.ceil( - (swiper.activeIndex - swiper.loopedSlides) / - swiper.params.slidesPerGroup, - ); - - if (current > slidesLength - 1 - swiper.loopedSlides * 2) { - current -= slidesLength - swiper.loopedSlides * 2; - } - - if (current > total - 1) current -= total; - if (current < 0 && swiper.params.paginationType !== "bullets") - current = total + current; - } else if (typeof swiper.snapIndex !== "undefined") { - current = swiper.snapIndex; - } else { - current = swiper.activeIndex || 0; - } // Types - - if ( - params.type === "bullets" && - swiper.pagination.bullets && - swiper.pagination.bullets.length > 0 - ) { - const bullets = swiper.pagination.bullets; - let firstIndex; - let lastIndex; - let midIndex; - - if (params.dynamicBullets) { - bulletSize = bullets - .eq(0) - [swiper.isHorizontal() ? "outerWidth" : "outerHeight"](true); - $el.css( - swiper.isHorizontal() ? "width" : "height", - `${bulletSize * (params.dynamicMainBullets + 4)}px`, - ); - - if ( - params.dynamicMainBullets > 1 && - swiper.previousIndex !== undefined - ) { - dynamicBulletIndex += - current - (swiper.previousIndex - swiper.loopedSlides || 0); - - if (dynamicBulletIndex > params.dynamicMainBullets - 1) { - dynamicBulletIndex = params.dynamicMainBullets - 1; - } else if (dynamicBulletIndex < 0) { - dynamicBulletIndex = 0; - } - } - - firstIndex = Math.max(current - dynamicBulletIndex, 0); - lastIndex = - firstIndex + - (Math.min(bullets.length, params.dynamicMainBullets) - 1); - midIndex = (lastIndex + firstIndex) / 2; - } - - bullets.removeClass( - ["", "-next", "-next-next", "-prev", "-prev-prev", "-main"] - .map((suffix) => `${params.bulletActiveClass}${suffix}`) - .join(" "), - ); - - if ($el.length > 1) { - bullets.each((bullet) => { - const $bullet = $(bullet); - const bulletIndex = $bullet.index(); - - if (bulletIndex === current) { - $bullet.addClass(params.bulletActiveClass); - } - - if (params.dynamicBullets) { - if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) { - $bullet.addClass(`${params.bulletActiveClass}-main`); - } - - if (bulletIndex === firstIndex) { - setSideBullets($bullet, "prev"); - } - - if (bulletIndex === lastIndex) { - setSideBullets($bullet, "next"); - } - } - }); - } else { - const $bullet = bullets.eq(current); - const bulletIndex = $bullet.index(); - $bullet.addClass(params.bulletActiveClass); - - if (params.dynamicBullets) { - const $firstDisplayedBullet = bullets.eq(firstIndex); - const $lastDisplayedBullet = bullets.eq(lastIndex); - - for (let i = firstIndex; i <= lastIndex; i += 1) { - bullets.eq(i).addClass(`${params.bulletActiveClass}-main`); - } - - if (swiper.params.loop) { - if (bulletIndex >= bullets.length) { - for (let i = params.dynamicMainBullets; i >= 0; i -= 1) { - bullets - .eq(bullets.length - i) - .addClass(`${params.bulletActiveClass}-main`); - } - - bullets - .eq(bullets.length - params.dynamicMainBullets - 1) - .addClass(`${params.bulletActiveClass}-prev`); - } else { - setSideBullets($firstDisplayedBullet, "prev"); - setSideBullets($lastDisplayedBullet, "next"); - } - } else { - setSideBullets($firstDisplayedBullet, "prev"); - setSideBullets($lastDisplayedBullet, "next"); - } - } - } - - if (params.dynamicBullets) { - const dynamicBulletsLength = Math.min( - bullets.length, - params.dynamicMainBullets + 4, - ); - const bulletsOffset = - (bulletSize * dynamicBulletsLength - bulletSize) / 2 - - midIndex * bulletSize; - const offsetProp = rtl ? "right" : "left"; - bullets.css( - swiper.isHorizontal() ? offsetProp : "top", - `${bulletsOffset}px`, - ); - } - } - - if (params.type === "fraction") { - $el - .find(classesToSelector(params.currentClass)) - .text(params.formatFractionCurrent(current + 1)); - $el - .find(classesToSelector(params.totalClass)) - .text(params.formatFractionTotal(total)); - } - - if (params.type === "progressbar") { - let progressbarDirection; - - if (params.progressbarOpposite) { - progressbarDirection = swiper.isHorizontal() - ? "vertical" - : "horizontal"; - } else { - progressbarDirection = swiper.isHorizontal() - ? "horizontal" - : "vertical"; - } - - const scale = (current + 1) / total; - let scaleX = 1; - let scaleY = 1; - - if (progressbarDirection === "horizontal") { - scaleX = scale; - } else { - scaleY = scale; - } - - $el - .find(classesToSelector(params.progressbarFillClass)) - .transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`) - .transition(swiper.params.speed); - } - - if (params.type === "custom" && params.renderCustom) { - $el.html(params.renderCustom(swiper, current + 1, total)); - emit("paginationRender", $el[0]); - } else { - emit("paginationUpdate", $el[0]); - } - - if (swiper.params.watchOverflow && swiper.enabled) { - $el[swiper.isLocked ? "addClass" : "removeClass"](params.lockClass); - } - } - - function render() { - // Render Container - const params = swiper.params.pagination; - if (isPaginationDisabled()) return; - const slidesLength = - swiper.virtual && swiper.params.virtual.enabled - ? swiper.virtual.slides.length - : swiper.slides.length; - const $el = swiper.pagination.$el; - let paginationHTML = ""; - - if (params.type === "bullets") { - let numberOfBullets = swiper.params.loop - ? Math.ceil( - (slidesLength - swiper.loopedSlides * 2) / - swiper.params.slidesPerGroup, - ) - : swiper.snapGrid.length; - - if ( - swiper.params.freeMode && - swiper.params.freeMode.enabled && - !swiper.params.loop && - numberOfBullets > slidesLength - ) { - numberOfBullets = slidesLength; - } - - for (let i = 0; i < numberOfBullets; i += 1) { - if (params.renderBullet) { - paginationHTML += params.renderBullet.call( - swiper, - i, - params.bulletClass, - ); - } else { - paginationHTML += `<${params.bulletElement} class="${params.bulletClass}">`; - } - } - - $el.html(paginationHTML); - swiper.pagination.bullets = $el.find( - classesToSelector(params.bulletClass), - ); - } - - if (params.type === "fraction") { - if (params.renderFraction) { - paginationHTML = params.renderFraction.call( - swiper, - params.currentClass, - params.totalClass, - ); - } else { - paginationHTML = - `` + - " / " + - ``; - } - - $el.html(paginationHTML); - } - - if (params.type === "progressbar") { - if (params.renderProgressbar) { - paginationHTML = params.renderProgressbar.call( - swiper, - params.progressbarFillClass, - ); - } else { - paginationHTML = ``; - } - - $el.html(paginationHTML); - } - - if (params.type !== "custom") { - emit("paginationRender", swiper.pagination.$el[0]); - } - } - - function init() { - swiper.params.pagination = createElementIfNotDefined( - swiper, - swiper.originalParams.pagination, - swiper.params.pagination, - { - el: "swiper-pagination", - }, - ); - const params = swiper.params.pagination; - if (!params.el) return; - let $el = $(params.el); - if ($el.length === 0) return; - - if ( - swiper.params.uniqueNavElements && - typeof params.el === "string" && - $el.length > 1 - ) { - $el = swiper.$el.find(params.el); // check if it belongs to another nested Swiper - - if ($el.length > 1) { - $el = $el.filter((el) => { - if ($(el).parents(".swiper")[0] !== swiper.el) return false; - return true; - }); - } - } - - if (params.type === "bullets" && params.clickable) { - $el.addClass(params.clickableClass); - } - - $el.addClass(params.modifierClass + params.type); - $el.addClass( - swiper.isHorizontal() ? params.horizontalClass : params.verticalClass, - ); - - if (params.type === "bullets" && params.dynamicBullets) { - $el.addClass(`${params.modifierClass}${params.type}-dynamic`); - dynamicBulletIndex = 0; - - if (params.dynamicMainBullets < 1) { - params.dynamicMainBullets = 1; - } - } - - if (params.type === "progressbar" && params.progressbarOpposite) { - $el.addClass(params.progressbarOppositeClass); - } - - if (params.clickable) { - $el.on( - "click", - classesToSelector(params.bulletClass), - function onClick(e) { - e.preventDefault(); - let index = $(this).index() * swiper.params.slidesPerGroup; - if (swiper.params.loop) index += swiper.loopedSlides; - swiper.slideTo(index); - }, - ); - } - - Object.assign(swiper.pagination, { - $el, - el: $el[0], - }); - - if (!swiper.enabled) { - $el.addClass(params.lockClass); - } - } - - function destroy() { - const params = swiper.params.pagination; - if (isPaginationDisabled()) return; - const $el = swiper.pagination.$el; - $el.removeClass(params.hiddenClass); - $el.removeClass(params.modifierClass + params.type); - $el.removeClass( - swiper.isHorizontal() ? params.horizontalClass : params.verticalClass, - ); - if (swiper.pagination.bullets && swiper.pagination.bullets.removeClass) - swiper.pagination.bullets.removeClass(params.bulletActiveClass); - - if (params.clickable) { - $el.off("click", classesToSelector(params.bulletClass)); - } - } - - on("init", () => { - init(); - render(); - update(); - }); - on("activeIndexChange", () => { - if (swiper.params.loop) { - update(); - } else if (typeof swiper.snapIndex === "undefined") { - update(); - } - }); - on("snapIndexChange", () => { - if (!swiper.params.loop) { - update(); - } - }); - on("slidesLengthChange", () => { - if (swiper.params.loop) { - render(); - update(); - } - }); - on("snapGridLengthChange", () => { - if (!swiper.params.loop) { - render(); - update(); - } - }); - on("destroy", () => { - destroy(); - }); - on("enable disable", () => { - const { $el } = swiper.pagination; - - if ($el) { - $el[swiper.enabled ? "removeClass" : "addClass"]( - swiper.params.pagination.lockClass, - ); - } - }); - on("lock unlock", () => { - update(); - }); - on("click", (_s, e) => { - const targetEl = e.target; - const { $el } = swiper.pagination; - - if ( - swiper.params.pagination.el && - swiper.params.pagination.hideOnClick && - $el.length > 0 && - !$(targetEl).hasClass(swiper.params.pagination.bulletClass) - ) { - if ( - swiper.navigation && - ((swiper.navigation.nextEl && - targetEl === swiper.navigation.nextEl) || - (swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) - ) - return; - const isHidden = $el.hasClass(swiper.params.pagination.hiddenClass); - - if (isHidden === true) { - emit("paginationShow"); - } else { - emit("paginationHide"); - } - - $el.toggleClass(swiper.params.pagination.hiddenClass); - } - }); - Object.assign(swiper.pagination, { - render, - update, - init, - destroy, - }); - } - - function Scrollbar(_ref) { - let { swiper, extendParams, on, emit } = _ref; - const document = getDocument(); - let isTouched = false; - let timeout = null; - let dragTimeout = null; - let dragStartPos; - let dragSize; - let trackSize; - let divider; - extendParams({ - scrollbar: { - el: null, - dragSize: "auto", - hide: false, - draggable: false, - snapOnRelease: true, - lockClass: "swiper-scrollbar-lock", - dragClass: "swiper-scrollbar-drag", - }, - }); - swiper.scrollbar = { - el: null, - dragEl: null, - $el: null, - $dragEl: null, - }; - - function setTranslate() { - if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return; - const { scrollbar, rtlTranslate: rtl, progress } = swiper; - const { $dragEl, $el } = scrollbar; - const params = swiper.params.scrollbar; - let newSize = dragSize; - let newPos = (trackSize - dragSize) * progress; - - if (rtl) { - newPos = -newPos; - - if (newPos > 0) { - newSize = dragSize - newPos; - newPos = 0; - } else if (-newPos + dragSize > trackSize) { - newSize = trackSize + newPos; - } - } else if (newPos < 0) { - newSize = dragSize + newPos; - newPos = 0; - } else if (newPos + dragSize > trackSize) { - newSize = trackSize - newPos; - } - - if (swiper.isHorizontal()) { - $dragEl.transform(`translate3d(${newPos}px, 0, 0)`); - $dragEl[0].style.width = `${newSize}px`; - } else { - $dragEl.transform(`translate3d(0px, ${newPos}px, 0)`); - $dragEl[0].style.height = `${newSize}px`; - } - - if (params.hide) { - clearTimeout(timeout); - $el[0].style.opacity = 1; - timeout = setTimeout(() => { - $el[0].style.opacity = 0; - $el.transition(400); - }, 1000); - } - } - - function setTransition(duration) { - if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return; - swiper.scrollbar.$dragEl.transition(duration); - } - - function updateSize() { - if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return; - const { scrollbar } = swiper; - const { $dragEl, $el } = scrollbar; - $dragEl[0].style.width = ""; - $dragEl[0].style.height = ""; - trackSize = swiper.isHorizontal() - ? $el[0].offsetWidth - : $el[0].offsetHeight; - divider = - swiper.size / - (swiper.virtualSize + - swiper.params.slidesOffsetBefore - - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0)); - - if (swiper.params.scrollbar.dragSize === "auto") { - dragSize = trackSize * divider; - } else { - dragSize = parseInt(swiper.params.scrollbar.dragSize, 10); - } - - if (swiper.isHorizontal()) { - $dragEl[0].style.width = `${dragSize}px`; - } else { - $dragEl[0].style.height = `${dragSize}px`; - } - - if (divider >= 1) { - $el[0].style.display = "none"; - } else { - $el[0].style.display = ""; - } - - if (swiper.params.scrollbar.hide) { - $el[0].style.opacity = 0; - } - - if (swiper.params.watchOverflow && swiper.enabled) { - scrollbar.$el[swiper.isLocked ? "addClass" : "removeClass"]( - swiper.params.scrollbar.lockClass, - ); - } - } - - function getPointerPosition(e) { - if (swiper.isHorizontal()) { - return e.type === "touchstart" || e.type === "touchmove" - ? e.targetTouches[0].clientX - : e.clientX; - } - - return e.type === "touchstart" || e.type === "touchmove" - ? e.targetTouches[0].clientY - : e.clientY; - } - - function setDragPosition(e) { - const { scrollbar, rtlTranslate: rtl } = swiper; - const { $el } = scrollbar; - let positionRatio; - positionRatio = - (getPointerPosition(e) - - $el.offset()[swiper.isHorizontal() ? "left" : "top"] - - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / - (trackSize - dragSize); - positionRatio = Math.max(Math.min(positionRatio, 1), 0); - - if (rtl) { - positionRatio = 1 - positionRatio; - } - - const position = - swiper.minTranslate() + - (swiper.maxTranslate() - swiper.minTranslate()) * positionRatio; - swiper.updateProgress(position); - swiper.setTranslate(position); - swiper.updateActiveIndex(); - swiper.updateSlidesClasses(); - } - - function onDragStart(e) { - const params = swiper.params.scrollbar; - const { scrollbar, $wrapperEl } = swiper; - const { $el, $dragEl } = scrollbar; - isTouched = true; - dragStartPos = - e.target === $dragEl[0] || e.target === $dragEl - ? getPointerPosition(e) - - e.target.getBoundingClientRect()[ - swiper.isHorizontal() ? "left" : "top" - ] - : null; - e.preventDefault(); - e.stopPropagation(); - $wrapperEl.transition(100); - $dragEl.transition(100); - setDragPosition(e); - clearTimeout(dragTimeout); - $el.transition(0); - - if (params.hide) { - $el.css("opacity", 1); - } - - if (swiper.params.cssMode) { - swiper.$wrapperEl.css("scroll-snap-type", "none"); - } - - emit("scrollbarDragStart", e); - } - - function onDragMove(e) { - const { scrollbar, $wrapperEl } = swiper; - const { $el, $dragEl } = scrollbar; - if (!isTouched) return; - if (e.preventDefault) e.preventDefault(); - else e.returnValue = false; - setDragPosition(e); - $wrapperEl.transition(0); - $el.transition(0); - $dragEl.transition(0); - emit("scrollbarDragMove", e); - } - - function onDragEnd(e) { - const params = swiper.params.scrollbar; - const { scrollbar, $wrapperEl } = swiper; - const { $el } = scrollbar; - if (!isTouched) return; - isTouched = false; - - if (swiper.params.cssMode) { - swiper.$wrapperEl.css("scroll-snap-type", ""); - $wrapperEl.transition(""); - } - - if (params.hide) { - clearTimeout(dragTimeout); - dragTimeout = nextTick(() => { - $el.css("opacity", 0); - $el.transition(400); - }, 1000); - } - - emit("scrollbarDragEnd", e); - - if (params.snapOnRelease) { - swiper.slideToClosest(); - } - } - - function events(method) { - const { - scrollbar, - touchEventsTouch, - touchEventsDesktop, - params, - support, - } = swiper; - const $el = scrollbar.$el; - const target = $el[0]; - const activeListener = - support.passiveListener && params.passiveListeners - ? { - passive: false, - capture: false, - } - : false; - const passiveListener = - support.passiveListener && params.passiveListeners - ? { - passive: true, - capture: false, - } - : false; - if (!target) return; - const eventMethod = - method === "on" ? "addEventListener" : "removeEventListener"; - - if (!support.touch) { - target[eventMethod]( - touchEventsDesktop.start, - onDragStart, - activeListener, - ); - document[eventMethod]( - touchEventsDesktop.move, - onDragMove, - activeListener, - ); - document[eventMethod]( - touchEventsDesktop.end, - onDragEnd, - passiveListener, - ); - } else { - target[eventMethod]( - touchEventsTouch.start, - onDragStart, - activeListener, - ); - target[eventMethod](touchEventsTouch.move, onDragMove, activeListener); - target[eventMethod](touchEventsTouch.end, onDragEnd, passiveListener); - } - } - - function enableDraggable() { - if (!swiper.params.scrollbar.el) return; - events("on"); - } - - function disableDraggable() { - if (!swiper.params.scrollbar.el) return; - events("off"); - } - - function init() { - const { scrollbar, $el: $swiperEl } = swiper; - swiper.params.scrollbar = createElementIfNotDefined( - swiper, - swiper.originalParams.scrollbar, - swiper.params.scrollbar, - { - el: "swiper-scrollbar", - }, - ); - const params = swiper.params.scrollbar; - if (!params.el) return; - let $el = $(params.el); - - if ( - swiper.params.uniqueNavElements && - typeof params.el === "string" && - $el.length > 1 && - $swiperEl.find(params.el).length === 1 - ) { - $el = $swiperEl.find(params.el); - } - - let $dragEl = $el.find(`.${swiper.params.scrollbar.dragClass}`); - - if ($dragEl.length === 0) { - $dragEl = $(`
`); - $el.append($dragEl); - } - - Object.assign(scrollbar, { - $el, - el: $el[0], - $dragEl, - dragEl: $dragEl[0], - }); - - if (params.draggable) { - enableDraggable(); - } - - if ($el) { - $el[swiper.enabled ? "removeClass" : "addClass"]( - swiper.params.scrollbar.lockClass, - ); - } - } - - function destroy() { - disableDraggable(); - } - - on("init", () => { - init(); - updateSize(); - setTranslate(); - }); - on("update resize observerUpdate lock unlock", () => { - updateSize(); - }); - on("setTranslate", () => { - setTranslate(); - }); - on("setTransition", (_s, duration) => { - setTransition(duration); - }); - on("enable disable", () => { - const { $el } = swiper.scrollbar; - - if ($el) { - $el[swiper.enabled ? "removeClass" : "addClass"]( - swiper.params.scrollbar.lockClass, - ); - } - }); - on("destroy", () => { - destroy(); - }); - Object.assign(swiper.scrollbar, { - updateSize, - setTranslate, - init, - destroy, - }); - } - - function Parallax(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - parallax: { - enabled: false, - }, - }); - - const setTransform = (el, progress) => { - const { rtl } = swiper; - const $el = $(el); - const rtlFactor = rtl ? -1 : 1; - const p = $el.attr("data-swiper-parallax") || "0"; - let x = $el.attr("data-swiper-parallax-x"); - let y = $el.attr("data-swiper-parallax-y"); - const scale = $el.attr("data-swiper-parallax-scale"); - const opacity = $el.attr("data-swiper-parallax-opacity"); - - if (x || y) { - x = x || "0"; - y = y || "0"; - } else if (swiper.isHorizontal()) { - x = p; - y = "0"; - } else { - y = p; - x = "0"; - } - - if (x.indexOf("%") >= 0) { - x = `${parseInt(x, 10) * progress * rtlFactor}%`; - } else { - x = `${x * progress * rtlFactor}px`; - } - - if (y.indexOf("%") >= 0) { - y = `${parseInt(y, 10) * progress}%`; - } else { - y = `${y * progress}px`; - } - - if (typeof opacity !== "undefined" && opacity !== null) { - const currentOpacity = - opacity - (opacity - 1) * (1 - Math.abs(progress)); - $el[0].style.opacity = currentOpacity; - } - - if (typeof scale === "undefined" || scale === null) { - $el.transform(`translate3d(${x}, ${y}, 0px)`); - } else { - const currentScale = scale - (scale - 1) * (1 - Math.abs(progress)); - $el.transform(`translate3d(${x}, ${y}, 0px) scale(${currentScale})`); - } - }; - - const setTranslate = () => { - const { $el, slides, progress, snapGrid } = swiper; - $el - .children( - "[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]", - ) - .each((el) => { - setTransform(el, progress); - }); - slides.each((slideEl, slideIndex) => { - let slideProgress = slideEl.progress; - - if ( - swiper.params.slidesPerGroup > 1 && - swiper.params.slidesPerView !== "auto" - ) { - slideProgress += - Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1); - } - - slideProgress = Math.min(Math.max(slideProgress, -1), 1); - $(slideEl) - .find( - "[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]", - ) - .each((el) => { - setTransform(el, slideProgress); - }); - }); - }; - - const setTransition = function (duration) { - if (duration === void 0) { - duration = swiper.params.speed; - } - - const { $el } = swiper; - $el - .find( - "[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]", - ) - .each((parallaxEl) => { - const $parallaxEl = $(parallaxEl); - let parallaxDuration = - parseInt($parallaxEl.attr("data-swiper-parallax-duration"), 10) || - duration; - if (duration === 0) parallaxDuration = 0; - $parallaxEl.transition(parallaxDuration); - }); - }; - - on("beforeInit", () => { - if (!swiper.params.parallax.enabled) return; - swiper.params.watchSlidesProgress = true; - swiper.originalParams.watchSlidesProgress = true; - }); - on("init", () => { - if (!swiper.params.parallax.enabled) return; - setTranslate(); - }); - on("setTranslate", () => { - if (!swiper.params.parallax.enabled) return; - setTranslate(); - }); - on("setTransition", (_swiper, duration) => { - if (!swiper.params.parallax.enabled) return; - setTransition(duration); - }); - } - - function Zoom(_ref) { - let { swiper, extendParams, on, emit } = _ref; - const window = getWindow(); - extendParams({ - zoom: { - enabled: false, - maxRatio: 3, - minRatio: 1, - toggle: true, - containerClass: "swiper-zoom-container", - zoomedSlideClass: "swiper-slide-zoomed", - }, - }); - swiper.zoom = { - enabled: false, - }; - let currentScale = 1; - let isScaling = false; - let gesturesEnabled; - let fakeGestureTouched; - let fakeGestureMoved; - const gesture = { - $slideEl: undefined, - slideWidth: undefined, - slideHeight: undefined, - $imageEl: undefined, - $imageWrapEl: undefined, - maxRatio: 3, - }; - const image = { - isTouched: undefined, - isMoved: undefined, - currentX: undefined, - currentY: undefined, - minX: undefined, - minY: undefined, - maxX: undefined, - maxY: undefined, - width: undefined, - height: undefined, - startX: undefined, - startY: undefined, - touchesStart: {}, - touchesCurrent: {}, - }; - const velocity = { - x: undefined, - y: undefined, - prevPositionX: undefined, - prevPositionY: undefined, - prevTime: undefined, - }; - let scale = 1; - Object.defineProperty(swiper.zoom, "scale", { - get() { - return scale; - }, - - set(value) { - if (scale !== value) { - const imageEl = gesture.$imageEl ? gesture.$imageEl[0] : undefined; - const slideEl = gesture.$slideEl ? gesture.$slideEl[0] : undefined; - emit("zoomChange", value, imageEl, slideEl); - } - - scale = value; - }, - }); - - function getDistanceBetweenTouches(e) { - if (e.targetTouches.length < 2) return 1; - const x1 = e.targetTouches[0].pageX; - const y1 = e.targetTouches[0].pageY; - const x2 = e.targetTouches[1].pageX; - const y2 = e.targetTouches[1].pageY; - const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2); - return distance; - } // Events - - function onGestureStart(e) { - const support = swiper.support; - const params = swiper.params.zoom; - fakeGestureTouched = false; - fakeGestureMoved = false; - - if (!support.gestures) { - if ( - e.type !== "touchstart" || - (e.type === "touchstart" && e.targetTouches.length < 2) - ) { - return; - } - - fakeGestureTouched = true; - gesture.scaleStart = getDistanceBetweenTouches(e); - } - - if (!gesture.$slideEl || !gesture.$slideEl.length) { - gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`); - if (gesture.$slideEl.length === 0) - gesture.$slideEl = swiper.slides.eq(swiper.activeIndex); - gesture.$imageEl = gesture.$slideEl - .find(`.${params.containerClass}`) - .eq(0) - .find("picture, img, svg, canvas, .swiper-zoom-target") - .eq(0); - gesture.$imageWrapEl = gesture.$imageEl.parent( - `.${params.containerClass}`, - ); - gesture.maxRatio = - gesture.$imageWrapEl.attr("data-swiper-zoom") || params.maxRatio; - - if (gesture.$imageWrapEl.length === 0) { - gesture.$imageEl = undefined; - return; - } - } - - if (gesture.$imageEl) { - gesture.$imageEl.transition(0); - } - - isScaling = true; - } - - function onGestureChange(e) { - const support = swiper.support; - const params = swiper.params.zoom; - const zoom = swiper.zoom; - - if (!support.gestures) { - if ( - e.type !== "touchmove" || - (e.type === "touchmove" && e.targetTouches.length < 2) - ) { - return; - } - - fakeGestureMoved = true; - gesture.scaleMove = getDistanceBetweenTouches(e); - } - - if (!gesture.$imageEl || gesture.$imageEl.length === 0) { - if (e.type === "gesturechange") onGestureStart(e); - return; - } - - if (support.gestures) { - zoom.scale = e.scale * currentScale; - } else { - zoom.scale = (gesture.scaleMove / gesture.scaleStart) * currentScale; - } - - if (zoom.scale > gesture.maxRatio) { - zoom.scale = - gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5; - } - - if (zoom.scale < params.minRatio) { - zoom.scale = - params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5; - } - - gesture.$imageEl.transform(`translate3d(0,0,0) scale(${zoom.scale})`); - } - - function onGestureEnd(e) { - const device = swiper.device; - const support = swiper.support; - const params = swiper.params.zoom; - const zoom = swiper.zoom; - - if (!support.gestures) { - if (!fakeGestureTouched || !fakeGestureMoved) { - return; - } - - if ( - e.type !== "touchend" || - (e.type === "touchend" && - e.changedTouches.length < 2 && - !device.android) - ) { - return; - } - - fakeGestureTouched = false; - fakeGestureMoved = false; - } - - if (!gesture.$imageEl || gesture.$imageEl.length === 0) return; - zoom.scale = Math.max( - Math.min(zoom.scale, gesture.maxRatio), - params.minRatio, - ); - gesture.$imageEl - .transition(swiper.params.speed) - .transform(`translate3d(0,0,0) scale(${zoom.scale})`); - currentScale = zoom.scale; - isScaling = false; - if (zoom.scale === 1) gesture.$slideEl = undefined; - } - - function onTouchStart(e) { - const device = swiper.device; - if (!gesture.$imageEl || gesture.$imageEl.length === 0) return; - if (image.isTouched) return; - if (device.android && e.cancelable) e.preventDefault(); - image.isTouched = true; - image.touchesStart.x = - e.type === "touchstart" ? e.targetTouches[0].pageX : e.pageX; - image.touchesStart.y = - e.type === "touchstart" ? e.targetTouches[0].pageY : e.pageY; - } - - function onTouchMove(e) { - const zoom = swiper.zoom; - if (!gesture.$imageEl || gesture.$imageEl.length === 0) return; - swiper.allowClick = false; - if (!image.isTouched || !gesture.$slideEl) return; - - if (!image.isMoved) { - image.width = gesture.$imageEl[0].offsetWidth; - image.height = gesture.$imageEl[0].offsetHeight; - image.startX = getTranslate(gesture.$imageWrapEl[0], "x") || 0; - image.startY = getTranslate(gesture.$imageWrapEl[0], "y") || 0; - gesture.slideWidth = gesture.$slideEl[0].offsetWidth; - gesture.slideHeight = gesture.$slideEl[0].offsetHeight; - gesture.$imageWrapEl.transition(0); - } // Define if we need image drag - - const scaledWidth = image.width * zoom.scale; - const scaledHeight = image.height * zoom.scale; - if ( - scaledWidth < gesture.slideWidth && - scaledHeight < gesture.slideHeight - ) - return; - image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0); - image.maxX = -image.minX; - image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0); - image.maxY = -image.minY; - image.touchesCurrent.x = - e.type === "touchmove" ? e.targetTouches[0].pageX : e.pageX; - image.touchesCurrent.y = - e.type === "touchmove" ? e.targetTouches[0].pageY : e.pageY; - - if (!image.isMoved && !isScaling) { - if ( - swiper.isHorizontal() && - ((Math.floor(image.minX) === Math.floor(image.startX) && - image.touchesCurrent.x < image.touchesStart.x) || - (Math.floor(image.maxX) === Math.floor(image.startX) && - image.touchesCurrent.x > image.touchesStart.x)) - ) { - image.isTouched = false; - return; - } - - if ( - !swiper.isHorizontal() && - ((Math.floor(image.minY) === Math.floor(image.startY) && - image.touchesCurrent.y < image.touchesStart.y) || - (Math.floor(image.maxY) === Math.floor(image.startY) && - image.touchesCurrent.y > image.touchesStart.y)) - ) { - image.isTouched = false; - return; - } - } - - if (e.cancelable) { - e.preventDefault(); - } - - e.stopPropagation(); - image.isMoved = true; - image.currentX = - image.touchesCurrent.x - image.touchesStart.x + image.startX; - image.currentY = - image.touchesCurrent.y - image.touchesStart.y + image.startY; - - if (image.currentX < image.minX) { - image.currentX = - image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8; - } - - if (image.currentX > image.maxX) { - image.currentX = - image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8; - } - - if (image.currentY < image.minY) { - image.currentY = - image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8; - } - - if (image.currentY > image.maxY) { - image.currentY = - image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8; - } // Velocity - - if (!velocity.prevPositionX) - velocity.prevPositionX = image.touchesCurrent.x; - if (!velocity.prevPositionY) - velocity.prevPositionY = image.touchesCurrent.y; - if (!velocity.prevTime) velocity.prevTime = Date.now(); - velocity.x = - (image.touchesCurrent.x - velocity.prevPositionX) / - (Date.now() - velocity.prevTime) / - 2; - velocity.y = - (image.touchesCurrent.y - velocity.prevPositionY) / - (Date.now() - velocity.prevTime) / - 2; - if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) - velocity.x = 0; - if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) - velocity.y = 0; - velocity.prevPositionX = image.touchesCurrent.x; - velocity.prevPositionY = image.touchesCurrent.y; - velocity.prevTime = Date.now(); - gesture.$imageWrapEl.transform( - `translate3d(${image.currentX}px, ${image.currentY}px,0)`, - ); - } - - function onTouchEnd() { - const zoom = swiper.zoom; - if (!gesture.$imageEl || gesture.$imageEl.length === 0) return; - - if (!image.isTouched || !image.isMoved) { - image.isTouched = false; - image.isMoved = false; - return; - } - - image.isTouched = false; - image.isMoved = false; - let momentumDurationX = 300; - let momentumDurationY = 300; - const momentumDistanceX = velocity.x * momentumDurationX; - const newPositionX = image.currentX + momentumDistanceX; - const momentumDistanceY = velocity.y * momentumDurationY; - const newPositionY = image.currentY + momentumDistanceY; // Fix duration - - if (velocity.x !== 0) - momentumDurationX = Math.abs( - (newPositionX - image.currentX) / velocity.x, - ); - if (velocity.y !== 0) - momentumDurationY = Math.abs( - (newPositionY - image.currentY) / velocity.y, - ); - const momentumDuration = Math.max(momentumDurationX, momentumDurationY); - image.currentX = newPositionX; - image.currentY = newPositionY; // Define if we need image drag - - const scaledWidth = image.width * zoom.scale; - const scaledHeight = image.height * zoom.scale; - image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0); - image.maxX = -image.minX; - image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0); - image.maxY = -image.minY; - image.currentX = Math.max( - Math.min(image.currentX, image.maxX), - image.minX, - ); - image.currentY = Math.max( - Math.min(image.currentY, image.maxY), - image.minY, - ); - gesture.$imageWrapEl - .transition(momentumDuration) - .transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`); - } - - function onTransitionEnd() { - const zoom = swiper.zoom; - - if (gesture.$slideEl && swiper.previousIndex !== swiper.activeIndex) { - if (gesture.$imageEl) { - gesture.$imageEl.transform("translate3d(0,0,0) scale(1)"); - } - - if (gesture.$imageWrapEl) { - gesture.$imageWrapEl.transform("translate3d(0,0,0)"); - } - - zoom.scale = 1; - currentScale = 1; - gesture.$slideEl = undefined; - gesture.$imageEl = undefined; - gesture.$imageWrapEl = undefined; - } - } - - function zoomIn(e) { - const zoom = swiper.zoom; - const params = swiper.params.zoom; - - if (!gesture.$slideEl) { - if (e && e.target) { - gesture.$slideEl = $(e.target).closest( - `.${swiper.params.slideClass}`, - ); - } - - if (!gesture.$slideEl) { - if ( - swiper.params.virtual && - swiper.params.virtual.enabled && - swiper.virtual - ) { - gesture.$slideEl = swiper.$wrapperEl.children( - `.${swiper.params.slideActiveClass}`, - ); - } else { - gesture.$slideEl = swiper.slides.eq(swiper.activeIndex); - } - } - - gesture.$imageEl = gesture.$slideEl - .find(`.${params.containerClass}`) - .eq(0) - .find("picture, img, svg, canvas, .swiper-zoom-target") - .eq(0); - gesture.$imageWrapEl = gesture.$imageEl.parent( - `.${params.containerClass}`, - ); - } - - if ( - !gesture.$imageEl || - gesture.$imageEl.length === 0 || - !gesture.$imageWrapEl || - gesture.$imageWrapEl.length === 0 - ) - return; - - if (swiper.params.cssMode) { - swiper.wrapperEl.style.overflow = "hidden"; - swiper.wrapperEl.style.touchAction = "none"; - } - - gesture.$slideEl.addClass(`${params.zoomedSlideClass}`); - let touchX; - let touchY; - let offsetX; - let offsetY; - let diffX; - let diffY; - let translateX; - let translateY; - let imageWidth; - let imageHeight; - let scaledWidth; - let scaledHeight; - let translateMinX; - let translateMinY; - let translateMaxX; - let translateMaxY; - let slideWidth; - let slideHeight; - - if (typeof image.touchesStart.x === "undefined" && e) { - touchX = e.type === "touchend" ? e.changedTouches[0].pageX : e.pageX; - touchY = e.type === "touchend" ? e.changedTouches[0].pageY : e.pageY; - } else { - touchX = image.touchesStart.x; - touchY = image.touchesStart.y; - } - - zoom.scale = - gesture.$imageWrapEl.attr("data-swiper-zoom") || params.maxRatio; - currentScale = - gesture.$imageWrapEl.attr("data-swiper-zoom") || params.maxRatio; - - if (e) { - slideWidth = gesture.$slideEl[0].offsetWidth; - slideHeight = gesture.$slideEl[0].offsetHeight; - offsetX = gesture.$slideEl.offset().left + window.scrollX; - offsetY = gesture.$slideEl.offset().top + window.scrollY; - diffX = offsetX + slideWidth / 2 - touchX; - diffY = offsetY + slideHeight / 2 - touchY; - imageWidth = gesture.$imageEl[0].offsetWidth; - imageHeight = gesture.$imageEl[0].offsetHeight; - scaledWidth = imageWidth * zoom.scale; - scaledHeight = imageHeight * zoom.scale; - translateMinX = Math.min(slideWidth / 2 - scaledWidth / 2, 0); - translateMinY = Math.min(slideHeight / 2 - scaledHeight / 2, 0); - translateMaxX = -translateMinX; - translateMaxY = -translateMinY; - translateX = diffX * zoom.scale; - translateY = diffY * zoom.scale; - - if (translateX < translateMinX) { - translateX = translateMinX; - } - - if (translateX > translateMaxX) { - translateX = translateMaxX; - } - - if (translateY < translateMinY) { - translateY = translateMinY; - } - - if (translateY > translateMaxY) { - translateY = translateMaxY; - } - } else { - translateX = 0; - translateY = 0; - } - - gesture.$imageWrapEl - .transition(300) - .transform(`translate3d(${translateX}px, ${translateY}px,0)`); - gesture.$imageEl - .transition(300) - .transform(`translate3d(0,0,0) scale(${zoom.scale})`); - } - - function zoomOut() { - const zoom = swiper.zoom; - const params = swiper.params.zoom; - - if (!gesture.$slideEl) { - if ( - swiper.params.virtual && - swiper.params.virtual.enabled && - swiper.virtual - ) { - gesture.$slideEl = swiper.$wrapperEl.children( - `.${swiper.params.slideActiveClass}`, - ); - } else { - gesture.$slideEl = swiper.slides.eq(swiper.activeIndex); - } - - gesture.$imageEl = gesture.$slideEl - .find(`.${params.containerClass}`) - .eq(0) - .find("picture, img, svg, canvas, .swiper-zoom-target") - .eq(0); - gesture.$imageWrapEl = gesture.$imageEl.parent( - `.${params.containerClass}`, - ); - } - - if ( - !gesture.$imageEl || - gesture.$imageEl.length === 0 || - !gesture.$imageWrapEl || - gesture.$imageWrapEl.length === 0 - ) - return; - - if (swiper.params.cssMode) { - swiper.wrapperEl.style.overflow = ""; - swiper.wrapperEl.style.touchAction = ""; - } - - zoom.scale = 1; - currentScale = 1; - gesture.$imageWrapEl.transition(300).transform("translate3d(0,0,0)"); - gesture.$imageEl.transition(300).transform("translate3d(0,0,0) scale(1)"); - gesture.$slideEl.removeClass(`${params.zoomedSlideClass}`); - gesture.$slideEl = undefined; - } // Toggle Zoom - - function zoomToggle(e) { - const zoom = swiper.zoom; - - if (zoom.scale && zoom.scale !== 1) { - // Zoom Out - zoomOut(); - } else { - // Zoom In - zoomIn(e); - } - } - - function getListeners() { - const support = swiper.support; - const passiveListener = - swiper.touchEvents.start === "touchstart" && - support.passiveListener && - swiper.params.passiveListeners - ? { - passive: true, - capture: false, - } - : false; - const activeListenerWithCapture = support.passiveListener - ? { - passive: false, - capture: true, - } - : true; - return { - passiveListener, - activeListenerWithCapture, - }; - } - - function getSlideSelector() { - return `.${swiper.params.slideClass}`; - } - - function toggleGestures(method) { - const { passiveListener } = getListeners(); - const slideSelector = getSlideSelector(); - swiper.$wrapperEl[method]( - "gesturestart", - slideSelector, - onGestureStart, - passiveListener, - ); - swiper.$wrapperEl[method]( - "gesturechange", - slideSelector, - onGestureChange, - passiveListener, - ); - swiper.$wrapperEl[method]( - "gestureend", - slideSelector, - onGestureEnd, - passiveListener, - ); - } - - function enableGestures() { - if (gesturesEnabled) return; - gesturesEnabled = true; - toggleGestures("on"); - } - - function disableGestures() { - if (!gesturesEnabled) return; - gesturesEnabled = false; - toggleGestures("off"); - } // Attach/Detach Events - - function enable() { - const zoom = swiper.zoom; - if (zoom.enabled) return; - zoom.enabled = true; - const support = swiper.support; - const { passiveListener, activeListenerWithCapture } = getListeners(); - const slideSelector = getSlideSelector(); // Scale image - - if (support.gestures) { - swiper.$wrapperEl.on( - swiper.touchEvents.start, - enableGestures, - passiveListener, - ); - swiper.$wrapperEl.on( - swiper.touchEvents.end, - disableGestures, - passiveListener, - ); - } else if (swiper.touchEvents.start === "touchstart") { - swiper.$wrapperEl.on( - swiper.touchEvents.start, - slideSelector, - onGestureStart, - passiveListener, - ); - swiper.$wrapperEl.on( - swiper.touchEvents.move, - slideSelector, - onGestureChange, - activeListenerWithCapture, - ); - swiper.$wrapperEl.on( - swiper.touchEvents.end, - slideSelector, - onGestureEnd, - passiveListener, - ); - - if (swiper.touchEvents.cancel) { - swiper.$wrapperEl.on( - swiper.touchEvents.cancel, - slideSelector, - onGestureEnd, - passiveListener, - ); - } - } // Move image - - swiper.$wrapperEl.on( - swiper.touchEvents.move, - `.${swiper.params.zoom.containerClass}`, - onTouchMove, - activeListenerWithCapture, - ); - } - - function disable() { - const zoom = swiper.zoom; - if (!zoom.enabled) return; - const support = swiper.support; - zoom.enabled = false; - const { passiveListener, activeListenerWithCapture } = getListeners(); - const slideSelector = getSlideSelector(); // Scale image - - if (support.gestures) { - swiper.$wrapperEl.off( - swiper.touchEvents.start, - enableGestures, - passiveListener, - ); - swiper.$wrapperEl.off( - swiper.touchEvents.end, - disableGestures, - passiveListener, - ); - } else if (swiper.touchEvents.start === "touchstart") { - swiper.$wrapperEl.off( - swiper.touchEvents.start, - slideSelector, - onGestureStart, - passiveListener, - ); - swiper.$wrapperEl.off( - swiper.touchEvents.move, - slideSelector, - onGestureChange, - activeListenerWithCapture, - ); - swiper.$wrapperEl.off( - swiper.touchEvents.end, - slideSelector, - onGestureEnd, - passiveListener, - ); - - if (swiper.touchEvents.cancel) { - swiper.$wrapperEl.off( - swiper.touchEvents.cancel, - slideSelector, - onGestureEnd, - passiveListener, - ); - } - } // Move image - - swiper.$wrapperEl.off( - swiper.touchEvents.move, - `.${swiper.params.zoom.containerClass}`, - onTouchMove, - activeListenerWithCapture, - ); - } - - on("init", () => { - if (swiper.params.zoom.enabled) { - enable(); - } - }); - on("destroy", () => { - disable(); - }); - on("touchStart", (_s, e) => { - if (!swiper.zoom.enabled) return; - onTouchStart(e); - }); - on("touchEnd", (_s, e) => { - if (!swiper.zoom.enabled) return; - onTouchEnd(); - }); - on("doubleTap", (_s, e) => { - if ( - !swiper.animating && - swiper.params.zoom.enabled && - swiper.zoom.enabled && - swiper.params.zoom.toggle - ) { - zoomToggle(e); - } - }); - on("transitionEnd", () => { - if (swiper.zoom.enabled && swiper.params.zoom.enabled) { - onTransitionEnd(); - } - }); - on("slideChange", () => { - if ( - swiper.zoom.enabled && - swiper.params.zoom.enabled && - swiper.params.cssMode - ) { - onTransitionEnd(); - } - }); - Object.assign(swiper.zoom, { - enable, - disable, - in: zoomIn, - out: zoomOut, - toggle: zoomToggle, - }); - } - - function Lazy(_ref) { - let { swiper, extendParams, on, emit } = _ref; - extendParams({ - lazy: { - checkInView: false, - enabled: false, - loadPrevNext: false, - loadPrevNextAmount: 1, - loadOnTransitionStart: false, - scrollingElement: "", - elementClass: "swiper-lazy", - loadingClass: "swiper-lazy-loading", - loadedClass: "swiper-lazy-loaded", - preloaderClass: "swiper-lazy-preloader", - }, - }); - swiper.lazy = {}; - let scrollHandlerAttached = false; - let initialImageLoaded = false; - - function loadInSlide(index, loadInDuplicate) { - if (loadInDuplicate === void 0) { - loadInDuplicate = true; - } - - const params = swiper.params.lazy; - if (typeof index === "undefined") return; - if (swiper.slides.length === 0) return; - const isVirtual = swiper.virtual && swiper.params.virtual.enabled; - const $slideEl = isVirtual - ? swiper.$wrapperEl.children( - `.${swiper.params.slideClass}[data-swiper-slide-index="${index}"]`, - ) - : swiper.slides.eq(index); - const $images = $slideEl.find( - `.${params.elementClass}:not(.${params.loadedClass}):not(.${params.loadingClass})`, - ); - - if ( - $slideEl.hasClass(params.elementClass) && - !$slideEl.hasClass(params.loadedClass) && - !$slideEl.hasClass(params.loadingClass) - ) { - $images.push($slideEl[0]); - } - - if ($images.length === 0) return; - $images.each((imageEl) => { - const $imageEl = $(imageEl); - $imageEl.addClass(params.loadingClass); - const background = $imageEl.attr("data-background"); - const src = $imageEl.attr("data-src"); - const srcset = $imageEl.attr("data-srcset"); - const sizes = $imageEl.attr("data-sizes"); - const $pictureEl = $imageEl.parent("picture"); - swiper.loadImage( - $imageEl[0], - src || background, - srcset, - sizes, - false, - () => { - if ( - typeof swiper === "undefined" || - swiper === null || - !swiper || - (swiper && !swiper.params) || - swiper.destroyed - ) - return; - - if (background) { - $imageEl.css("background-image", `url("${background}")`); - $imageEl.removeAttr("data-background"); - } else { - if (srcset) { - $imageEl.attr("srcset", srcset); - $imageEl.removeAttr("data-srcset"); - } - - if (sizes) { - $imageEl.attr("sizes", sizes); - $imageEl.removeAttr("data-sizes"); - } - - if ($pictureEl.length) { - $pictureEl.children("source").each((sourceEl) => { - const $source = $(sourceEl); - - if ($source.attr("data-srcset")) { - $source.attr("srcset", $source.attr("data-srcset")); - $source.removeAttr("data-srcset"); - } - }); - } - - if (src) { - $imageEl.attr("src", src); - $imageEl.removeAttr("data-src"); - } - } - - $imageEl - .addClass(params.loadedClass) - .removeClass(params.loadingClass); - $slideEl.find(`.${params.preloaderClass}`).remove(); - - if (swiper.params.loop && loadInDuplicate) { - const slideOriginalIndex = $slideEl.attr( - "data-swiper-slide-index", - ); - - if ($slideEl.hasClass(swiper.params.slideDuplicateClass)) { - const originalSlide = swiper.$wrapperEl.children( - `[data-swiper-slide-index="${slideOriginalIndex}"]:not(.${swiper.params.slideDuplicateClass})`, - ); - loadInSlide(originalSlide.index(), false); - } else { - const duplicatedSlide = swiper.$wrapperEl.children( - `.${swiper.params.slideDuplicateClass}[data-swiper-slide-index="${slideOriginalIndex}"]`, - ); - loadInSlide(duplicatedSlide.index(), false); - } - } - - emit("lazyImageReady", $slideEl[0], $imageEl[0]); - - if (swiper.params.autoHeight) { - swiper.updateAutoHeight(); - } - }, - ); - emit("lazyImageLoad", $slideEl[0], $imageEl[0]); - }); - } - - function load() { - const { $wrapperEl, params: swiperParams, slides, activeIndex } = swiper; - const isVirtual = swiper.virtual && swiperParams.virtual.enabled; - const params = swiperParams.lazy; - let slidesPerView = swiperParams.slidesPerView; - - if (slidesPerView === "auto") { - slidesPerView = 0; - } - - function slideExist(index) { - if (isVirtual) { - if ( - $wrapperEl.children( - `.${swiperParams.slideClass}[data-swiper-slide-index="${index}"]`, - ).length - ) { - return true; - } - } else if (slides[index]) return true; - - return false; - } - - function slideIndex(slideEl) { - if (isVirtual) { - return $(slideEl).attr("data-swiper-slide-index"); - } - - return $(slideEl).index(); - } - - if (!initialImageLoaded) initialImageLoaded = true; - - if (swiper.params.watchSlidesProgress) { - $wrapperEl - .children(`.${swiperParams.slideVisibleClass}`) - .each((slideEl) => { - const index = isVirtual - ? $(slideEl).attr("data-swiper-slide-index") - : $(slideEl).index(); - loadInSlide(index); - }); - } else if (slidesPerView > 1) { - for (let i = activeIndex; i < activeIndex + slidesPerView; i += 1) { - if (slideExist(i)) loadInSlide(i); - } - } else { - loadInSlide(activeIndex); - } - - if (params.loadPrevNext) { - if ( - slidesPerView > 1 || - (params.loadPrevNextAmount && params.loadPrevNextAmount > 1) - ) { - const amount = params.loadPrevNextAmount; - const spv = slidesPerView; - const maxIndex = Math.min( - activeIndex + spv + Math.max(amount, spv), - slides.length, - ); - const minIndex = Math.max(activeIndex - Math.max(spv, amount), 0); // Next Slides - - for (let i = activeIndex + slidesPerView; i < maxIndex; i += 1) { - if (slideExist(i)) loadInSlide(i); - } // Prev Slides - - for (let i = minIndex; i < activeIndex; i += 1) { - if (slideExist(i)) loadInSlide(i); - } - } else { - const nextSlide = $wrapperEl.children( - `.${swiperParams.slideNextClass}`, - ); - if (nextSlide.length > 0) loadInSlide(slideIndex(nextSlide)); - const prevSlide = $wrapperEl.children( - `.${swiperParams.slidePrevClass}`, - ); - if (prevSlide.length > 0) loadInSlide(slideIndex(prevSlide)); - } - } - } - - function checkInViewOnLoad() { - const window = getWindow(); - if (!swiper || swiper.destroyed) return; - const $scrollElement = swiper.params.lazy.scrollingElement - ? $(swiper.params.lazy.scrollingElement) - : $(window); - const isWindow = $scrollElement[0] === window; - const scrollElementWidth = isWindow - ? window.innerWidth - : $scrollElement[0].offsetWidth; - const scrollElementHeight = isWindow - ? window.innerHeight - : $scrollElement[0].offsetHeight; - const swiperOffset = swiper.$el.offset(); - const { rtlTranslate: rtl } = swiper; - let inView = false; - if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft; - const swiperCoord = [ - [swiperOffset.left, swiperOffset.top], - [swiperOffset.left + swiper.width, swiperOffset.top], - [swiperOffset.left, swiperOffset.top + swiper.height], - [swiperOffset.left + swiper.width, swiperOffset.top + swiper.height], - ]; - - for (let i = 0; i < swiperCoord.length; i += 1) { - const point = swiperCoord[i]; - - if ( - point[0] >= 0 && - point[0] <= scrollElementWidth && - point[1] >= 0 && - point[1] <= scrollElementHeight - ) { - if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line - - inView = true; - } - } - - const passiveListener = - swiper.touchEvents.start === "touchstart" && - swiper.support.passiveListener && - swiper.params.passiveListeners - ? { - passive: true, - capture: false, - } - : false; - - if (inView) { - load(); - $scrollElement.off("scroll", checkInViewOnLoad, passiveListener); - } else if (!scrollHandlerAttached) { - scrollHandlerAttached = true; - $scrollElement.on("scroll", checkInViewOnLoad, passiveListener); - } - } - - on("beforeInit", () => { - if (swiper.params.lazy.enabled && swiper.params.preloadImages) { - swiper.params.preloadImages = false; - } - }); - on("init", () => { - if (swiper.params.lazy.enabled) { - if (swiper.params.lazy.checkInView) { - checkInViewOnLoad(); - } else { - load(); - } - } - }); - on("scroll", () => { - if ( - swiper.params.freeMode && - swiper.params.freeMode.enabled && - !swiper.params.freeMode.sticky - ) { - load(); - } - }); - on("scrollbarDragMove resize _freeModeNoMomentumRelease", () => { - if (swiper.params.lazy.enabled) { - if (swiper.params.lazy.checkInView) { - checkInViewOnLoad(); - } else { - load(); - } - } - }); - on("transitionStart", () => { - if (swiper.params.lazy.enabled) { - if ( - swiper.params.lazy.loadOnTransitionStart || - (!swiper.params.lazy.loadOnTransitionStart && !initialImageLoaded) - ) { - if (swiper.params.lazy.checkInView) { - checkInViewOnLoad(); - } else { - load(); - } - } - } - }); - on("transitionEnd", () => { - if ( - swiper.params.lazy.enabled && - !swiper.params.lazy.loadOnTransitionStart - ) { - if (swiper.params.lazy.checkInView) { - checkInViewOnLoad(); - } else { - load(); - } - } - }); - on("slideChange", () => { - const { - lazy, - cssMode, - watchSlidesProgress, - touchReleaseOnEdges, - resistanceRatio, - } = swiper.params; - - if ( - lazy.enabled && - (cssMode || - (watchSlidesProgress && - (touchReleaseOnEdges || resistanceRatio === 0))) - ) { - load(); - } - }); - Object.assign(swiper.lazy, { - load, - loadInSlide, - }); - } - - /* eslint no-bitwise: ["error", { "allow": [">>"] }] */ - function Controller(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - controller: { - control: undefined, - inverse: false, - by: "slide", // or 'container' - }, - }); - swiper.controller = { - control: undefined, - }; - - function LinearSpline(x, y) { - const binarySearch = (function search() { - let maxIndex; - let minIndex; - let guess; - return (array, val) => { - minIndex = -1; - maxIndex = array.length; - - while (maxIndex - minIndex > 1) { - guess = (maxIndex + minIndex) >> 1; - - if (array[guess] <= val) { - minIndex = guess; - } else { - maxIndex = guess; - } - } - - return maxIndex; - }; - })(); - - this.x = x; - this.y = y; - this.lastIndex = x.length - 1; // Given an x value (x2), return the expected y2 value: - // (x1,y1) is the known point before given value, - // (x3,y3) is the known point after given value. - - let i1; - let i3; - - this.interpolate = function interpolate(x2) { - if (!x2) return 0; // Get the indexes of x1 and x3 (the array indexes before and after given x2): - - i3 = binarySearch(this.x, x2); - i1 = i3 - 1; // We have our indexes i1 & i3, so we can calculate already: - // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1 - - return ( - ((x2 - this.x[i1]) * (this.y[i3] - this.y[i1])) / - (this.x[i3] - this.x[i1]) + - this.y[i1] - ); - }; - - return this; - } // xxx: for now i will just save one spline function to to - - function getInterpolateFunction(c) { - if (!swiper.controller.spline) { - swiper.controller.spline = swiper.params.loop - ? new LinearSpline(swiper.slidesGrid, c.slidesGrid) - : new LinearSpline(swiper.snapGrid, c.snapGrid); - } - } - - function setTranslate(_t, byController) { - const controlled = swiper.controller.control; - let multiplier; - let controlledTranslate; - const Swiper = swiper.constructor; - - function setControlledTranslate(c) { - // this will create an Interpolate function based on the snapGrids - // x is the Grid of the scrolled scroller and y will be the controlled scroller - // it makes sense to create this only once and recall it for the interpolation - // the function does a lot of value caching for performance - const translate = swiper.rtlTranslate - ? -swiper.translate - : swiper.translate; - - if (swiper.params.controller.by === "slide") { - getInterpolateFunction(c); // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid - // but it did not work out - - controlledTranslate = -swiper.controller.spline.interpolate( - -translate, - ); - } - - if ( - !controlledTranslate || - swiper.params.controller.by === "container" - ) { - multiplier = - (c.maxTranslate() - c.minTranslate()) / - (swiper.maxTranslate() - swiper.minTranslate()); - controlledTranslate = - (translate - swiper.minTranslate()) * multiplier + c.minTranslate(); - } - - if (swiper.params.controller.inverse) { - controlledTranslate = c.maxTranslate() - controlledTranslate; - } - - c.updateProgress(controlledTranslate); - c.setTranslate(controlledTranslate, swiper); - c.updateActiveIndex(); - c.updateSlidesClasses(); - } - - if (Array.isArray(controlled)) { - for (let i = 0; i < controlled.length; i += 1) { - if ( - controlled[i] !== byController && - controlled[i] instanceof Swiper - ) { - setControlledTranslate(controlled[i]); - } - } - } else if (controlled instanceof Swiper && byController !== controlled) { - setControlledTranslate(controlled); - } - } - - function setTransition(duration, byController) { - const Swiper = swiper.constructor; - const controlled = swiper.controller.control; - let i; - - function setControlledTransition(c) { - c.setTransition(duration, swiper); - - if (duration !== 0) { - c.transitionStart(); - - if (c.params.autoHeight) { - nextTick(() => { - c.updateAutoHeight(); - }); - } - - c.$wrapperEl.transitionEnd(() => { - if (!controlled) return; - - if (c.params.loop && swiper.params.controller.by === "slide") { - c.loopFix(); - } - - c.transitionEnd(); - }); - } - } - - if (Array.isArray(controlled)) { - for (i = 0; i < controlled.length; i += 1) { - if ( - controlled[i] !== byController && - controlled[i] instanceof Swiper - ) { - setControlledTransition(controlled[i]); - } - } - } else if (controlled instanceof Swiper && byController !== controlled) { - setControlledTransition(controlled); - } - } - - function removeSpline() { - if (!swiper.controller.control) return; - - if (swiper.controller.spline) { - swiper.controller.spline = undefined; - delete swiper.controller.spline; - } - } - - on("beforeInit", () => { - swiper.controller.control = swiper.params.controller.control; - }); - on("update", () => { - removeSpline(); - }); - on("resize", () => { - removeSpline(); - }); - on("observerUpdate", () => { - removeSpline(); - }); - on("setTranslate", (_s, translate, byController) => { - if (!swiper.controller.control) return; - swiper.controller.setTranslate(translate, byController); - }); - on("setTransition", (_s, duration, byController) => { - if (!swiper.controller.control) return; - swiper.controller.setTransition(duration, byController); - }); - Object.assign(swiper.controller, { - setTranslate, - setTransition, - }); - } - - function A11y(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - a11y: { - enabled: true, - notificationClass: "swiper-notification", - prevSlideMessage: "Previous slide", - nextSlideMessage: "Next slide", - firstSlideMessage: "This is the first slide", - lastSlideMessage: "This is the last slide", - paginationBulletMessage: "Go to slide {{index}}", - slideLabelMessage: "{{index}} / {{slidesLength}}", - containerMessage: null, - containerRoleDescriptionMessage: null, - itemRoleDescriptionMessage: null, - slideRole: "group", - }, - }); - let liveRegion = null; - - function notify(message) { - const notification = liveRegion; - if (notification.length === 0) return; - notification.html(""); - notification.html(message); - } - - function getRandomNumber(size) { - if (size === void 0) { - size = 16; - } - - const randomChar = () => Math.round(16 * Math.random()).toString(16); - - return "x".repeat(size).replace(/x/g, randomChar); - } - - function makeElFocusable($el) { - $el.attr("tabIndex", "0"); - } - - function makeElNotFocusable($el) { - $el.attr("tabIndex", "-1"); - } - - function addElRole($el, role) { - $el.attr("role", role); - } - - function addElRoleDescription($el, description) { - $el.attr("aria-roledescription", description); - } - - function addElControls($el, controls) { - $el.attr("aria-controls", controls); - } - - function addElLabel($el, label) { - $el.attr("aria-label", label); - } - - function addElId($el, id) { - $el.attr("id", id); - } - - function addElLive($el, live) { - $el.attr("aria-live", live); - } - - function disableEl($el) { - $el.attr("aria-disabled", true); - } - - function enableEl($el) { - $el.attr("aria-disabled", false); - } - - function onEnterOrSpaceKey(e) { - if (e.keyCode !== 13 && e.keyCode !== 32) return; - const params = swiper.params.a11y; - const $targetEl = $(e.target); - - if ( - swiper.navigation && - swiper.navigation.$nextEl && - $targetEl.is(swiper.navigation.$nextEl) - ) { - if (!(swiper.isEnd && !swiper.params.loop)) { - swiper.slideNext(); - } - - if (swiper.isEnd) { - notify(params.lastSlideMessage); - } else { - notify(params.nextSlideMessage); - } - } - - if ( - swiper.navigation && - swiper.navigation.$prevEl && - $targetEl.is(swiper.navigation.$prevEl) - ) { - if (!(swiper.isBeginning && !swiper.params.loop)) { - swiper.slidePrev(); - } - - if (swiper.isBeginning) { - notify(params.firstSlideMessage); - } else { - notify(params.prevSlideMessage); - } - } - - if ( - swiper.pagination && - $targetEl.is(classesToSelector(swiper.params.pagination.bulletClass)) - ) { - $targetEl[0].click(); - } - } - - function updateNavigation() { - if (swiper.params.loop || swiper.params.rewind || !swiper.navigation) - return; - const { $nextEl, $prevEl } = swiper.navigation; - - if ($prevEl && $prevEl.length > 0) { - if (swiper.isBeginning) { - disableEl($prevEl); - makeElNotFocusable($prevEl); - } else { - enableEl($prevEl); - makeElFocusable($prevEl); - } - } - - if ($nextEl && $nextEl.length > 0) { - if (swiper.isEnd) { - disableEl($nextEl); - makeElNotFocusable($nextEl); - } else { - enableEl($nextEl); - makeElFocusable($nextEl); - } - } - } - - function hasPagination() { - return ( - swiper.pagination && - swiper.pagination.bullets && - swiper.pagination.bullets.length - ); - } - - function hasClickablePagination() { - return hasPagination() && swiper.params.pagination.clickable; - } - - function updatePagination() { - const params = swiper.params.a11y; - if (!hasPagination()) return; - swiper.pagination.bullets.each((bulletEl) => { - const $bulletEl = $(bulletEl); - - if (swiper.params.pagination.clickable) { - makeElFocusable($bulletEl); - - if (!swiper.params.pagination.renderBullet) { - addElRole($bulletEl, "button"); - addElLabel( - $bulletEl, - params.paginationBulletMessage.replace( - /\{\{index\}\}/, - $bulletEl.index() + 1, - ), - ); - } - } - - if ($bulletEl.is(`.${swiper.params.pagination.bulletActiveClass}`)) { - $bulletEl.attr("aria-current", "true"); - } else { - $bulletEl.removeAttr("aria-current"); - } - }); - } - - const initNavEl = ($el, wrapperId, message) => { - makeElFocusable($el); - - if ($el[0].tagName !== "BUTTON") { - addElRole($el, "button"); - $el.on("keydown", onEnterOrSpaceKey); - } - - addElLabel($el, message); - addElControls($el, wrapperId); - }; - - const handleFocus = (e) => { - const slideEl = e.target.closest(`.${swiper.params.slideClass}`); - if (!slideEl || !swiper.slides.includes(slideEl)) return; - const isActive = swiper.slides.indexOf(slideEl) === swiper.activeIndex; - const isVisible = - swiper.params.watchSlidesProgress && - swiper.visibleSlides && - swiper.visibleSlides.includes(slideEl); - if (isActive || isVisible) return; - swiper.slideTo(swiper.slides.indexOf(slideEl), 0); - }; - - function init() { - const params = swiper.params.a11y; - swiper.$el.append(liveRegion); // Container - - const $containerEl = swiper.$el; - - if (params.containerRoleDescriptionMessage) { - addElRoleDescription( - $containerEl, - params.containerRoleDescriptionMessage, - ); - } - - if (params.containerMessage) { - addElLabel($containerEl, params.containerMessage); - } // Wrapper - - const $wrapperEl = swiper.$wrapperEl; - const wrapperId = - $wrapperEl.attr("id") || `swiper-wrapper-${getRandomNumber(16)}`; - const live = - swiper.params.autoplay && swiper.params.autoplay.enabled - ? "off" - : "polite"; - addElId($wrapperEl, wrapperId); - addElLive($wrapperEl, live); // Slide - - if (params.itemRoleDescriptionMessage) { - addElRoleDescription( - $(swiper.slides), - params.itemRoleDescriptionMessage, - ); - } - - addElRole($(swiper.slides), params.slideRole); - const slidesLength = swiper.params.loop - ? swiper.slides.filter( - (el) => !el.classList.contains(swiper.params.slideDuplicateClass), - ).length - : swiper.slides.length; - swiper.slides.each((slideEl, index) => { - const $slideEl = $(slideEl); - const slideIndex = swiper.params.loop - ? parseInt($slideEl.attr("data-swiper-slide-index"), 10) - : index; - const ariaLabelMessage = params.slideLabelMessage - .replace(/\{\{index\}\}/, slideIndex + 1) - .replace(/\{\{slidesLength\}\}/, slidesLength); - addElLabel($slideEl, ariaLabelMessage); - }); // Navigation - - let $nextEl; - let $prevEl; - - if (swiper.navigation && swiper.navigation.$nextEl) { - $nextEl = swiper.navigation.$nextEl; - } - - if (swiper.navigation && swiper.navigation.$prevEl) { - $prevEl = swiper.navigation.$prevEl; - } - - if ($nextEl && $nextEl.length) { - initNavEl($nextEl, wrapperId, params.nextSlideMessage); - } - - if ($prevEl && $prevEl.length) { - initNavEl($prevEl, wrapperId, params.prevSlideMessage); - } // Pagination - - if (hasClickablePagination()) { - swiper.pagination.$el.on( - "keydown", - classesToSelector(swiper.params.pagination.bulletClass), - onEnterOrSpaceKey, - ); - } // Tab focus - - swiper.$el.on("focus", handleFocus, true); - } - - function destroy() { - if (liveRegion && liveRegion.length > 0) liveRegion.remove(); - let $nextEl; - let $prevEl; - - if (swiper.navigation && swiper.navigation.$nextEl) { - $nextEl = swiper.navigation.$nextEl; - } - - if (swiper.navigation && swiper.navigation.$prevEl) { - $prevEl = swiper.navigation.$prevEl; - } - - if ($nextEl) { - $nextEl.off("keydown", onEnterOrSpaceKey); - } - - if ($prevEl) { - $prevEl.off("keydown", onEnterOrSpaceKey); - } // Pagination - - if (hasClickablePagination()) { - swiper.pagination.$el.off( - "keydown", - classesToSelector(swiper.params.pagination.bulletClass), - onEnterOrSpaceKey, - ); - } // Tab focus - - swiper.$el.off("focus", handleFocus, true); - } - - on("beforeInit", () => { - liveRegion = $( - ``, - ); - }); - on("afterInit", () => { - if (!swiper.params.a11y.enabled) return; - init(); - }); - on("fromEdge toEdge afterInit lock unlock", () => { - if (!swiper.params.a11y.enabled) return; - updateNavigation(); - }); - on("paginationUpdate", () => { - if (!swiper.params.a11y.enabled) return; - updatePagination(); - }); - on("destroy", () => { - if (!swiper.params.a11y.enabled) return; - destroy(); - }); - } - - function History(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - history: { - enabled: false, - root: "", - replaceState: false, - key: "slides", - }, - }); - let initialized = false; - let paths = {}; - - const slugify = (text) => { - return text - .toString() - .replace(/\s+/g, "-") - .replace(/[^\w-]+/g, "") - .replace(/--+/g, "-") - .replace(/^-+/, "") - .replace(/-+$/, ""); - }; - - const getPathValues = (urlOverride) => { - const window = getWindow(); - let location; - - if (urlOverride) { - location = new URL(urlOverride); - } else { - location = window.location; - } - - const pathArray = location.pathname - .slice(1) - .split("/") - .filter((part) => part !== ""); - const total = pathArray.length; - const key = pathArray[total - 2]; - const value = pathArray[total - 1]; - return { - key, - value, - }; - }; - - const setHistory = (key, index) => { - const window = getWindow(); - if (!initialized || !swiper.params.history.enabled) return; - let location; - - if (swiper.params.url) { - location = new URL(swiper.params.url); - } else { - location = window.location; - } - - const slide = swiper.slides.eq(index); - let value = slugify(slide.attr("data-history")); - - if (swiper.params.history.root.length > 0) { - let root = swiper.params.history.root; - if (root[root.length - 1] === "/") - root = root.slice(0, root.length - 1); - value = `${root}/${key}/${value}`; - } else if (!location.pathname.includes(key)) { - value = `${key}/${value}`; - } - - const currentState = window.history.state; - - if (currentState && currentState.value === value) { - return; - } - - if (swiper.params.history.replaceState) { - window.history.replaceState( - { - value, - }, - null, - value, - ); - } else { - window.history.pushState( - { - value, - }, - null, - value, - ); - } - }; - - const scrollToSlide = (speed, value, runCallbacks) => { - if (value) { - for (let i = 0, length = swiper.slides.length; i < length; i += 1) { - const slide = swiper.slides.eq(i); - const slideHistory = slugify(slide.attr("data-history")); - - if ( - slideHistory === value && - !slide.hasClass(swiper.params.slideDuplicateClass) - ) { - const index = slide.index(); - swiper.slideTo(index, speed, runCallbacks); - } - } - } else { - swiper.slideTo(0, speed, runCallbacks); - } - }; - - const setHistoryPopState = () => { - paths = getPathValues(swiper.params.url); - scrollToSlide(swiper.params.speed, swiper.paths.value, false); - }; - - const init = () => { - const window = getWindow(); - if (!swiper.params.history) return; - - if (!window.history || !window.history.pushState) { - swiper.params.history.enabled = false; - swiper.params.hashNavigation.enabled = true; - return; - } - - initialized = true; - paths = getPathValues(swiper.params.url); - if (!paths.key && !paths.value) return; - scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit); - - if (!swiper.params.history.replaceState) { - window.addEventListener("popstate", setHistoryPopState); - } - }; - - const destroy = () => { - const window = getWindow(); - - if (!swiper.params.history.replaceState) { - window.removeEventListener("popstate", setHistoryPopState); - } - }; - - on("init", () => { - if (swiper.params.history.enabled) { - init(); - } - }); - on("destroy", () => { - if (swiper.params.history.enabled) { - destroy(); - } - }); - on("transitionEnd _freeModeNoMomentumRelease", () => { - if (initialized) { - setHistory(swiper.params.history.key, swiper.activeIndex); - } - }); - on("slideChange", () => { - if (initialized && swiper.params.cssMode) { - setHistory(swiper.params.history.key, swiper.activeIndex); - } - }); - } - - function HashNavigation(_ref) { - let { swiper, extendParams, emit, on } = _ref; - let initialized = false; - const document = getDocument(); - const window = getWindow(); - extendParams({ - hashNavigation: { - enabled: false, - replaceState: false, - watchState: false, - }, - }); - - const onHashChange = () => { - emit("hashChange"); - const newHash = document.location.hash.replace("#", ""); - const activeSlideHash = swiper.slides - .eq(swiper.activeIndex) - .attr("data-hash"); - - if (newHash !== activeSlideHash) { - const newIndex = swiper.$wrapperEl - .children(`.${swiper.params.slideClass}[data-hash="${newHash}"]`) - .index(); - if (typeof newIndex === "undefined") return; - swiper.slideTo(newIndex); - } - }; - - const setHash = () => { - if (!initialized || !swiper.params.hashNavigation.enabled) return; - - if ( - swiper.params.hashNavigation.replaceState && - window.history && - window.history.replaceState - ) { - window.history.replaceState( - null, - null, - `#${swiper.slides.eq(swiper.activeIndex).attr("data-hash")}` || "", - ); - emit("hashSet"); - } else { - const slide = swiper.slides.eq(swiper.activeIndex); - const hash = slide.attr("data-hash") || slide.attr("data-history"); - document.location.hash = hash || ""; - emit("hashSet"); - } - }; - - const init = () => { - if ( - !swiper.params.hashNavigation.enabled || - (swiper.params.history && swiper.params.history.enabled) - ) - return; - initialized = true; - const hash = document.location.hash.replace("#", ""); - - if (hash) { - const speed = 0; - - for (let i = 0, length = swiper.slides.length; i < length; i += 1) { - const slide = swiper.slides.eq(i); - const slideHash = - slide.attr("data-hash") || slide.attr("data-history"); - - if ( - slideHash === hash && - !slide.hasClass(swiper.params.slideDuplicateClass) - ) { - const index = slide.index(); - swiper.slideTo( - index, - speed, - swiper.params.runCallbacksOnInit, - true, - ); - } - } - } - - if (swiper.params.hashNavigation.watchState) { - $(window).on("hashchange", onHashChange); - } - }; - - const destroy = () => { - if (swiper.params.hashNavigation.watchState) { - $(window).off("hashchange", onHashChange); - } - }; - - on("init", () => { - if (swiper.params.hashNavigation.enabled) { - init(); - } - }); - on("destroy", () => { - if (swiper.params.hashNavigation.enabled) { - destroy(); - } - }); - on("transitionEnd _freeModeNoMomentumRelease", () => { - if (initialized) { - setHash(); - } - }); - on("slideChange", () => { - if (initialized && swiper.params.cssMode) { - setHash(); - } - }); - } - - /* eslint no-underscore-dangle: "off" */ - function Autoplay(_ref) { - let { swiper, extendParams, on, emit } = _ref; - let timeout; - swiper.autoplay = { - running: false, - paused: false, - }; - extendParams({ - autoplay: { - enabled: false, - delay: 3000, - waitForTransition: true, - disableOnInteraction: true, - stopOnLastSlide: false, - reverseDirection: false, - pauseOnMouseEnter: false, - }, - }); - - function run() { - const $activeSlideEl = swiper.slides.eq(swiper.activeIndex); - let delay = swiper.params.autoplay.delay; - - if ($activeSlideEl.attr("data-swiper-autoplay")) { - delay = - $activeSlideEl.attr("data-swiper-autoplay") || - swiper.params.autoplay.delay; - } - - clearTimeout(timeout); - timeout = nextTick(() => { - let autoplayResult; - - if (swiper.params.autoplay.reverseDirection) { - if (swiper.params.loop) { - swiper.loopFix(); - autoplayResult = swiper.slidePrev(swiper.params.speed, true, true); - emit("autoplay"); - } else if (!swiper.isBeginning) { - autoplayResult = swiper.slidePrev(swiper.params.speed, true, true); - emit("autoplay"); - } else if (!swiper.params.autoplay.stopOnLastSlide) { - autoplayResult = swiper.slideTo( - swiper.slides.length - 1, - swiper.params.speed, - true, - true, - ); - emit("autoplay"); - } else { - stop(); - } - } else if (swiper.params.loop) { - swiper.loopFix(); - autoplayResult = swiper.slideNext(swiper.params.speed, true, true); - emit("autoplay"); - } else if (!swiper.isEnd) { - autoplayResult = swiper.slideNext(swiper.params.speed, true, true); - emit("autoplay"); - } else if (!swiper.params.autoplay.stopOnLastSlide) { - autoplayResult = swiper.slideTo(0, swiper.params.speed, true, true); - emit("autoplay"); - } else { - stop(); - } - - if (swiper.params.cssMode && swiper.autoplay.running) run(); - else if (autoplayResult === false) { - run(); - } - }, delay); - } - - function start() { - if (typeof timeout !== "undefined") return false; - if (swiper.autoplay.running) return false; - swiper.autoplay.running = true; - emit("autoplayStart"); - run(); - return true; - } - - function stop() { - if (!swiper.autoplay.running) return false; - if (typeof timeout === "undefined") return false; - - if (timeout) { - clearTimeout(timeout); - timeout = undefined; - } - - swiper.autoplay.running = false; - emit("autoplayStop"); - return true; - } - - function pause(speed) { - if (!swiper.autoplay.running) return; - if (swiper.autoplay.paused) return; - if (timeout) clearTimeout(timeout); - swiper.autoplay.paused = true; - - if (speed === 0 || !swiper.params.autoplay.waitForTransition) { - swiper.autoplay.paused = false; - run(); - } else { - ["transitionend", "webkitTransitionEnd"].forEach((event) => { - swiper.$wrapperEl[0].addEventListener(event, onTransitionEnd); - }); - } - } - - function onVisibilityChange() { - const document = getDocument(); - - if (document.visibilityState === "hidden" && swiper.autoplay.running) { - pause(); - } - - if (document.visibilityState === "visible" && swiper.autoplay.paused) { - run(); - swiper.autoplay.paused = false; - } - } - - function onTransitionEnd(e) { - if (!swiper || swiper.destroyed || !swiper.$wrapperEl) return; - if (e.target !== swiper.$wrapperEl[0]) return; - ["transitionend", "webkitTransitionEnd"].forEach((event) => { - swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd); - }); - swiper.autoplay.paused = false; - - if (!swiper.autoplay.running) { - stop(); - } else { - run(); - } - } - - function onMouseEnter() { - if (swiper.params.autoplay.disableOnInteraction) { - stop(); - } else { - emit("autoplayPause"); - pause(); - } - - ["transitionend", "webkitTransitionEnd"].forEach((event) => { - swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd); - }); - } - - function onMouseLeave() { - if (swiper.params.autoplay.disableOnInteraction) { - return; - } - - swiper.autoplay.paused = false; - emit("autoplayResume"); - run(); - } - - function attachMouseEvents() { - if (swiper.params.autoplay.pauseOnMouseEnter) { - swiper.$el.on("mouseenter", onMouseEnter); - swiper.$el.on("mouseleave", onMouseLeave); - } - } - - function detachMouseEvents() { - swiper.$el.off("mouseenter", onMouseEnter); - swiper.$el.off("mouseleave", onMouseLeave); - } - - on("init", () => { - if (swiper.params.autoplay.enabled) { - start(); - const document = getDocument(); - document.addEventListener("visibilitychange", onVisibilityChange); - attachMouseEvents(); - } - }); - on("beforeTransitionStart", (_s, speed, internal) => { - if (swiper.autoplay.running) { - if (internal || !swiper.params.autoplay.disableOnInteraction) { - swiper.autoplay.pause(speed); - } else { - stop(); - } - } - }); - on("sliderFirstMove", () => { - if (swiper.autoplay.running) { - if (swiper.params.autoplay.disableOnInteraction) { - stop(); - } else { - pause(); - } - } - }); - on("touchEnd", () => { - if ( - swiper.params.cssMode && - swiper.autoplay.paused && - !swiper.params.autoplay.disableOnInteraction - ) { - run(); - } - }); - on("destroy", () => { - detachMouseEvents(); - - if (swiper.autoplay.running) { - stop(); - } - - const document = getDocument(); - document.removeEventListener("visibilitychange", onVisibilityChange); - }); - Object.assign(swiper.autoplay, { - pause, - run, - start, - stop, - }); - } - - function Thumb(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - thumbs: { - swiper: null, - multipleActiveThumbs: true, - autoScrollOffset: 0, - slideThumbActiveClass: "swiper-slide-thumb-active", - thumbsContainerClass: "swiper-thumbs", - }, - }); - let initialized = false; - let swiperCreated = false; - swiper.thumbs = { - swiper: null, - }; - - function onThumbClick() { - const thumbsSwiper = swiper.thumbs.swiper; - if (!thumbsSwiper) return; - const clickedIndex = thumbsSwiper.clickedIndex; - const clickedSlide = thumbsSwiper.clickedSlide; - if ( - clickedSlide && - $(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass) - ) - return; - if (typeof clickedIndex === "undefined" || clickedIndex === null) return; - let slideToIndex; - - if (thumbsSwiper.params.loop) { - slideToIndex = parseInt( - $(thumbsSwiper.clickedSlide).attr("data-swiper-slide-index"), - 10, - ); - } else { - slideToIndex = clickedIndex; - } - - if (swiper.params.loop) { - let currentIndex = swiper.activeIndex; - - if ( - swiper.slides - .eq(currentIndex) - .hasClass(swiper.params.slideDuplicateClass) - ) { - swiper.loopFix(); // eslint-disable-next-line - - swiper._clientLeft = swiper.$wrapperEl[0].clientLeft; - currentIndex = swiper.activeIndex; - } - - const prevIndex = swiper.slides - .eq(currentIndex) - .prevAll(`[data-swiper-slide-index="${slideToIndex}"]`) - .eq(0) - .index(); - const nextIndex = swiper.slides - .eq(currentIndex) - .nextAll(`[data-swiper-slide-index="${slideToIndex}"]`) - .eq(0) - .index(); - if (typeof prevIndex === "undefined") slideToIndex = nextIndex; - else if (typeof nextIndex === "undefined") slideToIndex = prevIndex; - else if (nextIndex - currentIndex < currentIndex - prevIndex) - slideToIndex = nextIndex; - else slideToIndex = prevIndex; - } - - swiper.slideTo(slideToIndex); - } - - function init() { - const { thumbs: thumbsParams } = swiper.params; - if (initialized) return false; - initialized = true; - const SwiperClass = swiper.constructor; - - if (thumbsParams.swiper instanceof SwiperClass) { - swiper.thumbs.swiper = thumbsParams.swiper; - Object.assign(swiper.thumbs.swiper.originalParams, { - watchSlidesProgress: true, - slideToClickedSlide: false, - }); - Object.assign(swiper.thumbs.swiper.params, { - watchSlidesProgress: true, - slideToClickedSlide: false, - }); - } else if (isObject(thumbsParams.swiper)) { - const thumbsSwiperParams = Object.assign({}, thumbsParams.swiper); - Object.assign(thumbsSwiperParams, { - watchSlidesProgress: true, - slideToClickedSlide: false, - }); - swiper.thumbs.swiper = new SwiperClass(thumbsSwiperParams); - swiperCreated = true; - } - - swiper.thumbs.swiper.$el.addClass( - swiper.params.thumbs.thumbsContainerClass, - ); - swiper.thumbs.swiper.on("tap", onThumbClick); - return true; - } - - function update(initial) { - const thumbsSwiper = swiper.thumbs.swiper; - if (!thumbsSwiper) return; - const slidesPerView = - thumbsSwiper.params.slidesPerView === "auto" - ? thumbsSwiper.slidesPerViewDynamic() - : thumbsSwiper.params.slidesPerView; - const autoScrollOffset = swiper.params.thumbs.autoScrollOffset; - const useOffset = autoScrollOffset && !thumbsSwiper.params.loop; - - if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) { - let currentThumbsIndex = thumbsSwiper.activeIndex; - let newThumbsIndex; - let direction; - - if (thumbsSwiper.params.loop) { - if ( - thumbsSwiper.slides - .eq(currentThumbsIndex) - .hasClass(thumbsSwiper.params.slideDuplicateClass) - ) { - thumbsSwiper.loopFix(); // eslint-disable-next-line - - thumbsSwiper._clientLeft = thumbsSwiper.$wrapperEl[0].clientLeft; - currentThumbsIndex = thumbsSwiper.activeIndex; - } // Find actual thumbs index to slide to - - const prevThumbsIndex = thumbsSwiper.slides - .eq(currentThumbsIndex) - .prevAll(`[data-swiper-slide-index="${swiper.realIndex}"]`) - .eq(0) - .index(); - const nextThumbsIndex = thumbsSwiper.slides - .eq(currentThumbsIndex) - .nextAll(`[data-swiper-slide-index="${swiper.realIndex}"]`) - .eq(0) - .index(); - - if (typeof prevThumbsIndex === "undefined") { - newThumbsIndex = nextThumbsIndex; - } else if (typeof nextThumbsIndex === "undefined") { - newThumbsIndex = prevThumbsIndex; - } else if ( - nextThumbsIndex - currentThumbsIndex === - currentThumbsIndex - prevThumbsIndex - ) { - newThumbsIndex = - thumbsSwiper.params.slidesPerGroup > 1 - ? nextThumbsIndex - : currentThumbsIndex; - } else if ( - nextThumbsIndex - currentThumbsIndex < - currentThumbsIndex - prevThumbsIndex - ) { - newThumbsIndex = nextThumbsIndex; - } else { - newThumbsIndex = prevThumbsIndex; - } - - direction = - swiper.activeIndex > swiper.previousIndex ? "next" : "prev"; - } else { - newThumbsIndex = swiper.realIndex; - direction = newThumbsIndex > swiper.previousIndex ? "next" : "prev"; - } - - if (useOffset) { - newThumbsIndex += - direction === "next" ? autoScrollOffset : -1 * autoScrollOffset; - } - - if ( - thumbsSwiper.visibleSlidesIndexes && - thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0 - ) { - if (thumbsSwiper.params.centeredSlides) { - if (newThumbsIndex > currentThumbsIndex) { - newThumbsIndex = - newThumbsIndex - Math.floor(slidesPerView / 2) + 1; - } else { - newThumbsIndex = - newThumbsIndex + Math.floor(slidesPerView / 2) - 1; - } - } else if ( - newThumbsIndex > currentThumbsIndex && - thumbsSwiper.params.slidesPerGroup === 1 - ); - - thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined); - } - } // Activate thumbs - - let thumbsToActivate = 1; - const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass; - - if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) { - thumbsToActivate = swiper.params.slidesPerView; - } - - if (!swiper.params.thumbs.multipleActiveThumbs) { - thumbsToActivate = 1; - } - - thumbsToActivate = Math.floor(thumbsToActivate); - thumbsSwiper.slides.removeClass(thumbActiveClass); - - if ( - thumbsSwiper.params.loop || - (thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) - ) { - for (let i = 0; i < thumbsToActivate; i += 1) { - thumbsSwiper.$wrapperEl - .children(`[data-swiper-slide-index="${swiper.realIndex + i}"]`) - .addClass(thumbActiveClass); - } - } else { - for (let i = 0; i < thumbsToActivate; i += 1) { - thumbsSwiper.slides - .eq(swiper.realIndex + i) - .addClass(thumbActiveClass); - } - } - } - - on("beforeInit", () => { - const { thumbs } = swiper.params; - if (!thumbs || !thumbs.swiper) return; - init(); - update(true); - }); - on("slideChange update resize observerUpdate", () => { - if (!swiper.thumbs.swiper) return; - update(); - }); - on("setTransition", (_s, duration) => { - const thumbsSwiper = swiper.thumbs.swiper; - if (!thumbsSwiper) return; - thumbsSwiper.setTransition(duration); - }); - on("beforeDestroy", () => { - const thumbsSwiper = swiper.thumbs.swiper; - if (!thumbsSwiper) return; - - if (swiperCreated && thumbsSwiper) { - thumbsSwiper.destroy(); - } - }); - Object.assign(swiper.thumbs, { - init, - update, - }); - } - - function freeMode(_ref) { - let { swiper, extendParams, emit, once } = _ref; - extendParams({ - freeMode: { - enabled: false, - momentum: true, - momentumRatio: 1, - momentumBounce: true, - momentumBounceRatio: 1, - momentumVelocityRatio: 1, - sticky: false, - minimumVelocity: 0.02, - }, - }); - - function onTouchStart() { - const translate = swiper.getTranslate(); - swiper.setTranslate(translate); - swiper.setTransition(0); - swiper.touchEventsData.velocities.length = 0; - swiper.freeMode.onTouchEnd({ - currentPos: swiper.rtl ? swiper.translate : -swiper.translate, - }); - } - - function onTouchMove() { - const { touchEventsData: data, touches } = swiper; // Velocity - - if (data.velocities.length === 0) { - data.velocities.push({ - position: touches[swiper.isHorizontal() ? "startX" : "startY"], - time: data.touchStartTime, - }); - } - - data.velocities.push({ - position: touches[swiper.isHorizontal() ? "currentX" : "currentY"], - time: now(), - }); - } - - function onTouchEnd(_ref2) { - let { currentPos } = _ref2; - const { - params, - $wrapperEl, - rtlTranslate: rtl, - snapGrid, - touchEventsData: data, - } = swiper; // Time diff - - const touchEndTime = now(); - const timeDiff = touchEndTime - data.touchStartTime; - - if (currentPos < -swiper.minTranslate()) { - swiper.slideTo(swiper.activeIndex); - return; - } - - if (currentPos > -swiper.maxTranslate()) { - if (swiper.slides.length < snapGrid.length) { - swiper.slideTo(snapGrid.length - 1); - } else { - swiper.slideTo(swiper.slides.length - 1); - } - - return; - } - - if (params.freeMode.momentum) { - if (data.velocities.length > 1) { - const lastMoveEvent = data.velocities.pop(); - const velocityEvent = data.velocities.pop(); - const distance = lastMoveEvent.position - velocityEvent.position; - const time = lastMoveEvent.time - velocityEvent.time; - swiper.velocity = distance / time; - swiper.velocity /= 2; - - if (Math.abs(swiper.velocity) < params.freeMode.minimumVelocity) { - swiper.velocity = 0; - } // this implies that the user stopped moving a finger then released. - // There would be no events with distance zero, so the last event is stale. - - if (time > 150 || now() - lastMoveEvent.time > 300) { - swiper.velocity = 0; - } - } else { - swiper.velocity = 0; - } - - swiper.velocity *= params.freeMode.momentumVelocityRatio; - data.velocities.length = 0; - let momentumDuration = 1000 * params.freeMode.momentumRatio; - const momentumDistance = swiper.velocity * momentumDuration; - let newPosition = swiper.translate + momentumDistance; - if (rtl) newPosition = -newPosition; - let doBounce = false; - let afterBouncePosition; - const bounceAmount = - Math.abs(swiper.velocity) * 20 * params.freeMode.momentumBounceRatio; - let needsLoopFix; - - if (newPosition < swiper.maxTranslate()) { - if (params.freeMode.momentumBounce) { - if (newPosition + swiper.maxTranslate() < -bounceAmount) { - newPosition = swiper.maxTranslate() - bounceAmount; - } - - afterBouncePosition = swiper.maxTranslate(); - doBounce = true; - data.allowMomentumBounce = true; - } else { - newPosition = swiper.maxTranslate(); - } - - if (params.loop && params.centeredSlides) needsLoopFix = true; - } else if (newPosition > swiper.minTranslate()) { - if (params.freeMode.momentumBounce) { - if (newPosition - swiper.minTranslate() > bounceAmount) { - newPosition = swiper.minTranslate() + bounceAmount; - } - - afterBouncePosition = swiper.minTranslate(); - doBounce = true; - data.allowMomentumBounce = true; - } else { - newPosition = swiper.minTranslate(); - } - - if (params.loop && params.centeredSlides) needsLoopFix = true; - } else if (params.freeMode.sticky) { - let nextSlide; - - for (let j = 0; j < snapGrid.length; j += 1) { - if (snapGrid[j] > -newPosition) { - nextSlide = j; - break; - } - } - - if ( - Math.abs(snapGrid[nextSlide] - newPosition) < - Math.abs(snapGrid[nextSlide - 1] - newPosition) || - swiper.swipeDirection === "next" - ) { - newPosition = snapGrid[nextSlide]; - } else { - newPosition = snapGrid[nextSlide - 1]; - } - - newPosition = -newPosition; - } - - if (needsLoopFix) { - once("transitionEnd", () => { - swiper.loopFix(); - }); - } // Fix duration - - if (swiper.velocity !== 0) { - if (rtl) { - momentumDuration = Math.abs( - (-newPosition - swiper.translate) / swiper.velocity, - ); - } else { - momentumDuration = Math.abs( - (newPosition - swiper.translate) / swiper.velocity, - ); - } - - if (params.freeMode.sticky) { - // If freeMode.sticky is active and the user ends a swipe with a slow-velocity - // event, then durations can be 20+ seconds to slide one (or zero!) slides. - // It's easy to see this when simulating touch with mouse events. To fix this, - // limit single-slide swipes to the default slide duration. This also has the - // nice side effect of matching slide speed if the user stopped moving before - // lifting finger or mouse vs. moving slowly before lifting the finger/mouse. - // For faster swipes, also apply limits (albeit higher ones). - const moveDistance = Math.abs( - (rtl ? -newPosition : newPosition) - swiper.translate, - ); - const currentSlideSize = swiper.slidesSizesGrid[swiper.activeIndex]; - - if (moveDistance < currentSlideSize) { - momentumDuration = params.speed; - } else if (moveDistance < 2 * currentSlideSize) { - momentumDuration = params.speed * 1.5; - } else { - momentumDuration = params.speed * 2.5; - } - } - } else if (params.freeMode.sticky) { - swiper.slideToClosest(); - return; - } - - if (params.freeMode.momentumBounce && doBounce) { - swiper.updateProgress(afterBouncePosition); - swiper.setTransition(momentumDuration); - swiper.setTranslate(newPosition); - swiper.transitionStart(true, swiper.swipeDirection); - swiper.animating = true; - $wrapperEl.transitionEnd(() => { - if (!swiper || swiper.destroyed || !data.allowMomentumBounce) - return; - emit("momentumBounce"); - swiper.setTransition(params.speed); - setTimeout(() => { - swiper.setTranslate(afterBouncePosition); - $wrapperEl.transitionEnd(() => { - if (!swiper || swiper.destroyed) return; - swiper.transitionEnd(); - }); - }, 0); - }); - } else if (swiper.velocity) { - emit("_freeModeNoMomentumRelease"); - swiper.updateProgress(newPosition); - swiper.setTransition(momentumDuration); - swiper.setTranslate(newPosition); - swiper.transitionStart(true, swiper.swipeDirection); - - if (!swiper.animating) { - swiper.animating = true; - $wrapperEl.transitionEnd(() => { - if (!swiper || swiper.destroyed) return; - swiper.transitionEnd(); - }); - } - } else { - swiper.updateProgress(newPosition); - } - - swiper.updateActiveIndex(); - swiper.updateSlidesClasses(); - } else if (params.freeMode.sticky) { - swiper.slideToClosest(); - return; - } else if (params.freeMode) { - emit("_freeModeNoMomentumRelease"); - } - - if (!params.freeMode.momentum || timeDiff >= params.longSwipesMs) { - swiper.updateProgress(); - swiper.updateActiveIndex(); - swiper.updateSlidesClasses(); - } - } - - Object.assign(swiper, { - freeMode: { - onTouchStart, - onTouchMove, - onTouchEnd, - }, - }); - } - - function Grid(_ref) { - let { swiper, extendParams } = _ref; - extendParams({ - grid: { - rows: 1, - fill: "column", - }, - }); - let slidesNumberEvenToRows; - let slidesPerRow; - let numFullColumns; - - const initSlides = (slidesLength) => { - const { slidesPerView } = swiper.params; - const { rows, fill } = swiper.params.grid; - slidesPerRow = slidesNumberEvenToRows / rows; - numFullColumns = Math.floor(slidesLength / rows); - - if (Math.floor(slidesLength / rows) === slidesLength / rows) { - slidesNumberEvenToRows = slidesLength; - } else { - slidesNumberEvenToRows = Math.ceil(slidesLength / rows) * rows; - } - - if (slidesPerView !== "auto" && fill === "row") { - slidesNumberEvenToRows = Math.max( - slidesNumberEvenToRows, - slidesPerView * rows, - ); - } - }; - - const updateSlide = (i, slide, slidesLength, getDirectionLabel) => { - const { slidesPerGroup, spaceBetween } = swiper.params; - const { rows, fill } = swiper.params.grid; // Set slides order - - let newSlideOrderIndex; - let column; - let row; - - if (fill === "row" && slidesPerGroup > 1) { - const groupIndex = Math.floor(i / (slidesPerGroup * rows)); - const slideIndexInGroup = i - rows * slidesPerGroup * groupIndex; - const columnsInGroup = - groupIndex === 0 - ? slidesPerGroup - : Math.min( - Math.ceil( - (slidesLength - groupIndex * rows * slidesPerGroup) / rows, - ), - slidesPerGroup, - ); - row = Math.floor(slideIndexInGroup / columnsInGroup); - column = - slideIndexInGroup - - row * columnsInGroup + - groupIndex * slidesPerGroup; - newSlideOrderIndex = column + (row * slidesNumberEvenToRows) / rows; - slide.css({ - "-webkit-order": newSlideOrderIndex, - order: newSlideOrderIndex, - }); - } else if (fill === "column") { - column = Math.floor(i / rows); - row = i - column * rows; - - if ( - column > numFullColumns || - (column === numFullColumns && row === rows - 1) - ) { - row += 1; - - if (row >= rows) { - row = 0; - column += 1; - } - } - } else { - row = Math.floor(i / slidesPerRow); - column = i - row * slidesPerRow; - } - - slide.css( - getDirectionLabel("margin-top"), - row !== 0 ? spaceBetween && `${spaceBetween}px` : "", - ); - }; - - const updateWrapperSize = (slideSize, snapGrid, getDirectionLabel) => { - const { spaceBetween, centeredSlides, roundLengths } = swiper.params; - const { rows } = swiper.params.grid; - swiper.virtualSize = (slideSize + spaceBetween) * slidesNumberEvenToRows; - swiper.virtualSize = Math.ceil(swiper.virtualSize / rows) - spaceBetween; - swiper.$wrapperEl.css({ - [getDirectionLabel("width")]: `${swiper.virtualSize + spaceBetween}px`, - }); - - if (centeredSlides) { - snapGrid.splice(0, snapGrid.length); - const newSlidesGrid = []; - - for (let i = 0; i < snapGrid.length; i += 1) { - let slidesGridItem = snapGrid[i]; - if (roundLengths) slidesGridItem = Math.floor(slidesGridItem); - if (snapGrid[i] < swiper.virtualSize + snapGrid[0]) - newSlidesGrid.push(slidesGridItem); - } - - snapGrid.push(...newSlidesGrid); - } - }; - - swiper.grid = { - initSlides, - updateSlide, - updateWrapperSize, - }; - } - - function appendSlide(slides) { - const swiper = this; - const { $wrapperEl, params } = swiper; - - if (params.loop) { - swiper.loopDestroy(); - } - - if (typeof slides === "object" && "length" in slides) { - for (let i = 0; i < slides.length; i += 1) { - if (slides[i]) $wrapperEl.append(slides[i]); - } - } else { - $wrapperEl.append(slides); - } - - if (params.loop) { - swiper.loopCreate(); - } - - if (!params.observer) { - swiper.update(); - } - } - - function prependSlide(slides) { - const swiper = this; - const { params, $wrapperEl, activeIndex } = swiper; - - if (params.loop) { - swiper.loopDestroy(); - } - - let newActiveIndex = activeIndex + 1; - - if (typeof slides === "object" && "length" in slides) { - for (let i = 0; i < slides.length; i += 1) { - if (slides[i]) $wrapperEl.prepend(slides[i]); - } - - newActiveIndex = activeIndex + slides.length; - } else { - $wrapperEl.prepend(slides); - } - - if (params.loop) { - swiper.loopCreate(); - } - - if (!params.observer) { - swiper.update(); - } - - swiper.slideTo(newActiveIndex, 0, false); - } - - function addSlide(index, slides) { - const swiper = this; - const { $wrapperEl, params, activeIndex } = swiper; - let activeIndexBuffer = activeIndex; - - if (params.loop) { - activeIndexBuffer -= swiper.loopedSlides; - swiper.loopDestroy(); - swiper.slides = $wrapperEl.children(`.${params.slideClass}`); - } - - const baseLength = swiper.slides.length; - - if (index <= 0) { - swiper.prependSlide(slides); - return; - } - - if (index >= baseLength) { - swiper.appendSlide(slides); - return; - } - - let newActiveIndex = - activeIndexBuffer > index ? activeIndexBuffer + 1 : activeIndexBuffer; - const slidesBuffer = []; - - for (let i = baseLength - 1; i >= index; i -= 1) { - const currentSlide = swiper.slides.eq(i); - currentSlide.remove(); - slidesBuffer.unshift(currentSlide); - } - - if (typeof slides === "object" && "length" in slides) { - for (let i = 0; i < slides.length; i += 1) { - if (slides[i]) $wrapperEl.append(slides[i]); - } - - newActiveIndex = - activeIndexBuffer > index - ? activeIndexBuffer + slides.length - : activeIndexBuffer; - } else { - $wrapperEl.append(slides); - } - - for (let i = 0; i < slidesBuffer.length; i += 1) { - $wrapperEl.append(slidesBuffer[i]); - } - - if (params.loop) { - swiper.loopCreate(); - } - - if (!params.observer) { - swiper.update(); - } - - if (params.loop) { - swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false); - } else { - swiper.slideTo(newActiveIndex, 0, false); - } - } - - function removeSlide(slidesIndexes) { - const swiper = this; - const { params, $wrapperEl, activeIndex } = swiper; - let activeIndexBuffer = activeIndex; - - if (params.loop) { - activeIndexBuffer -= swiper.loopedSlides; - swiper.loopDestroy(); - swiper.slides = $wrapperEl.children(`.${params.slideClass}`); - } - - let newActiveIndex = activeIndexBuffer; - let indexToRemove; - - if (typeof slidesIndexes === "object" && "length" in slidesIndexes) { - for (let i = 0; i < slidesIndexes.length; i += 1) { - indexToRemove = slidesIndexes[i]; - if (swiper.slides[indexToRemove]) - swiper.slides.eq(indexToRemove).remove(); - if (indexToRemove < newActiveIndex) newActiveIndex -= 1; - } - - newActiveIndex = Math.max(newActiveIndex, 0); - } else { - indexToRemove = slidesIndexes; - if (swiper.slides[indexToRemove]) - swiper.slides.eq(indexToRemove).remove(); - if (indexToRemove < newActiveIndex) newActiveIndex -= 1; - newActiveIndex = Math.max(newActiveIndex, 0); - } - - if (params.loop) { - swiper.loopCreate(); - } - - if (!params.observer) { - swiper.update(); - } - - if (params.loop) { - swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false); - } else { - swiper.slideTo(newActiveIndex, 0, false); - } - } - - function removeAllSlides() { - const swiper = this; - const slidesIndexes = []; - - for (let i = 0; i < swiper.slides.length; i += 1) { - slidesIndexes.push(i); - } - - swiper.removeSlide(slidesIndexes); - } - - function Manipulation(_ref) { - let { swiper } = _ref; - Object.assign(swiper, { - appendSlide: appendSlide.bind(swiper), - prependSlide: prependSlide.bind(swiper), - addSlide: addSlide.bind(swiper), - removeSlide: removeSlide.bind(swiper), - removeAllSlides: removeAllSlides.bind(swiper), - }); - } - - function effectInit(params) { - const { - effect, - swiper, - on, - setTranslate, - setTransition, - overwriteParams, - perspective, - } = params; - on("beforeInit", () => { - if (swiper.params.effect !== effect) return; - swiper.classNames.push( - `${swiper.params.containerModifierClass}${effect}`, - ); - - if (perspective && perspective()) { - swiper.classNames.push(`${swiper.params.containerModifierClass}3d`); - } - - const overwriteParamsResult = overwriteParams ? overwriteParams() : {}; - Object.assign(swiper.params, overwriteParamsResult); - Object.assign(swiper.originalParams, overwriteParamsResult); - }); - on("setTranslate", () => { - if (swiper.params.effect !== effect) return; - setTranslate(); - }); - on("setTransition", (_s, duration) => { - if (swiper.params.effect !== effect) return; - setTransition(duration); - }); - let requireUpdateOnVirtual; - on("virtualUpdate", () => { - if (!swiper.slides.length) { - requireUpdateOnVirtual = true; - } - - requestAnimationFrame(() => { - if (requireUpdateOnVirtual && swiper.slides.length) { - setTranslate(); - requireUpdateOnVirtual = false; - } - }); - }); - } - - function effectTarget(effectParams, $slideEl) { - if (effectParams.transformEl) { - return $slideEl.find(effectParams.transformEl).css({ - "backface-visibility": "hidden", - "-webkit-backface-visibility": "hidden", - }); - } - - return $slideEl; - } - - function effectVirtualTransitionEnd(_ref) { - let { swiper, duration, transformEl, allSlides } = _ref; - const { slides, activeIndex, $wrapperEl } = swiper; - - if (swiper.params.virtualTranslate && duration !== 0) { - let eventTriggered = false; - let $transitionEndTarget; - - if (allSlides) { - $transitionEndTarget = transformEl ? slides.find(transformEl) : slides; - } else { - $transitionEndTarget = transformEl - ? slides.eq(activeIndex).find(transformEl) - : slides.eq(activeIndex); - } - - $transitionEndTarget.transitionEnd(() => { - if (eventTriggered) return; - if (!swiper || swiper.destroyed) return; - eventTriggered = true; - swiper.animating = false; - const triggerEvents = ["webkitTransitionEnd", "transitionend"]; - - for (let i = 0; i < triggerEvents.length; i += 1) { - $wrapperEl.trigger(triggerEvents[i]); - } - }); - } - } - - function EffectFade(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - fadeEffect: { - crossFade: false, - transformEl: null, - }, - }); - - const setTranslate = () => { - const { slides } = swiper; - const params = swiper.params.fadeEffect; - - for (let i = 0; i < slides.length; i += 1) { - const $slideEl = swiper.slides.eq(i); - const offset = $slideEl[0].swiperSlideOffset; - let tx = -offset; - if (!swiper.params.virtualTranslate) tx -= swiper.translate; - let ty = 0; - - if (!swiper.isHorizontal()) { - ty = tx; - tx = 0; - } - - const slideOpacity = swiper.params.fadeEffect.crossFade - ? Math.max(1 - Math.abs($slideEl[0].progress), 0) - : 1 + Math.min(Math.max($slideEl[0].progress, -1), 0); - const $targetEl = effectTarget(params, $slideEl); - $targetEl - .css({ - opacity: slideOpacity, - }) - .transform(`translate3d(${tx}px, ${ty}px, 0px)`); - } - }; - - const setTransition = (duration) => { - const { transformEl } = swiper.params.fadeEffect; - const $transitionElements = transformEl - ? swiper.slides.find(transformEl) - : swiper.slides; - $transitionElements.transition(duration); - effectVirtualTransitionEnd({ - swiper, - duration, - transformEl, - allSlides: true, - }); - }; - - effectInit({ - effect: "fade", - swiper, - on, - setTranslate, - setTransition, - overwriteParams: () => ({ - slidesPerView: 1, - slidesPerGroup: 1, - watchSlidesProgress: true, - spaceBetween: 0, - virtualTranslate: !swiper.params.cssMode, - }), - }); - } - - function EffectCube(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - cubeEffect: { - slideShadows: true, - shadow: true, - shadowOffset: 20, - shadowScale: 0.94, - }, - }); - - const setTranslate = () => { - const { - $el, - $wrapperEl, - slides, - width: swiperWidth, - height: swiperHeight, - rtlTranslate: rtl, - size: swiperSize, - browser, - } = swiper; - const params = swiper.params.cubeEffect; - const isHorizontal = swiper.isHorizontal(); - const isVirtual = swiper.virtual && swiper.params.virtual.enabled; - let wrapperRotate = 0; - let $cubeShadowEl; - - if (params.shadow) { - if (isHorizontal) { - $cubeShadowEl = $wrapperEl.find(".swiper-cube-shadow"); - - if ($cubeShadowEl.length === 0) { - $cubeShadowEl = $('
'); - $wrapperEl.append($cubeShadowEl); - } - - $cubeShadowEl.css({ - height: `${swiperWidth}px`, - }); - } else { - $cubeShadowEl = $el.find(".swiper-cube-shadow"); - - if ($cubeShadowEl.length === 0) { - $cubeShadowEl = $('
'); - $el.append($cubeShadowEl); - } - } - } - - for (let i = 0; i < slides.length; i += 1) { - const $slideEl = slides.eq(i); - let slideIndex = i; - - if (isVirtual) { - slideIndex = parseInt($slideEl.attr("data-swiper-slide-index"), 10); - } - - let slideAngle = slideIndex * 90; - let round = Math.floor(slideAngle / 360); - - if (rtl) { - slideAngle = -slideAngle; - round = Math.floor(-slideAngle / 360); - } - - const progress = Math.max(Math.min($slideEl[0].progress, 1), -1); - let tx = 0; - let ty = 0; - let tz = 0; - - if (slideIndex % 4 === 0) { - tx = -round * 4 * swiperSize; - tz = 0; - } else if ((slideIndex - 1) % 4 === 0) { - tx = 0; - tz = -round * 4 * swiperSize; - } else if ((slideIndex - 2) % 4 === 0) { - tx = swiperSize + round * 4 * swiperSize; - tz = swiperSize; - } else if ((slideIndex - 3) % 4 === 0) { - tx = -swiperSize; - tz = 3 * swiperSize + swiperSize * 4 * round; - } - - if (rtl) { - tx = -tx; - } - - if (!isHorizontal) { - ty = tx; - tx = 0; - } - - const transform = `rotateX(${ - isHorizontal ? 0 : -slideAngle - }deg) rotateY(${ - isHorizontal ? slideAngle : 0 - }deg) translate3d(${tx}px, ${ty}px, ${tz}px)`; - - if (progress <= 1 && progress > -1) { - wrapperRotate = slideIndex * 90 + progress * 90; - if (rtl) wrapperRotate = -slideIndex * 90 - progress * 90; - } - - $slideEl.transform(transform); - - if (params.slideShadows) { - // Set shadows - let shadowBefore = isHorizontal - ? $slideEl.find(".swiper-slide-shadow-left") - : $slideEl.find(".swiper-slide-shadow-top"); - let shadowAfter = isHorizontal - ? $slideEl.find(".swiper-slide-shadow-right") - : $slideEl.find(".swiper-slide-shadow-bottom"); - - if (shadowBefore.length === 0) { - shadowBefore = $( - `
`, - ); - $slideEl.append(shadowBefore); - } - - if (shadowAfter.length === 0) { - shadowAfter = $( - `
`, - ); - $slideEl.append(shadowAfter); - } - - if (shadowBefore.length) - shadowBefore[0].style.opacity = Math.max(-progress, 0); - if (shadowAfter.length) - shadowAfter[0].style.opacity = Math.max(progress, 0); - } - } - - $wrapperEl.css({ - "-webkit-transform-origin": `50% 50% -${swiperSize / 2}px`, - "transform-origin": `50% 50% -${swiperSize / 2}px`, - }); - - if (params.shadow) { - if (isHorizontal) { - $cubeShadowEl.transform( - `translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${ - -swiperWidth / 2 - }px) rotateX(90deg) rotateZ(0deg) scale(${params.shadowScale})`, - ); - } else { - const shadowAngle = - Math.abs(wrapperRotate) - - Math.floor(Math.abs(wrapperRotate) / 90) * 90; - const multiplier = - 1.5 - - (Math.sin((shadowAngle * 2 * Math.PI) / 360) / 2 + - Math.cos((shadowAngle * 2 * Math.PI) / 360) / 2); - const scale1 = params.shadowScale; - const scale2 = params.shadowScale / multiplier; - const offset = params.shadowOffset; - $cubeShadowEl.transform( - `scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${ - swiperHeight / 2 + offset - }px, ${-swiperHeight / 2 / scale2}px) rotateX(-90deg)`, - ); - } - } - - const zFactor = - browser.isSafari || browser.isWebView ? -swiperSize / 2 : 0; - $wrapperEl.transform( - `translate3d(0px,0,${zFactor}px) rotateX(${ - swiper.isHorizontal() ? 0 : wrapperRotate - }deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate : 0}deg)`, - ); - }; - - const setTransition = (duration) => { - const { $el, slides } = swiper; - slides - .transition(duration) - .find( - ".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left", - ) - .transition(duration); - - if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) { - $el.find(".swiper-cube-shadow").transition(duration); - } - }; - - effectInit({ - effect: "cube", - swiper, - on, - setTranslate, - setTransition, - perspective: () => true, - overwriteParams: () => ({ - slidesPerView: 1, - slidesPerGroup: 1, - watchSlidesProgress: true, - resistanceRatio: 0, - spaceBetween: 0, - centeredSlides: false, - virtualTranslate: true, - }), - }); - } - - function createShadow(params, $slideEl, side) { - const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ""}`; - const $shadowContainer = params.transformEl - ? $slideEl.find(params.transformEl) - : $slideEl; - let $shadowEl = $shadowContainer.children(`.${shadowClass}`); - - if (!$shadowEl.length) { - $shadowEl = $( - `
`, - ); - $shadowContainer.append($shadowEl); - } - - return $shadowEl; - } - - function EffectFlip(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - flipEffect: { - slideShadows: true, - limitRotation: true, - transformEl: null, - }, - }); - - const setTranslate = () => { - const { slides, rtlTranslate: rtl } = swiper; - const params = swiper.params.flipEffect; - - for (let i = 0; i < slides.length; i += 1) { - const $slideEl = slides.eq(i); - let progress = $slideEl[0].progress; - - if (swiper.params.flipEffect.limitRotation) { - progress = Math.max(Math.min($slideEl[0].progress, 1), -1); - } - - const offset = $slideEl[0].swiperSlideOffset; - const rotate = -180 * progress; - let rotateY = rotate; - let rotateX = 0; - let tx = swiper.params.cssMode ? -offset - swiper.translate : -offset; - let ty = 0; - - if (!swiper.isHorizontal()) { - ty = tx; - tx = 0; - rotateX = -rotateY; - rotateY = 0; - } else if (rtl) { - rotateY = -rotateY; - } - - $slideEl[0].style.zIndex = - -Math.abs(Math.round(progress)) + slides.length; - - if (params.slideShadows) { - // Set shadows - let shadowBefore = swiper.isHorizontal() - ? $slideEl.find(".swiper-slide-shadow-left") - : $slideEl.find(".swiper-slide-shadow-top"); - let shadowAfter = swiper.isHorizontal() - ? $slideEl.find(".swiper-slide-shadow-right") - : $slideEl.find(".swiper-slide-shadow-bottom"); - - if (shadowBefore.length === 0) { - shadowBefore = createShadow( - params, - $slideEl, - swiper.isHorizontal() ? "left" : "top", - ); - } - - if (shadowAfter.length === 0) { - shadowAfter = createShadow( - params, - $slideEl, - swiper.isHorizontal() ? "right" : "bottom", - ); - } - - if (shadowBefore.length) - shadowBefore[0].style.opacity = Math.max(-progress, 0); - if (shadowAfter.length) - shadowAfter[0].style.opacity = Math.max(progress, 0); - } - - const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`; - const $targetEl = effectTarget(params, $slideEl); - $targetEl.transform(transform); - } - }; - - const setTransition = (duration) => { - const { transformEl } = swiper.params.flipEffect; - const $transitionElements = transformEl - ? swiper.slides.find(transformEl) - : swiper.slides; - $transitionElements - .transition(duration) - .find( - ".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left", - ) - .transition(duration); - effectVirtualTransitionEnd({ - swiper, - duration, - transformEl, - }); - }; - - effectInit({ - effect: "flip", - swiper, - on, - setTranslate, - setTransition, - perspective: () => true, - overwriteParams: () => ({ - slidesPerView: 1, - slidesPerGroup: 1, - watchSlidesProgress: true, - spaceBetween: 0, - virtualTranslate: !swiper.params.cssMode, - }), - }); - } - - function EffectCoverflow(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - coverflowEffect: { - rotate: 50, - stretch: 0, - depth: 100, - scale: 1, - modifier: 1, - slideShadows: true, - transformEl: null, - }, - }); - - const setTranslate = () => { - const { - width: swiperWidth, - height: swiperHeight, - slides, - slidesSizesGrid, - } = swiper; - const params = swiper.params.coverflowEffect; - const isHorizontal = swiper.isHorizontal(); - const transform = swiper.translate; - const center = isHorizontal - ? -transform + swiperWidth / 2 - : -transform + swiperHeight / 2; - const rotate = isHorizontal ? params.rotate : -params.rotate; - const translate = params.depth; // Each slide offset from center - - for (let i = 0, length = slides.length; i < length; i += 1) { - const $slideEl = slides.eq(i); - const slideSize = slidesSizesGrid[i]; - const slideOffset = $slideEl[0].swiperSlideOffset; - const centerOffset = (center - slideOffset - slideSize / 2) / slideSize; - const offsetMultiplier = - typeof params.modifier === "function" - ? params.modifier(centerOffset) - : centerOffset * params.modifier; - let rotateY = isHorizontal ? rotate * offsetMultiplier : 0; - let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0 - - let translateZ = -translate * Math.abs(offsetMultiplier); - let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders - - if (typeof stretch === "string" && stretch.indexOf("%") !== -1) { - stretch = (parseFloat(params.stretch) / 100) * slideSize; - } - - let translateY = isHorizontal ? 0 : stretch * offsetMultiplier; - let translateX = isHorizontal ? stretch * offsetMultiplier : 0; - let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values - - if (Math.abs(translateX) < 0.001) translateX = 0; - if (Math.abs(translateY) < 0.001) translateY = 0; - if (Math.abs(translateZ) < 0.001) translateZ = 0; - if (Math.abs(rotateY) < 0.001) rotateY = 0; - if (Math.abs(rotateX) < 0.001) rotateX = 0; - if (Math.abs(scale) < 0.001) scale = 0; - const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`; - const $targetEl = effectTarget(params, $slideEl); - $targetEl.transform(slideTransform); - $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1; - - if (params.slideShadows) { - // Set shadows - let $shadowBeforeEl = isHorizontal - ? $slideEl.find(".swiper-slide-shadow-left") - : $slideEl.find(".swiper-slide-shadow-top"); - let $shadowAfterEl = isHorizontal - ? $slideEl.find(".swiper-slide-shadow-right") - : $slideEl.find(".swiper-slide-shadow-bottom"); - - if ($shadowBeforeEl.length === 0) { - $shadowBeforeEl = createShadow( - params, - $slideEl, - isHorizontal ? "left" : "top", - ); - } - - if ($shadowAfterEl.length === 0) { - $shadowAfterEl = createShadow( - params, - $slideEl, - isHorizontal ? "right" : "bottom", - ); - } - - if ($shadowBeforeEl.length) - $shadowBeforeEl[0].style.opacity = - offsetMultiplier > 0 ? offsetMultiplier : 0; - if ($shadowAfterEl.length) - $shadowAfterEl[0].style.opacity = - -offsetMultiplier > 0 ? -offsetMultiplier : 0; - } - } - }; - - const setTransition = (duration) => { - const { transformEl } = swiper.params.coverflowEffect; - const $transitionElements = transformEl - ? swiper.slides.find(transformEl) - : swiper.slides; - $transitionElements - .transition(duration) - .find( - ".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left", - ) - .transition(duration); - }; - - effectInit({ - effect: "coverflow", - swiper, - on, - setTranslate, - setTransition, - perspective: () => true, - overwriteParams: () => ({ - watchSlidesProgress: true, - }), - }); - } - - function EffectCreative(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - creativeEffect: { - transformEl: null, - limitProgress: 1, - shadowPerProgress: false, - progressMultiplier: 1, - perspective: true, - prev: { - translate: [0, 0, 0], - rotate: [0, 0, 0], - opacity: 1, - scale: 1, - }, - next: { - translate: [0, 0, 0], - rotate: [0, 0, 0], - opacity: 1, - scale: 1, - }, - }, - }); - - const getTranslateValue = (value) => { - if (typeof value === "string") return value; - return `${value}px`; - }; - - const setTranslate = () => { - const { slides, $wrapperEl, slidesSizesGrid } = swiper; - const params = swiper.params.creativeEffect; - const { progressMultiplier: multiplier } = params; - const isCenteredSlides = swiper.params.centeredSlides; - - if (isCenteredSlides) { - const margin = - slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0; - $wrapperEl.transform(`translateX(calc(50% - ${margin}px))`); - } - - for (let i = 0; i < slides.length; i += 1) { - const $slideEl = slides.eq(i); - const slideProgress = $slideEl[0].progress; - const progress = Math.min( - Math.max($slideEl[0].progress, -params.limitProgress), - params.limitProgress, - ); - let originalProgress = progress; - - if (!isCenteredSlides) { - originalProgress = Math.min( - Math.max($slideEl[0].originalProgress, -params.limitProgress), - params.limitProgress, - ); - } - - const offset = $slideEl[0].swiperSlideOffset; - const t = [ - swiper.params.cssMode ? -offset - swiper.translate : -offset, - 0, - 0, - ]; - const r = [0, 0, 0]; - let custom = false; - - if (!swiper.isHorizontal()) { - t[1] = t[0]; - t[0] = 0; - } - - let data = { - translate: [0, 0, 0], - rotate: [0, 0, 0], - scale: 1, - opacity: 1, - }; - - if (progress < 0) { - data = params.next; - custom = true; - } else if (progress > 0) { - data = params.prev; - custom = true; - } // set translate - - t.forEach((value, index) => { - t[index] = `calc(${value}px + (${getTranslateValue( - data.translate[index], - )} * ${Math.abs(progress * multiplier)}))`; - }); // set rotates - - r.forEach((value, index) => { - r[index] = data.rotate[index] * Math.abs(progress * multiplier); - }); - $slideEl[0].style.zIndex = - -Math.abs(Math.round(slideProgress)) + slides.length; - const translateString = t.join(", "); - const rotateString = `rotateX(${r[0]}deg) rotateY(${r[1]}deg) rotateZ(${r[2]}deg)`; - const scaleString = - originalProgress < 0 - ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})` - : `scale(${1 - (1 - data.scale) * originalProgress * multiplier})`; - const opacityString = - originalProgress < 0 - ? 1 + (1 - data.opacity) * originalProgress * multiplier - : 1 - (1 - data.opacity) * originalProgress * multiplier; - const transform = `translate3d(${translateString}) ${rotateString} ${scaleString}`; // Set shadows - - if ((custom && data.shadow) || !custom) { - let $shadowEl = $slideEl.children(".swiper-slide-shadow"); - - if ($shadowEl.length === 0 && data.shadow) { - $shadowEl = createShadow(params, $slideEl); - } - - if ($shadowEl.length) { - const shadowOpacity = params.shadowPerProgress - ? progress * (1 / params.limitProgress) - : progress; - $shadowEl[0].style.opacity = Math.min( - Math.max(Math.abs(shadowOpacity), 0), - 1, - ); - } - } - - const $targetEl = effectTarget(params, $slideEl); - $targetEl.transform(transform).css({ - opacity: opacityString, - }); - - if (data.origin) { - $targetEl.css("transform-origin", data.origin); - } - } - }; - - const setTransition = (duration) => { - const { transformEl } = swiper.params.creativeEffect; - const $transitionElements = transformEl - ? swiper.slides.find(transformEl) - : swiper.slides; - $transitionElements - .transition(duration) - .find(".swiper-slide-shadow") - .transition(duration); - effectVirtualTransitionEnd({ - swiper, - duration, - transformEl, - allSlides: true, - }); - }; - - effectInit({ - effect: "creative", - swiper, - on, - setTranslate, - setTransition, - perspective: () => swiper.params.creativeEffect.perspective, - overwriteParams: () => ({ - watchSlidesProgress: true, - virtualTranslate: !swiper.params.cssMode, - }), - }); - } - - function EffectCards(_ref) { - let { swiper, extendParams, on } = _ref; - extendParams({ - cardsEffect: { - slideShadows: true, - transformEl: null, - }, - }); - - const setTranslate = () => { - const { slides, activeIndex } = swiper; - const params = swiper.params.cardsEffect; - const { startTranslate, isTouched } = swiper.touchEventsData; - const currentTranslate = swiper.translate; - - for (let i = 0; i < slides.length; i += 1) { - const $slideEl = slides.eq(i); - const slideProgress = $slideEl[0].progress; - const progress = Math.min(Math.max(slideProgress, -4), 4); - let offset = $slideEl[0].swiperSlideOffset; - - if (swiper.params.centeredSlides && !swiper.params.cssMode) { - swiper.$wrapperEl.transform(`translateX(${swiper.minTranslate()}px)`); - } - - if (swiper.params.centeredSlides && swiper.params.cssMode) { - offset -= slides[0].swiperSlideOffset; - } - - let tX = swiper.params.cssMode ? -offset - swiper.translate : -offset; - let tY = 0; - const tZ = -100 * Math.abs(progress); - let scale = 1; - let rotate = -2 * progress; - let tXAdd = 8 - Math.abs(progress) * 0.75; - const slideIndex = - swiper.virtual && swiper.params.virtual.enabled - ? swiper.virtual.from + i - : i; - const isSwipeToNext = - (slideIndex === activeIndex || slideIndex === activeIndex - 1) && - progress > 0 && - progress < 1 && - (isTouched || swiper.params.cssMode) && - currentTranslate < startTranslate; - const isSwipeToPrev = - (slideIndex === activeIndex || slideIndex === activeIndex + 1) && - progress < 0 && - progress > -1 && - (isTouched || swiper.params.cssMode) && - currentTranslate > startTranslate; - - if (isSwipeToNext || isSwipeToPrev) { - const subProgress = - (1 - Math.abs((Math.abs(progress) - 0.5) / 0.5)) ** 0.5; - rotate += -28 * progress * subProgress; - scale += -0.5 * subProgress; - tXAdd += 96 * subProgress; - tY = `${-25 * subProgress * Math.abs(progress)}%`; - } - - if (progress < 0) { - // next - tX = `calc(${tX}px + (${tXAdd * Math.abs(progress)}%))`; - } else if (progress > 0) { - // prev - tX = `calc(${tX}px + (-${tXAdd * Math.abs(progress)}%))`; - } else { - tX = `${tX}px`; - } - - if (!swiper.isHorizontal()) { - const prevY = tY; - tY = tX; - tX = prevY; - } - - const scaleString = - progress < 0 - ? `${1 + (1 - scale) * progress}` - : `${1 - (1 - scale) * progress}`; - const transform = ` - translate3d(${tX}, ${tY}, ${tZ}px) - rotateZ(${rotate}deg) - scale(${scaleString}) - `; - - if (params.slideShadows) { - // Set shadows - let $shadowEl = $slideEl.find(".swiper-slide-shadow"); - - if ($shadowEl.length === 0) { - $shadowEl = createShadow(params, $slideEl); - } - - if ($shadowEl.length) - $shadowEl[0].style.opacity = Math.min( - Math.max((Math.abs(progress) - 0.5) / 0.5, 0), - 1, - ); - } - - $slideEl[0].style.zIndex = - -Math.abs(Math.round(slideProgress)) + slides.length; - const $targetEl = effectTarget(params, $slideEl); - $targetEl.transform(transform); - } - }; - - const setTransition = (duration) => { - const { transformEl } = swiper.params.cardsEffect; - const $transitionElements = transformEl - ? swiper.slides.find(transformEl) - : swiper.slides; - $transitionElements - .transition(duration) - .find(".swiper-slide-shadow") - .transition(duration); - effectVirtualTransitionEnd({ - swiper, - duration, - transformEl, - }); - }; - - effectInit({ - effect: "cards", - swiper, - on, - setTranslate, - setTransition, - perspective: () => true, - overwriteParams: () => ({ - watchSlidesProgress: true, - virtualTranslate: !swiper.params.cssMode, - }), - }); - } - - // Swiper Class - const modules = [ - Virtual, - Keyboard, - Mousewheel, - Navigation, - Pagination, - Scrollbar, - Parallax, - Zoom, - Lazy, - Controller, - A11y, - History, - HashNavigation, - Autoplay, - Thumb, - freeMode, - Grid, - Manipulation, - EffectFade, - EffectCube, - EffectFlip, - EffectCoverflow, - EffectCreative, - EffectCards, - ]; - Swiper.use(modules); - - return Swiper; -}); diff --git a/themes/hugoplate/assets/scss/base.scss b/themes/hugoplate/assets/scss/base.scss deleted file mode 100755 index d519df3..0000000 --- a/themes/hugoplate/assets/scss/base.scss +++ /dev/null @@ -1,59 +0,0 @@ -html { - @apply text-base; -} - -body { - @apply bg-body dark:bg-darkmode-body font-primary font-normal leading-relaxed text-text dark:text-darkmode-text; -} - -h1, -h2, -h3, -h4, -h5, -h6 { - @apply font-secondary font-bold leading-tight text-dark dark:text-darkmode-dark; -} - -h1, -.h1 { - @apply text-h1-sm md:text-h1; -} - -h2, -.h2 { - @apply text-h2-sm md:text-h2; -} - -h3, -.h3 { - @apply text-h3-sm md:text-h3; -} - -h4, -.h4 { - @apply text-h4 font-medium; -} - -h5, -.h5 { - @apply text-h5 font-medium; -} - -h6, -.h6 { - @apply text-h6 font-medium; -} - -b, -strong { - @apply font-semibold; -} - -code { - @apply after:border-none; -} - -blockquote > p { - @apply my-0 #{!important}; -} diff --git a/themes/hugoplate/assets/scss/buttons.scss b/themes/hugoplate/assets/scss/buttons.scss deleted file mode 100755 index e75043f..0000000 --- a/themes/hugoplate/assets/scss/buttons.scss +++ /dev/null @@ -1,15 +0,0 @@ -.btn { - @apply inline-block rounded border border-transparent px-5 py-2 font-semibold capitalize transition; -} - -.btn-sm { - @apply rounded-sm px-4 py-1.5 text-sm; -} - -.btn-primary { - @apply border-primary bg-primary dark:border-darkmode-primary dark:text-dark text-white dark:bg-white; -} - -.btn-outline-primary { - @apply border-dark text-dark hover:bg-dark dark:hover:text-dark bg-transparent hover:text-white dark:border-white dark:text-white dark:hover:bg-white; -} diff --git a/themes/hugoplate/assets/scss/components.scss b/themes/hugoplate/assets/scss/components.scss deleted file mode 100755 index 213d5a1..0000000 --- a/themes/hugoplate/assets/scss/components.scss +++ /dev/null @@ -1,74 +0,0 @@ -main { - min-height: 70vh; -} - -// section style -.section { - @apply py-24 xl:py-28; - &-sm { - @apply py-16 xl:py-20; - } -} - -// container -.container { - @apply mx-auto px-4 2xl:max-w-[1320px]; -} - -// form style -.form-input { - @apply bg-theme-light text-dark placeholder:text-light focus:border-primary dark:border-darkmode-border dark:bg-darkmode-theme-light dark:text-darkmode-light w-full rounded border-transparent px-6 py-4 focus:ring-transparent; -} - -.form-label { - @apply font-secondary text-dark dark:text-darkmode-light mb-4 block text-xl font-normal; -} - -// social icons -.social-icons { - @apply space-x-4; - li { - @apply inline-block; - a { - @apply bg-primary dark:bg-darkmode-primary dark:text-dark flex h-9 w-9 items-center justify-center rounded text-center leading-9 text-white; - svg { - @apply h-5 w-5; - } - } - } -} - -// swiper pagination -.swiper-pagination-bullet { - @apply bg-theme-light dark:bg-darkmode-theme-light h-2.5 w-2.5 opacity-100 mx-1.5 #{!important}; - - &-active { - @apply bg-primary dark:bg-darkmode-primary h-4 w-4 #{!important}; - } -} - -// content style -.content { - @apply prose max-w-none; - @apply prose-headings:mb-[.3em] prose-headings:mt-[.6em] prose-headings:text-dark prose-headings:dark:text-darkmode-dark; - @apply prose-h1:text-h1-sm md:prose-h1:text-h1; - @apply prose-h2:text-h2-sm md:prose-h2:text-h2; - @apply prose-h3:text-h3-sm md:prose-h3:text-h3; - @apply prose-img:max-w-full prose-img:rounded; - @apply prose-hr:border-border prose-hr:dark:border-darkmode-border; - @apply prose-p:text-base prose-p:text-text prose-p:dark:text-darkmode-text; - @apply prose-blockquote:rounded-lg prose-blockquote:border prose-blockquote:border-l-[10px] prose-blockquote:border-primary prose-blockquote:bg-theme-light prose-blockquote:px-8 prose-blockquote:py-10 prose-blockquote:font-secondary prose-blockquote:text-2xl prose-blockquote:not-italic prose-blockquote:text-dark prose-blockquote:dark:border-darkmode-primary prose-blockquote:dark:bg-darkmode-theme-light prose-blockquote:dark:text-darkmode-light; - @apply prose-pre:rounded-lg prose-pre:bg-theme-light prose-pre:dark:bg-darkmode-theme-light; - @apply prose-code:px-1 prose-code:dark:text-darkmode-light; - @apply prose-strong:text-dark prose-strong:dark:text-darkmode-text; - @apply prose-a:text-text prose-a:underline hover:prose-a:text-primary prose-a:dark:text-darkmode-text hover:prose-a:dark:text-darkmode-primary; - @apply prose-li:text-text prose-li:dark:text-darkmode-text; - @apply prose-table:relative prose-table:overflow-hidden prose-table:rounded-lg prose-table:before:absolute prose-table:before:left-0 prose-table:before:top-0 prose-table:before:h-full prose-table:before:w-full prose-table:before:rounded-[inherit] prose-table:before:border prose-table:before:content-[""] prose-table:before:dark:border-darkmode-border; - @apply prose-thead:border-border prose-thead:bg-theme-light prose-thead:dark:border-darkmode-border prose-thead:dark:bg-darkmode-theme-light; - @apply prose-th:relative prose-th:z-10 prose-th:px-4 prose-th:py-[18px] prose-th:text-dark prose-th:dark:text-darkmode-text; - @apply prose-tr:border-border prose-tr:dark:border-darkmode-border; - @apply prose-td:relative prose-td:z-10 prose-td:px-3 prose-td:py-[18px] prose-td:dark:text-darkmode-text; - .btn { - @apply dark:hover:text-dark no-underline hover:text-white #{!important}; - } -} diff --git a/themes/hugoplate/assets/scss/custom.scss b/themes/hugoplate/assets/scss/custom.scss deleted file mode 100644 index 6dc68fe..0000000 --- a/themes/hugoplate/assets/scss/custom.scss +++ /dev/null @@ -1,2 +0,0 @@ -// DO NOT WRITE ANY STYLE IN THIS FILE -// If you want to add your own styles, please write it in the `./assets/scss/custom.scss` file. diff --git a/themes/hugoplate/assets/scss/main.scss b/themes/hugoplate/assets/scss/main.scss deleted file mode 100755 index 4bbaf78..0000000 --- a/themes/hugoplate/assets/scss/main.scss +++ /dev/null @@ -1,30 +0,0 @@ -@tailwind base; -@tailwind components; -@tailwind utilities; - -@layer base { - @import "base"; -} - -@layer components { - @import "components"; - @import "navigation"; - @import "buttons"; -} - -@layer utilities { - @import "utilities"; -} - -@import "search"; -@import "social-share"; -@import "gallery-slider"; -@import "images"; -@import "toc"; -@import "tab"; -@import "accordion"; -@import "modal"; -@import "notice"; - -@import "module-overrides"; -@import "custom"; diff --git a/themes/hugoplate/assets/scss/module-overrides.scss b/themes/hugoplate/assets/scss/module-overrides.scss deleted file mode 100644 index aacddcb..0000000 --- a/themes/hugoplate/assets/scss/module-overrides.scss +++ /dev/null @@ -1,53 +0,0 @@ -// table of contents -.table-of-content { - @apply overflow-hidden rounded; -} - -// share icons -.share-icons { - .share-link { - @apply h-9 w-9 rounded leading-9; - @apply bg-primary hover:bg-primary dark:bg-darkmode-primary dark:hover:bg-darkmode-primary; - } - .share-icon svg { - @apply dark:fill-dark; - } -} - -// tab -.tab { - @apply border-border dark:border-darkmode-border overflow-hidden rounded-lg border; - &-nav { - @apply border-border bg-theme-light dark:border-darkmode-border dark:bg-darkmode-theme-light pl-4; - - &-item { - @apply text-dark dark:text-darkmode-dark px-8 text-lg #{!important}; - &.active { - @apply border-dark dark:border-darkmode-primary; - } - } - } - &-content { - &-panel { - @apply px-4 pt-0 #{!important}; - } - } -} - -// accordion -.accordion { - @apply border-border bg-theme-light dark:border-darkmode-border dark:bg-darkmode-theme-light mb-6 overflow-hidden rounded-lg border; - &-header { - @apply text-dark dark:text-darkmode-dark; - } -} - -// cookie consent -.cookie-box { - @apply rounded-lg #{!important}; -} - -// slider -.gallery-slider { - @apply ml-0 #{!important}; -} diff --git a/themes/hugoplate/assets/scss/navigation.scss b/themes/hugoplate/assets/scss/navigation.scss deleted file mode 100755 index 7538a33..0000000 --- a/themes/hugoplate/assets/scss/navigation.scss +++ /dev/null @@ -1,87 +0,0 @@ -// navbar toggler -input#nav-toggle:checked + label #show-button { - @apply hidden; -} - -input#nav-toggle:checked + label #hide-button { - @apply block; -} - -input#nav-toggle:checked ~ #nav-menu { - @apply block; -} - -.header { - @apply bg-body dark:bg-darkmode-body py-6; -} - -// navbar items -.navbar { - @apply relative flex flex-wrap items-center justify-between; -} - -.navbar-brand { - @apply text-dark dark:text-darkmode-dark text-xl font-semibold; - image { - @apply max-h-full max-w-full; - } -} - -.navbar-nav { - @apply text-center lg:text-left; -} - -// .nav-item { -// @apply mx-3; -// } - -.nav-link { - @apply text-dark hover:text-primary dark:text-darkmode-dark dark:hover:text-darkmode-primary block p-3 font-semibold transition lg:px-2 lg:py-3; -} - -.nav-dropdown { - @apply mr-0; - & > svg { - @apply pointer-events-none; - } - &.active { - .nav-dropdown-list { - @apply block; - } - } -} - -.nav-dropdown-list { - @apply bg-body dark:bg-darkmode-body z-10 min-w-[180px] rounded p-4 shadow hidden lg:invisible lg:absolute lg:block lg:opacity-0; -} - -.nav-dropdown-item { - @apply [&:not(:last-child)]:mb-2; -} - -.nav-dropdown-link { - @apply text-dark hover:text-primary dark:text-darkmode-text dark:hover:text-darkmode-primary block py-1 font-semibold transition; -} - -//theme-switcher -.theme-switcher { - @apply inline-flex; - - label { - @apply bg-border relative inline-block h-4 w-6 cursor-pointer rounded-2xl lg:w-10; - } - - input { - @apply absolute opacity-0; - } - - span { - @apply bg-dark absolute -top-1 left-0 flex h-6 w-6 items-center justify-center rounded-full transition-all duration-300 dark:bg-white; - } - - input:checked + label { - span { - @apply lg:left-4; - } - } -} diff --git a/themes/hugoplate/assets/scss/utilities.scss b/themes/hugoplate/assets/scss/utilities.scss deleted file mode 100755 index 154570e..0000000 --- a/themes/hugoplate/assets/scss/utilities.scss +++ /dev/null @@ -1,20 +0,0 @@ -.bg-gradient { - @apply dark:from-darkmode-theme-light dark:to-darkmode-body bg-gradient-to-b from-[rgba(249,249,249,1)] from-[0.53%] to-white to-[83.28%]; -} - -.rounded-sm { - @apply rounded-[4px]; -} -.rounded { - @apply rounded-[6px]; -} -.rounded-lg { - @apply rounded-[12px]; -} -.rounded-xl { - @apply rounded-[16px]; -} - -.shadow { - box-shadow: 0px 4px 40px rgba(0, 0, 0, 0.05); -} diff --git a/themes/hugoplate/layouts/404.en.html b/themes/hugoplate/layouts/404.en.html deleted file mode 100755 index 9d174c6..0000000 --- a/themes/hugoplate/layouts/404.en.html +++ /dev/null @@ -1,26 +0,0 @@ -{{ define "main" }} -
-
-
-
- - 404 - -

Page not found

-
-

- The page you are looking for might have been removed, had its name - changed, or is temporarily unavailable. -

-
- - Back to home - -
-
-
-
-{{ end }} diff --git a/themes/hugoplate/layouts/404.html b/themes/hugoplate/layouts/404.html deleted file mode 100755 index 9d174c6..0000000 --- a/themes/hugoplate/layouts/404.html +++ /dev/null @@ -1,26 +0,0 @@ -{{ define "main" }} -
-
-
-
- - 404 - -

Page not found

-
-

- The page you are looking for might have been removed, had its name - changed, or is temporarily unavailable. -

-
- - Back to home - -
-
-
-
-{{ end }} diff --git a/themes/hugoplate/layouts/_default/baseof.html b/themes/hugoplate/layouts/_default/baseof.html deleted file mode 100755 index 4b1246b..0000000 --- a/themes/hugoplate/layouts/_default/baseof.html +++ /dev/null @@ -1,53 +0,0 @@ - - - - - {{ partial "essentials/head.html" . }} - - - - {{ partialCached "essentials/style.html" . }} - - - - - - {{ if hugo.IsProduction }} - {{ partialCached "preloader.html" . }} - {{ partialCached "gtm-noscript.html" . }} - {{ else }} - {{ partial "preloader.html" . }} - - - - {{ partial "components/tw-size-indicator.html" . }} - {{ end }} - - - - {{ partialCached "announcement.html" . }} - - - - {{ partial "essentials/header.html" . }} - {{ partial "search-modal.html" (dict "Context" . ) }} - - -
- {{ block "main" . }}{{ end }} -
- - - {{ partial "essentials/footer.html" . }} - - - - {{ partialCached "essentials/script.html" . }} - - diff --git a/themes/hugoplate/layouts/_default/list.html b/themes/hugoplate/layouts/_default/list.html deleted file mode 100755 index 457b96f..0000000 --- a/themes/hugoplate/layouts/_default/list.html +++ /dev/null @@ -1,20 +0,0 @@ -{{ define "main" }} - {{ partial "page-header" . }} - - -
-
- -
-
-{{ end }} diff --git a/themes/hugoplate/layouts/_default/single.html b/themes/hugoplate/layouts/_default/single.html deleted file mode 100755 index 5e2cb0f..0000000 --- a/themes/hugoplate/layouts/_default/single.html +++ /dev/null @@ -1,16 +0,0 @@ -{{ define "main" }} - {{ partial "page-header" . }} - - -
-
-
-
-
- {{ .Content }} -
-
-
-
-
-{{ end }} diff --git a/themes/hugoplate/layouts/_default/taxonomy.html b/themes/hugoplate/layouts/_default/taxonomy.html deleted file mode 100755 index ec083f8..0000000 --- a/themes/hugoplate/layouts/_default/taxonomy.html +++ /dev/null @@ -1,21 +0,0 @@ -{{ define "main" }} - {{ partial "page-header" . }} - - -
-
-
- -
-
- {{ range .Data.Pages }} -
- {{ partial "components/blog-card" . }} -
- {{ end }} -
-
-
-
-
-{{ end }} diff --git a/themes/hugoplate/layouts/_default/terms.html b/themes/hugoplate/layouts/_default/terms.html deleted file mode 100755 index 7e6f648..0000000 --- a/themes/hugoplate/layouts/_default/terms.html +++ /dev/null @@ -1,41 +0,0 @@ -{{ define "main" }} - {{ partial "page-header" . }} - - -
-
- -
-
-{{ end }} diff --git a/themes/hugoplate/layouts/about/list.html b/themes/hugoplate/layouts/about/list.html deleted file mode 100644 index 8205241..0000000 --- a/themes/hugoplate/layouts/about/list.html +++ /dev/null @@ -1,13 +0,0 @@ -{{ define "main" }} -
-
-
-
- {{ partial "image" (dict "Src" .Params.image "Context" .Page "Alt" .Title "Class" "mx-auto mb-6" "Size" "200x200") }} -

{{ .Title }}

-
{{ .Content }}
-
-
-
-
-{{ end }} diff --git a/themes/hugoplate/layouts/authors/list.html b/themes/hugoplate/layouts/authors/list.html deleted file mode 100644 index e45cd39..0000000 --- a/themes/hugoplate/layouts/authors/list.html +++ /dev/null @@ -1,16 +0,0 @@ -{{ define "main" }} - {{ partial "page-header" . }} - - -
-
-
- {{ range .RegularPages }} -
- {{ partial "components/author-card" . }} -
- {{ end }} -
-
-
-{{ end }} diff --git a/themes/hugoplate/layouts/authors/single.html b/themes/hugoplate/layouts/authors/single.html deleted file mode 100755 index 18c3601..0000000 --- a/themes/hugoplate/layouts/authors/single.html +++ /dev/null @@ -1,48 +0,0 @@ -{{ define "main" }} -
-
-
-
- {{ $image:= .Params.image }} - {{ if $image }} - {{ partial "image" (dict "Src" $image "Context" .Page "Alt" .Title "Class" "mx-auto" "Size" "200x200") }} - {{ else if .Params.Email }} - {{ .Title }} - {{ end }} -

{{ .Title }}

-
- {{ .Content }} -
- -
-
- -
- {{ $filterByAuthor := where site.RegularPages "Params.author" "==" .Title }} - {{ range $filterByAuthor }} -
- {{ partial "components/blog-card" . }} -
- {{ end }} -
-
-
-{{ end }} diff --git a/themes/hugoplate/layouts/blog/list.html b/themes/hugoplate/layouts/blog/list.html deleted file mode 100644 index 84b56e9..0000000 --- a/themes/hugoplate/layouts/blog/list.html +++ /dev/null @@ -1,29 +0,0 @@ -{{ define "main" }} - {{ partial "page-header" . }} - - -
-
-
- -
-
- {{ $paginator:= .Paginate .RegularPages }} - {{ range $paginator.Pages }} -
- {{ partial "components/blog-card" . }} -
- {{ end }} -
- {{ partial "components/pagination.html" . }} -
- -
- - {{ $widget:= site.Params.widgets.sidebar }} - {{ partialCached "widgets/widget-wrapper" ( dict "Widgets" $widget "Scope" . ) }} -
-
-
-
-{{ end }} diff --git a/themes/hugoplate/layouts/blog/single.html b/themes/hugoplate/layouts/blog/single.html deleted file mode 100644 index 283acba..0000000 --- a/themes/hugoplate/layouts/blog/single.html +++ /dev/null @@ -1,95 +0,0 @@ -{{ define "main" }} -
-
-
-
- {{ $image:= .Params.image }} - {{ if $image }} -
- {{ partial "image" (dict "Src" $image "Context" .Page "Alt" .Title "Class" "w-full rounded") }} -
- {{ end }} -

- {{ .Title }} -

- -
- {{ partial "toc.html" (dict "Class" "blog" "Collapsed" false "TableOfContents" .TableOfContents ) }} - {{ .Content }} -
-
- {{ $tags:= .Params.tags }} - {{ if $tags }} -
-
{{ T "tags" }} :
- -
- {{ end }} -
- {{ partial "social-share" (dict "Context" . "Class" "share-icons" "Title" (T "share") "Whatsapp" false "Telegram" false "Linkedin" false "Pinterest" false "Tumblr" false "Vk" false) }} -
-
- - {{ if site.Config.Services.Disqus.Shortname }} -
- {{ template "_internal/disqus.html" . }} -
- {{ end }} -
-
- - - {{ $related := (where site.RegularPages "Section" "in" site.Params.mainSections) | intersect (where site.RegularPages ".Title" "!=" .Title) | union (site.RegularPages.Related . ) }} - {{ $related = $related | shuffle | first 3 }} - {{ with $related }} -
-

{{ T "related_posts" }}

-
- {{ range . }} -
- {{ partial "components/blog-card" . }} -
- {{ end }} -
-
- {{ end }} -
-
-{{ end }} diff --git a/themes/hugoplate/layouts/contact/list.html b/themes/hugoplate/layouts/contact/list.html deleted file mode 100755 index 207f889..0000000 --- a/themes/hugoplate/layouts/contact/list.html +++ /dev/null @@ -1,120 +0,0 @@ -{{ define "main" }} - {{ partial "page-header" . }} - - -
-
-
-
-
-
- - -
-
- - -
-
- - -
- -
-
-
-
-
- - - {{ with site.Params.google_map }} - {{ if .enable }} -
- {{ end }} - {{ end }} - - {{ with site.Params.subscription }} - {{ if .enable }} - -
-
- - -
- - -
-
- - -
- - - {{ end }} - {{ end }} - - {{ if site.Params.google_map.enable }} - {{ $gmap:= resources.Get "plugins/maps/google-map.js" }} - - - {{ end }} - -{{ end }} diff --git a/themes/hugoplate/layouts/index.html b/themes/hugoplate/layouts/index.html deleted file mode 100755 index 2f6bfa1..0000000 --- a/themes/hugoplate/layouts/index.html +++ /dev/null @@ -1,139 +0,0 @@ -{{ define "main" }} - - {{ with .Params.banner }} -
-
-
-
-

- {{ .title | markdownify }} -

-

- {{ .content | markdownify }} -

- {{ with .button }} - {{ if .enable }} - - {{ .label }} - - - {{ end }} - {{ end }} -
-
- {{ partial "image" (dict "Src" .image "Alt" "Banner image" "Loading" "eager" "Class" "mx-auto lg:!max-w-[800px]" ) }} -
-
-
-
- {{ end }} - - - - {{ range $i, $e:= .Params.features }} -
-
-
-
- {{ partial "image" (dict "Src" .image "Alt" "feature image") }} -
-
-

- {{ .title | markdownify }} -

-

- {{ .content | markdownify }} -

-
    - {{ range .bulletpoints }} -
  • - - {{ . | markdownify }} -
  • - {{ end }} -
- {{ with .button }} - {{ if .enable }} - - {{ .label }} - - - {{ end }} - {{ end }} -
-
-
-
- {{ end }} - - - - {{ with site.GetPage "sections/testimonial" }} - {{ if .Params.enable }} -
-
-
-
-

- {{ .Title | markdownify }} -

-

- {{ .Params.description | markdownify }} -

-
-
-
-
- {{ range .Params.testimonials }} -
-
-
- - - -
-
- {{ .content | markdownify }} -
-
-
- {{ partial "image" (dict "Src" .avatar "Size" "50x50" "Class" "rounded-full" "Alt" .name) }} -
-
-

- {{ .name }} -

-

- {{ .designation | markdownify }} -

-
-
-
-
- {{ end }} -
-
-
-
-
-
-
- {{ end }} - {{ end }} - -{{ end }} diff --git a/themes/hugoplate/layouts/partials/call-to-action.html b/themes/hugoplate/layouts/partials/call-to-action.html deleted file mode 100644 index dce0837..0000000 --- a/themes/hugoplate/layouts/partials/call-to-action.html +++ /dev/null @@ -1,33 +0,0 @@ - -{{ with site.GetPage "sections/call-to-action" }} - {{ if .Params.enable }} -
-
-
-
-
- {{ partial "image" (dict "Src" .image "Alt" "call to action" "Class" "w-full") }} -
-
-

- {{ .Title | markdownify }} -

-

- {{ .Params.description | markdownify }} -

- {{ with .Params.button }} - {{ if .enable }} - - {{ .label }} - - {{ end }} - {{ end }} -
-
-
-
-
- {{ end }} -{{ end }} - diff --git a/themes/hugoplate/layouts/partials/components/author-card.html b/themes/hugoplate/layouts/partials/components/author-card.html deleted file mode 100755 index f28f6d5..0000000 --- a/themes/hugoplate/layouts/partials/components/author-card.html +++ /dev/null @@ -1,30 +0,0 @@ -
- {{ $image:= .Params.image }} - {{ if $image }} - {{ partial "image" (dict "Src" $image "Context" .Page "Alt" .Title "Class" "mx-auto mb-6 rounded" "size" "120x120") }} - {{ else if .Params.Email }} - {{ .Title }} - {{ end }} -

- {{ .Title }} -

-

- {{ .Summary }} -

- -
diff --git a/themes/hugoplate/layouts/partials/components/blog-card.html b/themes/hugoplate/layouts/partials/components/blog-card.html deleted file mode 100644 index 6b85691..0000000 --- a/themes/hugoplate/layouts/partials/components/blog-card.html +++ /dev/null @@ -1,37 +0,0 @@ -
- {{ $image:= .Params.image }} - {{ if $image }} - {{ partial "image" (dict "Src" $image "Context" .Page "Alt" .Title "Class" "mb-6 w-full rounded") }} - {{ end }} -

- - {{ .Title }} - -

- {{ $categories:= .Params.categories }} - {{ if $categories }} - - {{ end }} -

{{ .Summary }}

- - {{ T "read_more" }} - -
diff --git a/themes/hugoplate/layouts/partials/components/breadcrumb.html b/themes/hugoplate/layouts/partials/components/breadcrumb.html deleted file mode 100644 index eba367c..0000000 --- a/themes/hugoplate/layouts/partials/components/breadcrumb.html +++ /dev/null @@ -1,30 +0,0 @@ -{{ $context := .Context }} -{{ $class := .Class }} -{{ $base := site.Home.Permalink }} - - - diff --git a/themes/hugoplate/layouts/partials/components/language-switcher.html b/themes/hugoplate/layouts/partials/components/language-switcher.html deleted file mode 100644 index bbee9dd..0000000 --- a/themes/hugoplate/layouts/partials/components/language-switcher.html +++ /dev/null @@ -1,28 +0,0 @@ - -{{ $class := .Class }} -{{ $context := .Context }} -{{ $pageLang := $context.Lang }} -{{ $base:= urls.Parse site.Home.Permalink }} -{{ $siteLanguages := site.Home.AllTranslations }} -{{ $pageLink := replace (replace $context.RelPermalink (add $pageLang "/") "") $base.Path "/" }} - -{{ if $context.IsTranslated }} - -{{ end }} diff --git a/themes/hugoplate/layouts/partials/components/pagination.html b/themes/hugoplate/layouts/partials/components/pagination.html deleted file mode 100755 index 6701887..0000000 --- a/themes/hugoplate/layouts/partials/components/pagination.html +++ /dev/null @@ -1,138 +0,0 @@ -{{ $paginator := .Paginator }} - -{{ $adjacent_links := 2 }} - -{{ $max_links := (add (mul $adjacent_links 2) 1) }} - -{{ $lower_limit := (add $adjacent_links 1) }} - -{{ $upper_limit := (sub $paginator.TotalPages $adjacent_links) }} - -{{ if gt $paginator.TotalPages 1 }} - -{{ end }} diff --git a/themes/hugoplate/layouts/partials/components/theme-switcher.html b/themes/hugoplate/layouts/partials/components/theme-switcher.html deleted file mode 100644 index 309cbd2..0000000 --- a/themes/hugoplate/layouts/partials/components/theme-switcher.html +++ /dev/null @@ -1,70 +0,0 @@ - -{{ $class := .Class }} -{{ if site.Params.theme_switcher }} - - - - -{{ end }} diff --git a/themes/hugoplate/layouts/partials/components/tw-size-indicator.html b/themes/hugoplate/layouts/partials/components/tw-size-indicator.html deleted file mode 100644 index 38e54cf..0000000 --- a/themes/hugoplate/layouts/partials/components/tw-size-indicator.html +++ /dev/null @@ -1,9 +0,0 @@ -
- all - - - - - -
diff --git a/themes/hugoplate/layouts/partials/essentials/footer.html b/themes/hugoplate/layouts/partials/essentials/footer.html deleted file mode 100755 index f76fc36..0000000 --- a/themes/hugoplate/layouts/partials/essentials/footer.html +++ /dev/null @@ -1,57 +0,0 @@ -
-
-
- -
-
    - {{ range site.Menus.footer }} -
  • - {{ .Name }} -
  • - {{ end }} -
-
-
- -
-
-
-
-
-

- {{ site.Params.copyright | markdownify }} -

-
-
-
diff --git a/themes/hugoplate/layouts/partials/essentials/head.html b/themes/hugoplate/layouts/partials/essentials/head.html deleted file mode 100755 index bb7b1a7..0000000 --- a/themes/hugoplate/layouts/partials/essentials/head.html +++ /dev/null @@ -1,61 +0,0 @@ - - - - - - - - - -{{ partialCached "favicon" . }} - - - -{{ partialCached "manifest" . }} - - - -{{ partialCached "site-verifications.html" . }} - - - -{{ partial "basic-seo.html" . }} - - - -{{ partialCached "custom-script.html" . }} - - - -{{ if and site.Config.Services.GoogleAnalytics.ID (ne site.Config.Services.GoogleAnalytics.ID "G-MEASUREMENT_ID") }} - {{ template "_internal/google_analytics.html" . }} -{{ end }} - - - -{{ partialCached "gtm.html" . }} - - - -{{ partial "search-index.html" . }} - - - -{{/* {{ partialCached "matomo-analytics.html" . }} */}} - - -{{/* {{ partialCached "baidu-analytics.html" . }} */}} - - -{{/* {{ partialCached "plausible-analytics.html" . }} */}} - - -{{/* {{ partialCached "counter-analytics.html" . }} */}} - - -{{/* {{ partialCached "crisp-chat.html" . }} */}} - - -{{ partial "mermaid/assets/js" . }} diff --git a/themes/hugoplate/layouts/partials/essentials/header.html b/themes/hugoplate/layouts/partials/essentials/header.html deleted file mode 100755 index 15749fa..0000000 --- a/themes/hugoplate/layouts/partials/essentials/header.html +++ /dev/null @@ -1,139 +0,0 @@ -
- -
diff --git a/themes/hugoplate/layouts/partials/essentials/script.html b/themes/hugoplate/layouts/partials/essentials/script.html deleted file mode 100755 index 4d11a0d..0000000 --- a/themes/hugoplate/layouts/partials/essentials/script.html +++ /dev/null @@ -1,58 +0,0 @@ - -{{ $scripts := slice }} -{{ $scriptsLazy := slice }} -{{ range site.Params.plugins.js }} - {{ if findRE "^http" .link }} - - {{ else }} - {{ if not .lazy }} - {{ $scripts = $scripts | append (resources.Get .link) }} - {{ else }} - {{ $scriptsLazy = $scriptsLazy | append (resources.Get .link) }} - {{ end }} - {{ end }} -{{ end }} - - - -{{ $scripts = $scripts | append (resources.Get "js/main.js") }} -{{ $scripts = $scripts | resources.Concat "js/script.js" }} - -{{ $scriptsLazy = $scriptsLazy | resources.Concat "js/script-lazy.js" }} - -{{ if hugo.IsProduction }} - {{ $scripts = $scripts | minify | fingerprint }} - {{ $scriptsLazy = $scriptsLazy | minify | fingerprint }} -{{ end }} - -{{/* scripts */}} - - -{{/* scripts lazy */}} - - - -{{ partialCached "pwa.html" . }} - - - -{{ partialCached "cookie-consent.html" . }} - - - -{{ partialCached "adsense-script.html" . }} - - - -{{ partialCached "announcement-script.html" . }} diff --git a/themes/hugoplate/layouts/partials/essentials/style.html b/themes/hugoplate/layouts/partials/essentials/style.html deleted file mode 100755 index 5609469..0000000 --- a/themes/hugoplate/layouts/partials/essentials/style.html +++ /dev/null @@ -1,82 +0,0 @@ - - - - - - - - - - - - - - - - - -{{ $pf:= site.Data.theme.fonts.font_family.primary }} -{{ $sf:= site.Data.theme.fonts.font_family.secondary }} - - - - - -{{ $styles := slice }} -{{ $stylesLazy := slice }} -{{ range site.Params.plugins.css }} - {{ if findRE "^http" .link }} - - {{ else }} - {{ if not .lazy }} - {{ $styles = $styles | append (resources.Get .link) }} - {{ else }} - {{ $stylesLazy = $stylesLazy | append (resources.Get .link) }} - {{ end }} - {{ end }} -{{ end }} - -{{/* main style */}} -{{ $styles = $styles | append (resources.Get "scss/main.scss" | toCSS) }} -{{ $styles = $styles | resources.Concat "css/style.css" }} -{{ $styles = $styles | css.PostCSS }} - -{{ $stylesLazy = $stylesLazy | resources.Concat "css/style-lazy.css" }} -{{ $stylesLazy = $stylesLazy | css.PostCSS }} - -{{ if hugo.IsProduction }} - {{ $styles = $styles | resources.ExecuteAsTemplate "css/style.css" . | minify | fingerprint | resources.PostProcess }} - {{ $stylesLazy = $stylesLazy | resources.ExecuteAsTemplate "css/style-lazy.css" . | minify | fingerprint | resources.PostProcess }} -{{ else }} - {{ $styles = $styles | resources.ExecuteAsTemplate "css/style.css" . }} - {{ $stylesLazy = $stylesLazy | resources.ExecuteAsTemplate "css/style-lazy.css" . }} -{{ end }} - -{{/* styles */}} - - -{{/* styles lazy */}} - diff --git a/themes/hugoplate/layouts/partials/page-header.html b/themes/hugoplate/layouts/partials/page-header.html deleted file mode 100755 index c0b2baa..0000000 --- a/themes/hugoplate/layouts/partials/page-header.html +++ /dev/null @@ -1,9 +0,0 @@ -
-
-
-

{{ T (printf "%s" (lower .Title)) | default .Title | title }}

- {{ partial "components/breadcrumb" (dict "Context" . "Class" "mt-6") }} -
-
-
diff --git a/themes/hugoplate/layouts/partials/widgets/categories.html b/themes/hugoplate/layouts/partials/widgets/categories.html deleted file mode 100755 index 1a0792b..0000000 --- a/themes/hugoplate/layouts/partials/widgets/categories.html +++ /dev/null @@ -1,23 +0,0 @@ - -{{ if isset site.Taxonomies "categories" }} - {{ if not (eq (len site.Taxonomies.categories) 0) }} -
-
{{ T "categories" }}
-
- -
-
- {{ end }} -{{ end }} diff --git a/themes/hugoplate/layouts/partials/widgets/tags.html b/themes/hugoplate/layouts/partials/widgets/tags.html deleted file mode 100755 index 605b20c..0000000 --- a/themes/hugoplate/layouts/partials/widgets/tags.html +++ /dev/null @@ -1,23 +0,0 @@ - -{{ if isset site.Taxonomies "tags" }} - {{ if not (eq (len site.Taxonomies.tags) 0) }} -
-
{{ T "tags" }}
-
- -
-
- {{ end }} -{{ end }} diff --git a/themes/hugoplate/layouts/partials/widgets/widget-wrapper.html b/themes/hugoplate/layouts/partials/widgets/widget-wrapper.html deleted file mode 100755 index 03a8a44..0000000 --- a/themes/hugoplate/layouts/partials/widgets/widget-wrapper.html +++ /dev/null @@ -1,3 +0,0 @@ -{{ range .Widgets }} - {{ partial ( print "widgets/" . ) $.Scope }} -{{ end }} diff --git a/new-site/tsconfig.json b/tsconfig.json similarity index 100% rename from new-site/tsconfig.json rename to tsconfig.json