diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..4e637713 --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +node_modules +node_modules diff --git a/README.md b/README.md new file mode 100644 index 00000000..77f6afab --- /dev/null +++ b/README.md @@ -0,0 +1,37 @@ +# Bagisto Documentation + +You can find the online version of the Bagisto documentation at [https://devdocs.bagisto.com](https://devdocs.bagisto.com). + +## Contribution guide + +For contributing to the docs, you first need to set up the project, + +- Fork the repository. + +- Clone your fork. + +- Follow the [Install Dependencies](#Install-dependencies) section. + +Make sure your PR follows all these points, + +- Before writing the docs just make sure to check that if that topic is already written or not. + +- Make sure your markdown indentation should be proper. You can install `mark-down` lint also. This will help you to follow the markdown conventions. + +- If you are creating new files for the docs, then make sure the filename should be `kebab-case`. For e.g. `file-1.md`, `file-2.md`. + +## Install dependencies + +- Run the following command, + + ~~~sh + npm install + ~~~ + +- Run the docs locally, + + ~~~sh + npm run docs:dev + ~~~ + +- Open your browser and go to [http://localhost:8080](http://localhost:8080). diff --git a/deploy.sh b/deploy.sh new file mode 100644 index 00000000..964c073a --- /dev/null +++ b/deploy.sh @@ -0,0 +1,19 @@ +#!/usr/bin/env sh + +# abort on errors +set -e + +# build +npm run docs:build + +# navigate into the build output directory +cd docs/.vuepress/dist + +echo 'devdocs.bagisto.com' > CNAME + +git init +git add -A +git commit -m 'Deploy docs to GitHub' +git push -f git@github.com:bagisto/bagisto-docs.git master:gh-pages + +cd - diff --git a/docs/.vuepress/config.js b/docs/.vuepress/config.js new file mode 100644 index 00000000..e957a2a2 --- /dev/null +++ b/docs/.vuepress/config.js @@ -0,0 +1,37 @@ +module.exports = { + base: '/', + port: '8080', + cache: false, + title: 'Bagisto Documentation', + description: 'Bagisto Developer Portal', + head: [ + ['link', { rel: "icon", type: "image/png", href: "/favicon.ico" }], + ], + themeConfig: { + smoothScroll: true, + lastUpdated: 'Last Updated', + repo: 'bagisto/bagisto', + repoLabel: 'Contribute to Bagisto', + docsRepo: 'bagisto/bagisto-docs', + docsDir: 'docs', + docsBranch: 'master', + editLinks: true, + editLinkText: 'Help us improve this page on Github.', + + logo: '/logo.png', + nav: [ + { text: 'Home', link: '/' }, + { text: 'Extensions', link: 'https://bagisto.com/en/extensions/' }, + { text: 'Community Forum', link: 'https://forums.bagisto.com/' } + ], + sidebar: { + '/1.x/': require('./version-configs/1.x'), + '/1.5.x/': require('./version-configs/1.5.x'), + '/2.x/': require('./version-configs/2.x') + } + }, + markdown: { + lineNumbers: false + }, + plugins: ['@vuepress/pwa', 'copy-code', '@vuepress/back-to-top'] +}; diff --git a/docs/.vuepress/override.styl b/docs/.vuepress/override.styl new file mode 100644 index 00000000..69843be3 --- /dev/null +++ b/docs/.vuepress/override.styl @@ -0,0 +1,7 @@ +// color settings +$accentColor = #227CD9 +$borderColor = #e1e1e1 +$codeBgColor = #282c34 +$badgeTip = #42b983 +$badgeWarning = darken(#ffe564, 35%) +$badgeError = #DA596 \ No newline at end of file diff --git a/docs/.vuepress/public/favicon.ico b/docs/.vuepress/public/favicon.ico new file mode 100644 index 00000000..e9c217bb Binary files /dev/null and b/docs/.vuepress/public/favicon.ico differ diff --git a/docs/.vuepress/public/logo.png b/docs/.vuepress/public/logo.png new file mode 100644 index 00000000..fd410637 Binary files /dev/null and b/docs/.vuepress/public/logo.png differ diff --git a/docs/.vuepress/styles/palette.styl b/docs/.vuepress/styles/palette.styl new file mode 100644 index 00000000..458baf4a --- /dev/null +++ b/docs/.vuepress/styles/palette.styl @@ -0,0 +1,17 @@ +$accentColor = #0041FF +$borderColor = #e1e1e1 +$codeBgColor = #282c34 +$badgeTip = #42b983 +$badgeWarning = darken(#ffe564, 35%) +$badgeError = #DA596 + +// layout +$navbarHeight = 3.6rem +$sidebarWidth = 20rem +$contentWidth = 960px +$homePageWidth = 960px + +// responsive breakpoints +$MQNarrow = 959px +$MQMobile = 719px +$MQMobileNarrow = 419px \ No newline at end of file diff --git a/docs/.vuepress/theme/LICENSE b/docs/.vuepress/theme/LICENSE new file mode 100644 index 00000000..15f1f7e7 --- /dev/null +++ b/docs/.vuepress/theme/LICENSE @@ -0,0 +1,21 @@ +The MIT License (MIT) + +Copyright (c) 2018-present, Yuxi (Evan) You + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. diff --git a/docs/.vuepress/theme/components/AlgoliaSearchBox.vue b/docs/.vuepress/theme/components/AlgoliaSearchBox.vue new file mode 100644 index 00000000..7b2a5807 --- /dev/null +++ b/docs/.vuepress/theme/components/AlgoliaSearchBox.vue @@ -0,0 +1,171 @@ + + + + + diff --git a/docs/.vuepress/theme/components/DropdownLink.vue b/docs/.vuepress/theme/components/DropdownLink.vue new file mode 100644 index 00000000..be6563fa --- /dev/null +++ b/docs/.vuepress/theme/components/DropdownLink.vue @@ -0,0 +1,252 @@ + + + + + diff --git a/docs/.vuepress/theme/components/DropdownTransition.vue b/docs/.vuepress/theme/components/DropdownTransition.vue new file mode 100644 index 00000000..eeaf12b5 --- /dev/null +++ b/docs/.vuepress/theme/components/DropdownTransition.vue @@ -0,0 +1,33 @@ + + + + + diff --git a/docs/.vuepress/theme/components/Home.vue b/docs/.vuepress/theme/components/Home.vue new file mode 100644 index 00000000..05aa7046 --- /dev/null +++ b/docs/.vuepress/theme/components/Home.vue @@ -0,0 +1,175 @@ + + + + + \ No newline at end of file diff --git a/docs/.vuepress/theme/components/NavLink.vue b/docs/.vuepress/theme/components/NavLink.vue new file mode 100644 index 00000000..f7e65a44 --- /dev/null +++ b/docs/.vuepress/theme/components/NavLink.vue @@ -0,0 +1,90 @@ + + + diff --git a/docs/.vuepress/theme/components/NavLinks.vue b/docs/.vuepress/theme/components/NavLinks.vue new file mode 100644 index 00000000..49b4ec4e --- /dev/null +++ b/docs/.vuepress/theme/components/NavLinks.vue @@ -0,0 +1,186 @@ + + + + + diff --git a/docs/.vuepress/theme/components/Navbar.vue b/docs/.vuepress/theme/components/Navbar.vue new file mode 100644 index 00000000..f8dd49ca --- /dev/null +++ b/docs/.vuepress/theme/components/Navbar.vue @@ -0,0 +1,140 @@ + + + + + diff --git a/docs/.vuepress/theme/components/Page.vue b/docs/.vuepress/theme/components/Page.vue new file mode 100644 index 00000000..6c82f25d --- /dev/null +++ b/docs/.vuepress/theme/components/Page.vue @@ -0,0 +1,39 @@ + + + + + diff --git a/docs/.vuepress/theme/components/PageEdit.vue b/docs/.vuepress/theme/components/PageEdit.vue new file mode 100644 index 00000000..cf9b2d25 --- /dev/null +++ b/docs/.vuepress/theme/components/PageEdit.vue @@ -0,0 +1,155 @@ + + + + + diff --git a/docs/.vuepress/theme/components/PageNav.vue b/docs/.vuepress/theme/components/PageNav.vue new file mode 100644 index 00000000..4c19aae5 --- /dev/null +++ b/docs/.vuepress/theme/components/PageNav.vue @@ -0,0 +1,163 @@ + + + + + diff --git a/docs/.vuepress/theme/components/Sidebar.vue b/docs/.vuepress/theme/components/Sidebar.vue new file mode 100644 index 00000000..e70e3336 --- /dev/null +++ b/docs/.vuepress/theme/components/Sidebar.vue @@ -0,0 +1,64 @@ + + + + + diff --git a/docs/.vuepress/theme/components/SidebarButton.vue b/docs/.vuepress/theme/components/SidebarButton.vue new file mode 100644 index 00000000..3f54afd5 --- /dev/null +++ b/docs/.vuepress/theme/components/SidebarButton.vue @@ -0,0 +1,40 @@ + + + diff --git a/docs/.vuepress/theme/components/SidebarGroup.vue b/docs/.vuepress/theme/components/SidebarGroup.vue new file mode 100644 index 00000000..d7f19294 --- /dev/null +++ b/docs/.vuepress/theme/components/SidebarGroup.vue @@ -0,0 +1,141 @@ + + + + + diff --git a/docs/.vuepress/theme/components/SidebarLink.vue b/docs/.vuepress/theme/components/SidebarLink.vue new file mode 100644 index 00000000..4cd7665a --- /dev/null +++ b/docs/.vuepress/theme/components/SidebarLink.vue @@ -0,0 +1,133 @@ + + + diff --git a/docs/.vuepress/theme/components/SidebarLinks.vue b/docs/.vuepress/theme/components/SidebarLinks.vue new file mode 100644 index 00000000..ea084e25 --- /dev/null +++ b/docs/.vuepress/theme/components/SidebarLinks.vue @@ -0,0 +1,103 @@ + + + diff --git a/docs/.vuepress/theme/global-components/Badge.vue b/docs/.vuepress/theme/global-components/Badge.vue new file mode 100644 index 00000000..53951f9d --- /dev/null +++ b/docs/.vuepress/theme/global-components/Badge.vue @@ -0,0 +1,44 @@ + + + diff --git a/docs/.vuepress/theme/index.js b/docs/.vuepress/theme/index.js new file mode 100644 index 00000000..baaf102b --- /dev/null +++ b/docs/.vuepress/theme/index.js @@ -0,0 +1,59 @@ +const path = require('path') + +// Theme API. +module.exports = (options, ctx) => { + const { themeConfig, siteConfig } = ctx + + // resolve algolia + const isAlgoliaSearch = ( + themeConfig.algolia + || Object + .keys(siteConfig.locales && themeConfig.locales || {}) + .some(base => themeConfig.locales[base].algolia) + ) + + const enableSmoothScroll = themeConfig.smoothScroll === true + + return { + alias () { + return { + '@AlgoliaSearchBox': isAlgoliaSearch + ? path.resolve(__dirname, 'components/AlgoliaSearchBox.vue') + : path.resolve(__dirname, 'noopModule.js') + } + }, + + plugins: [ + ['@vuepress/active-header-links', options.activeHeaderLinks], + '@vuepress/search', + '@vuepress/plugin-nprogress', + ['container', { + type: 'tip', + defaultTitle: { + '/': 'TIP', + '/zh/': '提示' + } + }], + ['container', { + type: 'warning', + defaultTitle: { + '/': 'WARNING', + '/zh/': '注意' + } + }], + ['container', { + type: 'danger', + defaultTitle: { + '/': 'WARNING', + '/zh/': '警告' + } + }], + ['container', { + type: 'details', + before: info => `
${info ? `${info}` : ''}\n`, + after: () => '
\n' + }], + ['smooth-scroll', enableSmoothScroll] + ] + } +} diff --git a/docs/.vuepress/theme/layouts/404.vue b/docs/.vuepress/theme/layouts/404.vue new file mode 100644 index 00000000..2cbfa0f1 --- /dev/null +++ b/docs/.vuepress/theme/layouts/404.vue @@ -0,0 +1,30 @@ + + + diff --git a/docs/.vuepress/theme/layouts/Layout.vue b/docs/.vuepress/theme/layouts/Layout.vue new file mode 100644 index 00000000..32980709 --- /dev/null +++ b/docs/.vuepress/theme/layouts/Layout.vue @@ -0,0 +1,151 @@ + + + diff --git a/docs/.vuepress/theme/noopModule.js b/docs/.vuepress/theme/noopModule.js new file mode 100644 index 00000000..b1c6ea43 --- /dev/null +++ b/docs/.vuepress/theme/noopModule.js @@ -0,0 +1 @@ +export default {} diff --git a/docs/.vuepress/theme/styles/arrow.styl b/docs/.vuepress/theme/styles/arrow.styl new file mode 100644 index 00000000..20bffc0d --- /dev/null +++ b/docs/.vuepress/theme/styles/arrow.styl @@ -0,0 +1,22 @@ +@require './config' + +.arrow + display inline-block + width 0 + height 0 + &.up + border-left 4px solid transparent + border-right 4px solid transparent + border-bottom 6px solid $arrowBgColor + &.down + border-left 4px solid transparent + border-right 4px solid transparent + border-top 6px solid $arrowBgColor + &.right + border-top 4px solid transparent + border-bottom 4px solid transparent + border-left 6px solid $arrowBgColor + &.left + border-top 4px solid transparent + border-bottom 4px solid transparent + border-right 6px solid $arrowBgColor diff --git a/docs/.vuepress/theme/styles/code.styl b/docs/.vuepress/theme/styles/code.styl new file mode 100644 index 00000000..9d3aa9a5 --- /dev/null +++ b/docs/.vuepress/theme/styles/code.styl @@ -0,0 +1,137 @@ +{$contentClass} + code + color lighten($textColor, 20%) + padding 0.25rem 0.5rem + margin 0 + font-size 0.85em + background-color rgba(27,31,35,0.05) + border-radius 3px + .token + &.deleted + color #EC5975 + &.inserted + color $accentColor + +{$contentClass} + pre, pre[class*="language-"] + line-height 1.4 + padding 1.25rem 1.5rem + margin 0.85rem 0 + background-color $codeBgColor + border-radius 6px + overflow auto + code + color #fff + padding 0 + background-color transparent + border-radius 0 + +div[class*="language-"] + position relative + background-color $codeBgColor + border-radius 6px + .highlight-lines + user-select none + padding-top 1.3rem + position absolute + top 0 + left 0 + width 100% + line-height 1.4 + .highlighted + background-color rgba(0, 0, 0, 66%) + pre, pre[class*="language-"] + background transparent + position relative + z-index 1 + &::before + position absolute + z-index 3 + top 0.8em + right 1em + font-size 0.75rem + color rgba(255, 255, 255, 0.4) + &:not(.line-numbers-mode) + .line-numbers-wrapper + display none + &.line-numbers-mode + .highlight-lines .highlighted + position relative + &:before + content ' ' + position absolute + z-index 3 + left 0 + top 0 + display block + width $lineNumbersWrapperWidth + height 100% + background-color rgba(0, 0, 0, 66%) + pre + padding-left $lineNumbersWrapperWidth + 1 rem + vertical-align middle + .line-numbers-wrapper + position absolute + top 0 + width $lineNumbersWrapperWidth + text-align center + color rgba(255, 255, 255, 0.3) + padding 1.25rem 0 + line-height 1.4 + br + user-select none + .line-number + position relative + z-index 4 + user-select none + font-size 0.85em + &::after + content '' + position absolute + z-index 2 + top 0 + left 0 + width $lineNumbersWrapperWidth + height 100% + border-radius 6px 0 0 6px + border-right 1px solid rgba(0, 0, 0, 66%) + background-color $codeBgColor + + +for lang in $codeLang + div{'[class~="language-' + lang + '"]'} + &:before + content ('' + lang) + +div[class~="language-javascript"] + &:before + content "js" + +div[class~="language-typescript"] + &:before + content "ts" + +div[class~="language-markup"] + &:before + content "html" + +div[class~="language-markdown"] + &:before + content "md" + +div[class~="language-json"]:before + content "json" + +div[class~="language-ruby"]:before + content "rb" + +div[class~="language-python"]:before + content "py" + +div[class~="language-bash"]:before + content "sh" + +div[class~="language-php"]:before + content "php" + +@import '~prismjs/themes/prism-tomorrow.css' diff --git a/docs/.vuepress/theme/styles/config.styl b/docs/.vuepress/theme/styles/config.styl new file mode 100644 index 00000000..9e403210 --- /dev/null +++ b/docs/.vuepress/theme/styles/config.styl @@ -0,0 +1 @@ +$contentClass = '.theme-default-content' diff --git a/docs/.vuepress/theme/styles/custom-blocks.styl b/docs/.vuepress/theme/styles/custom-blocks.styl new file mode 100644 index 00000000..5b868166 --- /dev/null +++ b/docs/.vuepress/theme/styles/custom-blocks.styl @@ -0,0 +1,44 @@ +.custom-block + .custom-block-title + font-weight 600 + margin-bottom -0.4rem + &.tip, &.warning, &.danger + padding .1rem 1.5rem + border-left-width .5rem + border-left-style solid + margin 1rem 0 + &.tip + background-color #f3f5f7 + border-color #42b983 + &.warning + background-color rgba(255,229,100,.3) + border-color darken(#ffe564, 35%) + color darken(#ffe564, 70%) + .custom-block-title + color darken(#ffe564, 50%) + a + color $textColor + &.danger + background-color #ffe6e6 + border-color darken(red, 20%) + color darken(red, 70%) + .custom-block-title + color darken(red, 40%) + a + color $textColor + &.details + display block + position relative + border-radius 2px + margin 1.6em 0 + padding 1.6em + background-color #eee + h4 + margin-top 0 + figure, p + &:last-child + margin-bottom 0 + padding-bottom 0 + summary + outline none + cursor pointer diff --git a/docs/.vuepress/theme/styles/index.styl b/docs/.vuepress/theme/styles/index.styl new file mode 100644 index 00000000..976bfb04 --- /dev/null +++ b/docs/.vuepress/theme/styles/index.styl @@ -0,0 +1,201 @@ +@require './config' +@require './code' +@require './custom-blocks' +@require './arrow' +@require './wrapper' +@require './toc' + +html, body + padding 0 + margin 0 + background-color #fff + +body + font-family -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif + -webkit-font-smoothing antialiased + -moz-osx-font-smoothing grayscale + font-size 16px + color $textColor + +.page + padding-left $sidebarWidth + +.navbar + position fixed + z-index 20 + top 0 + left 0 + right 0 + height $navbarHeight + background-color #fff + box-sizing border-box + border-bottom 1px solid $borderColor + +.sidebar-mask + position fixed + z-index 9 + top 0 + left 0 + width 100vw + height 100vh + display none + +.sidebar + font-size 16px + background-color #fff + width $sidebarWidth + position fixed + z-index 10 + margin 0 + top $navbarHeight + left 0 + bottom 0 + box-sizing border-box + border-right 1px solid $borderColor + overflow-y auto + +{$contentClass}:not(.custom) + @extend $wrapper + > *:first-child + margin-top $navbarHeight + + a:hover + text-decoration underline + + p.demo + padding 1rem 1.5rem + border 1px solid #ddd + border-radius 4px + + img + max-width 100% + +{$contentClass}.custom + padding 0 + margin 0 + + img + max-width 100% + +a + font-weight 500 + color $accentColor + text-decoration none + +p a code + font-weight 400 + color $accentColor + +kbd + background #eee + border solid 0.15rem #ddd + border-bottom solid 0.25rem #ddd + border-radius 0.15rem + padding 0 0.15em + +blockquote + font-size 1rem + color #999; + border-left .2rem solid #dfe2e5 + margin 1rem 0 + padding .25rem 0 .25rem 1rem + + & > p + margin 0 + +ul, ol + padding-left 1.2em + +strong + font-weight 600 + +h1, h2, h3, h4, h5, h6 + font-weight 600 + line-height 1.25 + + {$contentClass}:not(.custom) > & + margin-top (0.5rem - $navbarHeight) + padding-top ($navbarHeight + 1rem) + margin-bottom 0 + + &:first-child + margin-top -1.5rem + margin-bottom 1rem + + + p, + pre, + .custom-block + margin-top 2rem + + &:hover .header-anchor + opacity: 1 + +h1 + font-size 2.2rem + +h2 + font-size 1.65rem + padding-bottom .3rem + border-bottom 1px solid $borderColor + +h3 + font-size 1.35rem + +a.header-anchor + font-size 0.85em + float left + margin-left -0.87em + padding-right 0.23em + margin-top 0.125em + opacity 0 + + &:hover + text-decoration none + +code, kbd, .line-number + font-family source-code-pro, Menlo, Monaco, Consolas, "Courier New", monospace + +p, ul, ol + line-height 1.7 + +hr + border 0 + border-top 1px solid $borderColor + +table + border-collapse collapse + margin 1rem 0 + display: block + overflow-x: auto + +tr + border-top 1px solid #dfe2e5 + + &:nth-child(2n) + background-color #f6f8fa + +th, td + border 1px solid #dfe2e5 + padding .6em 1em + +.theme-container + &.sidebar-open + .sidebar-mask + display: block + + &.no-navbar + {$contentClass}:not(.custom) > h1, h2, h3, h4, h5, h6 + margin-top 1.5rem + padding-top 0 + + .sidebar + top 0 + + +@media (min-width: ($MQMobile + 1px)) + .theme-container.no-sidebar + .sidebar + display none + + .page + padding-left 0 + +@require 'mobile.styl' diff --git a/docs/.vuepress/theme/styles/mobile.styl b/docs/.vuepress/theme/styles/mobile.styl new file mode 100644 index 00000000..f5bd3273 --- /dev/null +++ b/docs/.vuepress/theme/styles/mobile.styl @@ -0,0 +1,37 @@ +@require './config' + +$mobileSidebarWidth = $sidebarWidth * 0.82 + +// narrow desktop / iPad +@media (max-width: $MQNarrow) + .sidebar + font-size 15px + width $mobileSidebarWidth + .page + padding-left $mobileSidebarWidth + +// wide mobile +@media (max-width: $MQMobile) + .sidebar + top 0 + padding-top $navbarHeight + transform translateX(-100%) + transition transform .2s ease + .page + padding-left 0 + .theme-container + &.sidebar-open + .sidebar + transform translateX(0) + &.no-navbar + .sidebar + padding-top: 0 + +// narrow mobile +@media (max-width: $MQMobileNarrow) + h1 + font-size 1.9rem + {$contentClass} + div[class*="language-"] + margin 0.85rem -1.5rem + border-radius 0 diff --git a/docs/.vuepress/theme/styles/toc.styl b/docs/.vuepress/theme/styles/toc.styl new file mode 100644 index 00000000..d3e71069 --- /dev/null +++ b/docs/.vuepress/theme/styles/toc.styl @@ -0,0 +1,3 @@ +.table-of-contents + .badge + vertical-align middle diff --git a/docs/.vuepress/theme/styles/wrapper.styl b/docs/.vuepress/theme/styles/wrapper.styl new file mode 100644 index 00000000..a99262c7 --- /dev/null +++ b/docs/.vuepress/theme/styles/wrapper.styl @@ -0,0 +1,9 @@ +$wrapper + max-width $contentWidth + margin 0 auto + padding 2rem 2.5rem + @media (max-width: $MQNarrow) + padding 2rem + @media (max-width: $MQMobileNarrow) + padding 1.5rem + diff --git a/docs/.vuepress/theme/util/index.js b/docs/.vuepress/theme/util/index.js new file mode 100644 index 00000000..92fcd3b3 --- /dev/null +++ b/docs/.vuepress/theme/util/index.js @@ -0,0 +1,244 @@ +export const hashRE = /#.*$/ +export const extRE = /\.(md|html)$/ +export const endingSlashRE = /\/$/ +export const outboundRE = /^[a-z]+:/i + +export function normalize (path) { + return decodeURI(path) + .replace(hashRE, '') + .replace(extRE, '') +} + +export function getHash (path) { + const match = path.match(hashRE) + if (match) { + return match[0] + } +} + +export function isExternal (path) { + return outboundRE.test(path) +} + +export function isMailto (path) { + return /^mailto:/.test(path) +} + +export function isTel (path) { + return /^tel:/.test(path) +} + +export function ensureExt (path) { + if (isExternal(path)) { + return path + } + const hashMatch = path.match(hashRE) + const hash = hashMatch ? hashMatch[0] : '' + const normalized = normalize(path) + + if (endingSlashRE.test(normalized)) { + return path + } + return normalized + '.html' + hash +} + +export function isActive (route, path) { + const routeHash = decodeURIComponent(route.hash) + const linkHash = getHash(path) + if (linkHash && routeHash !== linkHash) { + return false + } + const routePath = normalize(route.path) + const pagePath = normalize(path) + return routePath === pagePath +} + +export function resolvePage (pages, rawPath, base) { + if (isExternal(rawPath)) { + return { + type: 'external', + path: rawPath + } + } + if (base) { + rawPath = resolvePath(rawPath, base) + } + const path = normalize(rawPath) + for (let i = 0; i < pages.length; i++) { + if (normalize(pages[i].regularPath) === path) { + return Object.assign({}, pages[i], { + type: 'page', + path: ensureExt(pages[i].path) + }) + } + } + console.error(`[vuepress] No matching page found for sidebar item "${rawPath}"`) + return {} +} + +function resolvePath (relative, base, append) { + const firstChar = relative.charAt(0) + if (firstChar === '/') { + return relative + } + + if (firstChar === '?' || firstChar === '#') { + return base + relative + } + + const stack = base.split('/') + + // remove trailing segment if: + // - not appending + // - appending to trailing slash (last segment is empty) + if (!append || !stack[stack.length - 1]) { + stack.pop() + } + + // resolve relative path + const segments = relative.replace(/^\//, '').split('/') + for (let i = 0; i < segments.length; i++) { + const segment = segments[i] + if (segment === '..') { + stack.pop() + } else if (segment !== '.') { + stack.push(segment) + } + } + + // ensure leading slash + if (stack[0] !== '') { + stack.unshift('') + } + + return stack.join('/') +} + +/** + * @param { Page } page + * @param { string } regularPath + * @param { SiteData } site + * @param { string } localePath + * @returns { SidebarGroup } + */ +export function resolveSidebarItems (page, regularPath, site, localePath) { + const { pages, themeConfig } = site + + const localeConfig = localePath && themeConfig.locales + ? themeConfig.locales[localePath] || themeConfig + : themeConfig + + const pageSidebarConfig = page.frontmatter.sidebar || localeConfig.sidebar || themeConfig.sidebar + if (pageSidebarConfig === 'auto') { + return resolveHeaders(page) + } + + const sidebarConfig = localeConfig.sidebar || themeConfig.sidebar + if (!sidebarConfig) { + return [] + } else { + const { base, config } = resolveMatchingConfig(regularPath, sidebarConfig) + if (config === 'auto') { + return resolveHeaders(page) + } + return config + ? config.map(item => resolveItem(item, pages, base)) + : [] + } +} + +/** + * @param { Page } page + * @returns { SidebarGroup } + */ +function resolveHeaders (page) { + const headers = groupHeaders(page.headers || []) + return [{ + type: 'group', + collapsable: false, + title: page.title, + path: null, + children: headers.map(h => ({ + type: 'auto', + title: h.title, + basePath: page.path, + path: page.path + '#' + h.slug, + children: h.children || [] + })) + }] +} + +export function groupHeaders (headers) { + // group h3s under h2 + headers = headers.map(h => Object.assign({}, h)) + let lastH2 + headers.forEach(h => { + if (h.level === 2) { + lastH2 = h + } else if (lastH2) { + (lastH2.children || (lastH2.children = [])).push(h) + } + }) + return headers.filter(h => h.level === 2) +} + +export function resolveNavLinkItem (linkItem) { + return Object.assign(linkItem, { + type: linkItem.items && linkItem.items.length ? 'links' : 'link' + }) +} + +/** + * @param { Route } route + * @param { Array | Array | [link: string]: SidebarConfig } config + * @returns { base: string, config: SidebarConfig } + */ +export function resolveMatchingConfig (regularPath, config) { + if (Array.isArray(config)) { + return { + base: '/', + config: config + } + } + for (const base in config) { + if (ensureEndingSlash(regularPath).indexOf(encodeURI(base)) === 0) { + return { + base, + config: config[base] + } + } + } + return {} +} + +function ensureEndingSlash (path) { + return /(\.html|\/)$/.test(path) + ? path + : path + '/' +} + +function resolveItem (item, pages, base, groupDepth = 1) { + if (typeof item === 'string') { + return resolvePage(pages, item, base) + } else if (Array.isArray(item)) { + return Object.assign(resolvePage(pages, item[0], base), { + title: item[1] + }) + } else { + const children = item.children || [] + if (children.length === 0 && item.path) { + return Object.assign(resolvePage(pages, item.path, base), { + title: item.title + }) + } + return { + type: 'group', + path: item.path, + title: item.title, + sidebarDepth: item.sidebarDepth, + initialOpenGroupIndex: item.initialOpenGroupIndex, + children: children.map(child => resolveItem(child, pages, base, groupDepth + 1)), + collapsable: item.collapsable !== false + } + } +} diff --git a/docs/.vuepress/version-configs/1.5.x.js b/docs/.vuepress/version-configs/1.5.x.js new file mode 100644 index 00000000..467f27a2 --- /dev/null +++ b/docs/.vuepress/version-configs/1.5.x.js @@ -0,0 +1,101 @@ +/* set version */ +let version = '1.5.x'; + +/* version prefix setter */ +function setVersionPrefix(children) { + if (children.constructor === Array) { + return children.map(child => { + child[0] = `/${version}/${child[0]}`; + return child; + }); + } + return `/${version}/${children}`; +} + +/* module export */ +module.exports = [ + { + title: 'Prologue', + path: setVersionPrefix('prologue'), + collapsable: true, + children: setVersionPrefix([ + ['prologue/upgrade-guide', 'Upgrade Guide'], + ['prologue/contribution-guide', ' Contribution Guide'] + ]) + }, + { + title: 'Introduction', + path: setVersionPrefix('introduction'), + collapsable: true, + children: setVersionPrefix([ + ['introduction/requirements', 'Requirements'], + ['introduction/installation', 'Installation'], + ['introduction/docker', 'Docker'] + ]) + }, + { + title: 'Architecture concepts', + path: setVersionPrefix('architecture'), + collapsable: true, + children: setVersionPrefix([ + ['architecture/packages', 'Packages'], + ['architecture/frontend', 'Frontend'], + ['architecture/theme', 'Theme'], + ['architecture/performance', 'Performance'], + ['architecture/repository-pattern', 'Repository Pattern'], + ['architecture/modular-design', 'Modular Design'] + ]) + }, + { + title: 'Package Development', + path: setVersionPrefix('packages'), + collapsable: true, + children: setVersionPrefix([ + ['packages/create-package', 'Getting Started'], + ['packages/create-migrations', 'Migrations'], + ['packages/create-models', 'Models'], + ['packages/store-data-through-repositories', 'Repository'], + ['packages/routes', 'Routes'], + ['packages/controllers', 'Controllers'], + ['packages/views', 'Views'], + ['packages/localization', 'Localization'], + ['packages/layouts', 'Layouts'], + ['packages/assets', 'Assets'], + ['packages/add-menu-in-admin', 'Admin Menu'], + ['packages/customize-hompepage-menu.md', 'Homepage Menu'], + ['packages/validation', 'Validation'], + ['packages/datagrid', 'DataGrid'], + ['packages/create-acl', 'Access Control List'], + ['packages/create-custom-configuration', 'Custom Configuration'] + ]) + }, + { + title: 'Digging Deeper', + path: setVersionPrefix('advanced'), + collapsable: true, + children: setVersionPrefix([ + ['advanced/create-shipping-method', 'Shipping Method'], + ['advanced/create-payment-method', 'Payment Method'], + ['advanced/create-product-type', 'Product Type'], + ['advanced/events', 'Events Listeners'], + ['advanced/helpers', 'Helpers'], + ['advanced/override-core-model', 'Override Core Models'], + ['advanced/render-event', 'View Render Event'], + ['advanced/change-email-template.md', 'Email Template'], + ['advanced/indexing-products-to-elasticsearch.md', 'Configure Elasticsearch'], + ['advanced/security-practice', 'Best Security Practices'], + ]) + }, + { + title: 'Themes', + path: setVersionPrefix('themes'), + collapsable: true, + children: setVersionPrefix([ + ['themes/create-theme', 'Store Theme'], + ['themes/create-admin-theme', 'Admin Theme'], + ['themes/notification', 'Real Time Notification'], + ['themes/integrate-image-search-in-theme', 'Image Search'] + ]) + } + +] diff --git a/docs/.vuepress/version-configs/1.x.js b/docs/.vuepress/version-configs/1.x.js new file mode 100644 index 00000000..04d74b5b --- /dev/null +++ b/docs/.vuepress/version-configs/1.x.js @@ -0,0 +1,158 @@ +/* set version */ +let version = '1.x'; + +/* version prefix setter */ +function setVersionPrefix(children) { + if (children.constructor === Array) { + return children.map(child => { + child[0] = `/${version}/${child[0]}`; + return child; + }); + } + return `/${version}/${children}`; +} + +/* module export */ +module.exports = [ + { + title: 'Introduction', + path: setVersionPrefix('introduction'), + collapsable: true, + children: setVersionPrefix([ + ['introduction/requirements', 'Requirements'], + ['introduction/installation', 'Installation'], + ['introduction/upgrade-to-latest-bagisto', 'Upgrade Bagisto'], + ['introduction/docker', 'Docker'] + + ]) + }, + { + title: 'Package Development', + path: setVersionPrefix('packages'), + collapsable: true, + children: setVersionPrefix([ + ['packages/create-package', 'Create a new package'], + ['packages/create-migrations', 'Create migrations'], + ['packages/add-menu-in-admin', 'Add menu in admin'], + ['packages/create-acl', 'Access control list'], + ['packages/create-custom-configuration', 'Create custom configuration'], + ['packages/create-models', 'Create models'], + ['packages/store-data-through-repositories', 'Store data through repositories'], + ]) + }, + { + title: 'Advanced Topics', + path: setVersionPrefix('advanced'), + collapsable: true, + children: setVersionPrefix([ + ['advanced/create-shipping-method', 'Create a shipping method'], + ['advanced/create-payment-method', 'Create a payment method'], + ['advanced/create-product-type', 'Create your own product type'], + ['advanced/datagrid', 'DataGrid'], + ['advanced/events', 'Events'], + ['advanced/helpers', 'Helpers'], + ['advanced/override-core-model', 'Override core models'], + ['advanced/render-event', 'View render event'], + ['advanced/indexing-products-to-elasticsearch.md', 'Indexing products to Elasticsearch'], + ['advanced/security-practice', 'Best Security Practices'], + ]) + }, + { + title: 'Themes', + path: setVersionPrefix('themes'), + collapsable: true, + children: setVersionPrefix([ + ['themes/tracer', 'Blade file tracer'], + ['themes/create-theme', 'Create a store theme'], + ['themes/create-admin-theme', 'Create an admin theme'], + ['themes/change-email-template.md', 'Change email template'], + ['themes/customize-hompepage-menu.md', 'Customize homepage menu'], + ['themes/integrate-image-search-in-theme', 'Integrate image search in theme'] + ]) + },{ + title: 'Admin Theme', + path: setVersionPrefix('admin-theme'), + collapsable: true, + children: setVersionPrefix([ + ['admin-theme/notification', 'Enable real time notification'], + ]) + },{ + title: 'Translations', + path: setVersionPrefix('translations/translation-based-on-locale'), + collapsable: true, + children: setVersionPrefix([ + ['translations/translation-based-on-locale', 'Translation based on locale'], + ['translations/change-the-language-of-error-validations-on-your-store', 'Change the language of error validations on your store'] + ]) + }, + { + title: 'User Guides', + path: setVersionPrefix('user-guides'), + collapsable: true, + children: setVersionPrefix([ + ['user-guides/tax-rates', 'Tax Rates'], + ['user-guides/cart-rule', 'Cart rules'], + ['user-guides/social-auth', 'Social Authentication'] + ]) + }, + { + title: 'Bagisto Web API', + path: setVersionPrefix('api'), + collapsable: true, + children: setVersionPrefix([ + ['api/getting-started-with-the-api', 'Authentication'], + ['api/customers', 'Customers'], + ['api/locales', 'Locales'], + ['api/addresses', 'Addresses'], + ['api/products', 'Products'], + ['api/categories', 'Categories'], + ['api/attributes', 'Attributes'], + ['api/attribute-families', 'Attribute Families'], + ['api/cart', 'Shopping Cart'], + ['api/orders', 'Orders'], + ['api/invoices', 'Invoices'], + ['api/shipments', 'Shipments'], + ['api/transactions', 'Transactions'], + ['api/reviews', 'Reviews'], + ['api/wishlists', 'Wishlists'], + ]) + }, + { + title: 'Bagisto GraphQL Admin API', + path: setVersionPrefix('graphql-admin-api'), + collapsable: true, + children: setVersionPrefix([ + ['graphql-admin-api/installation', 'Installation'], + ['graphql-admin-api/getting-started-with-the-api.md', 'Authentication'], + ['graphql-admin-api/settings.md', 'Settings'], + ['graphql-admin-api/cms.md', 'CMS'], + ['graphql-admin-api/velocity.md', 'Velocity'], + ['graphql-admin-api/customers.md', 'Customers'], + ['graphql-admin-api/promotions.md', 'Promotions'], + ['graphql-admin-api/products.md', 'Products'], + ['graphql-admin-api/categories.md', 'Categories'], + ['graphql-admin-api/attributes.md', 'Attributes'], + ['graphql-admin-api/attribute-groups.md', 'Attribute Groups'], + ['graphql-admin-api/attribute-families.md', 'Attribute Families'], + ['graphql-admin-api/sales.md', 'Sales'], + ]) + }, + { + title: 'Bagisto GraphQL Shop API', + path: setVersionPrefix('graphql-shop-api'), + collapsable: true, + children: setVersionPrefix([ + ['graphql-admin-api/installation', 'Installation'], + ['graphql-shop-api/getting-started-with-the-api.md', 'Authentication'], + ['graphql-shop-api/addresses.md', 'Addresses'], + ['graphql-shop-api/orders.md', 'Orders'], + ['graphql-shop-api/reviews.md', 'Reviews'], + ['graphql-shop-api/wishlists.md', 'Wishlists'], + ['graphql-shop-api/compare.md', 'Compare'], + ['graphql-shop-api/downloadable-links.md', 'Downloadable Links'], + ['graphql-shop-api/cart.md', 'Cart'], + ['graphql-shop-api/checkout.md', 'Checkout Process'], + ['graphql-shop-api/homepage.md', 'Home Page'], + ]) + }, +] \ No newline at end of file diff --git a/docs/.vuepress/version-configs/2.x.js b/docs/.vuepress/version-configs/2.x.js new file mode 100644 index 00000000..0431f038 --- /dev/null +++ b/docs/.vuepress/version-configs/2.x.js @@ -0,0 +1,30 @@ +/* set version */ +let version = '2.x'; + +/* version prefix setter */ +function setVersionPrefix(children) { + if (children.constructor === Array) { + return children.map(child => { + child[0] = `/${version}/${child[0]}`; + return child; + }); + } + return `/${version}/${children}`; +} + +/* module export */ +module.exports = [ + { + title: 'Product Types', + path: setVersionPrefix('products'), + collapsable: true, + children: setVersionPrefix([ + ['products/simple', 'Simple Product'], + ['products/configurable', 'Configurable Product'], + ['products/virtual', 'Virtual Product'], + ['products/bundle', 'Bundle Product'], + ['products/grouped', 'Grouped Product'], + ['products/downloadable', 'Downloadable Product'], + ]) + } +] diff --git a/docs/1.5.x/advanced/README.md b/docs/1.5.x/advanced/README.md new file mode 100644 index 00000000..d25989dd --- /dev/null +++ b/docs/1.5.x/advanced/README.md @@ -0,0 +1,33 @@ +# Digging Deeper + +Welcome to the "Digging Deeper" section of the Bagisto documentation. Here, we will explore various advanced topics related to Bagisto, which will enable you to customize and extend your e-commerce platform to suit your specific needs. + +We expect you to have knowledge of creating packages in Laravel. If you are new to package development, we recommend referring to the [Package Development](../packages/create-package.html) section for a primer on creating and managing packages in Laravel. + +### Creating Payment Methods + +Bagisto provides a flexible and configurable system for integrating different payment methods into your e-commerce store. We will guide you through the process of setting up and configuring payment methods, allowing you to offer a variety of options to your customers while ensuring a seamless and secure checkout experience. + +### Product Types + +Bagisto supports different types of products, allowing you to showcase and sell a wide range of items. We will delve into the details of configuring and managing product types, giving you the ability to define specific attributes and behaviors for each product category. + +### Shipping Methods + +Efficient and reliable shipping is crucial for any e-commerce business. Bagisto offers robust features for managing shipping methods, enabling you to define various shipping options, rates, and rules based on factors such as location, weight, or order value. We will explain how to configure and customize shipping methods to streamline your order fulfillment process. + +### Events and Event Handlers + +Events and event handlers provide a powerful way to extend the functionality of Bagisto by allowing you to react to specific actions or triggers within the application. We will show you how to utilize events and event handlers effectively, enabling you to integrate custom functionalities and automate processes. + +### Helpers + +Bagisto includes a comprehensive set of helper functions that simplify common development tasks and enhance productivity. We will explore the various helper functions available, explaining their purpose and usage to assist you in writing clean and efficient code. + +### Indexing through Elastic + +To optimize search performance, Bagisto integrates with Elasticsearch, a highly scalable search engine. We will guide you through the process of indexing your data using Elastic, improving the search functionality of your e-commerce store and providing a seamless search experience for your customers. + +### Overriding Core Models + +Sometimes, you may need to modify or extend the default behavior of Bagisto's core models to accommodate your specific business requirements. We will demonstrate how to override core models effectively, enabling you to customize the behavior of Bagisto without modifying the underlying codebase. \ No newline at end of file diff --git a/docs/1.5.x/advanced/change-email-template.md b/docs/1.5.x/advanced/change-email-template.md new file mode 100644 index 00000000..2dd7d406 --- /dev/null +++ b/docs/1.5.x/advanced/change-email-template.md @@ -0,0 +1,106 @@ +# Email Template + +[[TOC]] + +## Introduction + +In this section, we will explain how to customize the email templates in Bagisto. Customizing email templates allows you to personalize the appearance of your emails according to your preferences. + +## Email Template Flow + +Before we dive into template customization, let's understand how email templates work in Bagisto. + +Bagisto provides various mail notification classes, such as **`CancelOrderAdminNotification`** and **`NewCustomerNotification`**, located in the **`Webkul\Admin\Mail`** namespace. Let's take the **`CancelOrderAdminNotification`** class as an example. + +```php +order = $order; + } + + /** + * Build. + * + * @return void + */ + public function build() + { + return $this->from(core()->getSenderEmailDetails()['email'], core()->getSenderEmailDetails()['name']) + ->to(core()->getAdminEmailDetails()['email']) + ->subject(trans('shop::app.mail.order.cancel.subject')) + ->view('shop::emails.sales.order-cancel-admin'); + } +} +``` + +In the **`build()`** method of the above class, you can see that the main view file, **`view('shop::emails.sales.order-cancel-admin')`**, is loaded from the shop package. + +Now, let's explore the view file mentioned in **`view('shop::emails.sales.order-cancel-admin')`**. If you check the file at the path **`packages/Webkul/Shop/src/Resources/views/emails/sales/order-cancel-admin.blade.php`**, you will find it. This view file uses the main layout component **`shop::emails.layouts.master`**. + +```php +@component('shop::emails.layouts.master') + ... +@endcomponent +``` + +This layout component is responsible for the overall email layout. If desired, you can explore this file as well. Now, let's proceed to learn how to change these email templates. + +## Changing Email Template + +To customize the email template, the recommended approach is to override the package's view. Since all email views are defined in the shop package, we need to override the view within the shop package. + +Here's how you can override the view for the same file we mentioned above, **`view('shop::emails.sales.order-cancel-admin')`**. + +Bagisto registers two locations for views: the application's **`resources/themes`** directory specified in **`config/themes.php`**, and the directory you specify. If you are using the default theme, **`shop`** package, Bagisto will first check if a custom version of the view exists in the **`resources/themes/default`** directory. If the view has not been customized, Bagisto will then search the package's view directory. + +To override the view, create the same directory structure in the application's **`resources/themes/default`** directory: + +``` +- resources/ + └── themes/ + └── default/ + └── views/ + └── emails/ + └── sales/ + └── order-cancel-admin.blade.php +``` + +For example, create a file named **`order-cancel-admin.blade.php`** within the **`sales`** directory, and modify its content as desired: + +```blade + + Lorem ipsum dolor sit amet consectetur adipisicing elit. Laborum porro cumque numquam neque dicta quo, accusantium, perferendis sed beatae nesc + + iunt eum impedit vel doloribus dolor excepturi vero tenetur perspiciatis saepe? +``` + +Now you can test the modified email template. + +## Email Template Sample + +![Email Template Sample](../../assets/1.5.x/images/advanced-topics/mail-sample.png) \ No newline at end of file diff --git a/docs/1.5.x/advanced/create-payment-method.md b/docs/1.5.x/advanced/create-payment-method.md new file mode 100644 index 00000000..822333b1 --- /dev/null +++ b/docs/1.5.x/advanced/create-payment-method.md @@ -0,0 +1,220 @@ +# Payment Method + +[[TOC]] + +## Introduction + +Bagisto eases the task of creating payment methods, making it simple for both novice and professional developers. + +The diversity of payment methods provides customers with various options for payment when they proceed to checkout. Moreover, offering multiple payment methods is a great strategy to reach out to the global marketplace. + +## Using Bagisto Package Generator + +To create a payment method package, follow these commands in the Bagisto root directory: + +- If the package directory is not present: + + ```sh + php artisan package:make-payment-method Webkul/Blog + ``` + +- If the package directory is already present, you can use the force command to overwrite it. Simply add the **`--force`** flag: + + ```sh + php artisan package:make-payment-method Webkul/Blog --force + ``` + + These commands will generate the entire directory structure automatically, saving you from manual setup. + +## Manually Setting Up All Files + +1. To create your payment method, follow these steps to set up the respective directory structure: + + ``` + - Webkul/ + └── Blog/ + └── src/ + ├── ... + ├── Config/ + │ ├── system.php + │ └── paymentmethods.php + ├── Payment/ + │ └── Stripe.php + └── Providers/ + └── StripeServiceProvider.php + ``` + +2. The **`Config`** folder contains application configuration files. Create two files, **`system.php`** and **`paymentmethods.php`**, within the **`Config`** folder. In the **`system.php`** file, include the following array keys: + + ```php + 'sales.paymentmethods.stripe', + 'name' => 'Stripe', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'title', + 'title' => 'admin::app.admin.system.title', + 'type' => 'text', + 'validation' => 'required', + 'channel_based' => false, + 'locale_based' => true, + ], [ + 'name' => 'description', + 'title' => 'admin::app.admin.system.description', + 'type' => 'textarea', + 'channel_based' => false, + 'locale_based' => true, + ], [ + 'name' => 'active', + 'title' => 'admin::app.admin.system.status', + 'type' => 'boolean', + 'validation' => 'required', + 'channel_based' => false, + 'locale_based' => true, + ] + ] + ] + ]; + ``` + - **`key`**: A unique value for the configuration, concatenated with a dot (`.`) operator. + - **`name`**: The placeholder value for the configuration. It is recommended to use translations in Bagisto. + - **`sort`**: The position of the configuration menu. + - **`fields`**: An array containing the custom configurations and fields for the payment method. The example includes three arrays for **`title`**, **`description`**, and **`status`**. You can add more arrays for additional settings. + +3. In the **`paymentmethods.php`** file, add the following content: + + ```php + [ + 'code' => 'stripe', + 'title' => 'Stripe', + 'description' => 'Stripe', + 'class' => 'Webkul\Blog\Payment\Stripe', + 'active' => true, + 'sort' => 1, + ], + ]; + ``` + - **`code`**: A text representing the payment method. + - **`title`**: The name of the payment method. + - **`description`**: A brief description of the payment method. + - **`class`**: The namespace of the class where the payment method functions are defined. + - **`active`**: A boolean value (`true` or `false`) to enable or disable the module. + - **`sort`**: The position of the payment method. + +4. In the **`Stripe.php`** file within the **`Payment`** directory, add the following code: + + ```php + registerConfig(); + } + + /** + * Register package config. + * + * @return void + */ + protected function registerConfig() + { + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/paymentmethods.php', 'paymentmethods' + ); + + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/system.php', 'core' + ); + } + } + ``` + +2. Next, add your payment method namespace to the **`psr-4`** key in the **`composer.json`** file located in the Bagisto root directory: + + ```json + "autoload": { + ... + "psr-4": { + // Other PSR-4 namespaces + "Webkul\\Blog\\": "packages/Webkul/Blog/src" + } + } + ``` + +3. Register your service provider in the **`config/app.php`** file, also located in the Bagisto root directory: + + ```php + ServiceProvider::defaultProviders()->merge([ + // Other service providers + Webkul\Blog\Providers\StripeServiceProvider::class, + ])->toArray(), + + // Other configuration options + ]; + ``` + +4. After making these changes, run the following commands: + + ```sh + composer dump-autoload + ``` + + ```sh + php artisan config:cache + ``` + + If you encounter any issues with **`composer dump-autoload`**, delete all files from the **`bootstrap/cache`** directory and run **`composer dump-autoload`** again. \ No newline at end of file diff --git a/docs/1.5.x/advanced/create-product-type.md b/docs/1.5.x/advanced/create-product-type.md new file mode 100644 index 00000000..d6372ccc --- /dev/null +++ b/docs/1.5.x/advanced/create-product-type.md @@ -0,0 +1,80 @@ +# Product Type + +[[TOC]] + +## Introduction + +Bagisto provides several default product types, including simple, configurable, virtual, grouped, downloadable, bundled, and bookings. However, if these default product types do not meet your requirements, you can create your own custom product types. + +## Creating a New Product Type + +To create a new product type in Bagisto, follow these steps: + +**Note**: In this example, we will create a new product type called "coupon". + +1. Create your own package. If you need assistance with package development, you can refer to the [Package Development](../packages) section. + +2. Inside the **Config** folder of your package, create a file named **`product_types.php`**. + +3. Add the following code to the **`product_types.php`** file. This code will define the new product type and its properties: + + ```php + [ + 'key' => 'coupon', + 'name' => 'Coupon', + 'class' => 'Webkul\Blog\Type\Coupon', + 'sort' => 7 + ], + ]; + ``` + +### Merging the Configuration + +4. To merge the **`Config/product_types.php`** with the core product types configuration, use the **`mergeConfigFrom()`** method in the **`register()`** method of your service provider. For example, in the **`CouponServiceProvider.php`** file: + + ```php + mergeConfigFrom( + dirname(__DIR__) . '/Config/product_types.php', 'product_types' + ); + } + } + ``` + +5. In the code snippet above, notice the **`class`** key mentioned in step 3. This key specifies the class that loads the coupon product type. Create a file named **`Coupon.php`** within your package under the **`src/Type`** folder, and add the following code: + + ```php + [ + 'code' => 'blog', + 'title' => 'Blog', + 'description' => 'Blog', + 'active' => true, + 'default_rate' => '10', + 'type' => 'per_unit', + 'class' => 'Webkul\Blog\Carriers\Blog', + ] + ]; + ``` + + - **code**: A unique value used to refer to the particular shipping method. + - **title**: The label or name displayed in the user interface. + - **description**: Information about your shipping method. + - **active**: Enable or disable option for the shipping method. + - **default_rate**: The default rate value. + - **type**: Specifies whether the shipping method applies per unit or per order. + - **class**: The path and filename of the shipping method class (**`namespace\package-name\Carriers-folder\filename`**). + +3. Create a **`Carriers`** folder inside the **`src`** folder. Then, create a **`Blog.php`** file inside the **`Carriers`** folder. + + ``` + - Webkul + └── Blog/ + └── src/ + ├── ... + ├── Carriers/ + │ └── Blog.php + └── Config/ + ├── ... + └── carriers.php + + ``` + +4. Copy the following code into the **`Blog.php`** file: + + ```php + isAvailable()) { + return false; + } + + $object = new CartShippingRate; + + $object->carrier = 'blog'; + $object->carrier_title = $this->getConfigData('title'); + $object->method = 'blog_blog'; + $object->method_title = $this->getConfigData('title'); + $object->method_description = $this->getConfigData('description'); + $object->price = 0; + $object->base_price = 0; + + if ($this->getConfigData('type') == 'per_unit') { + foreach ($cart->items as $item) { + if ( + $this->getConfigData('base_amount') && + $this->getConfigData('base_amount') > ($item->product->price) + ) { + continue; + } + if ($item->product->getTypeInstance()->isStockable()) { + $object->price += core()->convertPrice($this->getConfigData('default_rate')) * $item->quantity; + $object->base_price += $this->getConfigData('default_rate') * $item->quantity; + } + } + } else { + if ( + $this->getConfigData('base_amount') && + $this->getConfigData('base_amount') > ($cart->sub_total) + ) { + return false; + } + $object->price = core()->convertPrice($this->getConfigData('default_rate')); + $object->base_price = $this->getConfigData('default_rate'); + } + + return $object; + } + } + ``` + + The **`Blog.php`** file extends the **`AbstractShipping`** class defined at **`Webkul\Shipping\Carriers\AbstractShipping`**. In this file, you can write all the operations needed for your shipping method. To render the shipping methods in the checkout process, define the **`calculate()`** method within the **`Blog.php`** file and return the shipping rate, title, and description within a **`CartShippingRate`** object. + +5. After creating all the necessary files and configurations, create a form that will appear in the configuration section. Create a **`system.php`** file in the **`src/Config`** path and add the following code to it: + + ```php + 'sales.carriers.blog', + 'name' => 'admin::app.admin.system.blog-shipping', + 'sort' => 2, + 'fields' => [ + [ + 'name' => 'title', + 'title' => 'admin::app.admin.system.title', + 'type' => 'depends', + 'depend' => 'active:1', + 'validation' => 'required_if:active,1', + 'channel_based' => true, + 'locale_based' => true + ], [ + 'name' => 'description', + 'title' => 'admin::app.admin.system.description', + 'type' => 'textarea', + 'channel_based' => true, + 'locale_based' => false + ], [ + 'name' => 'default_rate', + 'title' => 'admin::app.admin.system.rate', + 'type' => 'depends', + 'depend' => 'active:1', + 'validation' => 'required_if:active,1', + 'channel_based' => true, + 'locale_based' => false + ], [ + 'name' => 'base_amount', + 'title' => 'admin::app.admin.system.minimum-amount', + 'type' => 'text', + 'channel_based' => true, + 'locale_based' => false + ], [ + 'name' => 'type', + 'title' => 'admin::app.admin.system.type', + 'type' => 'select', + 'options' => [ + [ + 'title' => 'Per Unit', + 'value' => 'per_unit', + ], [ + 'title' => 'Per Order', + 'value' => 'per_order', + ], + ], + 'channel_based' => true, + 'locale_based' => false, + ], [ + 'name' => 'active', + 'title' => 'admin::app.admin.system.status', + 'type' => 'boolean', + 'validation' => 'required', + 'channel_based' => true, + 'locale_based' => false + ] + ] + ] + ``` + +## Merge Configuration + +1. To merge all your configurations, modify the **`packages/Webkul/Blog/src/Providers/BlogServiceProvider.php`** file as follows: + + ```php + mergeConfigFrom( + dirname(__DIR__) . '/Config/carriers.php', 'carriers' + ); + + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/system.php', 'core' + ); + } + } + ``` + +2. Add the namespace for your shipment method in the **`psr-4`** key of the **`composer.json`** file in the Bagisto root directory: + + ```json + "autoload": { + ... + "psr-4": { + // Other PSR-4 namespaces + "Webkul\\Blog\\": "packages/Webkul/Blog/src" + } + } + ``` + +3. Register your service provider in the **`config/app.php`** file located in the Bagisto root directory: + + ```php + ServiceProvider::defaultProviders()->merge([ + // Other service providers + Webkul\Blog\Providers\BlogServiceProvider::class, + ])->toArray(), + + // Other configuration options + ]; + ``` + +4. After making these changes, run the following commands: + + ```sh + composer dump-autoload + php artisan config:cache + ``` + + If you encounter an error with the **`composer dump-autoload`** command, try deleting all files in the **`bootstrap/cache`** directory and then running the command again. \ No newline at end of file diff --git a/docs/1.5.x/advanced/events.md b/docs/1.5.x/advanced/events.md new file mode 100644 index 00000000..bcd0332c --- /dev/null +++ b/docs/1.5.x/advanced/events.md @@ -0,0 +1,238 @@ +# Event Listeners + +[[TOC]] + +## Introduction + +Event Listeners in Bagisto are a way to implement the observer pattern, where listeners respond to events that occur in the application. Events can be thought of as announcements made by the application, and listeners are the actions taken in response to those announcements. All event classes in Bagisto are stored in the **Providers** folder, and the listeners are stored in the **Listeners** folder. + +## Creating an Event Class + +If you have the Bagisto Package Generator installed, you can use the following command to create a new event class in the **`packages/Webkul/Blog/src/Events`** directory: + +```sh +php artisan package:make-event BlogEvent Webkul/Blog +``` + +If the event class already exists, you can use the **`--force`** option to overwrite it: + +```sh +php artisan package:make-event BlogEvent Webkul/Blog --force +``` + +Alternatively, if you don't have the package generator, you can create the file manually. + +## Manually Registering Events + +In Bagisto, events are manually registered in the **`boot`** method of your **`EventServiceProvider.php`** file. Here is an example of how to register events: + +```php +/** + * Register any other events for your application. + * + * @return void + */ +public function boot() +{ + //... + + parent::boot(); + + Event::listen('event.name', 'path-upto-listener@function'); +} +``` + +## Manually Registering Listeners + +When registering events, you specify the listener function to be executed when an event is called. Here is an example of how to register a listener: + +```php +class EventServiceProvider extends ServiceProvider +{ + /** + * Bootstrap services. + * + * @return void + */ + public function boot() + { + //... + + Event::listen('checkout.order.save.after', 'Webkul\Admin\Listeners\Order@sendNewOrderMail'); + } +} +``` + +## Specifying Events + +In most CRUD operations, events are fired before and after the execution of a function. This allows listeners to perform additional operations before or after certain actions, such as product creation, update, or deletion. + +## Events Fired in Bagisto + +- Events fired in bagisto but not listened such that if any user wants to perform any action on event fire, then they may create listener file and perform the respective operation. + + | Events name | Functionality| + | ------------------------------- | ------------- | + |core.configuration.save.after|This event will be fired after core configuration form data gets saved, then you may create a listener file and perform the respective operation when that event fires | + |core.configuration.save.after|This event will be fired after core configuration form data gets saved, then you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.item.add.before |This event will be fired before saving into the database of item added in checkout and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.item.add.after|This event will be fired after saving into the database of item added in checkout and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.item.update.before|This event will be fired before updating the database item of checkout table of respective passed **`id`** and you may create a listener file and perform the respective operation when that event fires | + |checkout.cart.item.update.after|This event will be fired after updating the database item of checkout table of respective passed **`id`** and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.delete.before|This event will be fired before deleting the database item of checkout table of respective passed **`id`** and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.delete.after|This event will be fired after deleting the database item of checkout table of respective passed **`id`** and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.item.delete.before|This event will be fired before deleting the database item of checkout table of respective passed **`id`** and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.item.delete.after|This event will be fired after deleting the database item of checkout table of respective passed **`id`** and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.item.move-to-wishlist.before|This event will be fired before adding cart item to wishlist added in checkout and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.item.move-to-wishlist.after|This event will be fired after adding cart item to wishlist added in checkout and you may create a listener file and perform the respective operation when that event fires| + |customer.registration.before|This event will be fired before registration of customer details and you may create a listener file and perform the respective operation when that event fires| + |customer.registration.after|This event will be fired after registration of customer details and you may create a listener file and perform the respective operation when that event fires| + |customer.after.login|This event will be fired after login of customer and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute_family.create.before|This event will be fired before attribute family gets created and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute_family.create.after|This event will be fired after attribute family gets created and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute_family.update.before|This event will be fired before updating attribute family and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute_family.update.after|This event will be fired after updating attribute family and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute_family.delete.before|This event will be fired before deleting attribute family and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute_family.delete.after|This event will be fired after deleting attribute family and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute.create.before|This event will be fired before attribute gets created and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute.create.after|This event will be fired after attribute gets created and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute.update.before|This event will be fired before attribute gets updated and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute.update.after|This event will be fired after attribute gets updated and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute.delete.before|This event will be fired before attribute gets deleted and you may create a listener file and perform the respective operation when that event fires| + |catalog.attribute.delete.after|This event will be fired after attribute gets deleted and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.delete.after|This event will be fired after deleting category and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.delete.before|This event will be fired before deleting category with mass selection and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.delete.after|This event will be fired after deleting category with mass selection and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.create.before|This event will be fired before creating category and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.create.after|This event will be fired after creating category and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.update.before|This event will be fired before updating category and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.update.after|This event will be fired after updating category and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.delete.before|This event will be fired before deleting category and you may create a listener file and perform the respective operation when that event fires| + |catalog.category.delete.after|This event will be fired after deleting category and you may create a listener file and perform the respective operation when that event fires| + |core.channel.create.before|This event will be fired before channel gets created and you may create a listener file and perform the respective operation when that event fires| + |core.channel.create.after|This event will be fired after channel gets created and you may create a listener file and perform the respective operation when that event fires| + |core.channel.update.before|This event will be fired before channel gets updated and you may create a listener file and perform the respective operation when that event fires| + |core.channel.update.after|This event will be fired after channel gets updated and you may create a listener file and perform the respective operation when that event fires| + |core.channel.delete.before|This event will be fired before channel gets deleted and you may create a listener file and perform the respective operation when that event fires| + |core.channel.delete.after|This event will be fired after channel gets deleted and you may create a listener file and perform the respective operation when that event fires| + |core.currency.create.before|This event will be fired before currency gets created and you may create a listener file and perform the respective operation when that event fires| + |core.currency.create.after|This event will be fired after currency gets created and you may create a listener file and perform the respective operation when that event fires| + |core.currency.update.before|This event will be fired before currency gets updated and you may create a listener file and perform the respective operation when that event fires| + |core.currency.update.after|This event will be fired after currency gets updated and you may create a listener file and perform the respective operation when that event fires| + |core.currency.delete.before|This event will be fired before currency gets deleted and you may create a listener file and perform the respective operation when that event fires| + |core.currency.delete.after|This event will be fired after currency gets deleted and you may create a listener file and perform the respective operation when that event fires| + |core.currency.delete.before|This event will be fired before currency gets deleted with mass selection and you may create a listener file and perform the respective operation when that event fires| + |core.currency.delete.after|This event will be fired after currency gets deleted with mass selection and you may create a listener file and perform the respective operation when that event fires| + |core.exchange_rate.create.before|This event will be fired before exchange rate gets created and you may create a listener file and perform the respective operation when that event fires| + |core.exchange_rate.create.after|This event will be fired after exchange rate gets created and you may create a listener file and perform the respective operation when that event fires| + |core.exchange_rate.update.before |This event will be fired before exchange rate gets updated and you may create a listener file and perform the respective operation when that event fires| + |core.exchange_rate.update.after|This event will be fired after exchange rate gets updated and you may create a listener file and perform the respective operation when that event fires| + |core.exchange_rate.delete.before|This event will be fired before exchange rate gets deleted and you may create a listener file and perform the respective operation when that event fires| + |core.exchange_rate.delete.after|This event will be fired after exchange rate gets deleted and you may create a listener file and perform the respective operation when that event fires| + |core.locale.create.before|This event will be fired before locale gets created and you may create a listener file and perform the respective operation when that event fires| + |core.locale.create.after|This event will be fired after locale gets created and you may create a listener file and perform the respective operation when that event fires| + |core.locale.update.before|This event will be fired before locale gets updated and you may create a listener file and perform the respective operation when that event fires| + |core.locale.update.after|This event will be fired after locale gets updated and you may create a listener file and perform the respective operation when that event fires| + |core.locale.delete.before|This event will be fired before locale gets deleted and you may create a listener file and perform the respective operation when that event fires| + |core.locale.delete.after|This event will be fired after locale gets deleted and you may create a listener file and perform the respective operation when that event fires| + |customer.registration.before|This event will be fired before customer gets registered and you may create a listener file and perform the respective operation when that event fires| + |customer.registration.after|This event will be fired after customer gets registered and you may create a listener file and perform the respective operation when that event fires| + |customer.after.login|This event will be fired after customer successfully logins in store and you may create a listener file and perform the respective operation when that event fires| + |customer.after.logout|This event will be fired after customer successfully logouts from store and you may create a listener file and perform the respective operation when that event fires| + |inventory.inventory_source.create.before|This event will be fired before inventory source gets created and you may create a listener file and perform the respective operation when that event fires| + |inventory.inventory_source.create.after|This event will be fired after inventory source gets created and you may create a listener file and perform the respective operation when that event fires| + |inventory.inventory_source.update.before|This event will be fired before inventory source gets updated and you may create a listener file and perform the respective operation when that event fires| + |inventory.inventory_source.update.after|This event will be fired after inventory source gets updated and you may create a listener file and perform the respective operation when that event fires| + |inventory.inventory_source.delete.before|This event will be fired before inventory source gets deleted and you may create a listener file and perform the respective operation when that event fires| + |inventory.inventory_source.delete.after|This event will be fired after inventory source gets deleted and you may create a listener file and perform the respective operation when that event fires| + |customer.review.update.before|This event will be fired before customer review gets updated and you may create a listener file and perform the respective operation when that event fires| + |customer.review.update.after|This event will be fired after customer review gets updated and you may create a listener file and perform the respective operation when that event fires| + |customer.review.delete.before|This event will be fired before customer review gets deleted and you may create a listener file and perform the respective operation when that event fires| + |customer.review.delete.after|This event will be fired after customer review gets deleted and you may create a listener file and perform the respective operation when that event fires| + |customer.review.delete.before|This event will be fired before customer review gets deleted with mass selection and you may create a listener file and perform the respective operation when that event fires| + |customer.review.delete.after|This event will be fired after customer review gets deleted with mass selection and you may create a listener file and perform the respective operation when that event fires| + |customer.review.update.before|This event will be fired before customer review gets updated with mass selection and you may create a listener file and perform the respective operation when that event fires| + |customer.review.update.after|This event will be fired after customer review gets updated with mass selection and you may create a listener file and perform the respective operation when that event fires| + |catalog.product.create.before|This event will be fired before product gets created and you may create a listener file and perform the respective operation when that event fires| + |catalog.product.create.after|This event will be fired after product gets created and you may create a listener file and perform the respective operation when that event fires| + |catalog.product.update.before|This event will be fired before product gets updated and you may create a listener file and perform the respective operation when that event fires| + |catalog.product.update.after|This event will be fired after product gets updated and you may create a listener file and perform the respective operation when that event fires| + |catalog.product.delete.before|This event will be fired before product gets deleted and you may create a listener file and perform the respective operation when that event fires| + |catalog.product.delete.after|This event will be fired after product gets deleted and you may create a listener file and perform the respective operation when that event fires| + |sales.invoice.save.before|This event will be fired before invoice gets created and you may create a listener file and perform the respective operation when that event fires| + |sales.invoice.save.after|This event will be fired after invoice gets created and you may create a listener file and perform the respective operation when that event fires| + |checkout.order.save.before|This event will be fired before order gets created and you may create a listener file and perform the respective operation when that event fires| + |checkout.order.save.after|This event will be fired after order gets created and you may create a listener file and perform the respective operation when that event fires| + |sales.order.cancel.before|This event will be fired before order gets cancelled and you may create a listener file and perform the respective operation when that event fires| + |sales.order.cancel.after|This event will be fired after order gets cancelled and you may create a listener file and perform the respective operation when that event fires| + |catalog.product.update.after|This event will be fired after product gets updated and you may create a listener file and perform the respective operation when that event fires| + |sales.shipment.save.before|This event will be fired before shipment for product gets created and you may create a listener file and perform the respective operation when that event fires| + |sales.shipment.save.after|This event will be fired after shipment for product gets created and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.add.before|This event will be fired before product get added in cart and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.add.after|This event will be fired after product get added in cart and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.delete.before|This event will be fired before product get deleted from cart and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.delete.after|This event will be fired after product get deleted from cart and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.update.before|This event will be fired before cart item get updated and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.update.after|This event will be fired after cart item get updated and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.add.before|This event will be fired before configurable product get added in cart and you may create a listener file and perform the respective operation when that event fires| + |checkout.cart.add.after|This event will be fired after configurable product get added in cart and proceeded to but the product and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_category.create.before|This event will be fired before tax category gets created and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_category.create.after|This event will be fired after tax category gets created and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_category.update.before|This event will be fired before tax category gets updated and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_category.update.after|This event will be fired after tax category gets updated and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_category.delete.before|This event will be fired before tax category gets deleted and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_category.delete.after|This event will be fired after tax category gets deleted and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_rate.create.before|This event will be fired before tax rate gets created and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_rate.create.after|This event will be fired after tax rate gets created and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_rate.update.before|This event will be fired before tax rate gets updated and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_rate.update.after|This event will be fired after tax rate gets updated and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_rate.delete.before|This event will be fired before tax rate gets deleted and you may create a listener file and perform the respective operation when that event fires| + |tax.tax_rate.delete.after|This event will be fired after tax rate gets deleted and you may create a listener file and perform the respective operation when that event fires| + |user.role.create.before|This event will be fired before user role gets created. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.role.create.after|This event will be fired after user role gets created. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.role.update.before|This event will be fired before user role gets updated. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.role.update.after|This event will be fired after user role gets updated. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.role.delete.before|This event will be fired before user role gets updated. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.role.delete.after|This event will be fired after user role gets deleted. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.admin.create.before|This event will be fired before user gets created. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.admin.delete.after|This event will be fired after user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.admin.update.before|This event will be fired before user gets updated. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.admin.update.after|This event will be fired after user gets updated. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.admin.delete.before|This event will be fired before user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.admin.delete.after|This event will be fired after user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.admin.delete.before|This event will be fired before user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + |user.admin.delete.after|This event will be fired after user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + +## Events Listen in Bagisto + +- Event listen in bagisto is given below with their functionality. + + | Events name | functionality | + | ------------------------------- | ------------- | + | checkout.order.save.after | This event will be fired after order creation and listen in **`ProductFlat`** listener file to send new order mail from **`sendNewOrderMail`** function | + | sales.invoice.save.after | This event will be fired after invoice details have been saved and listen in **`ProductFlat`** listener file to send new invoice mail from **`sendNewInvoiceMail`** function | + | sales.shipment.save.after | This event will be fired after shipment details have been saved and listen in **`ProductFlat`** listener file to send new shipment mail from **`sendNewShipmentMail`** function | + | checkout.order.save.after | This event will be fired after order has been created and will listen in **`ProductFlat`** listener file to update product inventory from **`updateProductInventory`** function | + | catalog.attribute.create.after | This event will be fired after attribute has been created and listen in **`ProductFlat`** listener file from **`afterAttributeCreatedUpdated`** function | + | catalog.attribute.update.after | This event will be fired after attribute has updated and listen in **`ProductFlat`** listener file from **`afterAttributeCreatedUpdated`** function | + | catalog.attribute.delete.before | This event will be fired before attribute has been delete and listen in **`ProductFlat`** listener file from **`afterAttributeDeleted`** function | + | catalog.product.create.after | This event will be fired after product has been creation and listen in **`ProductFlat`** listener file from **`afterProductCreatedUpdated`** function | + | catalog.product.update.after | This event will be fired after product has been updated and listen in **`ProductFlat`** listener file from **`afterProductCreatedUpdated`** function | + +## Listening to Existing Events + +To listen to an existing event in Bagisto, you can follow these steps: + +1. Open the **`EventServiceProvider.php`** file located in the **`Providers`** folder. + +2. Inside the **`boot`** method, you can register your listener by calling the **`Event::listen`** method and providing the event name and the listener function. + + ```php + Event::listen('checkout.order.save.after', 'Webkul\Admin\Listeners\Order@sendNewOrderMail'); + ``` + + In the example above, we are listening to the **`checkout.order.save.after`** event and specifying the **`sendNewOrderMail`** function from the **`Order`** listener class in the **`Webkul\Admin\Listeners`** namespace. + +By registering the listener, you have associated the **`sendNewOrderMail`** function with the **`checkout.order.save.after`** event. Whenever this event is triggered, the specified function will be executed. + +You can modify the listener function according to your requirements to perform the desired operation. diff --git a/docs/1.5.x/advanced/helpers.md b/docs/1.5.x/advanced/helpers.md new file mode 100644 index 00000000..e0e4058e --- /dev/null +++ b/docs/1.5.x/advanced/helpers.md @@ -0,0 +1,187 @@ +# Helpers + +[[TOC]] + +## Introduction + +Bagisto provides several helper methods in its packages, which are designed to assist developers in building their projects more efficiently. + +## Core Helpers + +The core helper methods mentioned below are part of the `Core` class in the `Webkul\Core` namespace. Let's explore some common methods: + +- **Get all channels:** + + ```php + core()->getAllChannels(); + ``` + +- **Get the current channel:** + + ```php + core()->getCurrentChannel(); + ``` + +- **Set the current channel:** This method takes an instance of the `Webkul\Core\Models\Channel` class as an argument. + + ```php + core()->setCurrentChannel($channel); + ``` + +- **Get the current channel code:** + + ```php + core()->getCurrentChannelCode(); + ``` + +- **Get the default channel:** + + ```php + core()->getDefaultChannel(); + ``` + +- **Get the default channel code:** + + ```php + core()->getDefaultChannelCode(); + ``` + +- **Get the requested channel code:** This method is useful when you need to retrieve the channel from the request, with an optional fallback parameter. + + ```php + core()->getRequestedChannelCode($fallback = true); + ``` + +- **Get the channel name:** This method retrieves the name of the channel. It handles fallback cases by checking the name in the property, app locale code, and the `app.fallback_locale` config key. + + ```php + core()->getChannelName($channel); + ``` + +- **Get all locales:** + + ```php + core()->getAllLocales(); + ``` + +- **Get all locales by requested channel:** This method provides all the locales associated with the requested channel. + + ```php + core()->getAllLocalesByRequestedChannel(); + ``` + +- **Get the current locale:** + + ```php + core()->getCurrentLocale(); + ``` + +- **Get the requested locale code:** This method retrieves the locale code from the request, with optional parameters for specifying the locale key and fallback behavior. + + ```php + core()->getRequestedLocaleCode($localeKey = null, $fallback = true); + ``` + +- **Get all customer groups:** + + ```php + core()->getAllCustomerGroups(); + ``` + +- **Get the requested customer group code:** This method fetches the customer group code from the request. + + ```php + core()->getRequestedCustomerGroupCode(); + ``` + +- **Get all currencies:** + + ```php + core()->getAllCurrencies(); + ``` + +- **Get the base currency:** + + ```php + core()->getBaseCurrency(); + ``` + +- **Get the base currency code:** + + ```php + core()->getBaseCurrencyCode(); + ``` + +- **Get the channel-based currency:** + + ```php + core()->getChannelBaseCurrency(); + ``` + +- **Get the channel-based currency code:** + + ```php + core()->getChannelBaseCurrencyCode(); + ``` + +- **Get the current currency:** + + ```php + core()->getCurrentCurrency(); + ``` + +- **Get the current currency code:** + + ```php + core()->getCurrentCurrencyCode(); + ``` + +- **Get the exchange rate based on the currency ID:** + + ```php + core()->getExchangeRate($targetCurrencyId); + ``` + +- **Get the formatted amount:** + + ```php + core()->currency($amount = 0); + ``` + +- **Get the configuration data based on the key, channel, and locale:** + + ```php + core()->getConfigData($field, $channel = null, $locale = null); + ``` + +- **Get all countries:** + + ```php + core()->countries(); + ``` + +- **Get the country name by country code:** + + ```php + core()->country_name($countryCode); + ``` + +- **Get all states of a country:** + + ```php + core()->states($countryCode); + ``` + +- **Get sender email details:** + + ```php + core()->getSenderEmailDetails(); + ``` + +- **Get admin email details:** + + ```php + core()->getAdminEmailDetails(); + ``` + +These core helper methods provide various functionalities to simplify common tasks and streamline development in Bagisto. \ No newline at end of file diff --git a/docs/1.5.x/advanced/indexing-products-to-elasticsearch.md b/docs/1.5.x/advanced/indexing-products-to-elasticsearch.md new file mode 100644 index 00000000..4ae0bbe5 --- /dev/null +++ b/docs/1.5.x/advanced/indexing-products-to-elasticsearch.md @@ -0,0 +1,100 @@ +# Elasticsearch Configuration + +[[TOC]] + +In this section, we will explain how to configure Elasticsearch for indexing products from the database. + +## Environment Setup + +Before we proceed, make sure you have [Elasticsearch](https://www.elastic.co/guide/en/elasticsearch/reference/current/install-elasticsearch.html) installed on your system. By default, Elasticsearch uses port **`9200`**. We will be using the same port for our configuration. + +To verify if Elasticsearch is installed successfully on your system, open your browser and navigate to **`http://localhost:9200`**. If you see the following output, it means Elasticsearch is installed: + +```json +{ + "name" : "webkul-pc", + "cluster_name" : "elasticsearch", + "cluster_uuid" : "suPotT8zQjCOlq9dteWKyQ", + "version" : { + "number" : "8.6.2", + "build_flavor" : "default", + "build_type" : "deb", + "build_hash" : "2d58d0f136141f03239816a4e360a8d17b6d8f29", + "build_date" : "2023-02-13T09:35:20.314882762Z", + "build_snapshot" : false, + "lucene_version" : "9.4.2", + "minimum_wire_compatibility_version" : "7.17.0", + "minimum_index_compatibility_version" : "7.0.0" + }, + "tagline" : "You Know, for Search" +} +``` + +Alternatively, you can use the curl command: + +```sh +curl -X GET 'http://localhost:9200' +``` + +## Configuration Setup + +To configure Elasticsearch, you can set the necessary key-value pairs in the **`.env`** file of your project. + +Open the **`.env`** file and add the following lines: + +```env +ELASTICSEARCH_PORT=9200 +ELASTICSEARCH_HOST=localhost +``` + +Save the file and run the following command to cache the configuration: + +```sh +php artisan config:cache +``` + +Now your environment is set up and ready to index products. + +If you encounter any issues, you can directly set the configuration in the **`config/elasticsearch.php`** file: + +```php +'hosts' => [ + [ + 'host' => env('ELASTICSEARCH_HOST', 'localhost'), + 'port' => env('ELASTICSEARCH_PORT', 9200), + // Additional configuration options can be added here + ] +] +``` + +## Indexing + +After setting up the environment and configuration, new products will be automatically indexed when created. + +To index existing products, run the following command: + +```sh +php artisan indexer:index +``` + +This command will index all the data from the **`product_flat`** table to the Elasticsearch index. + +## Checking Indexes + +To check if your products have been indexed successfully, open your browser and navigate to **`http://localhost:9200/_cat/indices?v`**. You should see information about the imported index. + +Alternatively, you can use the curl command: + +```sh +curl -X GET 'http://localhost:9200/_cat/indices?v' +``` + +The output will provide details about the product index: + +:::details Output + +![Product Index Information](../../assets/1.5.x/images/advanced-topics/product-index.png) + +::: + +By following these steps, you have successfully configured Elasticsearch and indexed your products. \ No newline at end of file diff --git a/docs/1.5.x/advanced/override-core-model.md b/docs/1.5.x/advanced/override-core-model.md new file mode 100644 index 00000000..fd08acdf --- /dev/null +++ b/docs/1.5.x/advanced/override-core-model.md @@ -0,0 +1,66 @@ +# Override Core Model + +[[TOC]] + +## Introduction + +Bagisto utilizes Concord, a Laravel extension, for building modules on top of Laravel's built-in service providers. Concord introduces the concept of model proxies, which allow you to override and extend core models in a modular way. + +Concord requires the existence of an interface, such as **Product**, which serves as a contract that can be bound to a concrete class using Concord's **registerModel()** method. + +By default, the **`Models\Product`** class is bound to the **`Contracts\Product`** interface within the module. If you want to extend or override this class, you can use Concord's **registerModel()** method. + +The **registerModel()** method handles the binding of the interface and implementation in Laravel's service container, enabling you to easily type-hint the interface for automatic injection. + +For more details, you can visit the [Concord GitHub repository](https://github.com/artkonekt/concord) or refer to the [Concord documentation](https://artkonekt.github.io/concord/#/). + +## Overriding a Model Class + +- In Concord modules, an interface is typically defined for each Eloquent model. If you wish to override a model, you can instruct Concord to use another class for that interface. Here's an example: + + ```php + app->concord->registerModel( + \Webkul\Product\Contracts\Product::class, \App\Http\Product::class + ); + } + } + ``` + +- In the code above, the **registerModel()** method accepts two parameters: + + - The first parameter specifies the path to the interface (contract) you want to override. + - The second parameter specifies the path to the model class that will override the default implementation. + +- The model class you're overriding must extend your specified model path, as shown in the example below: + + ```php + field('home_page_content') + ->with(['sliderData' => $sliderData])->render() !!} + + {!! view_render_event('bagisto.shop.home.content.after') !!} + +@endsection +``` + +In the example above, we use **`view_render_event()`** to inject content before and after the main content of the **`home_page_content`** template. + +## Render View + +To render content before or after a specific section of a template, follow these steps: + +1. Add the event in the blade file where you want to inject the content. For example: + + ```php + {!! view_render_event('bagisto.shop.test.before') !!} + ``` + + In this example, **`bagisto.shop.test`** is the event name defined in a random blade file of your project. + +2. Next, you need to listen to the event in the **`EventServiceProvider.php`** file. Add the following code in the **`boot()`** method: + + ```php + addTemplate('template file path to be injected'); + }); + } + } + ``` + + In the code above, replace **`'template file path to be injected'`** with the actual path to the template file that you want to render. + +:::warning + Make sure that you have registered the **`EventServiceProvider`** in your own service provider. +::: + +By following these steps, you can use the **`view_render_event()`** function to dynamically inject content before or after the main content of a template in Bagisto. \ No newline at end of file diff --git a/docs/1.5.x/advanced/security-practice.md b/docs/1.5.x/advanced/security-practice.md new file mode 100644 index 00000000..a3ce5d39 --- /dev/null +++ b/docs/1.5.x/advanced/security-practice.md @@ -0,0 +1,135 @@ +# Best Security Practices + +[[TOC]] + +## Software Updates + +To ensure the security of your system, follow these best practices: + +- Use HTTPS to encrypt communication. Google now considers HTTPS as a ranking factor. +- Keep all software on the server up-to-date, including Bagisto, the database, Adminer/phpMyAdmin, Apache, Redis, etc. +- Regularly update the server operating system to apply available security patches. +- Manage files only through secure communication protocols like SSH, SFTP, or HTTPS. Disable FTP. +- Use the **`.htaccess`** file to protect system files when using the Apache web server. +- Disable unused ports and stop unnecessary services running on the server. +- Restrict access to the admin panel by allowing only specific IP addresses and enforcing two-factor authorization for admin logins. +- Ensure the use of strong and unique passwords. +- Configure and update the firewall properly to secure the connection between payment card data and the public network. + +## Limiting Error Messages + +To limit the exposure of sensitive information in error messages, follow these steps: + +- Edit your Apache configuration file to avoid displaying server and operating system details. +- Set **`ServerSignature`** to **`Off`** (by default, it is **`On`**). +- Add **`ServerTokens Prod`** to display Apache only as the product. + +:::details Screenshot + +![limiting-error-messages](../../assets/1.5.x/images/advanced-topics/limiting-error-messages.png) + +::: + +## Limiting Admin Access + +To restrict access to the admin area, modify the **`.htaccess`** file with the following code: + +```apacheconf +RewriteEngine On +RewriteCond %{REQUEST_URI} .*/admin +RewriteCond %{REMOTE_ADDR} != +RewriteCond %{REMOTE_ADDR} != +RewriteRule ^(.*)$ - [R=403,L] +``` + +Ensure that there are no accessible development leftovers on the server, such as "log files," ".git directories," "database dumps," or "zip files." + +## Restricting Unnecessary Files + +To restrict access to unnecessary files, add the following code to your **`.htaccess`** file: + +```apacheconf + + Require all denied + +``` + +Consider using a Web Application Firewall (WAF) to analyze traffic and detect suspicious patterns, such as credit card information being sent to attackers. Additionally, restrict public access to only ports 80 (HTTP) and 443 (HTTPS), while blocking other ports. + +## Restricting PHP Execution Inside Storage + +To restrict PHP execution inside the storage directory, modify your Apache configuration file: + +```apacheconf + + + Require all denied + + php_flag engine off + +``` + +Don't forget to restart Apache after making these changes. + +## Server Hardening + +Take the following measures to harden your server: + +- Use the **`mod_security`** module to detect and prevent intrusions. +- Implement the **`mod_passive`** module to prevent brute force attacks. +- Allow only specific users to log in. +- Disable login for users with empty passwords. +- Review and configure iptable rules to prevent unauthorized access and activity. +- Regularly back up important files and store them remotely in a secure environment. + +## Strong Passwords + +Ensure the use of strong and unique passwords and encourage periodic password changes. You can use a password generator tool ([Password Generator](https://passwords-generator.org/)) to create strong passwords. Limit access to the Bagisto admin + + panel by updating the whitelist with authorized IP addresses. + +## Implementation of HTTP Security Headers + +Implementing the following HTTP security headers enhances web security: + +### HTTP Strict Transport Security (HSTS) + +Set the **`Strict-Transport-Security`** response header to instruct the browser to only access the application using HTTPS: + +``` +Strict-Transport-Security: max-age= +``` + +### Cross-Site Scripting Protection (X-XSS Protection) + +Set the **`X-XSS-Protection`** response header to enable browsers to detect and prevent cross-site scripting (XSS) attacks: + +``` +X-XSS-Protection: 1; mode=block +``` + +### X-Frame-Options​ + +The **`X-Frame-Options`** response header protects applications against clickjacking. It specifies whether the content can be displayed within frames: + +``` +X-Frame-Options: deny +``` + +### X-Content-Type-Options​ + +The **`X-Content-Type-Options`** response header forces the browser to disable MIME sniffing, preventing MIME sniffing vulnerabilities: + +``` +X-Content-Type-Options: nosniff +``` + +### Content Security Policy (CSP) + +Implement a Content Security Policy (CSP) response header to control resources that can be loaded in users' browsers. CSP helps detect and mitigate attacks such as XSS and clickjacking. + +### Continuous Logging And Monitoring + +Maintain continuous logging and monitoring of all network access and cardholder data activities. Keep an eye out for large volume orders of a single item from new customers, a series of orders shipped to the same address but using different payment methods. + +By implementing these best security practices, you can enhance the security of your system and protect it from potential threats. \ No newline at end of file diff --git a/docs/1.5.x/architecture/README.md b/docs/1.5.x/architecture/README.md new file mode 100644 index 00000000..ac1ebe2b --- /dev/null +++ b/docs/1.5.x/architecture/README.md @@ -0,0 +1,12 @@ +# Architecture concepts +**Bagisto** is very easy framework to understand. The goal of this document to give you overview of how bagisto works. + +We love to work with hot [Opensource](https://en.wikipedia.org/wiki/Open_source) softwares so Bagisto is built on technologies such as [PHP](https://php.net), [Laravel](https://laravel.com) and [Vue.js](https://vuejs.org/) + +As **Bagisto** targets e-commerce businesses so it provides front and back end features to enable customer account and administrative control simultaneously. + +Laravel packages are being used to separate each functionality such as Category, Product, Cart, Checkout, etc. + +We developed and used built-in components of Vue.js + +**Bagisto** registers useful events that are triggered on most of the pages which could enable to perform some custom operations in the application. diff --git a/docs/1.5.x/architecture/frontend.md b/docs/1.5.x/architecture/frontend.md new file mode 100644 index 00000000..f0eaf168 --- /dev/null +++ b/docs/1.5.x/architecture/frontend.md @@ -0,0 +1,13 @@ +# Vue and Sass + +[Vue.js](https://vuejs.org/) handles the complete UI of **Bagisto** + +[Laravel Mix](https://laravel.com/docs/10.x/mix) is a package that provides a fluent API for defining [webpack](https://webpack.js.org/) and it build steps for your [Laravel](https://laravel.com) application using several common CSS and JavaScript [pre-processors](https://en.wikipedia.org/wiki/Preprocessor). + +**Bagisto** is using [Vue.js](https://vuejs.org/) and [Sass](https://sass-lang.com/), webpack compiles all of CSS and JavaScript assets that are placed into public directory. + +In **webpack.mix.js** file, just define your [Vue.js](https://vuejs.org/) and [Sass](https://sass-lang.com/) assets, [webpack](https://webpack.js.org/) will be responsible to compile all the assets on defined location. + +# Blade + +**Bagisto** uses blade template engine that is included with **Laravel**. It does not restrict you from using plain PHP code in your templates. [This documentation](http://localhost:8080/1.5.x/packages/views.html#directory-structure) provides an explanation of directory structure and package configuration for implementations. \ No newline at end of file diff --git a/docs/1.5.x/architecture/modular-design.md b/docs/1.5.x/architecture/modular-design.md new file mode 100644 index 00000000..34b05255 --- /dev/null +++ b/docs/1.5.x/architecture/modular-design.md @@ -0,0 +1,13 @@ +# Modular Design + +**Modular design** is the preferred approach for e-commerce software, as it enables the separation of each package and empowers users to work with self-contained modules. + +This architectural style effectively manages the complexity of the system by breaking down problems into smaller, more manageable modules. + +To implement this modular approach, Bagisto utilizes the [Concord package](https://github.com/artkonekt/concord). + +Concord plays a pivotal role in enabling the modular architecture within **Bagisto**, providing the necessary tools and features. + +By leveraging **Concord**, **Bagisto** is able to follow a modular architecture that enhances **flexibility** and **scalability**. + +Through Concord, Bagisto users can take advantage of the benefits offered by a modular architecture, enabling them to easily customize and extend the software according to their specific requirements. \ No newline at end of file diff --git a/docs/1.5.x/architecture/packages.md b/docs/1.5.x/architecture/packages.md new file mode 100644 index 00000000..150bb4cb --- /dev/null +++ b/docs/1.5.x/architecture/packages.md @@ -0,0 +1,11 @@ +# Packages +[Laravel](https://laravel.com) packages are the primary way of adding functionality so the following features are distributed into packages to enhance the application and allow developers to follow the standard way of developing custom functionality. + +- Theme +- Category +- Product +- Cart +- Checkout +- Payment + +Service provider enables features such as loading [routes](/1.5.x/packages/routes.html), [migrations](/1.5.x/packages/create-migrations.html), [languages](/1.5.x/packages/localization.html) or publishing [views](/1.5.x/packages/views.html), etc so **Bagisto** is developed considering these aspects. diff --git a/docs/1.5.x/architecture/performance.md b/docs/1.5.x/architecture/performance.md new file mode 100644 index 00000000..21457486 --- /dev/null +++ b/docs/1.5.x/architecture/performance.md @@ -0,0 +1,29 @@ +# Performance + +[[TOC]] + +In the realm of online stores, [web vitals](https://web.dev/vitals/) have become increasingly crucial. **Bagisto** prioritizes good [LCP](https://web.dev/lcp/) and [CLS](https://web.dev/cls/) to ensure optimal user experience. + +Additionally, **Bagisto** has seamlessly integrated [ElasticSearch](https://bagisto.com/en/elasticsearch-for-bagisto/) to further enhance user experience. + +## Indexing + +When dealing with large volumes of data and retrieving complex information like variants and prices, optimizing queries becomes a challenge. + +To enhance **Bagisto's** performance, the following indexers play a crucial role: + +- Inventory +- Price +- ElasticSearch + +### Inventory + +This indexer focuses on indexing the inventory of the website for various product types such as configurable, grouped, and bundled products. + +### Price + +The price indexer manages the prices of the aforementioned product types. + +### ElasticSearch + +As Elastic is designed to handle large amounts of data and provide fast and scalable search capabilities, **Bagisto** leverages its capabilities to index all products, thereby significantly enhancing the search functionality. \ No newline at end of file diff --git a/docs/1.5.x/architecture/repository-pattern.md b/docs/1.5.x/architecture/repository-pattern.md new file mode 100644 index 00000000..3d6f0ad7 --- /dev/null +++ b/docs/1.5.x/architecture/repository-pattern.md @@ -0,0 +1,9 @@ +# Repository Pattern + +[Eloquent](https://laravel.com/docs/10.x/eloquent), the [ORM](https://en.wikipedia.org/wiki/Object%E2%80%93relational_mapping) in **Laravel**, provide a higher level of abstraction and make working with databases more convenient, as you can focus on manipulating objects rather than dealing with raw SQL queries. + +To further enhance flexibility and maintainability, Bagisto incorporates the **Repository pattern** as an additional layer on top of the **ORM**. + +By implementing the **Repository pattern**, **Bagisto** restricts the use of raw queries throughout the application. This ensures consistency and promotes better code organization. + +Bagisto utilizes the [Prettus Repository](https://github.com/prettus/l5-repository) package to facilitate the implementation of the **Repository pattern**. This choice enhances the flexibility of the application, making it easier to maintain and extend. \ No newline at end of file diff --git a/docs/1.5.x/architecture/theme.md b/docs/1.5.x/architecture/theme.md new file mode 100644 index 00000000..7b5750e5 --- /dev/null +++ b/docs/1.5.x/architecture/theme.md @@ -0,0 +1,3 @@ +# Theme + +In e-commerce businesses, themes provides an elegant way to attract users. **Bagisto** provides front-end theme i.e. **Velocity** and allow developers to create new theme as per their convenience. \ No newline at end of file diff --git a/docs/1.5.x/deploy/README.md b/docs/1.5.x/deploy/README.md new file mode 100644 index 00000000..6ca0fb29 --- /dev/null +++ b/docs/1.5.x/deploy/README.md @@ -0,0 +1,9 @@ +# Deploy + +this article will explain how you can deploy your Bagisto store to your production server when you have been developing your Bagisto store on your local system. + +## Deploy Bagisto with (S)FTP + +## Deploy on Cpanel + +## Deploy on Plesk diff --git a/docs/1.5.x/introduction/README.md b/docs/1.5.x/introduction/README.md new file mode 100644 index 00000000..c4bdee56 --- /dev/null +++ b/docs/1.5.x/introduction/README.md @@ -0,0 +1,45 @@ +# Introduction + +## Bagisto: A Powerful Open-Source E-Commerce Platform + +Bagisto is a popular open-source e-commerce platform built on the combination of Laravel PHP framework and Vue.js. It provides a comprehensive set of tools and features to help developers and businesses create and manage their online stores effectively. With its flexible and adaptable nature, Bagisto has gained recognition and support from a growing community of users, as evidenced by its impressive 6K+ stars on [GitHub](https://github.com/bagisto/bagisto). + +## Key Features of Bagisto + +Bagisto comes with a rich set of features that empower developers and businesses to create and manage their online stores effectively: + +### Modular Design + +Bagisto adopts a modular design approach, providing developers with the flexibility to customize and extend the platform's functionalities to meet specific business requirements. It allows you to tailor your e-commerce store precisely to your needs. + +### Multi-Channel and Multi-Vendor Support + +With Bagisto, you can easily create and manage multiple sales channels, enabling you to expand your reach and cater to different customer segments. It also supports multi-vendor functionality, allowing various vendors to sell their products on your platform. + +### Responsive and Mobile-Friendly + +Bagisto ensures that your online store looks great and performs flawlessly across different devices, including mobile phones and tablets. With a responsive design, you can provide a seamless shopping experience to your customers, no matter the device they use. + +### Efficient Inventory Management + +Bagisto simplifies inventory management by providing tools to effectively track stock levels, set low inventory alerts, and streamline order fulfillment processes. You can efficiently manage your product inventory and ensure a smooth flow of operations. + +### Secure Payment Gateways and Shipping Methods + +Integrating popular payment gateways and shipping methods is effortless with Bagisto. It offers seamless integration options to ensure secure and convenient transactions for your customers, making the checkout process a breeze. + +### Search Engine Optimization (SEO) Capabilities + +Bagisto equips you with built-in features to optimize your online store for search engines. You can customize meta tags, URLs, and keywords to improve your store's visibility and attract more organic traffic. + +## Community and Support + +Bagisto has a vibrant and supportive community of developers and users who actively contribute to its growth and improvement. + +- **Explore Bagisto**: Visit our website at [https://bagisto.com](https://bagisto.com) to discover more about Bagisto's features and experience a demo. + +- **Stay Updated**: Refer to the [Bagisto roadmap](https://bagisto.com/roadmap) for the latest version and recently added features. + +- **GitHub Repository**: Access the Bagisto repository on [GitHub](https://github.com/bagisto/bagisto) with over 6K+ stars, reflecting its popularity and community support. + +Join the Bagisto community today and build and manage your online store with ease. \ No newline at end of file diff --git a/docs/1.5.x/introduction/docker.md b/docs/1.5.x/introduction/docker.md new file mode 100644 index 00000000..986e2333 --- /dev/null +++ b/docs/1.5.x/introduction/docker.md @@ -0,0 +1,225 @@ +# Docker + +[[toc]] + +## Introduction + +[Docker](https://www.docker.com/) is an open platform for developing, shipping, and running applications. Docker enables you to separate your applications from your infrastructure so you can deliver software quickly. With Docker, you can manage your infrastructure in the same ways you manage your applications. Docker can also be used for defining and running multi-container Docker applications using the Docker Compose tool. + +With the help of Docker Compose, you can define containers to be built, their configuration, links, volumes, ports, etc., in a single file, and it gets launched by a single command. You can also add multiple servers and services just by adding them to the Docker Compose configuration file. This configuration file is in [YAML](https://en.wikipedia.org/wiki/YAML) format. + +#### Application Data and Database Volume Persistence + +It is recommended to keep your application files and database data volume on the Docker host and mount them on the running container. This ensures that the application and database data persistence even in the case of containers' failure or termination. In this way, even if you destroy containers, your data won't get lost unless you remove them forcefully. +This compose configuration file mounts the application directory **`app`** and database volume **`dbvolume`** from the host to running Docker containers at the time of containers' launch. + +## Installation & Setup + +### First steps + +Before you can launch Bagisto in a Docker environment, you need to install the latest versions of Docker and Docker Compose. + +- [Docker](https://docs.docker.com/install/) +- [Docker Compose](https://docs.docker.com/compose/install/) +- [Composer](https://getcomposer.org) (optional) + +### Configure the Docker container + +Once Docker and Docker Compose are installed, you need to create a **`docker-compose.yml`** file. The **`docker-compose.yml`** configuration file requires the following inputs from the user: + +#### Webserver configuration + +In the **`web_server`** service block, assign your system's working user UID to the **`USER_UID`** environment variable. To find your user ID, run the following command on Linux or macOS: +```shell +id -u +``` + +#### Database configuration + +In the **`database_server`** service block, assign the MySQL database name, MySQL database user name, MySQL database user password, and MySQL root password to the **`MYSQL_DATABASE`**, **`MYSQL_USER`**, **`MYSQL_PASSWORD`**, and **`MYSQL_ROOT_PASSWORD`** environment variables, respectively. + +#### Clone configuration from GitHub + +You can make use of our repository from GitHub by cloning it into your new directory: +```shell +git clone https://github.com/bagisto/bagisto-docker.git . +``` + +#### Manual configuration + +Alternatively, you can create a new folder, for example, **`bagisto-docker`**, and manually create the **`docker-compose.yml`** file inside it. Add the following content to **`docker-compose.yml`**: + +```yml +version: '3' + +services: + + web_server: + image: webkul/apache-php:latest + container_name: apache2 + restart: always + volumes: + - ./app:/var/www/html + working_dir: /var/www/html/ + environment: + USER_UID: 'mention your system user ID here. ex: 1001, 1000, 33, etc' + networks: + - bagisto-network + ports: + - '80:80' + expose: + - '80' + depends_on: + - database_server + links: + - database_server + + database_server: + image: mysql:5.7 + container_name: mysql + restart: always + environment: + MYSQL_DATABASE: 'mention the name of the database to be created here. eg: mydatabase' + MYSQL_USER: 'mention database user here. eg: mydatabase_user' + MYSQL_PASSWORD: 'mention database user password here. ex: mystrongPassword' + MYSQL_ROOT_PASSWORD: 'mention mysql root password here. ex: mysqlstrongpass' + MYSQL_ROOT_HOST: '%' + networks: + - bagisto-network + ports: + - '3306:3306' + expose: + - '3306' + volumes: + - ./dbvolume:/var/lib/mysql + +volumes: + dbvolume: + app: + +networks: + bagisto-network: + ** +``` + +#### Downloading the Docker Image + +To download the Docker images for Apache-PHP version 7.3 and MySQL version 5.7, execute the following command: + +```shell +docker-compose pull +``` + +### Launching the Docker Container + +Execute the following command to create a network and launch web server and database containers with the names **`apache2`** and **`mysql`** respectively. It will also create new directories **`app`** and **`dbvolume`** within your current directory and mount them to the respective Docker containers as specified in the **`docker-compose.yml`** file. Additionally, it binds your **`host port 80`** to the Apache2 container's port 80, and your **`host port 3306`** to the MySQL container's port 3306. If you wish to use different ports for the containers, modify their values in the **`docker-compose.yml`** file. + +``` +docker-compose up -d +``` + +### Monitoring Your Container(s) + +To check the running Docker containers, use the following commands: + +**`docker ps`** OR **`docker-compose ps`** +```shell +CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +62a10346b84a webkul/apache-php:latest "/usr/bin/supervisord" About an hour ago Up About an hour 0.0.0.0:80->80/tcp apache2 +90a0a2e0e46b mysql:5.7 "docker-entrypoint.s…" About an hour ago Up About an hour 0.0.0.0:3306->3306/tcp, 33060/tcp mysql +``` + +## Configuring Bagisto + +After setting up your environment, you can proceed with the installation of Bagisto. There are two ways to install Bagisto: either from [Github](#install-without-composer) or using [composer](#install-with-composer). + +### Install without Composer + +To install Bagisto without using composer, follow these steps: +1. Download the [latest release](https://bagisto.com/en/download) and save it in the **`app/bagisto`** directory. +2. Open the **`.env`** file located inside the **app/bagisto** directory. +3. Set the following environment variables as shown below: + +```editorconfig +APP_URL=https://127.0.0.1 +DB_CONNECTION=mysql +DB_HOST=mysql +DB_PORT=3306 +DB_DATABASE= +DB_USERNAME= +DB_PASSWORD= +``` + +Run the following commands to install Bagisto. +```shell +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan migrate'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan db:seed'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan vendor:publish'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan storage:link'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'composer dump-autoload -d bagisto'" +``` + +Mention the database details same as docker-compose.yml and admin details. + + +### Install with composer + +The following commands will be exexcuted within the docker container +```shell +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'composer create-project bagisto/bagisto'" +``` + +Open the .env file inside **`app/bagisto`** directory and set the following environment variables listed below: + +```editorconfig +APP_URL=https://127.0.0.1 +DB_CONNECTION=mysql +DB_HOST=mysql +DB_PORT=3306 +DB_DATABASE= +DB_USERNAME= +DB_PASSWORD= +``` + +To install Bagisto, execute the following commands: + +```shell +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan migrate'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan db:seed'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan vendor:publish'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan storage:link'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'composer dump-autoload -d bagisto'" +``` + +Bagisto has been successfully installed and is now ready to use. To access it, open your web browser and enter your server's IP address or domain name. + +### Configuring Apache + +By default, the Apache document root is set to **/var/www/html/public_html**. Additionally, the **app** directory on your host machine is mapped to the **html** directory inside the container. To ensure proper configuration, we need to create a symlink of **`bagisto/public`** in the **`app`** directory that points to **`/var/www/html/public_html`**. + +To create the symlink, follow the steps below: + +On Linux or macOS, run the following command: +```bash +cd app; ln -snf bagisto/public public_html +``` + +On Windows, run the following command: +```command-line +cd app +mklink bagisto/public public_html +``` + +### Ready to Use + +#### Admin Login: + +You can access the admin interface by visiting [http://your_server_endpoint/admin](http://your_server_endpoint/admin/) and logging in with the following credentials: + +| Email | Password | +|----------------------|----------| +| admin@example.com | admin123 | + +#### Customer Login: + +To access your store, visit [http://your_server_endpoint/](http://your_server_endpoint/). \ No newline at end of file diff --git a/docs/1.5.x/introduction/installation.md b/docs/1.5.x/introduction/installation.md new file mode 100644 index 00000000..bd08110b --- /dev/null +++ b/docs/1.5.x/introduction/installation.md @@ -0,0 +1,103 @@ +# Installation + +[[TOC]] + +## Install Using GUI Installer + +To install Bagisto using our GUI installer, follow these steps: + +1. [Download Bagisto](https://bagisto.com/en/download/) from our website. +2. Extract the contents of the downloaded zip file. +3. Navigate to the project root directory. +4. Run the following command: + + ```sh + composer install + ``` + +5. Configure your HTTP server to point to the **`public/`** directory of the project. +6. Open your browser and access the following URL: + + ``` + http://localhost/bagisto/public/ + ``` + + This will launch the Bagisto installer. + +## Install Using Composer + +To install Bagisto using Composer, use the following steps: + +1. Run the following command: + + ```sh + composer create-project bagisto/bagisto + ``` + +2. Navigate to the project root directory. +3. Open the **`.env`** file and add your database credentials: + + ```editorconfig + DB_DATABASE= + DB_USERNAME= + DB_PASSWORD= + ``` + +4. Run the following command: + + ```sh + php artisan bagisto:install + ``` + + ::: warning + During the installation process, if the **`.env`** file doesn't exist, the installer will prompt you to provide the necessary information. + ::: + + - Follow the prompts during the installation process to provide the following details: + + ``` + - Please Enter the APP URL : + - Please Enter the Admin URL : + - Please select the default locale or press enter to continue [en]: + - Please enter the default timezone [Asia/Kolkata]: + - Please enter the default currency [USD]: + - What is the database name to be used by Bagisto?: + - What is your database username?: + - What is your database password?: + ``` + +## Start Using Bagisto + +### On a Production Server + +To access Bagisto on a production server, open your domain in a web browser. For example: + +``` +https://example.com/ +``` + +### On Your Local Server + +To access Bagisto on your local server, follow these steps: + +1. Configure your HTTP server to point to the **`public/`** directory of the project. +2. Run the following command: + + ```sh + php artisan serve + ``` + +3. Open your browser and access the provided local server URL. + +### Login as an Admin + +To log in as an admin, visit **`https://example.com/admin/`**. If you used the **`php artisan bagisto:install`** command, use the following credentials: + +``` +Email: admin@example.com +Password: admin123 +``` + +### Login as a Customer + +To log in as a customer, you can directly register on **`https://example.com/customer/register`**. After registration, you can log in using your credentials on the domain. \ No newline at end of file diff --git a/docs/1.5.x/introduction/requirements.md b/docs/1.5.x/introduction/requirements.md new file mode 100644 index 00000000..321128c9 --- /dev/null +++ b/docs/1.5.x/introduction/requirements.md @@ -0,0 +1,53 @@ +# Requirements + +[[TOC]] + +## Server Configuration + +- **Server**: Apache 2 or NGINX +- **RAM**: 4GB or higher +- **Node**: 18.12.0 LTS or higher +- **PHP**: 8.1 or higher +- **Composer**: 2.5 or higher + +## PHP Extensions + +Ensure the following extensions are installed and enabled. You can check using the **`phpinfo()`** page or the **`php -m`** command. + +- **php-intl extension**: This extension is required for internationalization support in Bagisto. + +- **php-gd extension**: The **`php-gd`** extension must be properly installed to ensure correct image functionality in the project. If not installed correctly, image-related features may not work as expected. + + ::: tip Note + It is important to ensure proper installation of the **`php-gd`** extension to avoid any issues with image manipulation in Bagisto. + ::: + +## PHP Configuration + +Open your **`php.ini`** file and modify the following settings. + +- **memory_limit**: Set the **`memory_limit`** directive to **`4G`** or higher to ensure sufficient memory allocation for the application. + +- **max_execution_time**: Adjust the **`max_execution_time`** directive to **`360`** or higher. This value determines the maximum time (in seconds) a script is allowed to run. Increasing this value ensures that longer operations, such as import/export processes, can be completed successfully. + +- **date.timezone**: Set the **`date.timezone`** directive to your specific timezone. For example, **`Asia/Kolkata`**. This ensures that date and time-related functions work accurately based on the specified timezone. + +```ini +memory_limit = 4G +max_execution_time = 360 +date.timezone = Asia/Kolkata <- Change this to your own timezone. +``` + +::: tip Remember to restart your web server +Whenever you make changes to the PHP configuration file, be sure to restart Apache or NGINX to apply the modifications. +::: + +## Supported Database Servers + +Bagisto supports the following database servers: + +- **MySQL**: Version 8.0.32 or higher is recommended for optimal performance and compatibility. + +- **MariaDB**: Version 10.3 or higher is recommended for optimal performance and compatibility. + +- **Database Collation**: The recommended collation for the database is **`utf8mb4_unicode_ci`**, which ensures proper handling of Unicode characters and multilingual support. \ No newline at end of file diff --git a/docs/1.5.x/packages/README.md b/docs/1.5.x/packages/README.md new file mode 100644 index 00000000..104b96d5 --- /dev/null +++ b/docs/1.5.x/packages/README.md @@ -0,0 +1,88 @@ +## Package Development + +If you are looking to extend the functionalities of Bagisto eCommerce platform, creating a package is the way to go. A package is a self-contained module that adds specific features to the platform. It allows developers to add custom functionality to the platform without modifying the core codebase. + +This guide will walk you through the process of developing a package for Bagisto. + +In Bagisto, we have created numerous packages located at **`packages/Webkul/`**. Below is a basic tree structure of a package: + +~~~directory-structure +└── Webkul + └── Blog + ├── publishable + │ └── assets + │ ├── css + │ │ ├── admin.css + │ │ ├── default.css + │ │ └── velocity.css + │ ├── images + │ │ └── blog-icon.png + │ └── js + │ └── app.js + └── src + ├── Config + │ ├── acl.php + │ ├── admin-menu.php + │ └── system.php + ├── Console + │ └── Commands + ├── Contracts + │ └── Post.php + ├── Database + │ ├── Migrations + │ │ └── 2023_04_21_173057_create_posts_table + │ └── Seeders + ├── Events + ├── Http + │ ├── Controllers + │ │ ├── Admin + │ │ │ └── PostController.php + │ │ └── Shop + │ │ └── PostController.php + │ ├── Middleware + │ └── Requests + ├── Listeners + ├── Mail + ├── Models + │ ├── Post.php + │ └── PostProxy.php + ├── Providers + │ ├── BlogServiceProvider.php + │ └── ModuleServiceProvider.php + ├── Routes + │ ├── admin-routes.php + │ └── shop-routes.php + ├── Repositories + │ └── PostRepository.php + └── Resources + ├── assets + │ ├── images + │ │ └── blog-icon.png + │ ├── js + │ │ └── app.js + │ └── sass + │ ├── admin.scss + │ ├── default.scss + │ └── velocity.scss + ├── lang + │ └── app.php + └── views + ├── admin + │ └── layouts + │ └── style.blade.php + ├── index.blade.php + ├── create.blade.php + ├── edit.blade.php + ├── shop + │ └── default + │ └── layouts + │ └── style.blade.php + │ ├── index.blade.php + │ └── blog-details.blade.php + └── velocity + └── layouts + └── style.blade.php + ├── index.blade.php + └── blog-details.blade.php + +~~~ \ No newline at end of file diff --git a/docs/1.5.x/packages/add-menu-in-admin.md b/docs/1.5.x/packages/add-menu-in-admin.md new file mode 100644 index 00000000..6ed72274 --- /dev/null +++ b/docs/1.5.x/packages/add-menu-in-admin.md @@ -0,0 +1,106 @@ +# Admin Menu + +[[TOC]] + +## Directory Structure + +To ensure that the admin menu includes the necessary configuration, follow these steps: + +1. In your package's source directory, which is typically located at **`packages/Webkul/Blog/src`**, create a new folder named **`Config`** if it doesn't already exist. + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Config + └── admin-menu.php + ``` + +2. Inside the newly created **`Config`** folder, create a file named **`admin-menu.php`**. + +3. Copy and paste the following code into the **`admin-menu.php`** file: + + ```php + 'blogs', + 'name' => 'Blogs', + 'route' => 'blog.admin.index', + 'sort' => 2, + 'icon-class' => 'blog-icon', + ], + ]; + ``` + +4. In your **`admin-routes.php`** file (located in the same package's source directory), add the named route **`blog.admin.index`** as follows: + + ```php + Route::get('/blog', [PostController::class, 'index'])->name('blog.admin.index'); + ``` + + In this step, we define the route that corresponds to the menu item added in the previous step. + +## Add Menu Icon + +5. To add the menu icon styling, open the **`assets/scss/admin.scss`** file within your package and add the following code: + + ```css + .blog-icon { + background-image: url("../images/blog.png"); + width: 45px; + height: 45px; + opacity: 0.6; + margin-left: 4px !important; + } + + .active { + .blog-icon { + opacity: 1; + background-image: url("../images/blog-active.png"); + } + } + ``` + + Ensure that you have the necessary **`.png`** image files (**`blog.png`** and **`blog-active.png`**) and manually place them inside the **`assets/images`** folder of your package. + +6. To merge the **`admin-menu.php`** configuration with the core menu file, use the **`mergeConfigFrom()`** method in the **`register()`** method of your package's service provider. Here's an example: + + ```php + mergeConfigFrom( + dirname(__DIR__) . '/Config/admin-menu.php', 'menu.admin' + ); + } + } + ``` + +7. Finally, run the following command to optimize your application: + + ``` + php artisan optimize + ``` + + After completing these steps, the menu item should appear in the admin panel. + + ::: details Admin Menu Output + + ![Admin Menu Output](../../assets/1.5.x/images/package-development/admin-menu-output.png) + + ::: \ No newline at end of file diff --git a/docs/1.5.x/packages/assets.md b/docs/1.5.x/packages/assets.md new file mode 100644 index 00000000..f4d1a247 --- /dev/null +++ b/docs/1.5.x/packages/assets.md @@ -0,0 +1,236 @@ +# Assets + +[[TOC]] + +## Directory Structure + +- To organize our assets, we need to create the following folder structure in the **`Resources`** folder: + - Create a folder named **`assets`**. + - Inside the **`assets`** folder, create the following folders: **`sass`**, **`js`**, and **`images`**. + - In the **sass** folder, add the files **_admin.scss_**, **_default.scss_**, and **_velocity.scss_**. + - In the **js** folder, add the file **app.js**. + +Here's the updated directory structure: + +``` +└── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Resources + ├── ... + └── assets + ├── sass + │ ├── admin.scss + │ ├── default.scss + │ └── velocity.scss + ├── js + │ └── app.js + └── images + +``` + +## Compiling Assets + +To compile the assets, perform the following steps: + +1. Create a **`package.json`** and **`webpack.mix.js`** file inside the root of your package (**`packages/Webkul/Blog`**). + +2. Copy the following code into the **`package.json`** file: + + ```json + { + "scripts": { + "dev": "npm run development", + "development": "cross-env NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js", + "watch": "cross-env NODE_ENV=development node_modules/webpack/bin/webpack.js --watch --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js", + "watch-poll": "npm run watch -- --watch-poll", + "hot": "cross-env NODE_ENV=development node_modules/webpack-dev-server/bin/webpack-dev-server.js --inline --hot --config=node_modules/laravel-mix/setup/webpack.config.js", + "prod": "npm run production", + "production": "cross-env NODE_ENV=production node_modules/webpack/bin/webpack.js --no-progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js" + }, + "devDependencies": { + "cross-env": "^7.0.2", + "laravel-mix": "^5.0.1", + "laravel-mix-merge-manifest": "^0.1.2", + "sass": "^1.62.0", + "sass-loader": "^8.0.2", + "vue-template-compiler": "^2.7.14" + } + } + ``` + +3. Copy the following code into the **`webpack.mix.js`** file: + + ```javascript + const mix = require("laravel-mix"); + + if (typeof mix == "undefined") { + const { mix } = require("laravel-mix"); + } + + require("laravel-mix-merge-manifest"); + + if (mix.inProduction()) { + var publicPath = "publishable/assets"; + } else { + var publicPath = "../../../public/vendor/webkul/blog/assets"; + } + + mix.setPublicPath(publicPath).mergeManifest(); + + mix.disableNotifications(); + + mix + .js([__dirname + "/src/Resources/assets/js/app.js"], "js/blog.js") + .copyDirectory( + __dirname + "/src/Resources/assets/images", + publicPath + "/images" + ) + .sass( + __dirname + "/src/Resources/assets/sass/app.scss", + "css/admin.css" + ) + .sass( + __dirname + '/src/Resources/assets/sass/default.scss', + 'css/default.css' + ) + .sass( + __dirname + '/src/Resources/assets/sass/velocity.scss', + 'css/velocity.css' + ) + .options({ + processCssUrls: false, + }); + + if (mix.inProduction()) { + mix.version(); + } + ``` + +4. Run **`npm install`** in the root of your package (**`packages/Webkul/Blog`**) to install all the dependencies. + +Now, your **`scss`** and **`js`** files are ready to use. You can write all your CSS and JS code here. + +To compile the assets, run **`npm run prod`**. This will compile all your CSS, JS, and images into the publishable folder. Finally, make sure to register your publishable in the **`BlogServiceProvider`**. + +::: tip +You can also use **`npm run watch`**, which watches for changes in your assets and automatically updates the public path. When you're done making changes, run **`npm run prod`** to compile all your changes and move them to the publishable folder. +::: + +## Load Assets From Package + +- To load the assets from your package, add the following code to the **`BlogServiceProvider.php`** file: + + ```php + publishes([ + __DIR__ . '/../../publishable/assets' => public_path('vendor/webkul/blog/assets'), + ], 'public'); + } + } + ``` + +### Linking Stylesheets + +To link the stylesheets to the layouts, follow these steps: + +1. Create a **`layouts`** folder within the **`/Resources/views/shop/default`**, **`/Resources/views/shop/velocity`**, and **`/Resources/views/admin`** folders. + +2. Inside each **layouts** folder, create a file called **`style.blade.php`**. + +3. Copy the following code into the **`admin/layouts/style.blade.php`** file: + + ```html + + ``` + +4. Copy the following code into the **`shop/default/layouts/style.blade.php`** file: + + ```html + + ``` + +5. Copy the following code into the **`shop/velocity/layouts/style.blade.php`** file: + + ```html + + ``` + +### Event Listener + +- To ensure that the admin layouts include our CSS, we should add an event listener. You can add the following code to the **`BlogServiceProvider.php`** file: + + ```php + publishes([ + __DIR__ . '/../../publishable/assets' => public_path('vendor/webkul/blog/assets'), + ], 'public'); + + Event::listen('bagisto.admin.layout.head', function($viewRenderEventManager) { + $viewRenderEventManager->addTemplate('blog::admin.layouts.style'); + }); + + Event::listen('bagisto.shop.layout.head', function($viewRenderEventManager) { + $viewRenderEventManager->addTemplate('blog::shop.default.layouts.style'); + }); + + Event::listen('bagisto.shop.layout.head', function($viewRenderEventManager) { + $viewRenderEventManager->addTemplate('blog::shop.velocity.layouts.style'); + }); + } + + /** + * Register services. + * + * @return void + */ + public function register() + { + } + } + ``` \ No newline at end of file diff --git a/docs/1.5.x/packages/controllers.md b/docs/1.5.x/packages/controllers.md new file mode 100644 index 00000000..d82ac3c9 --- /dev/null +++ b/docs/1.5.x/packages/controllers.md @@ -0,0 +1,149 @@ +# Controller + +[[TOC]] + +To learn in detail about Controllers, you can visit the Laravel documentation [here](https://laravel.com/docs/10.x/controllers). + +## Directory Structure + +- Create an **`Http`** folder in the **`packages/Webkul/Blog/src`** path. Inside the **`Http`** folder, create another folder named **`Controllers`**. Inside the **`Controllers`** folder, we need to create one file named **`Controller.php`** and two folders, namely **`Admin`** and **`Shop`**. + +- Inside both the **`Admin`** and **`Shop`** folders, create a **`PostController.php`** file. The updated directory structure will look like this: + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Http + └── Controllers + ├── Controller.php + ├── Admin + │ └── PostController.php + └── Shop + └── PostController.php + ``` + +## Base Controller + +- **`Controller.php`**: This is the base controller. Add the following code to this file: + + ```php + postRepository->all(); + + return view('blog::admin.index', ['blogs' => $blogs]); + } + + /** + * Create. + * + * @return \Illuminate\View\View + */ + public function create() { + // + } + + /** + * Store. + * + * @param \Illuminate\Http\Request $request + * @return \Illuminate\View\View + */ + public function store(Request $request) { + // + } + } + ``` + +- **`Shop/PostController.php`**: This file is for shop usage. Add the following code to this file: + + ```php + postRepository->with(['author'])->all(); + + return view('blog::shop.index', ['blogs' => $blogs]); + } + + /** + * Blog details. + * + * @return \Illuminate\View\View + */ + public function blogDetails($id) + { + // + } + } + ``` \ No newline at end of file diff --git a/docs/1.5.x/packages/create-acl.md b/docs/1.5.x/packages/create-acl.md new file mode 100644 index 00000000..cd84246e --- /dev/null +++ b/docs/1.5.x/packages/create-acl.md @@ -0,0 +1,110 @@ +# Access Control List + +[[TOC]] + +## Introduction + +In addition to providing authentication services out of the box, Bagisto also offers an Access Control List (ACL) functionality. This feature allows administrators to control user access to different parts of Bagisto. + +## Directory Structure + +To configure the ACL, follow these steps: + +1. Create a new file named **`acl.php`** in the **`packages/Webkul/Blog/src/Config`** folder of your package. + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Config + ├── acl.php + └── ... + ``` + +2. Add the following code to **`acl.php`**: + + ```php + 'blog', + 'name' => 'blog', + 'route' => 'blog.admin.index', + 'sort' => 2 + ] + ]; + ``` + + In the above code, we have defined an array for each menu item with the parameters (key, name, route, and sort). You need to define the menus you want to include in the ACL here. + +## Merge Configuration + +To merge the ACL configuration, follow these steps: + +1. Open the **`BlogServiceProvider`** class in the **`Webkul\Blog\Providers`** namespace. + +2. In the **`register`** method, add the following code to merge the ACL configuration: + + ```php + mergeConfigFrom( + dirname(__DIR__) . '/Config/acl.php', 'acl' + ); + } + } + ``` + + This will merge the ACL configuration with the existing configuration. + +3. After making the changes, run the following command to cache the latest changes: + + ```sh + php artisan optimize + ``` + + This will ensure that the latest ACL configuration is used. + +4. You can now check the updated ACL configuration in the admin panel: + + :::details Admin ACL Output + + ![Admin ACL Output](../../assets/1.5.x/images/package-development/admin-acl-output.png) + + ::: + +## Checking Roles and Permissions + +To check roles and permissions, follow these steps: + +1. Open the **`Admin`** model in the **`Webkul\User\Models`** namespace. + +2. In this model, you will find a relationship binding with the **`Role`** model in the same namespace. You can use this relationship to access all the permissions of the current user. + +3. We have provided the **`bouncer()`** helper function, which allows you to check permissions. Use the following code to check if the current user has a specific permission: + + ```php + bouncer()->hasPermission($permission) + ``` + + Replace `$permission` with the actual permission you want to check. + +By following these steps, you can configure and manage the Access Control List (ACL) in Bagisto. \ No newline at end of file diff --git a/docs/1.5.x/packages/create-custom-configuration.md b/docs/1.5.x/packages/create-custom-configuration.md new file mode 100644 index 00000000..75108965 --- /dev/null +++ b/docs/1.5.x/packages/create-custom-configuration.md @@ -0,0 +1,305 @@ +# Custom Configuration + +[[TOC]] + +Creating a custom configuration makes it easier for developers or non-developers to manage settings in Bagisto. In Bagisto, custom configurations can be found in the admin panel under the **Configuration Menu**. + +## Directory Structure + +To create a custom configuration for your application, follow these steps: + +1. Create a **`system.php`** file in the **`Config`** folder of your package: + + ``` + └── packages + └── Webkul + └── Blog + ├── ... + └── src + └── ... + └── Config + └── system.php + + ``` + +2. Inside the **`system.php`** file, include the following code: + + ```php + 'blog', + 'name' => 'Blog', + 'sort' => 1 + ], + [ + 'key' => 'blog.settings', + 'name' => 'Blog Settings', + 'sort' => 1, + ], + [ + 'key' => 'blog.settings.package', + 'name' => 'Package Status', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'status', + 'title' => 'Status', + 'type' => 'boolean', + 'validation' => 'required' + ] + ] + ], + [ + 'key' => 'blog.settings.blog-setting', + 'name' => 'blog::app.admin.system.blog-setting', + 'sort' => 2, + 'fields' => [ + [ + 'name' => 'pagination', + 'title' => 'blog::app.admin.system.pagination', + 'type' => 'select', + 'validation' => 'required', + 'options' => [ + [ + 'title' => 'Yes', + 'value' => 1, + ], + [ + 'title' => 'No', + 'value' => 0, + ], + ] + ], + [ + 'name' => 'items', + 'title' => 'blog::app.admin.system.items', + 'type' => 'number', + 'validation' => 'numeric' + ] + ] + ] + ]; + ``` + + This code defines the custom configuration settings. Each configuration has a key, name, sort, and fields (if applicable). + +## Merge Configuration + +To merge the custom configuration, follow these steps: + +1. Open the **`BlogServiceProvider`** class in the **`Webkul\Blog\Providers`** namespace. + +2. In the **`register`** method, add the following code to merge the custom configuration: + + ```php + mergeConfigFrom( + dirname(__DIR__) . '/Config/system.php', 'core' + ); + } + } + ``` + + This code merges the custom configuration with the existing configuration. + +3. After making the changes, run the following command to cache the latest changes: + + ```sh + php artisan optimize + ``` + + This ensures that the latest custom configuration is used. + +4. You can now check the updated configuration in the admin panel: + + :::details Custom Configuration + + ![Admin Custom Config Output](../../assets/1.5.x/images/package-development/custom-config-output.png) + + ::: + +## Supported Field Types + +Bagisto supports several field types for custom configurations. Let's explore each of them: + +### Text Type + +This field type provides an input field of type text. + +#### Example + +```php +return [ + // ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + + + [ + 'name' => 'text_type', + 'title' => 'admin::app.admin.system.text-type', + 'type' => 'text', + 'default_value' => '', + ], + ], + ], + // ... +]; +``` + +### Number Type + +This field type provides an input field of type number. + +#### Example + +```php +return [ + // ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'number_type', + 'title' => 'admin::app.admin.system.number-type', + 'type' => 'number', + ], + ], + ], + // ... +]; +``` + +### Boolean Type + +This field type provides an enable/disable switch. + +#### Example + +```php +return [ + // ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'boolean_type', + 'title' => 'admin::app.admin.system.boolean-type', + 'type' => 'boolean', + ], + ], + ], + // ... +]; +``` + +### Select Type + +This field type provides a select field with specified options. + +#### Example + +```php +return [ + // ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'select_type', + 'title' => 'admin::app.admin.system.select-type', + 'type' => 'select', + 'options' => [ + [ + 'title' => 'option_1', + 'value' => 'value_1', + ], + [ + 'title' => 'option_2', + 'value' => 'vallue_2', + ], + ], + ], + ], + ], + // ... +]; +``` + +### Textarea Type + +This field type provides a textarea field, mostly used for long text. + +#### Example + +```php +return [ + // ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'textarea_type', + 'title' => 'admin::app.admin.system.textarea-type', + 'type' => 'textarea' + ], + ], + ], + // ... +]; +``` + +### Image Type + +This field type provides a file upload option for uploading images. + +#### Example + +```php +return [ + // ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'image_type', + 'title' => 'admin::app.admin.system.image-type', + 'type' => 'image', + 'validation' => 'mimes:bmp,jpeg,jpg,png,webp', + ], + ], + ], + // ... +]; +``` \ No newline at end of file diff --git a/docs/1.5.x/packages/create-migrations.md b/docs/1.5.x/packages/create-migrations.md new file mode 100644 index 00000000..928baba8 --- /dev/null +++ b/docs/1.5.x/packages/create-migrations.md @@ -0,0 +1,112 @@ +# Migrations + +[[TOC]] + +To understand Migrations in detail, you can visit the Laravel documentation [here](https://laravel.com/docs/10.x/migrations). + +## Using Bagisto Package Generator + +This command creates a new migration class in the **`packages/Webkul/Blog/src/Database/Migrations`** directory. + +```sh +php artisan package:make-migration CreatePostsTable Webkul/Blog +``` + +## Using Laravel Artisan Command + +- Create a **`Database`** folder in the **`packages/Webkul/Blog/src`** path. Inside the **`Database`** folder, create **`Migrations`** and **`Seeders`** folders. + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Database + ├── Migrations + └── Seeders + ``` + +- Run the following command with the **`--path`** option to specify where your migration file will be placed. + + ```sh + php artisan make:migration create_posts_table --path=packages/Webkul/Blog/src/Database/Migrations + ``` + +- Copy the code provided here and paste it into your migration file. + + ```php + id(); + $table->string('title')->nullable(); + $table->longText('description')->nullable(); + $table->integer('user_id'); + $table->tinyInteger('status')->default(1); + $table->timestamps(); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::dropIfExists('posts'); + } + }; + ``` + +### Loading Migration from Package + +- We need to add the migrations to our service provider to load them. + + ```php + loadMigrationsFrom(__DIR__ .'/../Database/Migrations'); + } + } + ``` + +### Creating Tables from Migrations + +- Run the following command to create the **`posts`** table in your database. + + ```sh + php artisan migrate + ``` diff --git a/docs/1.5.x/packages/create-models.md b/docs/1.5.x/packages/create-models.md new file mode 100644 index 00000000..2adc7e9d --- /dev/null +++ b/docs/1.5.x/packages/create-models.md @@ -0,0 +1,192 @@ +# Models + +[[TOC]] + +To understand Models in detail, you can visit the Laravel documentation [here](https://laravel.com/docs/10.x/eloquent). + +We are using the [konekt/concord](https://packagist.org/packages/konekt/concord) package, which is an extension of Laravel. It helps in building modular Laravel applications. + +## Using Bagisto Package Generator + +- This command creates a new **`Post`** Model inside your package. + + ```sh + php artisan package:make-model Post Webkul/Blog + ``` + +- This command creates the following files: + - New model **`Post.php`** in the **`packages/Webkul/Blog/src/Models`** directory. + - New model proxy **`PostProxy.php`** in the **`packages/Webkul/Blog/src/Models`** directory. + - New model contract **`Post.php*`** in the **`packages/Webkul/Blog/src/Contracts`** directory. + +## Using Laravel Artisan Command + +Before creating the model class, we need to create two things: the **`Contract`** and the **`Proxy`**. + +### Contract + +Laravel's Contracts are a set of interfaces that define the core services provided by the framework. For example, the **`Illuminate\Contracts\Queue\Queue`** contract defines the methods needed for queueing jobs, while the **`Illuminate\Contracts\Mail\Mailer`** contract defines the methods needed for sending an email. + +Each contract has a corresponding implementation provided by the framework. For example, Laravel provides a queue implementation with various drivers and a mailer implementation powered by SwiftMailer. + +All Laravel contracts are stored in their own GitHub repository. This provides a quick reference for all available contracts and a single, decoupled package that can be used by package developers. + +- Now, create a folder named **`Contracts`** inside **`Webkul/Blog/src/`** and create an interface file named **`Post.php`**. + + ``` + packages + └── Webkul + └── Blog + └── src + ├── ... + └── Contracts + └── Post.php + ``` + +- Copy the following code into the **`Post.php`** file. + + ```php + belongsTo(Admin::class, 'user_id'); + } + } + ``` + +### Module Service Provider + +- Now, we need to create a provider named **`ModuleServiceProvider.php`** inside **`Webkul/Blog/src/Providers`**. + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Providers + ├── BlogServiceProvider.php + └── ModuleServiceProvider.php + ``` + +- In this file, we register the models used in this package. You can see the code below. + + ```php + [ + // Other service providers + \Webkul\Blog\Providers\ModuleServiceProvider::class, + ] + ]; + ``` \ No newline at end of file diff --git a/docs/1.5.x/packages/create-package.md b/docs/1.5.x/packages/create-package.md new file mode 100644 index 00000000..41b57f56 --- /dev/null +++ b/docs/1.5.x/packages/create-package.md @@ -0,0 +1,195 @@ +# Getting Started + +[[TOC]] + +## Using Bagisto Package Generator + +To facilitate package development, you can use the [Bagisto Package Generator](https://github.com/bagisto/bagisto-package-generator). Follow the steps below to install it: + +1. Install the Bagisto Package Generator by running the following command in the root folder of your Bagisto application: + + ```shell + composer require bagisto/bagisto-package-generator + ``` + +2. Once installed, you can generate your package using the following command: + + - If the package directory does not exist: + + ```shell + php artisan package:make Webkul/Blog + ``` + + - If the package directory already exists, you can use the **`--force`** option to overwrite it: + + ```shell + php artisan package:make Webkul/Blog --force + ``` + + This command will set up the necessary files and directories in the **`packages`** directory. + +### Registering Your Package + +To register your package, follow these steps: + +1. Add your package's namespace to the **`psr-4`** section in the **`composer.json`** file located in the root directory of your Bagisto application. Update it as follows: + + ```json + "autoload": { + ... + "psr-4": { + // Other PSR-4 namespaces + "Webkul\\Blog\\": "packages/Webkul/Blog/src" + } + } + ``` + +2. Register your package's service provider in the **`config/app.php`** file located in the root directory of your Bagisto application. Add the following line to the **`providers`** array: + + ```php + ServiceProvider::defaultProviders()->merge([ + // Other service providers + Webkul\Blog\Providers\BlogServiceProvider::class, + ])->toArray(), + + // Other configuration options + ]; + ``` + +3. Run the following commands to autoload your package and publish its assets and configurations: + + ```shell + composer dump-autoload + php artisan optimize + php artisan vendor:publish --force + ``` + + When prompted to select which items to publish, choose the number corresponding to **`"Webkul\Blog\Providers\BlogServiceProvider"`** and press enter to publish all assets and configurations. + +::: details Example Output in the Browser + +![helloworld-admin-browser-output](../../assets/1.5.x/images/package-development/blog-package-output.png) + +::: + +Congratulations! Your package is now registered and ready to use. Start creating something cool! + +## Manual Setup of Files + +If you prefer to set up your package manually, follow these steps assuming you are familiar with package directory structures and workflows. We'll use the default **`package`** folder in Bagisto as an example. + +### Create Package Directory + +1. Inside the **`packages/Webkul`** folder, create a folder with your package name. Your structure should look like this: + + ``` + └── packages + └── Webkul + └── Blog + ``` + +2. In your package folder, create a folder named as **`src`**. This is where you'll put all your package-related files. Your updated structure will look like this: + + ``` + └── packages + └── Webkul + └── Blog + └── src + ``` + +### Create Service Provider + +1. In the **`src`** folder, create a folder named as **`Providers`**. Inside that folder, create a file named as **`BlogServiceProvider.php`**. Your structure should look like this: + + ``` + └── packages + └── Webkul + └── Blog + └── src + └── Providers + └── BlogServiceProvider.php + ``` + +2. Copy the following code and paste it into **`BlogServiceProvider.php`**: + + ```php + ServiceProvider::defaultProviders()->merge([ + // Other service providers + Webkul\Blog\Providers\BlogServiceProvider::class, + ])->toArray(), + + // Other configuration options + ]; + ``` + +3. Run the following command to autoload your package: + + ```shell + composer dump-autoload + ``` + + Your package is now ready to use! \ No newline at end of file diff --git a/docs/1.5.x/packages/customize-hompepage-menu.md b/docs/1.5.x/packages/customize-hompepage-menu.md new file mode 100644 index 00000000..f294d147 --- /dev/null +++ b/docs/1.5.x/packages/customize-hompepage-menu.md @@ -0,0 +1,29 @@ +# Homepage Menu + +[[TOC]] + +This section provides an overview of menu items, how to access them, and how they can be customized. Both the **`default`** and **`velocity`** themes display categories in the menu items. + +## Accessing Categories + +To access the menu categories, you can utilize the **`CategoryRepository`** class located in the **`Webkul\Category\Repositories\CategoryRepository`** namespace. This repository class provides useful methods for retrieving and managing categories. + +One such method is **`getVisibleCategoryTree`**, which returns a list of all visible categories under the specified root category. You can pass the ID of the main root category as a parameter to this method. + +## Example from the Default Theme + +In the default theme's blade file, you can find the following code snippet: + +```php +@foreach (app('Webkul\Category\Repositories\CategoryRepository')->getVisibleCategoryTree(core()->getCurrentChannel()->root_category_id) as $category) + // ... +@endforeach +``` + +You can iterate through the retrieved categories and customize the menu according to your specific requirements. + +::: tip + +The **`CategoryRepository`** class provides several other methods for working with categories. Take some time to explore and utilize those methods as needed. + +::: \ No newline at end of file diff --git a/docs/1.5.x/packages/datagrid.md b/docs/1.5.x/packages/datagrid.md new file mode 100644 index 00000000..f55747b9 --- /dev/null +++ b/docs/1.5.x/packages/datagrid.md @@ -0,0 +1,337 @@ +# DataGrid + +[[TOC]] + +## Introduction + +A DataGrid is a concept of displaying your database records in a tabular format. It is a powerful tool that helps you present large amounts of data in an organized way. At Bagisto, we have implemented this feature, which allows you to use it to display data in a tabular format or write code from scratch to display data. In addition to the basic functionality of DataGrid, we have also implemented additional features such as sorting, filtering, and mass action, which are explained in detail below. + +## Global Properties of DataGrid + +Here are the global properties of the DataGrid: + +| Property | Functionality | +| ----------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| **`index`** | This property is defined in the grid, and the value assigned to this property must be unique, typically the primary key, so that data will be uniquely identified and operations performed will be based on your index value. | +| **`sortOrder`** | The **`sortOrder`** key is used to arrange the results in ascending or descending order. Set the **`sortOrder`** variable to **`asc`** or **`desc`**. | +| **`queryBuilder`** | This is used to perform database operations in your application. | +| **`enableMassAction`** | This accepts boolean values **`true`** or **`false`** to enable or disable the mass action in DataGrid. | +| **`enableAction`** | This accepts boolean values **`true`** or **`false`** to enable or disable the action column of DataGrid. | +| **`paginate`** | Set the **`paginate`** property to **`true`** to allow pagination on your page. | +| **`itemsPerPage`** | The **`itemsPerPage`** key is used to display the number of items per page. | +| **`enableFilterMap`** | This accepts boolean values **`true`** or **`false`** to enable or disable filtering on the basis of columns. | + +## How DataGrid Works + +The **`DataGrid`** abstract class is created in the **`Webkul\Ui`** package. In the abstract class, a list of properties and methods are declared. To create your own DataGrid, you need to extend the **`Webkul\Ui\DataGrid\DataGrid`** abstract class. + +In **`Webkul\Ui\DataGrid\DataGrid.php`** abstract class, two abstract methods are declared **`prepareQueryBuilder()`** and **`addColumns()`**. You can prepare your grid by defining these two methods. + +- **`prepareQueryBuilder()`**: In this method, records are retrieved through queries applicable to the database and stored in a collection. When records are retrieved, the **`setQueryBuilder()`** method is called. + +- **`setQueryBuilder()`**: This method is used for setting the **`$queryBuilder`**. + + ```php + public function prepareQueryBuilder() + { + $queryBuilder = DB::table('posts') + ->select('id', 'title', 'status', 'created_at', 'updated_at') + ->where('user_id', '=', auth()->guard('admin')->user()->id); + + $this->setQueryBuilder($queryBuilder); + } + ``` + +- **`addColumns()`**: In this method, columns are created which are displayed in the grid. The parameter accepts an array in key-value pairs. Some of the essential keys are described below: + + | Key | Functionality | + | ------------- | ------------------------------------------------------------------------ | + | **`index`** | This key is defined in the grid, and the value assigned to this key must be unique, typically the primary key, so that data will be uniquely identified and operations performed will be based on your index value. | + | **`label`** | This key defines the name of the column. | + | **`type`** | This key accepts the type of data in the column. | + | **`searchable`** | This accepts boolean values **`true`** or **`false`** to make the column searchable. | + | **`sortable`** | This accepts boolean values **`true`** or **`false`** to make the column sortable. | + | **`filterable`** | This accepts boolean values **`true`** or **`false`** to make the column filterable. | + | **`wrapper`** | Perform actions based on a condition satisfied or apply some customization to the value. | + + ```php + public function addColumns() + { + $this->addColumn([ + 'index' => 'id', + 'label' => trans('blog::app.admin.datagrid.id'), + 'type' => 'number', + 'searchable' => false, + 'sortable' => true, + 'filterable' => true + ]); + } + ``` + +- **`prepareActions()`**: This method is defined when there is a need to perform any action such as edit or delete on the grid. In this method, the **`addAction()`** method is called to define a particular action. + +- **`addAction()`**: This method is used for adding actions (like **`edit`**, **`delete`**, etc.) to each row generated by the DataGrid. + + | Key | Functionality | + | ------------- | ------------------------------------------------------------------------ | + | **`title`** | The text to be displayed is written here. | + | **`method`** | HTTP methods are declared. | + | **`route`** | This key accepts the route of the icon. | + | **`icon`** | Class of the icon to be displayed in the action column. You may prefer text also. | + + ```php + public function prepareActions() + { + $this->addAction([ + 'title' => trans('blog::app.admin.datagrid.edit'), + 'method' => 'GET', + 'route' => 'admin.blog.edit', + 'icon' => 'icon pencil-lg-icon' + ]); + } + ``` + +## Multiple DataGrids + +When working with multiple DataGrids, the default DataGrid implementation can handle only a single request at a time. This means that operations such as filtration, sorting, and others can conflict when implementing multiple DataGrids. To overcome this, we provide a trait called **`ProvideDataGridPlus`** in the namespace **`Webkul\Ui\DataGrid\Traits`**. + +Follow the steps below to implement multiple DataGrids: + +1. Create a folder called **`DataGrids`** inside the **`src`** folder of your package. Within the **`DataGrids`** folder, create a file called **`PostDataGrid.php`** that extends the **`DataGrid`** class from the **`Webkul\Ui`** package. The directory structure will be as follows: + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── DataGrids + └── PostDataGrid.php + ``` + +2. Add the following code to your DataGrid file, i.e., **`PostDataGrid.php`**: + + ```php + namespace Webkul\Blog\DataGrids; + + use Webkul\Ui\DataGrid\DataGrid; + + class PostDataGrid extends DataGrid + { + // ... + } + ``` + +### DataGrid to JSON + +3. Import the **`ProvideDataGridPlus`** trait into the **`PostDataGrid`** class: + + ```php + namespace Webkul\Blog\DataGrids; + + use Webkul\Ui\DataGrid\Traits\ProvideDataGridPlus; + + class PostDataGrid extends DataGrid + { + use ProvideDataGridPlus; + + // ... + } + ``` + +4. After that, the **`toJson()`** method will be available in the DataGrid instance, which provides data to the component. + +5. Now, go to **`Admin/PostController.php`** and locate the **`index`** method. Use the **`toJson()`** method as follows: + + ```php + use Webkul\Blog\DataGrids\PostDataGrid; + + class PostController extends Controller + { + /** + * Display a listing of the resource. + * + * @return \Illuminate\View\View + */ + public function index() + { + if (request()->ajax()) { + return app(PostDataGrid::class)->toJson(); + } + + return view('blog::admin.index'); + } + + // ... + } + ``` + +### Render DataGrid + +6. In the view file **`views/admin/index.blade.php`**, use the **`datagrid-plus`** component and specify the URL from which it will load the JSON data: + + ```php +
+ ... + + + + ... +
+ ``` + + With these steps, your DataGrid is now ready to be used. + +::: warning +Make sure to copy the sample code provided below to your own **`PostDataGrid.php`** file, as we have already included all the necessary methods and functions there. This code can be used later as an example for your implementation. +::: + +## Sample DataGrid + +Here's an improved version of the provided DataGrid sample: + +```php +select('id', 'title', 'status', 'created_at', 'updated_at') + ->where('user_id', '=', auth()->guard('admin')->user()->id); + + $this->setQueryBuilder($queryBuilder); + } + + /** + * Add columns. + */ + public function addColumns() + { + $this->addColumn([ + 'index' => 'id', + 'label' => trans('blog::app.admin.datagrid.id'), + 'type' => 'number', + 'searchable' => false, + 'sortable' => true, + 'filterable' => true, + ]); + + $this->addColumn([ + 'index' => 'title', + 'label' => trans('blog::app.admin.datagrid.title'), + 'type' => 'string', + 'searchable' => true, + 'sortable' => true, + 'filterable' => false, + 'wrapper' => function ($value) { + return substr($value->title, 0, 30); + }, + ]); + + $this->addColumn([ + 'index' => 'status', + 'label' => trans('blog::app.admin.datagrid.status'), + 'type' => 'boolean', + 'sortable' => true, + 'searchable' => false, + 'filterable' => true, + 'closure' => function ($value) { + $html = ''; + + if ($value->status) { + $html .= '' . trans('blog::app.admin.datagrid.active') . ''; + } else { + $html .= '' . trans('blog::app.admin.datagrid.inactive') . ''; + } + + return $html; + }, + ]); + + $this->addColumn([ + 'index' => 'created_at', + 'label' => trans('blog::app.admin.datagrid.created_at'), + 'type' => 'datetime', + 'searchable' => true, + 'sortable' => true, + 'filterable' => true, + ]); + + $this->addColumn([ + 'index' => 'updated_at', + 'label' => trans('blog::app.admin.datagrid.updated_at'), + 'type' => 'datetime', + 'searchable' => true, + 'sortable' => true, + 'filterable' => true, + ]); + } + + /** + * Prepare actions. + */ + public function prepareActions() + { + $this->addAction([ + 'title' => trans('blog::app.admin.datagrid.edit'), + 'method' => 'GET', + 'route' => 'admin.blog.edit', + 'icon' => 'icon pencil-lg-icon', + ]); + + $this->addAction([ + 'title' => trans('blog::app.admin.datagrid.delete'), + 'method' => 'POST', + 'route' => 'admin.blog.delete', + 'icon' => 'icon trash-icon', + ]); + } + + /** + * Prepare mass actions. + */ + public function prepareMassActions() + { + $this->addMassAction([ + 'type' => 'update', + 'action' => route('admin.blog.massupdate'), + 'label' => trans('blog::app.admin.datagrid.massupdate'), + 'method' => 'POST', + 'options' => [ + trans('blog::app.admin.datagrid.active') => 1, + trans('blog::app.admin.datagrid.inactive') => 0, + ], + ]); + + $this->addMassAction([ + 'type' => 'delete', + 'action' => route('admin.blog.massdelete'), + 'label' => trans('blog::app.admin.datagrid.massdelete'), + 'method' => 'POST', + ]); + } +} +``` \ No newline at end of file diff --git a/docs/1.5.x/packages/layouts.md b/docs/1.5.x/packages/layouts.md new file mode 100644 index 00000000..3b5a4c2e --- /dev/null +++ b/docs/1.5.x/packages/layouts.md @@ -0,0 +1,56 @@ +# Layouts + +[[TOC]] + +To learn in detail about Layouts, you can visit the Laravel documentation [here](https://laravel.com/docs/10.x/blade). + +## Extend Admin Layout + +Now, let's extend the default layout of the Bagisto admin panel by using **`@extends('admin::layouts.master')`** in the file **`packages/Webkul/Blog/src/Resources/views/admin/index.blade.php`**. You can copy the following template to your **`index.blade.php`** file: + +```html +@extends('admin::layouts.master') + +@section('page_title') {{ __('blog::app.admin.index.page-title') }} @stop + +@section('content-wrapper') + +
+ +
+
+
+ +@stop +``` + +## Extend Shop Layout + +Similarly, for the file **`packages/Webkul/Blog/src/Resources/views/shop/velocity/index.blade.php`**, you can extend the shop layout by using **`@extends('shop::layouts.master')`**. You can copy the following template to your **`index.blade.php`** file: + +```html +@extends('shop::layouts.master') + +@section('page_title') {{ __('blog::app.shop.blogs.page-title') }} @stop + +@section('content-wrapper') + +
+
+
+
+ +@stop +``` + +::: warning +Notice that there are translations used in the blade files, so you will also need to add the corresponding translations in **`lang/app.php`**. +::: + +If you don't want to include these layouts, you can create your own master file. \ No newline at end of file diff --git a/docs/1.5.x/packages/localization.md b/docs/1.5.x/packages/localization.md new file mode 100644 index 00000000..0b98ec4e --- /dev/null +++ b/docs/1.5.x/packages/localization.md @@ -0,0 +1,86 @@ +# Localization + +[[TOC]] + +To learn in detail about Localization, you can visit the Laravel documentation [here](https://laravel.com/docs/10.x/localization). + +## Directory Structure + +- Now, let's create a language file for our package. Create a **`lang`** folder in the **`packages/Webkul/Blog/src/Resources`** path. + +- Inside the **`lang`** folder, you can create different folders for language translations. For example, you can create folders for English ('en'), Hindi ('hi'), etc. For now, let's create a folder named **`en`** (representing the language code). Inside the **`en`** folder, create a file named **`app.php`** for language translation. + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Resources + ├── ... + └── lang + └── en + └── app.php + ``` + +- Now, let's write a translation in **`app.php`** as follows: + + ```php + [ + 'name' => 'John Doe' + ] + ]; + ``` + +## Load Translation from Package + +- We need to register the language file in the service provider. + + ```php + loadTranslationsFrom(__DIR__ . '/../Resources/lang', 'blog'); + } + } + ``` + +- Add the following code to your Blade file: + + ```html + {{ __('blog::app.admin.name') }} + ``` + + ::: details Admin Output + + ![Translation Output](../../assets/1.5.x/images/package-development/blog-admin-lang-output.png) + + ::: + + ::: details Shop Output + + ![Translation Output](../../assets/1.5.x/images/package-development/blog-shop-lang-output.png) + + ::: \ No newline at end of file diff --git a/docs/1.5.x/packages/routes.md b/docs/1.5.x/packages/routes.md new file mode 100644 index 00000000..79f8eb58 --- /dev/null +++ b/docs/1.5.x/packages/routes.md @@ -0,0 +1,80 @@ +# Routes + +[[TOC]] + +To learn in detail about Routes, you can visit the Laravel documentation [here](https://laravel.com/docs/10.x/routing). + +## Directory Structure + +- Create a **`Routes`** folder inside **`packages/Webkul/Blog/src`** and create two files named **`admin-routes.php`** and **`shop-routes.php`**. The updated directory structure will look like this: + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Routes + ├── admin-routes.php + └── shop-routes.php + ``` + +- **`admin-routes.php`**: This file is for admin routes. Add the following code to this file: + + ```php + ['web', 'admin'], 'prefix' => config('app.admin_url')], function () { + Route::get('/blog', [PostController::class, 'index']); + }); + ``` + +- **`shop-routes.php`**: This file is for shop routes. Add the following code to this file: + + ```php + ['web', 'theme', 'locale', 'currency']], function () { + Route::get('/blogs', [PostController::class, 'index']); + }); + ``` + +## Loading Routes + +- Now, we need to register our routes in the service provider's boot method, which is located in **`BlogServiceProvider.php`**. + + ```php + loadRoutesFrom(__DIR__ . '/../Routes/admin-routes.php'); + + $this->loadRoutesFrom(__DIR__ . '/../Routes/shop-routes.php'); + } + } + ``` \ No newline at end of file diff --git a/docs/1.5.x/packages/store-data-through-repositories.md b/docs/1.5.x/packages/store-data-through-repositories.md new file mode 100644 index 00000000..38fc23ef --- /dev/null +++ b/docs/1.5.x/packages/store-data-through-repositories.md @@ -0,0 +1,78 @@ +# Repository + +[[TOC]] + +## Introduction + +In traditional development, application logic is often written directly in the controller. However, there is an alternative approach that abstracts some of these calls into PHP classes called Repositories. The purpose of repositories is to decouple models from controllers and provide readable names for complex queries. + +This file defines our Repository class. Instances of this class have a model property that is bound to an Eloquent model. With this binding in the constructor, we can call Eloquent methods such as findOrFail, update, or all from the class methods. + +We are using the Prettus Repository package. You can find all available methods in the Prettus repository [here](https://github.com/andersao/l5-repository). Here are some examples: + +Examples: + +| Sl. no. | Method | Description | +| ------- | ------ | ----------- | +| 1 | all | Find all results in the Repository | +| 2 | paginate | Find all results in the Repository with pagination | +| 3 | find | Find a result by ID | +| 4 | with(['table_name'])| Load the model relationships | +| 5 | findWhereIn | Find results by multiple values in one field| + +```php +// Bound in constructor +public function __construct(protected PostRepository $postRepository) {} +``` + +```php +// Find all results in the Repository +$posts = $this->postRepository->all(); +``` + +## Using Bagisto Package Generator + +- This command creates a new Repository class in the **`packages/Webkul/Blog/src/Repository`** directory. + + ```sh + php artisan package:make-repository PostRepository Webkul/Blog + ``` + +## Manual Setup of Files + +- Create a **`Repository`** folder inside **`Webkul/Blog/src/`** and create a file named **`PostRepository.php`**. In the repository class, create the **`model()`** method that returns the path of your contract class. + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Repository + └── PostRepository.php + ``` + +- Copy the following code into your newly created repository file. + + ```php + validate([ + 'title' => 'required|unique:posts|max:255', + 'body' => 'required', + ]); +} +``` + +Alternatively, you can manually create a validator instance using the Validator facade, as shown in this example: + +```php + 'required', + 'email' => 'required|email', + 'message' => 'required|max:250', + ]; + + $customMessages = [ + 'required' => 'The :attribute field is required.', + ]; + + $this->validate($request, $rules, $customMessages); + } +} +``` + +## Validation Using Vue + +### Introduction + +VeeValidate is a validation library for Vue.js that provides plenty of validation rules out of the box, along with support for custom rules. It is template-based and similar to the HTML5 validation API, making it easy to validate HTML5 inputs as well as custom Vue components. VeeValidate also supports localization with 44 languages maintained by the community. + +For detailed information about validation in Vue.js using VeeValidate, refer to the [VeeValidate documentation](https://vee-validate.logaretm.com/v2/guide/). + +### Installation + +Bagisto already comes with the VeeValidate library, so there is no need to install it separately. + +### Configuration + +Bagisto includes the configuration for **`vee-validate`**. For example, you can find the configuration in the following path: **`bagisto/packages/Webkul/Admin/src/Resources/assets/js/app.js`**. + +```js +import Vue from 'vue'; +import VeeValidate from 'vee-validate'; + +/** + * Language imports. +*/ +import de from 'vee-validate/dist/locale/en'; +import de from 'vee-validate/dist/locale/de'; +import fa from 'vee-validate/dist/locale/fa'; + +/** + * Vue plugins. +*/ +Vue.use(VeeValidate, { + dictionary: { + en: en, + de: de, + fa: fa, + }, + events: 'input|change|blur' +}); +``` + +### Examples + +Here are some examples of Vue validation using VeeValidate: + +```html + + + + + +``` \ No newline at end of file diff --git a/docs/1.5.x/packages/views.md b/docs/1.5.x/packages/views.md new file mode 100644 index 00000000..43b8ba7c --- /dev/null +++ b/docs/1.5.x/packages/views.md @@ -0,0 +1,108 @@ +# Views + +[[TOC]] + +To learn in detail about Views, you can visit the Laravel documentation [here](https://laravel.com/docs/10.x/views). + +## Directory Structure + +- Create a **`Resources`** folder in the **`packages/Webkul/Blog/src`** path. Inside the **`Resources`** folder, create another folder named **`views`**. Now, inside the **`views`** folder, we need to create two folders, namely **`admin`** and **`shop`**. Finally, we need to create two more folders, namely **`default`** and **`velocity`**, under the **`shop`** folder. The updated directory structure will look like this: + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Resources + └── views + ├── admin + └── shop + ├── default + └── velocity + ``` + + ::: tip The default and velocity folders + Whenever you create a Blade file for the shop front, you need to keep the same file in both the **`default`** and **`velocity`** folders. This is because we are using the **`theme`** middleware. When we use the **`default`** theme, the files will be called from the **`default`** folder, and when we use the **`velocity`** theme, the files will be called from the **`velocity`** folder. + ::: + + ::: warning + In this tutorial, we are using the **`theme`** middleware and the **`velocity`** theme. Therefore, it is necessary to keep the files in the **`velocity`** folder. However, if we are not using the **`default`** theme, it is not necessary to keep the same files in the **`default`** folder. + ::: + +- Inside each folder, **`admin`** and **`velocity`**, create a file named **`index.blade.php`** and add some HTML to it. + + ``` + └── packages + └── Webkul + └── Blog + └── src + ├── ... + └── Resources + └── views + ├── admin + │ └── index.blade.php + └── shop + ├── default + └── velocity + └── index.blade.php + + ``` + + - **`admin/index.blade.php`** + + ```html +

Blog Admin Page

+ ``` + + - **`shop/velocity/index.blade.php`** + + ```html +

Blog Shop Page

+ ``` + +## Load Views from Package + +- Now, we need to register our views in the service provider's `boot` method. Open the file **`packages/Webkul/Blog/src/Providers/BlogServiceProvider.php`** and update it as follows: + + ```php + loadViewsFrom(__DIR__ . '/../Resources/views', 'blog'); + } + } + ``` + +- Now, check the routes in your browser. + + ::: details Shop Output + + ![Shop Browser Output](../../assets/1.5.x/images/package-development/blog-shop-output.png) + + ::: + + ::: details Admin Output + + ![Admin Browser Output](../../assets/1.5.x/images/package-development/blog-admin-output.png) + + ::: diff --git a/docs/1.5.x/products/simple.md b/docs/1.5.x/products/simple.md new file mode 100644 index 00000000..6ca0fb29 --- /dev/null +++ b/docs/1.5.x/products/simple.md @@ -0,0 +1,9 @@ +# Deploy + +this article will explain how you can deploy your Bagisto store to your production server when you have been developing your Bagisto store on your local system. + +## Deploy Bagisto with (S)FTP + +## Deploy on Cpanel + +## Deploy on Plesk diff --git a/docs/1.5.x/prologue/README.md b/docs/1.5.x/prologue/README.md new file mode 100644 index 00000000..08f5cdf6 --- /dev/null +++ b/docs/1.5.x/prologue/README.md @@ -0,0 +1,23 @@ +# Prologue + +## Introduction to Bagisto + +[Bagisto](https://bagisto.com/) is a fantastic open-source eCommerce platform that allows businesses to create modern online stores easily. Bagisto offers a wide range of customizable features to meet the specific needs of any online business. + +The platform is built on top of the reliable [Laravel](https://laravel.com/) framework and [Vue.js](https://vuejs.org/), a user-friendly JavaScript framework. It provides businesses with a user-friendly interface and powerful tools to manage their online stores, handle inventory and orders, and create a smooth shopping experience for customers. + +## Customization and Branding + +With Bagisto, businesses have the flexibility to customize the look and feel of their online stores, from choosing themes and layouts to adding unique branding elements. The platform offers a comprehensive set of marketing and promotional tools, enabling businesses to attract customers and drive sales effectively. + +## SEO Optimization + +One of Bagisto's standout features is its robust SEO capabilities. It includes built-in SEO tools and optimization options, empowering businesses to improve their search engine rankings and increase organic traffic to their online stores. + +## Payment and Shipping Integration + +Moreover, Bagisto supports a wide range of payment gateways, allowing businesses to offer convenient and secure payment options to their customers. It also integrates seamlessly with popular shipping providers, streamlining the order fulfillment process and ensuring reliable and timely deliveries. + +## Summary + +In summary, Bagisto is a powerful and flexible eCommerce platform that empowers businesses to build and manage online stores efficiently. With its customizable features, user-friendly interface, reliable framework, robust SEO capabilities, and comprehensive set of tools, Bagisto is the perfect choice for businesses looking to establish a strong online presence, drive sales growth, and deliver exceptional customer experiences. \ No newline at end of file diff --git a/docs/1.5.x/prologue/contribution-guide.md b/docs/1.5.x/prologue/contribution-guide.md new file mode 100644 index 00000000..7763c460 --- /dev/null +++ b/docs/1.5.x/prologue/contribution-guide.md @@ -0,0 +1,64 @@ +# Contribution Guide + +[[Toc]] + +## Bug Reports + +To encourage active collaboration, Bagisto welcomes both bug reports and pull requests. Instead of just reporting bugs, we encourage you to submit pull requests that include fixes or negative test cases demonstrating the issue. When filing a bug report, please provide a clear title and description of the problem. Include as much relevant information as possible, along with a code sample that reproduces the bug. The goal is to make it easy for everyone to understand and fix the issue. + +Bug reports are meant to foster collaboration and find solutions. By reporting bugs, you can engage others in solving the problem and contribute to the project's improvement. + +## Projects to Contribute + +You can contribute to the following projects: + +- Bagisto +- Bagisto docs +- Laravel-aliexpress-dropship +- Laravel-aliexpress-dropship-chrome-extension +- Bagisto-custom-style-extension + +## Feature Requests + +We welcome proposals for new features and enhancements to the existing Bagisto app. If you have a new feature in mind, please be prepared to contribute some of the code required to implement it. + +## Branch Selection + +Before submitting a pull request, it's important to consider the following points to help you choose the appropriate branch: + +- **Bug Fixes**: If you're fixing a bug, make sure to port the fix to the latest version that supports it (currently v1.5.1). +- **Minor Feature Requests**: For minor features compatible with the current release, push your changes to the latest stable branch (currently v1.x). +- **Major Feature Requests**: If your request involves a major new feature with potential breaking changes, send it to the master branch, which corresponds to the upcoming release (v2.x). + +## Compiled Assets + +When submitting a change that includes compiled files, please avoid committing the compiled files directly. Maintainers find it difficult to review compiled files, and they may contain malicious code. To prevent this issue, the Bagisto maintainers will generate and commit the compiled files themselves. + +## Security Vulnerabilities + +If you discover a security vulnerability within Bagisto, please notify us immediately by sending an email to Jitendra Singh at [jitendra@webkul.in](mailto:jitendra@webkul.in). We take security vulnerabilities seriously and will address them promptly. + +## Coding Style + +Bagisto follows the [PSR-2](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-2-coding-style-guide.md) coding standard and the [PSR-4](https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-4-autoloader.md) autoloading standard. These standards ensure consistency and readability in the codebase, similar to Laravel. + +## PHPDoc + +Below is an example of a valid Bagisto doc block that follows the coding style: + +```php +/** + * Register a service with CoreServiceProvider. + * + * @param string|array $loader + * @param \Closure|string|null $concrete + * @param bool $shared + * @return void + * + * @throws \Exception + */ +protected function registerFacades($loader, $concrete = null, $shared = false) +{ + // +} +``` \ No newline at end of file diff --git a/docs/1.5.x/prologue/upgrade-guide.md b/docs/1.5.x/prologue/upgrade-guide.md new file mode 100644 index 00000000..93ea4d99 --- /dev/null +++ b/docs/1.5.x/prologue/upgrade-guide.md @@ -0,0 +1,83 @@ +# Upgrade Guide + +[[TOC]] + +## Upgrade Steps + +To upgrade your current version to the latest version of Bagisto, follow these steps: + +1. Download the latest version of Bagisto from one of the following links: + - [Download From Official Bagisto Site](https://bagisto.com/en/download/) + - [Download From GitHub](https://github.com/bagisto/bagisto) + +2. Extract the downloaded Bagisto zip file to the desired deployment location. + +3. Open the terminal and navigate to the root folder of the extracted Bagisto folder. + +4. Run the following command in the terminal: + + ```sh + composer create-project + ``` + + This command will install the necessary dependencies for the latest version of Bagisto. + +5. Open the **`.env`** file in your project's root folder. Provide the database credentials of your old project, which you want to upgrade using Bagisto. + +6. Run one of the following commands to cache the new changes: + + ```sh + php artisan optimize + + # -- OR -- + + php artisan config:cache + ``` + + These commands will cache the configuration files and optimize the project. + +7. Now, your project is ready to run the migration command. Execute the following command in the terminal: + + ```sh + php artisan migrate + ``` + + ::: danger + Be cautious when using the seeder command as it may reset settings and categories. Add default settings manually if necessary. + ::: + +8. Create a symbolic link to link public assets to the storage folder by running the following command: + + ```sh + php artisan storage:link + ``` + +9. Copy the contents of the previous version's folder (e.g., **`old-project/storage/app/public`**) to the corresponding folder in the latest version (e.g., **`new-project/storage/app/public`**). + + ::: tip + If your existing project depends on local storage, has changed paths, or requires previous logs, ensure to include those as well. + ::: + +10. Once the copying is complete, publish the new files by running the following command: + + ```sh + php artisan vendor:publish --all + ``` + + ::: warning + Avoid using the **`--force`** flag, as it will reset all your views. Only use it if you understand the consequences. + ::: + +11. Congratulations! Your project is now upgraded to the latest version of Bagisto. However, keep in mind that if you have made significant customizations, ensure compatibility with the latest version. + +## New Changes + +The following changes have been implemented in Bagisto from version 1.4.5 to 1.5.1: + +- Implemented Elasticsearch for improved search functionality. +- Added a count of selected products in Datagrid. ([GitHub](https://github.com/bagisto/bagisto/pull/7437)) +- Changed the appearance of checkboxes in dark mode. ([GitHub](https://github.com/bagisto/bagisto/pull/7304)) +- Modified routes in Packages. ([GitHub](https://github.com/bagisto/bagisto/pull/7345)) +- Removed Triggers feature. ([GitHub](https://github.com/bagisto/bagisto/pull/7334)) +- Consistent mail configuration as per Laravel standards. ([GitHub](https://github.com/bagisto/bagisto/pull/7509)) +- Removed REST API and JWT package related dependencies. ([GitHub](https://github.com/bagisto/bagisto/pull/7546)) \ No newline at end of file diff --git a/docs/1.5.x/themes/README.md b/docs/1.5.x/themes/README.md new file mode 100644 index 00000000..050378c7 --- /dev/null +++ b/docs/1.5.x/themes/README.md @@ -0,0 +1,27 @@ +# Themes + +If you are looking to customize the appearance and design of your Bagisto e-commerce store, creating a custom theme is the way to go. Bagisto offers a flexible and straightforward approach to theme development, allowing you to tailor the look and feel of your store to align with your brand and meet your specific requirements. + +## Package Development Prerequisite + +Before diving into theme development, it is recommended to have knowledge of creating packages in Laravel. If you are new to package development, you can refer to the [Package Development](../packages) section for a primer on creating and managing packages in Laravel. Understanding package development concepts will greatly assist you in creating and organizing your custom theme. + +## Creating a Custom Theme + +Creating a custom theme for Bagisto involves a few simple steps. Here's an overview of the process: + +1. **Create a Package**: As themes in Bagisto are treated as packages, the first step is to create a new package specifically for your theme. This package will serve as the container for your theme files and configuration. + +2. **Configure the Package**: Once the package is created, you need to configure it by defining the necessary details such as the package name, author, description, and other relevant information. This configuration ensures that Bagisto recognizes your package as a theme. + +3. **Define the Theme Assets**: In Bagisto, themes are primarily composed of assets such as CSS stylesheets, JavaScript files, and image files. You will need to create the appropriate directories within your theme package to store these assets. + +4. **Create Blade Views**: Blade views are the templates used to render the frontend of your store. You can create your own custom views within your theme package, allowing you to customize the appearance of different pages and components. + +5. **Configure Theme Layout**: Bagisto provides a layout system that defines the structure and organization of your store's pages. You can configure the layout for your theme by specifying the positions of various components, such as the header, footer, sidebar, and content sections. + +6. **Customize Theme Styles**: To achieve a unique and visually appealing design, you can customize the CSS stylesheets of your theme. This includes modifying colors, typography, spacing, and other visual elements to match your branding and aesthetic preferences. + +7. **Activate and Test the Theme**: Once your custom theme is ready, you can activate it in the Bagisto admin panel. This will make your theme the active theme for your store, reflecting the changes and customizations you have made. It is crucial to thoroughly test your theme to ensure its compatibility and responsiveness across different devices and browsers. + +By following these steps, you can create a fully customized theme for your Bagisto e-commerce store. This empowers you to create a unique and engaging shopping experience for your customers, aligning with your brand identity and enhancing your online presence. \ No newline at end of file diff --git a/docs/1.5.x/themes/create-admin-theme.md b/docs/1.5.x/themes/create-admin-theme.md new file mode 100644 index 00000000..1ad7a16c --- /dev/null +++ b/docs/1.5.x/themes/create-admin-theme.md @@ -0,0 +1,101 @@ +# Admin Theme + +[[TOC]] + +## Configuration + +To configure the admin theme in Bagisto, follow these steps: + +1. In the Bagisto root directory, navigate to the **config** folder and open the **`themes.php`** file. Look for the keys **`admin-default`** and **`admin-themes`**. The configuration will appear as follows: + + ```php + 'default', + + 'admin-themes' => [ + 'default' => [ + 'views_path' => 'resources/admin-themes/default/views', + 'assets_path' => 'public/admin-themes/default/assets', + 'name' => 'Default' + ] + ] + ]; + ``` + + | Key | Description | + | -------------- | ---------------------------------------- | + | admin-default | Sets the current theme for the admin area | + | admin-themes | Stores a list of available themes | + +## Creating a Theme + +To create a new admin theme, follow these steps: + +1. Add a new theme entry to the **`admin-themes`** array in the **`themes.php`** file: + + ```php + 'default', + + 'admin-themes' => [ + 'default' => [ + 'views_path' => 'resources/admin-themes/default/views', + 'assets_path' => 'public/admin-themes/default/assets', + 'name' => 'Default' + ], + + 'theme1' => [ + 'views_path' => 'resources/admin-themes/theme1/views', + 'assets_path' => 'public/admin-themes/theme1/assets', + 'name' => 'Theme 1' + ] + ] + ]; + ``` + +2. In the new theme entry, specify the path to the views and assets folders according to your desired structure. For example: + + - Views structure: + + ``` + - resources + └── admin-themes + └── theme1 + └── views + ``` + + - Assets structure: + + ``` + - public + └── admin-themes + └── theme1 + └── assets + ``` + +3. To replace the dashboard page with a custom version, create the same directory structure for the dashboard in the **`theme1`** folder as it exists in the **`default`** folder. For example: + + ``` + - resources + └── admin-themes + └── theme1 + └── views + └── dashboard + └── index.blade.php + ``` + +4. In the newly created **`index.blade.php`** file, add the desired content for the dashboard page. For example: + + ```php + Theme 1 Sample + ``` + +5. Finally, activate the new theme by changing the value of the **`admin-default`** key in the **`config/themes.php`** file: + + ```php + 'admin-default' => 'theme1', + ``` + +Now, when you access the dashboard page in the admin area, you should see the customized version provided by the new theme (Theme 1). \ No newline at end of file diff --git a/docs/1.5.x/themes/create-theme.md b/docs/1.5.x/themes/create-theme.md new file mode 100644 index 00000000..3c24c36e --- /dev/null +++ b/docs/1.5.x/themes/create-theme.md @@ -0,0 +1,82 @@ +# Store Theme + +[[TOC]] + +## Configuration + +To configure the store theme in Bagisto, follow these steps: + +1. Go to your project's root directory and locate the **`config`** folder. Inside the **`config`** folder, you will find a file named **`themes.php`**. + + ``` + - app + - bin + - bootstrap + - config + ├── ... + └── themes.php + - database + - packages + └── Webkul + ``` + +2. Open the **`themes.php`** file to examine its contents. This file contains all the necessary information for creating a custom theme in Bagisto. + + ```php + 'default', + + 'themes' => [ + 'default' => [ + 'views_path' => 'resources/themes/default/views', + 'assets_path' => 'public/themes/default/assets', + 'name' => 'Default' + ], + + 'velocity' => [ + 'views_path' => 'resources/themes/velocity/views', + 'assets_path' => 'public/themes/velocity/assets', + 'name' => 'Velocity', + 'parent' => 'default' + ], + ], + ]; + ``` + +3. Let's go through the parameters defined in the **`themes.php`** file as understanding them will help you in creating a custom theme. + +### Explanation of Parameters: + +- **default**: This parameter at the top of the file indicates the currently active or default theme in Bagisto. It is set to **`'default'`**, representing the name of the currently active theme. + +- **themes**: This parameter allows you to define the configurations for your custom themes. You can create and use multiple themes simultaneously in Bagisto. + + - Inside the **`'themes'`** array, there is another array named **`'default'`**, which represents your currently active theme. It contains several key-value pairs that are explained below: + + - **views_path**: This parameter specifies the path to the views or blade files for your custom theme. + + - **assets_path**: It determines the path to the assets such as images, CSS files, and JavaScript files for your theme. + + - **name**: This parameter defines a global name for your theme inside Bagisto. + + - **parent**: This is an optional parameter that allows you to customize existing themes in Bagisto. By setting the **`'parent'`** parameter to the value of the **`'name'`** parameter listed above, you can inherit the configuration of the parent theme and make further customizations. + +4. Once you have defined the paths and names for your custom theme in the **`themes.php`** file, you can start creating your view files. Make sure to cover all the GET routes of the shop package that include a parameter called **`'view'`**. You can find the route file of the shop package located at **`packages/Webkul/Shop/src/Http/routes.php`**. + +5. Ensure that the name of your blade file matches the value passed in the GET route file. For example: + + ```php + // Store front header nav-menu fetch + Route::get('/categories/{slug}', 'Webkul\Shop\Http\Controllers\CategoryController@index') + ->defaults('_config', [ + 'view' => 'shop::products.index' + ])->name('shop.categories.index'); + ``` + + In this example, the view file should be named **`index.blade.php`** and placed in the appropriate directory within your custom theme. + +6. For all the views, check all the GET routes as they include a **`'view'`** parameter with the corresponding value to be used. + +By following these steps, you can configure and create custom view files for your store theme in Bagisto. This allows you to personalize the appearance and layout of your storefront to align with your branding and provide an enhanced user experience. \ No newline at end of file diff --git a/docs/1.5.x/themes/integrate-image-search-in-theme.md b/docs/1.5.x/themes/integrate-image-search-in-theme.md new file mode 100644 index 00000000..b753e6b0 --- /dev/null +++ b/docs/1.5.x/themes/integrate-image-search-in-theme.md @@ -0,0 +1,72 @@ +# Image Search + +[[TOC]] + +## Introduction + +In this section, we will guide you on integrating image search with your new theme. Our **`Default Theme`** and **`Velocity Theme`** utilize [TensorFlow.js](https://www.tensorflow.org/js) and load the **`TensorFlow`** MobileNet model. + +The **`TensorFlow`** JS model doesn't require any machine learning expertise. You simply need to pass browser-based image elements, such as **``**, and it will return an array containing the best predictions along with their confidences. + +## Usage + +Ensure that all your scripts are loaded in the footer. If you examine the **`default theme`** and **`velocity theme`**, you will notice that we use the `yielding` feature. You can also use the same approach by including a `scripts` yield in your main layouts. + +Let's begin by loading the library and model: + +```php +@push('scripts') + + +@endpush +``` + +Since the **`TensorFlow`** model only requires an image element, we will use a sample image element: + +```php +@push('scripts') + + + + +@endpush +``` + +::: tip +This is a sample image element. You can add a file input to allow users to select an image. +::: + +Now, for the main part, pass your image element to the model: + +```php +@push('scripts') + + + + + + +@endpush +``` + +Now you have all the predictions. Simply pass your predictions to your search input. + +::: tip +Create a query string from the predictions and redirect to the search route. +::: + +## Conclusion + +By following the entire flow, you can see that we pass an image element to the **`TensorFlow`** model. In return, we receive an array of predictions. From these predictions, we can generate query strings and redirect to the search route. \ No newline at end of file diff --git a/docs/1.5.x/themes/notification.md b/docs/1.5.x/themes/notification.md new file mode 100644 index 00000000..72bb22d7 --- /dev/null +++ b/docs/1.5.x/themes/notification.md @@ -0,0 +1,21 @@ +# Real-Time Notification + +To enable real-time notifications in the updated admin theme, you need to configure your project by following these steps: + +1. Create an account on [Pusher](https://dashboard.pusher.com/accounts/sign_up?_ga=2.266851022.1754006062.1647430118-1332525715.1647430118&_gl=1*jiq2no*_ga*MTMzMjUyNTcxNS4xNjQ3NDMwMTE4*_ga_V7TRZJDKDQ*MTY0NzQzMDExOC4xLjAuMTY0NzQzMDE0MC4w). + +2. Once you have created an account, create a Channels app for your application. In the app settings, go to the **`"App Keys"`** menu and copy the app ID, key, secret, and cluster. + +3. Open your application's **`.env`** file and replace the respective values with the credentials generated by Pusher. + +4. After updating the **`.env`** file, run the following command in your terminal to start the queue listener: + + ``` + php artisan queue:listen --queue=broadcastable + ``` + + This command ensures that the queue broadcasts are processed, making your application more responsive and providing a real-time experience. + + Note: Make sure you have set up the required configurations for queues and broadcasting in your Laravel application. + +By implementing real-time notifications, whenever an order is created or updated, you will receive immediate updates in the admin notification menu without having to wait for the process to complete or refresh the page. This enhances the responsiveness and user experience of your application. \ No newline at end of file diff --git a/docs/1.x/admin-theme/README.md b/docs/1.x/admin-theme/README.md new file mode 100644 index 00000000..a8f53ba2 --- /dev/null +++ b/docs/1.x/admin-theme/README.md @@ -0,0 +1,7 @@ +# Themes + +We hope that now you know how to create a package, if not then you may refer to [Package Development](../packages) section. + +Creating a custom admin theme for Bagisto had been a hot topic lately. More and more users are actively trying our framework and we’re genuinely overwhelmed by it. + +Creating a custom admin theme for Bagisto is super easy with just a few lines of configuration code. Similarly following the traditional way of creating view files in Laravel would be enough. diff --git a/docs/1.x/admin-theme/notification.md b/docs/1.x/admin-theme/notification.md new file mode 100644 index 00000000..03656ba8 --- /dev/null +++ b/docs/1.x/admin-theme/notification.md @@ -0,0 +1,9 @@ +### Real time notification + +In the updated admin theme, we have introduced an option of getting real time notifications upon order creation and updation. For the real time notification, you need to have some of the configuration within your project as mentioned below: + +- [Create an account](https://dashboard.pusher.com/accounts/sign_up?_ga=2.266851022.1754006062.1647430118-1332525715.1647430118&_gl=1*jiq2no*_ga*MTMzMjUyNTcxNS4xNjQ3NDMwMTE4*_ga_V7TRZJDKDQ*MTY0NzQzMDExOC4xLjAuMTY0NzQzMDE0MC4w), then create a Channels app for your application. Go to the “App Keys” menu for that app, and copy the app_id, key, secret and cluster. +- Upon successfull generation of pusher credentials, go to your application .env file and replace the respective values with generated credentials. +- After that run queue listener command i.e. php artisan queue:listen --queue=broadcastable + +Queue broadcasts actually make your application more responsive and allows a realtime experience. When you have any action for order creation or updation, then you can immediately get respond to the admin notification menu instead of having to wait on the process to complete or page to refresh. diff --git a/docs/1.x/advanced/README.md b/docs/1.x/advanced/README.md new file mode 100644 index 00000000..5efcfa7b --- /dev/null +++ b/docs/1.x/advanced/README.md @@ -0,0 +1,3 @@ +# Advanced Topics + +In this section, we will discuss the advanced topics of Bagisto like creating payment methods, shipping methods, data grids, and many more. Before diving into this, we are assuming that you are familiar with Laravel. diff --git a/docs/1.x/advanced/create-payment-method.md b/docs/1.x/advanced/create-payment-method.md new file mode 100644 index 00000000..c488d8d9 --- /dev/null +++ b/docs/1.x/advanced/create-payment-method.md @@ -0,0 +1,269 @@ +# Create a new payment method + +We hope that now you know how to create a package, if not refer to [Package Development](../packages). + +Bagisto eases the task of creating payment methods. So, a novice developer or a professional developer can easily create payment methods. + +As the diversity of payment methods provide the options to customer for payment when they proceed to checkout. + +On another perspective, multiple payment methods are a great strategy to reach out to the global marketplace. + +In this section, we will explain how to create a payment method. You can create a payment method in two ways. + +1. By using Bagisto Package Generator (**Recommended**) +2. By manually setting up all files (**Expert Level**) + +## 1. By using Bagisto Package Generator + +- For creating payment method package, you need to use these commands in bagisto root directory, + + - If package directory not present, + + ```php + php artisan package:make-payment-method ACME/Stripe + ``` + + - If somehow package directory already present then you can use force command as well. For that you just need to pass the '**--force**' command. + + ```php + php artisan package:make-payment-method ACME/Stripe --force + ``` + + - This will generate whole directory structures. You don't need to do manually. + +- After that, you need to register your service provider in `config/app.php` which is located Bagisto root directory. + + ```php + [ + ... + ACME\Stripe\Providers\StripeServiceProvider::class, + ... + ] + ... + ]; + ``` + +- After that, add you payment method namespace in `psr-4` key in `composer.json` file for auto loading which is located Bagisto root directory. + + ```json + "autoload": { + ... + "psr-4": { + ... + "ACME\\Stripe\\": "packages/ACME/Stripe/src" + ... + } + ... + } + ``` + +- Run `composer dump-autoload`. + +- After that run `php artisan config:cache`. + +- This will setup the configuration in the admin panel. Now start creating routes, controllers and make some cool stuff. + +## 2. By manually setting up all files + +### Steps to create a payment method + +- Create respective directory structure to create your payment method. + + ```file-structure + - ACME/Stripe/src/ + - Config/ + - system.php + - paymentmethods.php + - Payment/ + - Stripe.php + - Providers/ + - StripeServiceProvider.php + ``` + +- Within `Config` folder, it contains application's configuration files. Let's just create two files i.e. `system.php` and `paymentmethods.php`. In `system.php` file, you have to include the array keys in the file as shown below, + + ```php + 'sales.paymentmethods.stripe', + 'name' => 'Stripe', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'title', + 'title' => 'admin::app.admin.system.title', + 'type' => 'text', + 'validation' => 'required', + 'channel_based' => false, + 'locale_based' => true, + ], [ + 'name' => 'description', + 'title' => 'admin::app.admin.system.description', + 'type' => 'textarea', + 'channel_based' => false, + 'locale_based' => true, + ], [ + 'name' => 'active', + 'title' => 'admin::app.admin.system.status', + 'type' => 'boolean', + 'validation' => 'required', + 'channel_based' => false, + 'locale_based' => true, + ] + ] + ] + ]; + ``` + + - Let's discuss what these keys are, + + - `key`: Value which is provided in this key should be unique and concatenated with '.' (dot) operator. + + - `name`: This key accept the value as a placeholder for your configuration. Generally, in Bagisto, we consider writing it using translation. + + - `sort`: This key accept the sort position for your configuration menu. + + - `fields`: This key accept the list of arrays representing your custom configurations and fields. Right now you are seeing that it only holding 3 array i.e. title, description and status. If you need some other settings than you can add one more array to this. + +- Similarly in `paymentmethods.php`, + + ```php + [ + 'code' => 'stripe', + 'title' => 'Stripe', + 'description' => 'Stripe', + 'class' => 'ACME\Stripe\Payment\Stripe', + 'active' => true, + 'sort' => 1, + ], + ]; + ``` + + - Now, let's look into this what these keys are, + - `code`: A text to represent payment method. + - `title`: Name of the payment method. + - `description`: A brief description of the payment method. + - `class`: This key includes the class namespace where all functions of payment method are written. + - `active`: This key accepts true/false to enable or disable the module. + - `sort`: This key accept the sort position of the payment. + +- If you check the above point, we have discussed the key `class` which includes the class namespace. So let's create that class in the respective file. In `Stripe.php`, add the below code, + + ```php + registerConfig(); + } + + /** + * Register package config. + * + * @return void + */ + protected function registerConfig() + { + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/paymentmethods.php', 'paymentmethods' + ); + + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/system.php', 'core' + ); + } + } + ``` + +- After that, you need to register your service provider in `config/app.php` which is located Bagisto root directory. + + ```php + [ + ... + ACME\Stripe\Providers\StripeServiceProvider::class, + ... + ] + ... + ]; + ``` + +- After that, add payment method namespace in `psr-4` key in `composer.json` file for auto loading which is located Bagisto root directory. + + ```json + "autoload": { + ... + "psr-4": { + ... + "ACME\\Stripe\\": "packages/ACME/Stripe/src" + ... + } + ... + } + ``` + +- Run `composer dump-autoload`. + +- After that run `php artisan config:cache`. + +::: tip + +If `composer dump-autoload` giving some error than in that case delete all files from the `bootstrap/cache` and again run `composer dump-autoload`. + +::: diff --git a/docs/1.x/advanced/create-product-type.md b/docs/1.x/advanced/create-product-type.md new file mode 100644 index 00000000..85a521bd --- /dev/null +++ b/docs/1.x/advanced/create-product-type.md @@ -0,0 +1,77 @@ +# Create your own product type + +By default Bagisto provides the following product types: simple, configurable, virtual, grouped, downloadable, bundled and bookings. +If the default product types do not meet your requirements, you can create your own product type. + +## Steps to create your own product-types + +You may access this super-functionality of creating your own product-types by following the points listed below. + +**Note**: To demonstrate the process here, we will be creating a new product-type say "`coupon`" + +1. Create your own package, you can check out the [Package Development](../packages) section if you need help with this. +2. Within the Config folder of your package, create a file `product_types.php` +3. Write the below piece of code in it, which is will be used to add product-type in your project. + + ```php + [ + 'key' => 'coupon', + 'name' => 'Coupon', + 'class' => 'ACME\Coupon\Type\Coupon', + 'sort' => 7 + ], + ]; + ``` +4. After that, we need to merge this `Config/product_types.php` with a core product_types option. For this, we use the method mergeConfigFrom() in the register method of the service provider(`ACME\Coupon\Providers\CouponServiceProvider.php`). + + + ```php + mergeConfigFrom( + dirname(__DIR__) . '/Config/product_types.php', 'product_types' + ); + } + } + + ``` + +5. In 3rd point above, that have mentioned key `class` which loads coupon product type. So, you need to create a file `Coupon.php` within your package under Type folder and add the below code. + +```php + + +``` + +6. After successfully completion of above steps, your product type will get created. But, still we don't have any code written for coupon type product in the `Type/Coupon.php`. To inherit basic functionality of any product to your product type, we need to inherit the classes from the Product package `type/AbstractType.php` file. + +7. Extending `AbstractType.php` class within your product_type (`Type\Coupon.php`) class let you to provide some core functionality of product. But, in addition, if user need to defined it's own custom methods, then he can define within their `Coupon.php` file. diff --git a/docs/1.x/advanced/create-shipping-method.md b/docs/1.x/advanced/create-shipping-method.md new file mode 100644 index 00000000..4dcf7f90 --- /dev/null +++ b/docs/1.x/advanced/create-shipping-method.md @@ -0,0 +1,257 @@ +# Create a new shipping method + +We hope that now you know how to create a package, if not refer to [Package Development](../packages). + +In this section, we will understand how to create a shipping method. + +You can create a shipping method in two ways. + +1. By using Bagisto Package Generator (**Recommended**) +2. By manually setting up all files (**Expert Level**) + +## 1. By using Bagisto Package Generator + +For creating shipping method package, you need to use this command in bagisto root directory, + +~~~php +php artisan package:make-shipping-method ACME/FedEx +~~~ + +If somehow package directory already present then you can use force command as well. For that you just need to pass the '**--force**' command. + +~~~php +php artisan package:make-shipping-method ACME/FedEx --force +~~~ + +This will generate whole directory structures. You don't need to do manually. + +## 2. By manually setting up all files + +- User needs to create a `carriers.php` file in the `src/Config` path in the package (say FedEx). Here, we are going to specify what to include in your `carriers.php` file. + + ::: details Directory structure + + ~~~ + - ACME/FedEx/ + - FedEx/ + - src/ + - Config/ + - carriers.php + ~~~ + + ::: + + ~~~php + [ + 'code' => 'fedex', + 'title' => 'FedEx', + 'description' => 'FedEx Shipping', + 'active' => true, + 'type' => 'per_unit', + 'class' => 'ACME\FedEx\Carriers\FedEx', + ] + ]; + ~~~ + + - Explanation + - **code**: Unique value used for referring the particular menu. + - **title**: Label or name to display at the user interface. + - **description**: About your shipping method. + - **active**: Enable or disable option for shipping method. + - **type**: This field specifies that the shipping method applies as `per_unit` or + `per_order`. + - **class**: Path specified with filename `namespace\package-name\Carriers-folder\filename` + +- Create `Carriers` folder inside the `src` folder. Now, create `Fedex.php` in `Carriers` folder and add the below code to `Fedex.php` file. + +~~~php + isAvailable()) { + return false; + } + + $object = new CartShippingRate; + + $object->carrier = 'fedex'; + $object->carrier_title = $this->getConfigData('title'); + $object->method = 'fedex_fedex'; + $object->method_title = $this->getConfigData('title'); + $object->method_description = $this->getConfigData('description'); + $object->price = 0; + $object->base_price = 0; + + return $object; + } + } + ~~~ + + - File `Fedex.php` will extends `AbstractShipping` class which is defined at `Webkul\Shipping\Carriers\AbstractShipping`. In `Fedex.php`, methods are defined that you can use while creating a shipping method. + + - Now, you can write all the operations needed for your shipping method in `Fedex.php` file. + + - To render the shipping methods in checkout process, you need to define `calculate()` within your `Fedex.php` and return shipping rate, shipping title, shipping description within an object. + + ::: tip + May refer [FlatRate](https://github.com/bagisto/bagisto/blob/master/packages/Webkul/Shipping/src/Carriers/FlatRate.php#L28) `calculate()` method. + ::: + +- After creating all the necessary files and configurations, you need to create the form which will appear on the config section. So for that create file `system.php` in `src/Config`. Add below code to following file, + + ~~~php + 'sales.carriers.Fedex', + 'name' => 'admin::app.admin.system.fedex-shipping', + 'sort' => 2, + 'fields' => [ + [ + 'name' => 'title', + 'title' => 'admin::app.admin.system.title', + 'type' => 'text', + 'validation' => 'required', + 'channel_based' => true, + 'locale_based' => true + ], [ + 'name' => 'description', + 'title' => 'admin::app.admin.system.description', + 'type' => 'textarea', + 'channel_based' => true, + 'locale_based' => false + ], [ + 'name' => 'default_rate', + 'title' => 'admin::app.admin.system.rate', + 'type' => 'text', + 'channel_based' => true, + 'locale_based' => false + ], [ + 'name' => 'base_amount', + 'title' => 'admin::app.admin.system.minimum-amount', + 'type' => 'text', + 'channel_based' => true, + 'locale_based' => false + ], [ + 'name' => 'active', + 'title' => 'admin::app.admin.system.status', + 'type' => 'select', + 'options' => [ + [ + 'title' => 'Active', + 'value' => true + ], [ + 'title' => 'Inactive', + 'value' => false + ] + ], + 'validation' => 'required', + 'channel_based' => false, + 'locale_based' => true + ] + ] + ] + ~~~ + +- Now merge all your config in `packages/ACME/FedEx/src/Providers/FedExServiceProvider.php`, + + ~~~php + mergeConfigFrom( + dirname(__DIR__) . '/Config/carriers.php', 'carriers' + ); + + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/system.php', 'core' + ); + } + } + ~~~ + +- After that, you need to register your service provider in `config/app.php` which is located in Bagisto root directory. + + ~~~php + [ + ... + ACME\FedEx\Providers\FedExServiceProvider::class, + ... + ] + ... + ]; + ~~~ + +- After that, add you shipment method namespace in `psr-4` key in `composer.json` file for auto loading which is located in Bagisto root directory. + + ~~~json + "autoload": { + ... + "psr-4": { + ... + "ACME\\FedEx\\": "packages/ACME/FedEx/src" + ... + } + ... + } + ~~~ + +- Run `composer dump-autoload`. + +- After that run `php artisan config:cache`. + +::: tip + +If `composer dump-autoload` giving some error than in that case delete all files from the `bootstrap/cache` and again run `composer dump-autoload`. + +::: diff --git a/docs/1.x/advanced/datagrid.md b/docs/1.x/advanced/datagrid.md new file mode 100644 index 00000000..56ff73e2 --- /dev/null +++ b/docs/1.x/advanced/datagrid.md @@ -0,0 +1,434 @@ +# DataGrid + +DataGrid is just a concept of displaying your database records in tabular format. We have implemented this in Bagisto either you can use it to display data in tabular format or write code from scratch to display data in tabular format. In addition to DataGrid, we have implemented additional features such as sorting, filtering, mass action. You may refer to the table below for detailed information about the features. + +Let us take a sample of one DataGrid, + +~~~php +select('id') + ->addSelect('id', 'code', 'admin_name', 'type', 'is_required', 'is_unique', 'value_per_locale', 'value_per_channel'); + + $this->setQueryBuilder($queryBuilder); + } + + /** + * Add columns. + */ + public function addColumns() + { + $this->addColumn([ + 'index' => 'id', + 'label' => trans('admin::app.datagrid.id'), + 'type' => 'number', + 'searchable' => false, + 'sortable' => true, + 'filterable' => true + ]); + + $this->addColumn([ + 'index' => 'code', + 'label' => trans('admin::app.datagrid.code'), + 'type' => 'string', + 'searchable' => true, + 'sortable' => true, + 'filterable' => true + ]); + + $this->addColumn([ + 'index' => 'admin_name', + 'label' => trans('admin::app.datagrid.admin-name'), + 'type' => 'string', + 'searchable' => true, + 'sortable' => true, + 'filterable' => true + ]); + + $this->addColumn([ + 'index' => 'type', + 'label' => trans('admin::app.datagrid.type'), + 'type' => 'string', + 'sortable' => true, + 'searchable' => true, + 'filterable' => true + ]); + + $this->addColumn([ + 'index' => 'is_required', + 'label' => trans('admin::app.datagrid.required'), + 'type' => 'boolean', + 'sortable' => true, + 'searchable' => false, + 'wrapper' => function ($value) { + if ($value->is_required == 1) + return 'True'; + else + return 'False'; + } + ]); + + $this->addColumn([ + 'index' => 'is_unique', + 'label' => trans('admin::app.datagrid.unique'), + 'type' => 'boolean', + 'sortable' => true, + 'searchable' => false, + 'filterable' => true, + 'wrapper' => function ($value) { + if ($value->is_unique == 1) + return 'True'; + else + return 'False'; + } + ]); + + $this->addColumn([ + 'index' => 'value_per_locale', + 'label' => trans('admin::app.datagrid.per-locale'), + 'type' => 'boolean', + 'sortable' => true, + 'searchable' => false, + 'filterable' => true, + 'wrapper' => function ($value) { + if ($value->value_per_locale == 1) + return 'True'; + else + return 'False'; + } + ]); + + $this->addColumn([ + 'index' => 'value_per_channel', + 'label' => trans('admin::app.datagrid.per-channel'), + 'type' => 'boolean', + 'sortable' => true, + 'searchable' => false, + 'filterable' => true, + 'wrapper' => function ($value) { + if ($value->value_per_channel == 1) + return 'True'; + else + return 'False'; + } + ]); + } + + /** + * Prepare actions. + */ + public function prepareActions() + { + $this->addAction([ + 'title' => trans('admin::app.datagrid.edit'), + 'method' => 'GET', + 'route' => 'admin.catalog.attributes.edit', + 'icon' => 'icon pencil-lg-icon' + ]); + + $this->addAction([ + 'title' => trans('admin::app.datagrid.delete'), + 'method' => 'POST', + 'route' => 'admin.catalog.attributes.delete', + 'icon' => 'icon trash-icon' + ]); + } + + /** + * Prepare mass actions. + */ + public function prepareMassActions() + { + $this->addMassAction([ + 'type' => 'delete', + 'action' => route('admin.catalog.attributes.massdelete'), + 'label' => 'Delete', + 'method' => 'DELETE' + ]); + } +} +~~~ + +## Global properties of DataGrid + +As you see the above sample Datagrid, now let us discuss some properties, + +| Name | Functionality | +| ----------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| index | This property is defined in the grid, and the value assigned to this property must be unique i.e. `id`, so that data will be uniquely identified and operations performed will be based on your index value. | +| sortOrder | The `sortOrder` key is used to arrange the results in ascending or descending order, we have to set the sort order variable to `asc` or `desc`. | +| queryBuilder | It is used to perform database operations in your application. | +| enableMassAction | This accepts boolean values `true` or `false` to enable or disable the mass action in Datagrid. | +| enableAction | This accepts boolean values `true` or `false` to enable or disable the action column of Datagrid. | +| paginate | While creating your grid file you have to declare paginate property and set it to `true` to allow pagination on your page. | +| itemsPerPage | The `itemsPerPage` key is used to display the number of items per page. | +| enableFilterMap | This accepts boolean values `true` or `false` to enable or disable the filter on the basis of columns. | + +## Steps to create DataGrid + +You can create a DataGrid in two ways. + +1. By using Bagisto Package Generator (**Recommended**) +2. By manually setting up all files (**Expert Level**) + +### 1. By using Bagisto Package Generator + +This command will create a new data grid class in `packages/ACME/TestPackage/src/Datagrids` directory., + +~~~php +php artisan package:make-datagrid TestDataGrid ACME/TestPackage +~~~ + +If data grid class already present then you can use force command for overwriting. + +~~~php +php artisan package:make-datagrid TestDataGrid ACME/TestPackage --force +~~~ + +This will generate whole directory structures. You don't need to do manually. + +### 2. By manually setting up all files +1. We assume that you have created package let's say `ACME\TestPackage` with the below directory structure. +~~~directory-structure +- ACME/TestPackage/ + - publishable/assets + - css/ + - images/ + - js/ + - src/ + - Config/ + - acl.php + - admin-menu.php + - Console/ + - Commands/ + - Contracts/ + - Database/ + - Migrations/ + - Seeders/ + - Events/ + - Http/ + - Controllers/ + - Admin/ + - TestPackageController.php + - Shop/ + - TestPackageController.php + - Middleware/ + - Requests/ + - admin-routes.php + - shop-routes.php + - Listeners/ + - Mail/ + - Models/ + - Providers/ + - TestPackageServiceProvider.php + - TestPackageProvider.php + - Repositories/ + - Resources/ + - assets/ + - images/ + - js/ + - app.js + - sass/ + - admin.scss + - default.scss + - velocity.scss + - lang/ + - views/ + - admin/ + - layouts/ + - style.blade.php + - index.blade.php + - shop/ + - default/ + - index.blade.php + - velocity/ + - index.blade.php + - package.json + - webpack.mix.js +~~~ +2. Create a folder **Datagrids** in your package inside `src` folder, inside **Datagrids** folder, create a class let's say `TestDataGrid.php` that extends DataGrid class from Webkul `Ui` package. + +3. We have created `DataGrid` abstract class in Webkul `Ui` package. In the DataGrid abstract class, a list of properties and methods are declared. So, while creating your own DataGrid you need to only extends the `Webkul\Ui\DataGrid\DataGrid` abstract class inside your `TestDataGrid.php` class. + +4. In `Webkul\Ui\DataGrid\DataGrid.php` abstract class, two abstract methods are declared `prepareQueryBuilder()` and `addColumns()`. We can prepare grid by defining these two methods + + - `prepareQueryBuilder()`: In this method, records are retrieved through queries that is applicable on database and stored in a collection. When records are retrieved, `$this->setQueryBuilder($queryBuilder)` setQueryBuilder method is called. + + - `setQueryBuilder()`: This method is written in DataGrid abstract class of Webkul `Ui` package. This is used for setting the `$queryBuilder`. + + ~~~php + public function prepareQueryBuilder() + { + $queryBuilder = DB::table('attributes') + ->select('id') + ->addSelect('id', 'code', 'admin_name', 'type', 'is_required', 'is_unique', 'value_per_locale', 'value_per_channel'); + + $this->setQueryBuilder($queryBuilder); + } + ~~~ + + - `addColumns()`: In this method, the columns are created which are displayed in the grid. In this method, the parameter accepts the array in key-value pairs. Some of the essential keys are described below, + + | Name | functionality | + | ---------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | + | index | This key is defined in the grid, and the value assigned to this key must be unique, so that data will be uniquely identified and operations performed will be based on your index value. | + | label | In this key, the name of the column is defined. | + | type | This key accepts the type of data in column. | + | searchable | This accepts boolean values `true` or `false` to make the column searchable. | + | sortable | This accepts boolean values `true` or `false` to make the column sortable. | + | filterable | This accepts boolean values `true` or `false` to make the column filterable. | + | wrapper | Perform actions based on condition satisfied or some customization to value. | + + ~~~php + public function addColumns() + { + $this->addColumn([ + 'index' => 'id', + 'label' => trans('admin::app.datagrid.id'), + 'type' => 'number', + 'searchable' => false, + 'sortable' => true, + 'filterable' => true + ]); + + $this->addColumn([ + 'index' => 'code', + 'label' => trans('admin::app.datagrid.code'), + 'type' => 'string', + 'searchable' => true, + 'sortable' => true, + 'filterable' => true + ]); + } + ~~~ + + - `prepareActions()`: Additionally, this method is defined when there is a need to perform any action such as edit or delete on the grid. In this method, `addAction()` is called to define particular action. + + - `addAction()`: It is used for adding actions (like `edit`, `delete`, etc) to each row generated by Datagrid. + + | Name | Functionality | + | ------------ | ------------------------------------------------------------------------ | + | title | The text to be displayed in written here. | + | method | HTTP methods are declared. | + | route | This key accepts the route of icon. | + | icon | Class of icon to be displayed in action column you may prefer text also. | + + ~~~php + public function prepareActions() + { + $this->addAction([ + 'title' => trans('admin::app.datagrid.edit'), + 'method' => 'GET', + 'route' => 'admin.catalog.attributes.edit', + 'icon' => 'icon pencil-lg-icon' + ]); + + $this->addAction([ + 'title' => trans('admin::app.datagrid.delete'), + 'method' => 'POST', + 'route' => 'admin.catalog.attributes.delete', + 'icon' => 'icon trash-icon' + ]); + } + ~~~ + +::: warning + +- Use JavaScript with wrapper property set to true when needed. +- Return static blade files loaded with scripts in it with caution. + +::: + +## Multiple DataGrids + +As the default Datagrid will handle only a single request at a time which means filtration, sorting and many other operations will get conflicted when you try to implement the multiple DataGrids. To overcome this we have provided a trait `ProvideDataGridPlus` in the namespace `Webkul\Ui\DataGrid\Traits`. + +- Just take any of the Datagrid, let say `ProductDataGrid` in the namespace `Webkul\Admin\DataGrids`, + + ~~~php + namespace Webkul\Admin\DataGrids; + + class ProductDataGrid extends DataGrid + { + ... + } + ~~~ + +- Import the `ProvideDataGridPlus` trait in the mentioned class, + + ~~~php + namespace Webkul\Admin\DataGrids; + + use Webkul\Ui\DataGrid\Traits\ProvideDataGridPlus; + + class ProductDataGrid extends DataGrid + { + use ProvideDataGridPlus; + + ... + } + ~~~ + +- After that `toJson()` method will be available in the Datagrid instance which will provide data to the component. + +- Now you need to create one route and method from where the response will come. Let us take an example of the product listing page. Now go to `ProductController` in the namespace `Webkul\Product\Http\Controllers`, there is an index method, just use the `toJson`. + + ~~~php + use Webkul\Admin\DataGrids\ProductDataGrid; + + class ProductController extends Controller + { + /** + * Display a listing of the resource. + * + * @return \Illuminate\View\View + */ + public function index() + { + if (request()->ajax()) { + return app(ProductDataGrid::class)->toJson(); + } + + return view($this->_config['view']); + } + + ... + } + ~~~ + +- Now, in the view portion use this component i.e. `datagrid-plus` and add the url from where it will load the json data, + + ~~~php +
+ ... + + + + ... +
+ ~~~ + +- Done, your datagrid is ready. diff --git a/docs/1.x/advanced/events.md b/docs/1.x/advanced/events.md new file mode 100644 index 00000000..6db88d38 --- /dev/null +++ b/docs/1.x/advanced/events.md @@ -0,0 +1,245 @@ +# Events +Events are an implementation of observer pattern such that whenever an event takes place, then one or more listener(s) associated with that event responds. Imagine something like making an announcement to your application, and then actions being taken due to that announcement. All the event classes in Bagisto are stored in the **Providers** folder and the listeners are stored in the **Listeners** folder. + +## How to create Event Class? + +If you have the Bagisto Package Generator installed, then you can use the following command which will create a new event class in `packages/ACME/TestPackage/src/Events` directory. + +Please follow the following steps to create a new event class in your `packages/ACME/TestPackage` + +1. We assume that you have created a new TestPackage using Bagisto Package Generator like the below command. + +`php artisan package:make ACME/TestPackage` + +2. Now, you can create a event `Events\TestEvent.php` class using the below command. + +`php artisan package:make-event TestEvent ACME/TestPackage` + +If event class already present then you can use force command for overwriting by passing `--force` option. + +`php artisan package:make-event TestEvent ACME/TestPackage --force` + +Or if you don't have package generator then, you can create file manually also. + +## How to create Listener Class? + +If you have the Bagisto Package Generator installed, then you can use the following command which will create a new listener class in `packages/ACME/TestPackage/src/Listeners` directory. + +`php artisan package:make-listener TestListener ACME/TestPackage` + +If listener class already present then you can use force command for overwriting. + +`php artisan package:make-listener TestListener ACME/TestPackage --force` + +Or if you don't have package generator then, you can create file manually also. + +## Manually Registering Events + +For the sake of simplicity, in bagisto, we register events manually in the boot method of your **_EventServiceProvider.php_** as below: + +~~~php +/** +* Register any other events for your application. +* +* @return void +*/ + +public function boot() +{ + parent::boot(); + + Event::listen('event.name', 'path-upto-listener@function'); +} +~~~ + +## Manually Registering Listeners + +In registering events, we specify listener function to be executed when an event is called so on every event a listener function is to be executed + +~~~php +class EventServiceProvider extends ServiceProvider +{ + /** + * Bootstrap services. + * + * @return void + */ + public function boot() + { + Event::listen('checkout.order.save.after', 'Webkul\Admin\Listeners\Order@sendNewOrderMail'); + } +} +~~~ + +### How we specify events? + +In most of **CRUD** operation, we had fired an event before and after the execution of function. So, that if some one want to perform any operation after or before product create/update/delete can perform by simply calling a listener function in event registration + +## Events Fired in Bagisto + +Events fired in bagisto but not listened such that if any user wants to perform any action on event fire, then they may create listener file and perform the respective operation. + +| Events name | Functionality| +| ------------------------------- | ------------- | +|core.configuration.save.after|This event will be fired after core configuration form data gets saved, then you may create a listener file and perform the respective operation when that event fires | +|core.configuration.save.after|This event will be fired after core configuration form data gets saved, then you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.item.add.before |This event will be fired before saving into the database of item added in checkout and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.item.add.after|This event will be fired after saving into the database of item added in checkout and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.item.update.before|This event will be fired before updating the database item of checkout table of respective passed `id` and you may create a listener file and perform the respective operation when that event fires | +|checkout.cart.item.update.after|This event will be fired after updating the database item of checkout table of respective passed `id` and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.delete.before|This event will be fired before deleting the database item of checkout table of respective passed `id` and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.delete.after|This event will be fired after deleting the database item of checkout table of respective passed `id` and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.item.delete.before|This event will be fired before deleting the database item of checkout table of respective passed `id` and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.item.delete.after|This event will be fired after deleting the database item of checkout table of respective passed `id` and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.item.move-to-wishlist.before|This event will be fired before adding cart item to wishlist added in checkout and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.item.move-to-wishlist.after|This event will be fired after adding cart item to wishlist added in checkout and you may create a listener file and perform the respective operation when that event fires| +|customer.registration.before|This event will be fired before registration of customer details and you may create a listener file and perform the respective operation when that event fires| +|customer.registration.after|This event will be fired after registration of customer details and you may create a listener file and perform the respective operation when that event fires| +|customer.after.login|This event will be fired after login of customer and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute_family.create.before|This event will be fired before attribute family gets created and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute_family.create.after|This event will be fired after attribute family gets created and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute_family.update.before|This event will be fired before updating attribute family and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute_family.update.after|This event will be fired after updating attribute family and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute_family.delete.before|This event will be fired before deleting attribute family and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute_family.delete.after|This event will be fired after deleting attribute family and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute.create.before|This event will be fired before attribute gets created and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute.create.after|This event will be fired after attribute gets created and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute.update.before|This event will be fired before attribute gets updated and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute.update.after|This event will be fired after attribute gets updated and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute.delete.before|This event will be fired before attribute gets deleted and you may create a listener file and perform the respective operation when that event fires| +|catalog.attribute.delete.after|This event will be fired after attribute gets deleted and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.delete.after|This event will be fired after deleting category and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.delete.before|This event will be fired before deleting category with mass selection and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.delete.after|This event will be fired after deleting category with mass selection and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.create.before|This event will be fired before creating category and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.create.after|This event will be fired after creating category and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.update.before|This event will be fired before updating category and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.update.after|This event will be fired after updating category and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.delete.before|This event will be fired before deleting category and you may create a listener file and perform the respective operation when that event fires| +|catalog.category.delete.after|This event will be fired after deleting category and you may create a listener file and perform the respective operation when that event fires| +|core.channel.create.before|This event will be fired before channel gets created and you may create a listener file and perform the respective operation when that event fires| +|core.channel.create.after|This event will be fired after channel gets created and you may create a listener file and perform the respective operation when that event fires| +|core.channel.update.before|This event will be fired before channel gets updated and you may create a listener file and perform the respective operation when that event fires| +|core.channel.update.after|This event will be fired after channel gets updated and you may create a listener file and perform the respective operation when that event fires| +|core.channel.delete.before|This event will be fired before channel gets deleted and you may create a listener file and perform the respective operation when that event fires| +|core.channel.delete.after|This event will be fired after channel gets deleted and you may create a listener file and perform the respective operation when that event fires| +|core.currency.create.before|This event will be fired before currency gets created and you may create a listener file and perform the respective operation when that event fires| +|core.currency.create.after|This event will be fired after currency gets created and you may create a listener file and perform the respective operation when that event fires| +|core.currency.update.before|This event will be fired before currency gets updated and you may create a listener file and perform the respective operation when that event fires| +|core.currency.update.after|This event will be fired after currency gets updated and you may create a listener file and perform the respective operation when that event fires| +|core.currency.delete.before|This event will be fired before currency gets deleted and you may create a listener file and perform the respective operation when that event fires| +|core.currency.delete.after|This event will be fired after currency gets deleted and you may create a listener file and perform the respective operation when that event fires| +|core.currency.delete.before|This event will be fired before currency gets deleted with mass selection and you may create a listener file and perform the respective operation when that event fires| +|core.currency.delete.after|This event will be fired after currency gets deleted with mass selection and you may create a listener file and perform the respective operation when that event fires| +|core.exchange_rate.create.before|This event will be fired before exchange rate gets created and you may create a listener file and perform the respective operation when that event fires| +|core.exchange_rate.create.after|This event will be fired after exchange rate gets created and you may create a listener file and perform the respective operation when that event fires| +|core.exchange_rate.update.before |This event will be fired before exchange rate gets updated and you may create a listener file and perform the respective operation when that event fires| +|core.exchange_rate.update.after|This event will be fired after exchange rate gets updated and you may create a listener file and perform the respective operation when that event fires| +|core.exchange_rate.delete.before|This event will be fired before exchange rate gets deleted and you may create a listener file and perform the respective operation when that event fires| +|core.exchange_rate.delete.after|This event will be fired after exchange rate gets deleted and you may create a listener file and perform the respective operation when that event fires| +|core.locale.create.before|This event will be fired before locale gets created and you may create a listener file and perform the respective operation when that event fires| +|core.locale.create.after|This event will be fired after locale gets created and you may create a listener file and perform the respective operation when that event fires| +|core.locale.update.before|This event will be fired before locale gets updated and you may create a listener file and perform the respective operation when that event fires| +|core.locale.update.after|This event will be fired after locale gets updated and you may create a listener file and perform the respective operation when that event fires| +|core.locale.delete.before|This event will be fired before locale gets deleted and you may create a listener file and perform the respective operation when that event fires| +|core.locale.delete.after|This event will be fired after locale gets deleted and you may create a listener file and perform the respective operation when that event fires| +|customer.registration.before|This event will be fired before customer gets registered and you may create a listener file and perform the respective operation when that event fires| +|customer.registration.after|This event will be fired after customer gets registered and you may create a listener file and perform the respective operation when that event fires| +|customer.after.login|This event will be fired after customer successfully logins in store and you may create a listener file and perform the respective operation when that event fires| +|customer.after.logout|This event will be fired after customer successfully logouts from store and you may create a listener file and perform the respective operation when that event fires| +|inventory.inventory_source.create.before|This event will be fired before inventory source gets created and you may create a listener file and perform the respective operation when that event fires| +|inventory.inventory_source.create.after|This event will be fired after inventory source gets created and you may create a listener file and perform the respective operation when that event fires| +|inventory.inventory_source.update.before|This event will be fired before inventory source gets updated and you may create a listener file and perform the respective operation when that event fires| +|inventory.inventory_source.update.after|This event will be fired after inventory source gets updated and you may create a listener file and perform the respective operation when that event fires| +|inventory.inventory_source.delete.before|This event will be fired before inventory source gets deleted and you may create a listener file and perform the respective operation when that event fires| +|inventory.inventory_source.delete.after|This event will be fired after inventory source gets deleted and you may create a listener file and perform the respective operation when that event fires| +|customer.review.update.before|This event will be fired before customer review gets updated and you may create a listener file and perform the respective operation when that event fires| +|customer.review.update.after|This event will be fired after customer review gets updated and you may create a listener file and perform the respective operation when that event fires| +|customer.review.delete.before|This event will be fired before customer review gets deleted and you may create a listener file and perform the respective operation when that event fires| +|customer.review.delete.after|This event will be fired after customer review gets deleted and you may create a listener file and perform the respective operation when that event fires| +|customer.review.delete.before|This event will be fired before customer review gets deleted with mass selection and you may create a listener file and perform the respective operation when that event fires| +|customer.review.delete.after|This event will be fired after customer review gets deleted with mass selection and you may create a listener file and perform the respective operation when that event fires| +|customer.review.update.before|This event will be fired before customer review gets updated with mass selection and you may create a listener file and perform the respective operation when that event fires| +|customer.review.update.after|This event will be fired after customer review gets updated with mass selection and you may create a listener file and perform the respective operation when that event fires| +|catalog.product.create.before|This event will be fired before product gets created and you may create a listener file and perform the respective operation when that event fires| +|catalog.product.create.after|This event will be fired after product gets created and you may create a listener file and perform the respective operation when that event fires| +|catalog.product.update.before|This event will be fired before product gets updated and you may create a listener file and perform the respective operation when that event fires| +|catalog.product.update.after|This event will be fired after product gets updated and you may create a listener file and perform the respective operation when that event fires| +|catalog.product.delete.before|This event will be fired before product gets deleted and you may create a listener file and perform the respective operation when that event fires| +|catalog.product.delete.after|This event will be fired after product gets deleted and you may create a listener file and perform the respective operation when that event fires| +|sales.invoice.save.before|This event will be fired before invoice gets created and you may create a listener file and perform the respective operation when that event fires| +|sales.invoice.save.after|This event will be fired after invoice gets created and you may create a listener file and perform the respective operation when that event fires| +|checkout.order.save.before|This event will be fired before order gets created and you may create a listener file and perform the respective operation when that event fires| +|checkout.order.save.after|This event will be fired after order gets created and you may create a listener file and perform the respective operation when that event fires| +|sales.order.cancel.before|This event will be fired before order gets cancelled and you may create a listener file and perform the respective operation when that event fires| +|sales.order.cancel.after|This event will be fired after order gets cancelled and you may create a listener file and perform the respective operation when that event fires| +|catalog.product.update.after|This event will be fired after product gets updated and you may create a listener file and perform the respective operation when that event fires| +|sales.shipment.save.before|This event will be fired before shipment for product gets created and you may create a listener file and perform the respective operation when that event fires| +|sales.shipment.save.after|This event will be fired after shipment for product gets created and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.add.before|This event will be fired before product get added in cart and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.add.after|This event will be fired after product get added in cart and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.delete.before|This event will be fired before product get deleted from cart and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.delete.after|This event will be fired after product get deleted from cart and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.update.before|This event will be fired before cart item get updated and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.update.after|This event will be fired after cart item get updated and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.add.before|This event will be fired before configurable product get added in cart and you may create a listener file and perform the respective operation when that event fires| +|checkout.cart.add.after|This event will be fired after configurable product get added in cart and proceeded to but the product and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_category.create.before|This event will be fired before tax category gets created and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_category.create.after|This event will be fired after tax category gets created and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_category.update.before|This event will be fired before tax category gets updated and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_category.update.after|This event will be fired after tax category gets updated and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_category.delete.before|This event will be fired before tax category gets deleted and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_category.delete.after|This event will be fired after tax category gets deleted and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_rate.create.before|This event will be fired before tax rate gets created and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_rate.create.after|This event will be fired after tax rate gets created and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_rate.update.before|This event will be fired before tax rate gets updated and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_rate.update.after|This event will be fired after tax rate gets updated and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_rate.delete.before|This event will be fired before tax rate gets deleted and you may create a listener file and perform the respective operation when that event fires| +|tax.tax_rate.delete.after|This event will be fired after tax rate gets deleted and you may create a listener file and perform the respective operation when that event fires| +|user.role.create.before|This event will be fired before user role gets created. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.role.create.after|This event will be fired after user role gets created. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.role.update.before|This event will be fired before user role gets updated. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.role.update.after|This event will be fired after user role gets updated. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.role.delete.before|This event will be fired before user role gets updated. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.role.delete.after|This event will be fired after user role gets deleted. The role of user in created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.admin.create.before|This event will be fired before user gets created. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.admin.delete.after|This event will be fired after user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.admin.update.before|This event will be fired before user gets updated. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.admin.update.after|This event will be fired after user gets updated. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.admin.delete.before|This event will be fired before user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.admin.delete.after|This event will be fired after user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.admin.delete.before|This event will be fired before user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| +|user.admin.delete.after|This event will be fired after user gets deleted. The user gets created from admin panel and you may create a listener file and perform the respective operation when that event fires| + +## Events Listen in Bagisto + +| Events name | functionality | +| ------------------------------- | ------------- | +| checkout.order.save.after | This event will be fired after order creation and listen in `ProductFlat` listener file to send new order mail from `sendNewOrderMail` function | +| sales.invoice.save.after | This event will be fired after invoice details have been saved and listen in `ProductFlat` listener file to send new invoice mail from `sendNewInvoiceMail` function | +| sales.shipment.save.after | This event will be fired after shipment details have been saved and listen in `ProductFlat` listener file to send new shipment mail from `sendNewShipmentMail` function | +| checkout.order.save.after | This event will be fired after order has been created and will listen in `ProductFlat` listener file to update product inventory from `updateProductInventory` function | +| catalog.attribute.create.after | This event will be fired after attribute has been created and listen in `ProductFlat` listener file from `afterAttributeCreatedUpdated` function | +| catalog.attribute.update.after | This event will be fired after attribute has updated and listen in `ProductFlat` listener file from `afterAttributeCreatedUpdated` function | +| catalog.attribute.delete.before | This event will be fired before attribute has been delete and listen in `ProductFlat` listener file from `afterAttributeDeleted` function | +| catalog.product.create.after | This event will be fired after product has been creation and listen in `ProductFlat` listener file from `afterProductCreatedUpdated` function | +| catalog.product.update.after | This event will be fired after product has been updated and listen in `ProductFlat` listener file from `afterProductCreatedUpdated` function | + +## Listen Existing Event + +As above, all events used in bagisto are listed here so you may change or edit the listener function such as- `sendNewOrderMail` that is defined in `productFlat` listener file, so you can edit and perform the required operation + +~~~php +class EventServiceProvider extends ServiceProvider +{ + /** + * Bootstrap services. + * + * @return void + */ + public function boot() + { + Event::listen('checkout.order.save.after', 'Webkul\Admin\Listeners\Order@sendNewOrderMail'); + } +} +~~~ \ No newline at end of file diff --git a/docs/1.x/advanced/helpers.md b/docs/1.x/advanced/helpers.md new file mode 100644 index 00000000..8a26e243 --- /dev/null +++ b/docs/1.x/advanced/helpers.md @@ -0,0 +1,181 @@ +# Helpers + +In Bagisto, there are several packages have been used. We have provided useful helper methods in the packages which can help developers to develop their projects with ease. + +## Core Helpers + +All the mentioned helper methods are from Bagisto's core package class named `Core` in the `Webkul\Core` namespace. Let's discuss some common methods, + +- Get all the channels, + + ~~~php + core()->getAllChannels(); + ~~~ + +- Get the current channel, + + ~~~php + core()->getCurrentChannel(); + ~~~ + +- Set the current channel, this method will take one argument i.e. instance of this class `Webkul\Core\Models\Channel`, + + ~~~php + core()->setCurrentChannel($channel); + ~~~ + +- Get the current channel code, + + ~~~php + core()->getCurrentChannelCode(); + ~~~ + +- Get the default channel, + + ~~~php + core()->getDefaultChannel(); + ~~~ + +- Get the default channel code, + + ~~~php + core()->getDefaultChannelCode(); + ~~~ + +- Get requested channel code, this method is useful when you need to fetch the channel from the request, and no need to worry about the fallback as well. This method also has the optional parameter `$fallback`, which means the developer can use this with or without fallback, + + ~~~php + core()->getRequestedChannelCode(); + ~~~ + +- Get the channel name, yeah we know that you can chain it with the `Channel` instance but the purpose of this method is to handle the fallback case as well. This method will first check the name in the property, if not found then it will proceed further with app locale code, if still not found then it will check from the config key name as `app.fallback_locale`, + + ~~~php + core()->getChannelName($channel); + ~~~ + +- Get all the locales, + + ~~~php + core()->getAllLocales(); + ~~~ + +- Get all locales by requested channel, this method will provide you all the locales associated with the requested channel, + + ~~~php + core()->getAllLocalesByRequestedChannel(); + ~~~ + +- Get the current locale, + + ~~~php + core()->getCurrentLocale(); + ~~~ + +- Get the requested locale code, this method is useful when you need to fetch the locale code from the request, and no need to worry about the fallback as well. This method also has the optional parameter `$localeKey` and `$fallback`, which means the developer can use this with or without fallback, + + ~~~php + core()->getRequestedLocaleCode(); + ~~~ + +- Get all the customer groups, + + ~~~php + core()->getAllCustomerGroups(); + ~~~ + +- Get requested customer group code, this method will fetch you customer group code from the request, + + ~~~php + core()->getRequestedCustomerGroupCode(); + ~~~ + +- Get all the currencies, + + ~~~php + core()->getAllCurrencies(); + ~~~ + +- Get the base currency, + + ~~~php + core()->getBaseCurrency(); + ~~~ + +- Get the base currency code, + + ~~~php + core()->getBaseCurrencyCode(); + ~~~ + +- Get the channel based currency, + + ~~~php + core()->getChannelBaseCurrency(); + ~~~ + +- Get the channel based currency code, + + ~~~php + core()->getChannelBaseCurrencyCode(); + ~~~ + +- Get the current currency, + + ~~~php + core()->getCurrentCurrency(); + ~~~ + +- Get the current currency code, + + ~~~php + core()->getCurrentCurrencyCode(); + ~~~ + +- Get the exchange rate based on the currency id, + + ~~~php + core()->getExchangeRate($targetCurrencyId); + ~~~ + +- Get the formatted amount, + + ~~~php + core()->currency($amount = 0); + ~~~ + +- Get the configuration date based on the key, channel and locale, + + ~~~php + core()->getConfigData($field, $channel = null, $locale = null); + ~~~ + +- Get all the countries, + + ~~~php + core()->countries(); + ~~~ + +- Get the country name by country code, + + ~~~php + core()->country_name($countryCode); + ~~~ + +- Get all the country's state, + + ~~~php + core()->states($countryCode); + ~~~ + +- Get sender email details, + + ~~~php + core()->getSenderEmailDetails(); + ~~~ + +- Get admin email details, + + ~~~php + core()->getAdminEmailDetails(); + ~~~ diff --git a/docs/1.x/advanced/indexing-products-to-elasticsearch.md b/docs/1.x/advanced/indexing-products-to-elasticsearch.md new file mode 100644 index 00000000..e5bf70e0 --- /dev/null +++ b/docs/1.x/advanced/indexing-products-to-elasticsearch.md @@ -0,0 +1,96 @@ +# Indexing products to Elasticsearch + +In this section, we will explain the indexing of products from the database to the Elasticsearch engine. + +## Setting up environment + +To continue with this make sure you have [Elasticseach](https://www.elastic.co/guide/en/elasticsearch/reference/current/install-elasticsearch.html) installed on your system. By default, Elasticsearch uses the `9200` port. So, we are using the same port. + +Just hit this route `http://localhost:9200`, if you see the below image then Elasticsearch is successfully installed on your system, + +![Elasticsearch Installation Info](../../assets/1.x/images/advanced-topics/elastic-search/installed-elastic-info.png) + +::: tip + +If you want to use curl, you can hit this command, + +~~~sh +curl -X GET 'http://localhost:9200' +~~~ + +::: + +You can use [Kibana](https://www.elastic.co/guide/en/kibana/7.10/index.html) for visualization also, but in this section, we are using only the Elasticsearch engine. + +## Setting up config + +The most simple way to set up your environment is by just setting the key in the `.env` file. + +- Now, open the `.env` file in your project and this line, + + ~~~env + SCOUT_DRIVER=elastic + ELASTIC_HOST="localhost:9200" + ~~~ + +- After that run `php artisan config:cache`. + +- Done! Now you are all set to index your products. + +::: tip + +If still it is not working, then you can directly set your config in the following files i.e., + +- `config/elastic.client.php` + + ~~~php + ... + + 'hosts' => [ + env('ELASTIC_HOST', 'localhost:9200'), + ] + + ... + ~~~ + +- `config/scout.php` + + ~~~php + ... + + 'driver' => env('SCOUT_DRIVER', 'elastic'), + + ... + ~~~ + +Then run `php artisan config:cache`. + +::: + +## Indexing + +Now, after setting up the environment and config, your product gets automatically indexed when you create a new one. + +If you want to index the existing products, then you need to run the below command, + +~~~php +php artisan scout:import Webkul\\Product\\Models\\ProductFlat +~~~ + +This command will index all your data from `product_flat` table to Elasticsearch index. + +## Checking index + +Now, let's check our imported index in the Elasticsearch by hitting this URL `http://localhost:9200/_cat/indices?v`, + +![Product Index Info](../../assets/1.x/images/advanced-topics/elastic-search/product-index.png) + +::: tip + +If you want to use curl, you can hit this command, + +~~~sh +curl -X GET 'http://localhost:9200/_cat/indices?v' +~~~ + +::: diff --git a/docs/1.x/advanced/override-core-model.md b/docs/1.x/advanced/override-core-model.md new file mode 100644 index 00000000..6ad2c19e --- /dev/null +++ b/docs/1.x/advanced/override-core-model.md @@ -0,0 +1,61 @@ +# Override core model + +Concord is a Laravel Extension that helps building modules on top of Laravel's built-in Service Providers. +Bagisto uses Concord for managing their modules. +The concept of model proxies has been introduced. Proxies, as the name suggests will drive you to the actual model class. + +Concord's concept also requires to have an interface **_Product_** and this way it's possible to freely bind a concrete class to it using Concord's **registerModel()** method. + +`Models\Product` class gets bound to the `Contracts\Product` interface within the module (consider it as a default). If the application wants to extend that class, it invokes Concord's **registerModel()** again, and that's all. + +The **registerModel()** method also silently binds the interface to the implementation with Laravel's service container so you can simply type-hint the interface at any point where automatic injection happens. + +**Note** : _For more details check_ Concord _on github or refer to its_ Documentation + +Overriding Model class in the application: + +Concord modules generally define an interface for every eloquent model. If you want to override a model you can tell concord to use another class for that interface. Below, you may have a look at code + +```php + namespace App\Providers; + + use Illuminate\Support\ServiceProvider; + use Illuminate\Support\Facades\Schema; + + class AppServiceProvider extends ServiceProvider + { + + /** + * Bootstrap any application services. + * + * @return void + */ + public function boot() + { + $this->app->concord->registerModel( + \Webkul\Product\Contracts\Product::class, \App\Http\Product::class + ); + } + } +``` + +In the code shown above, **registerModel()** method accepts two parameters, described below: + +- The first parameter states your Contracts path which you want to override. + +- The second parameter states the model path from where you will override the model. + +The model from which you want to override must extend your model path as shown below + +```php +field('home_page_content') + ->with(['sliderData' => $sliderData])->render() !!} + + {!! view_render_event('bagisto.shop.home.content.after') !!} + + @endsection +``` + +To render any template before or after any function we may use 'view_render_event'. +You can define any event view_render_event() in the template by following steps: + +## Steps to render View + +- Create an event in the blade file in which you want to render any content before or after any content of that template: + +```php + {!! view_render_event('bagisto.shop.test.before') !!} +``` + +As you can see, `bagisto.shop.test` is the event name here that is defined in a random blade file of the project. + +- Now you have to listen to the event at **_EventServiceProvider.php_** file and in the boot method like: + +```php + Event::listen('bagisto.shop.test.before', function($viewRenderEventManager) { + $viewRenderEventManager->addTemplate('template file path that you want to inject'); + }); +``` + +As you can see, you have to add the path of the template that you want to render. +After that, this will automatically fire and your template will be injected before the content. +Make sure that you have registered EventServiceProvider in your ServiceProvider. diff --git a/docs/1.x/advanced/security-practice.md b/docs/1.x/advanced/security-practice.md new file mode 100644 index 00000000..72e052c3 --- /dev/null +++ b/docs/1.x/advanced/security-practice.md @@ -0,0 +1,151 @@ +# Best Security Practices + +## Keep your software up-to-date + +- Using HTTPS (Google now uses HTTPS as a ranking factor). + +- Keep all software on the server up-to-date. + - Bagisto + - Database + - Adminer/phpMyAdmin + - Apache + - Redis, etc. + +- Make sure the server operating system is up-to-date for available security patches. + +- Manage files only with secure communication protocols (SSH/ SFTP/ HTTPs), disable FTP. + +- [ .htaccess ] file to protect system files, when using apache webserver. + +- Disable unused ports, and stop services running unnecessarily. + +- Restrict access to certain IPs to the admin panel and use Admin logins with two-factor authorization. + +- Use of strong and unique passwords. + +- Use a properly configured and updated firewall between the payment card data and the public network. + +## Limiting error messages + +![limiting-error-messages](../../assets/1.x/images/advanced-topics/best-security-practices/limiting-error-messages.png) + +- Edit your apache configuration file to avoid displaying server and os details. + +- Set “ServerSignature” to OFF as by default it is ON. + +- Add “ServerTokens Prod” to display Apache as product only. + +## Allow admin access to certain IPs + +- Edit your .htaccess file with the following code + +~~~ +RewriteEngine On +RewriteCond %{REQUEST*URI} .*/admin +RewriteCond %{REMOTE*ADDR} != +RewriteCond %{REMOTE_ADDR} != +RewriteRule ^(.*)\$ - [R=403,L] +~~~ + +- Review your server for development leftovers. Make sure there are no accessible "log files", ".git directories", "database dumps", "zip files". + +## Restrict files with .git, .zip, .gz, and .sql extensions + +- Edit your .htaccess file + +~~~ + + Require all denied + +~~~ + +- Use a Web application firewall to analyze traffic and discover suspicious patterns such as credit card information being sent to an attacker. + +- Make sure only port 80 and 443 are publicly accessible and the rest of the ports are restricted. + + +## Restrict php execution inside storage directory + +- Edit your apache configuration file + + ~~~ + + + Require all denied + + php_flag engine off + + ~~~ + + ::: tip + + Don't forget to restart apache. + + ::: + +## Harden your server + +- Use of mod_security module to detect and prevent intrusions. + +- Use of mod_passive module to prevent brute force attack. + +- Allow only specific users to login. + +- Disable login to users with empty passwords. + +- Check iptable rules to prevent unauthorized access and activity. + +- Take regular backup of important files and also save them remotely in a secure environment. + +## Use strong and unique passwords + +- Use strong and unique passwords, and change them periodically. + + ::: tip + + Use password generator. ([Password Generator](https://passwords-generator.org/)) + + ::: + +- Limit access to the Bagisto admin by updating the whitelist with the IP address of each computer that is authorized to use the admin. + +## Implementation of HTTP Security Headers + +- In addition, Headers play a key role in communication between the client and the server, some of +them have been mentioned in order to enhance the web security. + +### HTTP Strict Transport Security (HSTS) + +- This response header will tell the browser that the application is only to be accessed using https instead of http. + + `Strict-Transport-Security: max-age=` + +### Cross Site Scripting Protection (X-XSS Protection) + +- This response header will enforce browsers to detect cross site scripting attacks and not to execute malicious js script in response. + + `X-XSS-Protection: 1; mode=block` + +### X-Frame-Options​ + +- This response header enables the protection of applications against clickjacking. It tells the browser whether the content can be displayed within frames. + + `X-Frame-Options: deny` + +### X-Content-Type-Options​ + +- This header will force the browser to disable MIME sniffing. + +- MIME sniffing vulnerability occurs when an attacker uploads an HTML file as a different file type such as jpg. + + `X-Content-Type-Options: nosniff` + +### Content Security Policy (CSP) + +- This response header allows application administrators to control resources that can be loaded in users' browsers and helps to detect and mitigate attacks such as xss, clickjacking. + +### Continuous Logging And Monitoring + +- Likewise, monitor all access to the network and cardholder data environment. +- Keep an eye on large volume orders for a single item from a new customer. +- A series of orders, shipped to the same address using different payment methods. diff --git a/docs/1.x/api/README.md b/docs/1.x/api/README.md new file mode 100644 index 00000000..6c1ba515 --- /dev/null +++ b/docs/1.x/api/README.md @@ -0,0 +1,21 @@ +# Bagisto Web APIs + +Bagisto Web API is a medium to use the features of the core Bagisto System. By using Bagisto Web API, you can integrate your application to serve the default content of Bagisto. + +## Key Features + +- Bagisto APIs supports REST (Representational State Transfer). +- Authentication: Customer Authentication with Login Details. +- Provide access to performed CRUD operations. +- Also Provide the option to filter the responses based on attribute fields. +- The Framework supports the pagination which helps to increase the performance of application. + +## Where can I use Bagisto Web APIs? + +We can use the Bagisto APIs in different areas. Some of them are: + +- To build a PWA (Progressive Web Application) application, which uses modern web capabilities to deliver an application like experience to the users and provide more user friendly experience than a web application. + +- Use to integrate an Online-Shopping Mobile Application with the Bagisto Store to help the customers make purchase. + +- Use to integrate with CRM (Customer Relationship Management) systems Like: HubSpot, Salesforce etc. which allows you to manage the business relationships with your customers to help you grow your business. diff --git a/docs/1.x/api/addresses.md b/docs/1.x/api/addresses.md new file mode 100644 index 00000000..dfbf4754 --- /dev/null +++ b/docs/1.x/api/addresses.md @@ -0,0 +1,278 @@ +# Addresses + +In this section, we will use all the addresses' API. We will check the creation of address, fetching of addresses, and updation of address. + +## Create a new address + +To add an address, you have to use the `addresses/create` endpoint url and have to pass the address fields in the request payload. This `addresses/create` API call resource will create a new address of the customer, only if that customer has logged in the store. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/addresses/create` + +- Params + + | Name | Info | Type | + | ------------ | ------------ | ------ | + | address1 | Address | Array | + | city | City | String | + | country | Country | String | + | country_name | Country Name | String | + | phone | Phone | String | + | postcode | Post Code | String | + | state | State | String | + +### Examples + +Let's take an example of creating an address, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST http(s)://example.com/api/addresses/create` + +- Params + + | Name | Value | + | ------------ | --------------- | + | address1 | ['Clock Tower'] | + | city | Dehradun | + | country | IN | + | country_name | India | + | phone | 0123456798 | + | postcode | 248001 | + | state | UT | + + ~~~json + { + "address1": [ + "Clock Tower" + ], + "city": "Dehradun", + "country": "IN", + "country_name": "India", + "phone": "0123456798", + "postcode": "248001", + "state": "UT" + } + ~~~ + +::: details Response + + ~~~json + { + "message":"Address has been created successfully.", + "data": {...} // This contains the data you send to the api. + } + ~~~ + +::: + +## Get all addresses + +To get all the address of a customer, that customer must be logged in to the store. You can achieve this job by using `addresses` API call resource. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/addresses` + +### Examples + +Let's take an example, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/addresses` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 3, + "address1": [...], + "country": "IN", + "country_name": "India", + "state": "UT", + "city": "Dehradun", + "postcode": 248001, + "phone": "01345679", + }, + { + "id": 2, + "address1": [...], + "country": "IN", + "country_name": "India", + "state": "UP", + "city": "Noida", + "postcode": 201301, + "phone": "012345679", + }, + ] + } + ~~~ + +::: + +## Get address by id + +To get the customer's specific address, you have to pass an `address_id` as a request payload like `addresses/{address_id}` in API URL. By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/addresses/{address_id}` + +- Params + + | Name | Info | Type | + | ---------- | ------- | ------ | + | address_id | Address | Number | + +### Examples + +Let's take an example, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/addresses/1` + +::: details Response + + ~~~json + { + "data": { + "id": 1, + "address1": [ + "Block H-ARP Park, Sector 63 " + ], + "country": "IN", + "country_name": "India", + "state": "UP", + "city": "Noida", + "postcode": 201301, + "phone": "0132456789", + "created_at": { + "date": "", + "timezone_type": 3, + "timezone": "Asia/Kolkata" + }, + "updated_at": { + "date": "", + "timezone_type": 3, + "timezone": "Asia/Kolkata" + }, + } + } + ~~~ + +::: + +## Update address + +To update the customer's specific address, you have to pass an `address_id` as a request payload like `addresses/{address_id}` in API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `PUT /api/addresses/1` + +- Params + + | Name | Info | Type | + | ------------ | ------------ | ------ | + | address1 | Address | Array | + | city | City | String | + | country | Country | String | + | country_name | Country Name | String | + | phone | Phone | String | + | postcode | Post Code | String | + | state | State | String | + +### Examples + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `PUT http(s)://example.com/api/addresses/1` + +- Params + + ~~~json + { + "id": 1, + "address1": [ + "Clock Tower" + ], + "city": "New Delhi", + "country": "IN", + "country_name": "India", + "phone": "9876543210", + "postcode": "248001", + "state": "DL" + } + ~~~ + +::: details Response + + ~~~json + { + "message":"Your address has been updated successfully.", + "data": {...} // Address' detail. + } + ~~~ + +::: diff --git a/docs/1.x/api/attribute-families.md b/docs/1.x/api/attribute-families.md new file mode 100644 index 00000000..a686e627 --- /dev/null +++ b/docs/1.x/api/attribute-families.md @@ -0,0 +1,239 @@ +# Attribute Families + +Attribute families are the group of attributes that can be assigned to the product according to the product's needs. + +## Get all attribute familes + +This api request will fetch all the attribute families. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/families(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ------------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | will display all the records if set to `0` | Number | + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Get attribute families of the specific page + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/families?page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/families` + + ::: + +::: details Response + + ~~~json + { + "data": [ + { + "id": 1, + "code": "default", + "name": "Default", + "status": 0, + "groups": [...] + "created_at": null, + "updated_at": null + } + ], + "links": { + "first": "https://example.com/api/families?page=1", + "last": "https://example.com/api/families?page=1", + "prev": null, + "next": null + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 1, + "links": [ + { "url": null, "label": "« Previous", "active": false }, + { + "url": "https://example.com/api/families?page=1", + "label": "1", + "active": true + }, + { "url": null, "label": "Next »", "active": false } + ], + "path": "https://example.com/api/families", + "per_page": 10, + "to": 1, + "total": 1 + } + } + ~~~ + +::: + +#### 2. Get attribute families of the specific page with limit + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/families?page=1&limit=5` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 1, + "code": "default", + "name": "Default", + "status": 0, + "groups": [...], + "created_at": null, + "updated_at": null + } + ], + "links": { + "first": "https://example.com/api/families?limit=5&page=1", + "last": "https://example.com/api/families?limit=5&page=1", + "prev": null, + "next": null + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 1, + "links": [ + { "url": null, "label": "« Previous", "active": false }, + { + "url": "https://example.com/api/families?limit=5&page=1", + "label": "1", + "active": true + }, + { "url": null, "label": "Next »", "active": false } + ], + "path": "https://example.com/api/families", + "per_page": "5", + "to": 1, + "total": 1 + } + } + ~~~ + +::: + +#### 3. Get all attribute families without pagination + +If you don't want to use the pagination and want to access all the store's attribute families at once, then you have to send a filter parameter named as`pagination` with value `zero`. By doing this you will get all attributes objects at once in the data object and this will not give you link and meta objects. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/families?pagination=0` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 1, + "code": "default", + "name": "Default", + "status": 0, + "groups": [...], + "created_at": null, + "updated_at": null + } + ] + } + ~~~ + +::: + +## Get attribute family by id + +For fetching any specific attribute family, you have to provide the attribute family's id as an input parameter. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/families/{id}` + +- Params + + | Name | Info | Type | + | ---- | --------------------- | ------ | + | id | Attribute Family's id | Number | + +### Examples + +#### 1. Let's try to fetch attribute family by id + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/families/1` + +::: details Response + + ~~~json + { + "data": { + "id": 1, + "code": "default", + "name": "Default", + "status": 0, + "groups": [...], + "created_at": null, + "updated_at": null + } + } + ~~~ + +::: diff --git a/docs/1.x/api/attributes.md b/docs/1.x/api/attributes.md new file mode 100644 index 00000000..9181c9b5 --- /dev/null +++ b/docs/1.x/api/attributes.md @@ -0,0 +1,355 @@ +# Attributes + +In this section, we are using the attributes' API. An Attribute is a specification or characteristics of a product for example color, size, pattern are an attribute of T-Shirt. You can as create many attributes for a single product. Product Attribute plays a major factor in buying decision of the Customer. + +## Get all attributes + +This api request will fetch all the attributes. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/attributes(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ------------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | will display all the records if set to `0` | Number | + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Get attributes of the specific page + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/attributes?page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/attributes` + + ::: + +::: details Response + + ~~~json + { + "data": [ + { + "id":27, + "code":"product_number", + "type":"text", + "name":"Product Number", + "swatch_type":null, + "options":[], + "created_at":"2021-05-24T05:09:12.000000Z", + "updated_at":"2021-05-24T05:09:12.000000Z" + }, + {...}, + {...} + ], + "links": { + "first": "https://example.com/api/attributes?page=1", + "last": "https://example.com/api/attributes?page=3", + "prev": null, + "next": "https://example.com/api/attributes?page=2" + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 3, + "links": [...], + "path": "https://example.com/api/attributes", + "per_page": 10, + "to": 10, + "total": 27 + } + } + ~~~ + +::: + +#### 2. Get attributes of the specific page with limit + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/attributes?page=1&limit=5` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 27, + "code": "product_number", + "type": "text", + "name": "Product Number", + "swatch_type": null, + "options": [], + "created_at": "2021-05-24T05:09:12.000000Z", + "updated_at": "2021-05-24T05:09:12.000000Z" + }, + { + "id": 26, + "code": "guest_checkout", + "type": "boolean", + "name": "Allow Guest Checkout", + "swatch_type": null, + "options": [], + "created_at": "2021-05-24T05:09:12.000000Z", + "updated_at": "2021-05-24T05:09:12.000000Z" + }, + { + "id": 25, + "code": "brand", + "type": "select", + "name": "Brand", + "swatch_type": null, + "options": [], + "created_at": "2021-05-24T05:09:12.000000Z", + "updated_at": "2021-05-24T05:09:12.000000Z" + }, + { + "id": 24, + "code": "size", + "type": "select", + "name": "Size", + "swatch_type": null, + "options": [ + { "id": 6, "admin_name": "S", "label": "S", "swatch_value": null }, + { "id": 7, "admin_name": "M", "label": "M", "swatch_value": null }, + { "id": 8, "admin_name": "L", "label": "L", "swatch_value": null }, + { "id": 9, "admin_name": "XL", "label": "XL", "swatch_value": null } + ], + "created_at": "2021-05-24T05:09:12.000000Z", + "updated_at": "2021-05-24T05:09:12.000000Z" + }, + { + "id": 23, + "code": "color", + "type": "select", + "name": "Color", + "swatch_type": null, + "options": [ + { "id": 1, "admin_name": "Red", "label": "Red", "swatch_value": null }, + { + "id": 2, + "admin_name": "Green", + "label": "Green", + "swatch_value": null + }, + { + "id": 3, + "admin_name": "Yellow", + "label": "Yellow", + "swatch_value": null + }, + { + "id": 4, + "admin_name": "Black", + "label": "Black", + "swatch_value": null + }, + { + "id": 5, + "admin_name": "White", + "label": "White", + "swatch_value": null + } + ], + "created_at": "2021-05-24T05:09:12.000000Z", + "updated_at": "2021-05-24T05:09:12.000000Z" + } + ], + "links": { + "first": "https://example.com/api/attributes?limit=5&page=1", + "last": "https://example.com/api/attributes?limit=5&page=6", + "prev": null, + "next": "https://example.com/api/attributes?limit=5&page=2" + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 6, + "links": [ + { + "url": null, + "label": "« Previous", + "active": false + }, + { + "url": "https://example.com/api/attributes?limit=5&page=1", + "label": "1", + "active": true + }, + { + "url": "https://example.com/api/attributes?limit=5&page=2", + "label": "2", + "active": false + }, + { + "url": "https://example.com/api/attributes?limit=5&page=3", + "label": "3", + "active": false + }, + { + "url": "https://example.com/api/attributes?limit=5&page=4", + "label": "4", + "active": false + }, + { + "url": "https://example.com/api/attributes?limit=5&page=5", + "label": "5", + "active": false + }, + { + "url": "https://example.com/api/attributes?limit=5&page=6", + "label": "6", + "active": false + }, + { + "url": "https://example.com/api/attributes?limit=5&page=2", + "label": "Next »", + "active": false + } + ], + "path": "https://example.com/api/attributes", + "per_page": "5", + "to": 5, + "total": 27 + } + } + ~~~ + +::: + +#### 3. Get all attributes without pagination + +If you don't want to use the pagination and want to access all the store's attributes at once, then you have to send a filter parameter named as`pagination` with value `zero`. By doing this you will get all attributes objects at once in the data object and this will not give you link and meta objects. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/attributes?pagination=0` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 27, + "code": "product_number", + "type": "text", + "name": "Product Number", + "swatch_type": null, + "options": [], + "created_at": "2021-05-24T05:09:12.000000Z", + "updated_at": "2021-05-24T05:09:12.000000Z" + }, + { + "id": 26, + "code": "guest_checkout", + "type": "boolean", + "name": "Allow Guest Checkout", + "swatch_type": null, + "options": [], + "created_at": "2021-05-24T05:09:12.000000Z", + "updated_at": "2021-05-24T05:09:12.000000Z" + }, + {...}, + {...}, + {...}, + {...} + ] + } + ~~~ + +::: + +## Get attribute by id + +For fetching any specific attribute, you have to provide the attribute's id as an input parameter. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/attributes/{id}` + +- Params + + | Name | Info | Type | + | ---- | -------------- | ------ | + | id | Attribute's id | Number | + +### Examples + +#### 1. Let's try to fetch attribute by id + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/attributes/1` + +::: details Response + + ~~~json + { + "data": { + "id": 1, + "code": "sku", + "type": "text", + "name": "SKU", + "swatch_type": null, + "options": [], + "created_at": "2021-05-24T05:09:12.000000Z", + "updated_at": "2021-05-24T05:09:12.000000Z" + } + } + ~~~ + +::: diff --git a/docs/1.x/api/cart.md b/docs/1.x/api/cart.md new file mode 100644 index 00000000..32c6dfd5 --- /dev/null +++ b/docs/1.x/api/cart.md @@ -0,0 +1,1104 @@ +# Cart + +In this section, we will use the cart's API. We will see how to add the product to the cart, fetching cart details, updating cart, and many more things related to the cart. + +## Add product to cart + +By using this API call you can add new products to the cart and also you can add quantity to the existing product in the cart. To do this task, you have to use the `checkout/cart/add/{product_id}` as a request payload in the API URL. This API call will work with both customer's authentication or without customer's authentication. + +Currently,Bagisto support the following types of product, + +- [Simple](#simple-and-virtual-product) +- [Configurable](#configurable-product) +- [Bundle](#bundle-product) +- [Grouped](#grouped-product) +- [Downloadable](#downloadable-product) +- [Virtual](#simple-and-virtual-product) + +Let us discuss each product, + +### Simple And Virtual Product + +A simple product is a physical item with no configurable option like size, color, etc. Whereas virtual product is slightly same as simple but is not a physical item. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/cart/add/{product_id}` + +- Params + + | Name | Info | Type | + | ---------- | ------------ | ------ | + | product_id | Product's ID | Number | + | quantity | Quantity | Number | + + ```json + { + "product_id": "product_id", + "quantity": "quantity" + } + ``` + +### Configurable Product + +A Configurable product allows the seller to sell the product in a different variation in Bagisto. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/cart/add/{product_id}` + +- Params + + | Name | Info | Type | + | ---------------------------- | --------------------------------- | ------ | + | product_id | Product's ID | Number | + | quantity | Quantity | Number | + | selected_configurable_option | Configurable product variant's ID | Number | + | super_attribute | Attribute's ID collections | Object | + + ```json + { + "product_id": "product_id", + "quantity": "quantity", + "selected_configurable_option": "configurable_product_variant_id", + "super_attribute": { + "attribute_id": "attribute_option_id", + "attribute_id": "attribute_option_id" + } + } + ``` + +### Bundle Product + +A bundle product includes a customizable product that you can build for your own. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/cart/add/{product_id}` + +- Params + + | Name | Info | Type | + | ----------------- | -------------------------- | ------ | + | product_id | Product's ID | Number | + | quantity | Quantity | Number | + | bundle_options | Bundle options collections | Object | + | bundle_option_qty | Bundle options qunatity | Object | + + ```json + { + "product_id": "product_id", + "quantity": "quantity", + "bundle_options": { + "first_option_id": { + "index_0": "option_product_id" + }, + "second_option_id": { + "index_0": "option_product_id", + "index_1": "another_option_product_id" + } + }, + "bundle_option_qty": { + "first_option_id": "quantity" + } + } + ``` + +### Grouped Product + +A grouped product is a group of simple products that can be combined together. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/cart/add/{product_id}` + +- Params + + | Name | Info | Type | + | ---------- | ----------------------------------- | ------ | + | product_id | Product's ID | Number | + | quantity | Quantity | Number | + | qty | Collection of product with quantity | Object | + + ```json + { + "product_id": "product_id", + "quantity": "quantity", + "qty": { + "product_id_1": "quantity", + "product_id_2": "quantity", + "product_id_3": "quantity", + "product_id_4": "quantity" + } + } + ``` + +### Downloadable Product + +Downloadable product allows you to sell digital products, such as eBooks, software applications, music, updates, games, etc. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/cart/add/{product_id}` + +- Params + + | Name | Info | Type | + | ---------- | ------------------- | ------ | + | product_id | Product's ID | Number | + | quantity | Quantity | Number | + | links | Collection of links | Object | + + ```json + { + "product_id": "product_id", + "quantity": "quantity", + "links": { + "0": "link_id_1", + "1": "link_id_2" + } + } + ``` + +### Examples + +#### 1. For simple product + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST http(s)://example.com/api/checkout/cart/add/24` + +- Params + + ```json + { + "product_id": 24, + "quantity": 2 + } + ``` + +#### 2. For configurable product + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST http(s)://example.com/api/checkout/cart/add/6` + +- Params + + ```json + { + "product_id": 6, + "quantity": 1, + "selected_configurable_option": 26, + "super_attribute": { + "23": 2, + "24": 6 + } + } + ``` + +::: details Response + +```json +{ + "message": "Product added to cart successfully.", + "data": { + "id": 4, + "customer_email": "johndoe@example.com", + "customer_first_name": "John", + "customer_last_name": "Doe", + "shipping_method": null, + "items_qty": "1.0000", + "grand_total": "50.0000", + "sub_total": "50.0000", + "tax_total": "0.0000", + "discount": "0.0000", + "checkout_method": null, + "is_guest": 0, + "items": [ + {...}, // Cart Item 1 + {...}, // Cart Item 2 + ], + "selected_shipping_rate": null, + "payment": null, + "billing_address": null, + "shipping_address": null, + } +} +``` + +![bagisto_cart_add](../../assets/1.x/images/api/bagisto_cart_add.jpg) + +::: + +#### 3. Adding more products to the same cart + +For this, you need to pass the `product_id` in the request body also. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST http(s)://example.com/api/checkout/cart/add/25` + +- Params + + ```json + { + "product_id": 25, + "quantity": 2 + } + ``` + +## Get complete cart details + +To get the current cart details, you have to use the `checkout/cart` resource in the API URL. You will see in all the `cart` related API, we used the `checkout` prefix. This API call will work with both customer's authentication or without customer's authentication. If the customer is not logged-in to the store, then this API resource will return the guest's cart detail. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/checkout/cart` + +### Examples + +#### 1. In case of guest customer + +In, Bagisto guest cart is handled by session, and Laravel handles session by cookies. So you need to save the cookies for the guest cart when you are adding product to the cart and then send it as a header when you want to fetch. + +- Headers + + | Key | Value | + | ------ | ------------------- | + | Accept | application/json | + | Cookie | bagisto_session=key | + +- Request + + `GET http(s)://example.com/api/checkout/cart` + +::: details Response + +```json +{ + "data": { + "id": 7, + "customer_email": null, + "customer_first_name": null, + "customer_last_name": null, + "shipping_method": null, + "items_qty": "1.0000", + "grand_total": "50.0000", + "sub_total": "50.0000", + "tax_total": "0.0000", + "discount": "0.0000", + "checkout_method": null, + "is_guest": 1, + "items": [ + {...}, // Cart Item 1 + {...} // Cart Item 2 + ], + "selected_shipping_rate": null, + "payment": null, + "billing_address": null, + "shipping_address": null, + } +} +``` + +![bagisto_cart_guest](../../assets/1.x/images/api/bagisto_cart_guest.jpg) + +::: + +#### 2. In case of logged in customer + +In the case of the logged-in user, no need for cookies as the cart is in the database and linked with the customer. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/checkout/cart` + +::: details Response + +```json +{ + "data": { + "id": 6, + "customer_email": "johndoe@example.com", + "customer_first_name": "John", + "customer_last_name": "Doe", + "shipping_method": null, + "items_count": 2, + "items_qty": "2.0000", + "grand_total": "170.0000", + "sub_total": "170.0000", + "tax_total": "0.0000", + "discount": "0.0000", + "checkout_method": null, + "is_guest": 0, + "items": [ + {...}, // Cart Item 1 + {...} // Cart Item 2 + ], + "selected_shipping_rate": null, + "payment": null, + "billing_address": null, + "shipping_address": null, + } +} +``` + +![bagisto_cart](../../assets/1.x/images/api/bagisto_cart.jpg) + +::: + +## Empty cart + +By using this API call you can remove all the products from the cart. To do this task, you have to use the `checkout/cart/empty` resource in the API URL. This API call will work both with customer's authentication or without customer's authentication. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/checkout/cart/empty` + +### Examples + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/checkout/cart/empty` + +::: details Response + +```json +{ + "message": "Cart removed successfully.", + "data": null +} +``` + +::: + +## Update cart + +By using this API call you can update the cart's product(s) quantity. To do this task, you have to use the `checkout/cart/update` resource in the API URL. This API call will work with both customer's authentication or without customer's authentication. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `PUT /api/checkout/cart/update` + +- Params + + ```json + { + "qty": { + "cart_item_id": "quantity" + } + } + ``` + +### Examples + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `PUT http(s)://example.com/api/checkout/cart/update` + +- Params + + ```json + { + "qty": { + "4": 2 + } + } + ``` + +::: details Response: + +```json +{ + "message": "Cart updated successfully.", + "data": { + "id": 7, + "customer_email": "johndoe@example.com", + "customer_first_name": "John", + "customer_last_name": "Doe", + "shipping_method": null, + "items_qty": "7.0000", + "grand_total": "450.0000", + "sub_total": "450.0000", + "tax_total": "0.0000", + "discount": "0.0000", + "checkout_method": null, + "is_guest": 0, + "items": [ + {...}, // Cart Item 1 + {...}, // Cart Item 2 + {...} // Cart Item 3 + ], + "selected_shipping_rate": null, + "payment": null, + "billing_address": null, + "shipping_address": null, + } +} +``` + +![Bagisto Cart Update](../../assets/1.x/images/api/bagisto_cart_update.jpg) + +::: + +## Apply coupon + +You can also apply the coupon by using the `checkout/cart/coupon` endpoint. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/cart/coupon` + +- Params + + ```json + { + "code": "OFFER20" + } + ``` + +### Examples + +Now, let's apply the coupon and check the responses, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST http(s)://example.com/api/checkout/cart/coupon` + +- Params + + ```json + { + "code": "OFFER20" + } + ``` + +::: details Response + +```json +{ + "success": true, + "message": "Coupon code applied successfully." +} +``` + +::: + +## Remove coupon + +For removing the coupon, you just need to hit the `checkout/cart/coupon` endpoint with the `DELETE` method. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `DELETE /api/checkout/cart/coupon` + +### Examples + +Let's remove the coupon and check the responses, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `DELETE http(s)://example.com/api/checkout/cart/coupon` + +::: details Response + +```json +{ + "success": true, + "message": "Remove Coupon" +} +``` + +::: + +## Remove specific product from cart + +You can remove any particular product from the cart. To do this task, you have to use the `checkout/cart/remove-item/{cart_item_id}` as request payload in the API URL. This API call will work with both customer's authentication or without customer's authentication. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/checkout/cart/remove-item/{cart_item_id}` + +- Params + + | Name | Info | Type | + | ------------ | -------------- | ------ | + | cart_item_id | Cart item's ID | Number | + +### Examples + +- Request + + `GET http(s)://example.com/api/checkout/cart/remove-item/15` + +::: details Response + +```json +{ + "message": "Cart removed successfully.", + "data": { + "id": 6, + "customer_email": "johndoe@example.com", + "customer_first_name": "John", + "customer_last_name": "Doe", + "shipping_method": null, + "items_count": 2, + "items_qty": "5.0000", + "grand_total": "210.0000", + "sub_total": "210.0000", + "tax_total": "0.0000", + "discount": "0.0000", + "checkout_method": null, + "is_guest": 0, + "items": [ + {...}, + {...} + ], + "selected_shipping_rate": null, + "payment": null, + "billing_address": null, + "shipping_address": null, + } +} +``` + +![bagisto_cart_remove_item](../../assets/1.x/images/api/bagisto_cart_remove_item.jpg){:class="screenshot-dimension center"} + +::: + +## Move product from cart to wishlist + +You can move a product from cart to wishlist. To do this task, you have to use the `checkout/cart/move-to-wishlist/{cart_item_id}` as request payload in the API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/checkout/cart/move-to-wishlist/{cart_item_id}` + +- Params + + | Name | Info | Type | + | ------------ | -------------- | ------ | + | cart_item_id | Cart item's ID | Number | + +### Examples + +- Request + + `http(s)://example.com/api/checkout/cart/move-to-wishlist/16` + +::: details Response: + +```json +{ + "message": "Cart item moved to wishlist successfully.", + "data": { + "id": 1, + "customer_email": "johndoe@example.com", + "customer_first_name": "John", + "customer_last_name": "Doe", + "shipping_method": null, + "items_qty": "1.0000", + "grand_total": "50.0000", + "sub_total": "50.0000", + "tax_total": "0.0000", + "discount": "0.0000", + "checkout_method": null, + "is_guest": 0, + "items": [ + {...} // Remaining Cart Item + ], + "selected_shipping_rate": null, + "payment": null, + "billing_address": null, + "shipping_address": null, + } +} +``` + +![bagisto_move_to_wishlist](../../assets/1.x/images/api/bagisto_move_to_wishlist.jpg) + +::: + +## Save addresses to cart + +At the checkout step, customers can create new addresses or select from the existing addresses for billing & shipping the cart's item. You can achieve this task by using the `checkout/save-address` resource in the API URL. This API will work for both logged-in customers and guest users. + +- Request + + `POST /api/checkout/save-address` + +### Examples + +#### 1. For logged in user, + +- Request + + `POST http(s)://example.com/api/checkout/save-address` + +- Params + + ```json + { + "billing": { + "address1": { + "0": "" + }, + "use_for_shipping": "false", + "first_name": "john", + "last_name": "doe", + "email": "john@gmail.com", + "address_id": 1 + }, + "shipping": { + "address1": { + "0": "" + }, + "first_name": "john", + "last_name": "doe", + "email": "john@gmail.com", + "address_id": 2 + } + } + ``` + +#### 2. For guest user + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `POST http(s)://example.com/api/checkout/save-address` + +- Params + + ```json + { + "billing": { + "address1": { + "0": "H 23" + }, + "use_for_shipping": "true", + "first_name": "john", + "last_name": "doe", + "email": "john@webkul.com", + "city": "noida", + "state": "DL", + "postcode": "110092", + "country": "IN", + "phone": "8802097347" + }, + "shipping": { + "address1": { + "0": "" + } + } + } + ``` + +::: details Response + +```json +{ + "data": { + "rates": [{...},{...}], + "cart": { + "id": 6, + "customer_email": "johndoe@example.com", + "items": [{...}, {...}], + "billing_address": { + "id": 7, + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "email": "johndoe@example.com", + "address1": [ + "Block H-ARP Park, Sector 63 " + ], + "country": "IN", + "country_name": "India", + "state": "UP", + "city": "Noida", + "postcode": 201301, + "phone": "0132456789" + }, + "shipping_address": { + "id": 8, + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "email": "johndoe@example.com", + "address1": [ + "Block H-ARP Park, Sector 63 " + ], + "country": "IN", + "country_name": "India", + "state": "UP", + "city": "Noida", + "postcode": 201301, + "phone": "0132456789" + } + } + } +} +``` + +![bagisto_save_address](../../assets/1.x/images/api/bagisto_save_address.jpg) + +::: + +## Save shipping method to cart + +After saving the customer's addresses to the cart, you have to select a shipping method to proceed for completing the order. You can achieve this task by using the `checkout/save-shipping` resource in the API URL. The shipping method and changes will apply to the cart through this API call. This API will work for both logged-in customers and guest users. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/save-shipping` + +- Params + + ```json + { + "shipping_method": "shipping_method_key" + } + ``` + +### Examples + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST http(s)://example.com/api/checkout/save-shipping` + +- Params + + ```json + { + "shipping_method": "flatrate_flatrate" + } + ``` + +::: details Response + +```json +{ + "data": { + "methods": [{...},{...}], + "cart": { + "id": 6, + "customer_email": "johndoe@example.com", + "customer_first_name": "John", + "customer_last_name": "Doe", + "shipping_method": "flatrate_flatrate", + "items": [{...}], + "selected_shipping_rate": { + "id": 9, + "carrier": "flatrate", + "carrier_title": "Flat Rate", + "method": "flatrate_flatrate", + "method_title": "Flat Rate", + "method_description": "This is a flat rate", + "price": 20, + }, + "payment": null, + "billing_address": {...}, + "shipping_address": {...} + } + } +} +``` + +![bagisto_save_shipping](../../assets/1.x/images/api/bagisto_save_shipping.jpg) + +::: + +## Save payment method to cart + +After applying the shipping method to the cart, you have to select a payment method to proceed for completing the order. You can achieve this task by using the `checkout/save-payment` resource in the API URL. By using this API payment method will apply to the cart and will work with both logged-in customers and as well as guest users. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/save-payment` + +- Params + + ```json + { + "payment": { + "method": "payment_method_key" + } + } + ``` + +### Examples + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST http(s)://example.com/api/checkout/save-payment` + +- Params + + ```json + { + "payment": { + "method": "cashondelivery" + } + } + ``` + +::: details Response + +```json +{ + "data": { + "cart": { + "id": 6, + "customer_email": "johndoe@example.com", + "customer_first_name": "John", + "customer_last_name": "Doe", + "shipping_method": "flatrate_flatrate", + "items": [{...}], + "selected_shipping_rate": {...}, + "payment": { + "id": 4, + "method": "cashondelivery", + "method_title": "Cash On Delivery" + }, + "billing_address": {...}, + "shipping_address": {...} + } + } +} +``` + +![bagisto_save_payment](../../assets/1.x/images/api/bagisto_save_payment.jpg) + +::: + +## Save Order + +After applying shipping addresses, shipping methods, and payment methods to the cart, now finally you have to create/save the order. You can achieve this task by using the `checkout/save-order` resource in the API URL. By using this API order will be placed and save to the current store and this API will work for both logged-in customers and with guest users. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `POST /api/checkout/save-order` + +### Examples + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `POST http(s)://example.com/api/checkout/save-order` + +::: details Response + +```json +{ + "success": true, + "order": { + "id": 4, + "status": "pending", + "customer_email": "johndoe@example.com", + "customer_first_name": "John", + "customer_last_name": "Doe", + "shipping_title": "Flat Rate - Flat Rate", + "payment_title": "Cash On Delivery", + "total_qty_ordered": "2.0000", + "grand_total": "120.0000", + "shipping_amount": 20, + "customer": {...}, + "shipping_address": {...}, + "billing_address": {...}, + "items": [{...}], + "invoices": [], + "shipments": [] + } +} +``` + +![bagisto_save_order](../../assets/1.x/images/api/bagisto_save_order.jpg) + +::: diff --git a/docs/1.x/api/categories.md b/docs/1.x/api/categories.md new file mode 100644 index 00000000..e4b1012a --- /dev/null +++ b/docs/1.x/api/categories.md @@ -0,0 +1,363 @@ +# Categories + +In this section, we are using the categories' API. We will fetch all the categories based on `id` and `parent_id` as well. + +## Get all categories + +This api request will fetch all the categories. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/categories(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ------------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | will display all the records if set to `0` | Number | + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Get categories of the specific page + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/categories?page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/categories` + + ::: + +::: details Response + + ~~~json + { + "data": [ + { + "id": 3, + "code": null, + "name": "Laptops", + "slug": "laptops", + "display_mode": "products_only", + "description": "", + "meta_title": "Laptops", + "meta_description": "", + "meta_keywords": "", + "status": 1, + "image_url": null, + "additional": null, + "created_at": "2020-09-08T23:41:24.000000Z", + "updated_at": "2020-09-08T23:41:24.000000Z" + }, + {...}, + {...} + ], + "links": { + "first": "https://example.com/api/categories?page=1", + "last": "https://example.com/api/categories?page=1", + "prev": null, + "next": null + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 1, + "path": "https://example.com/api/categories", + "per_page": 10, + "to": 3, + "total": 3 + } + } + ~~~ + +::: + +#### 2. Get categories of the specific page with limit + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/categories?page=1&limit=10` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 10, + "code": null, + "name": "Lights", + "slug": "lights", + "display_mode": "products_only", + "description": "", + "meta_title": "", + "meta_description": "", + "meta_keywords": "", + "status": 1, + "image_url": null, + "additional": null, + "created_at": "2020-09-24T11:44:42.000000Z", + "updated_at": "2020-09-24T11:44:42.000000Z" + }, + {...}, + {...}, + {...}, + {...} + ], + "links": { + "first": "https://example.com/api/categories?limit=5&page=1", + "last": "https://example.com/api/categories?limit=5&page=2", + "prev": null, + "next": "https://example.com/api/categories?limit=5&page=2" + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 2, + "path": "https://example.com/api/categories", + "per_page": "5", + "to": 5, + "total": 10 + } + } + ~~~ + +::: + +#### 3. Get all categories without pagination + +If you don't want to use the pagination and want to access all the store's categories at once, then you have to send a filter parameter named as`pagination` with value `zero`. By doing this you will get all categories objects at once in the data object and this will not give you link and meta objects. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/categories?pagination=0` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 10, + "code": null, + "name": "Lights", + "slug": "lights", + "display_mode": "products_only", + "description": "", + "meta_title": "", + "meta_description": "", + "meta_keywords": "", + "status": 1, + "image_url": null, + "additional": null, + "created_at": "2020-09-24T11:44:42.000000Z", + "updated_at": "2020-09-24T11:44:42.000000Z" + }, + {...}, + {...}, + {...}, + {...}, + {...}, + {...}, + {...}, + {...}, + {...} + ] + } + ~~~ + +::: + +## Get category by id + +For fetching any specific category, you have to provide the category's id as an input parameter. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/categories/{id}` + +- Params + + | Name | Info | Type | + | ---- | ------------- | ------ | + | id | Category's id | Number | + +### Examples + +#### 1. Let's try to fetch category by id + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/categories/6` + +::: details Response + + ~~~json + { + "data": { + "id": 6, + "code": null, + "name": "Kitchen Appliances", + "slug": "kitchen-appliances", + "display_mode": "products_only", + "description": "", + "meta_title": "", + "meta_description": "", + "meta_keywords": "", + "status": 1, + "image_url": null, + "additional": null, + "created_at": "2020-09-24T11:42:17.000000Z", + "updated_at": "2020-09-24T11:42:17.000000Z" + } + } + ~~~ + +::: + +## Get descendant categories of specific category + +This api request will fetch all the descendant categories based on the `parent_id`. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/descendant-categories(?parent_id)` + +- Params + + | Name | Info | Type | + | --------- | ------------------------------------ | ------ | + | parent_id | Parent id of the descendant category | Number | + +### Examples + +#### 1. Get data based on the `parent_id` which have descendant categories + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/descendant-categories?parent_id=2` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 3, + "code": null, + "name": "Bike Accessories", + "slug": "bike-accessories", + "display_mode": "products_only", + "description": "", + "meta_title": "", + "meta_description": "", + "meta_keywords": "", + "status": 1, + "image_url": null, + "additional": null, + "created_at": "2020-09-22T07:16:32.000000Z", + "updated_at": "2020-09-24T13:08:21.000000Z" + }, + { + "id": 11, + "code": null, + "name": "Bike Tyres", + "slug": "bike-tyres", + "display_mode": "products_only", + "description": "", + "meta_title": "", + "meta_description": "", + "meta_keywords": "", + "status": 1, + "image_url": null, + "additional": null, + "created_at": "2020-09-24T13:20:01.000000Z", + "updated_at": "2020-09-24T13:20:01.000000Z" + } + ] + } + ~~~ + +::: + +#### 2. Let's try with `parent_id` which have no descendant categories + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/descendant-categories?parent_id=3` + +::: details Response + + ~~~json + { + "data": [] + } + ~~~ + +::: diff --git a/docs/1.x/api/customers.md b/docs/1.x/api/customers.md new file mode 100644 index 00000000..71c111a1 --- /dev/null +++ b/docs/1.x/api/customers.md @@ -0,0 +1,524 @@ +# Customers + +In this section, we will use all APIs which relates to customer like registration, authentication, details and reset password. + +Let's start with registration first, + +## Registration + +You can create/register a new customer in the Bagisto store. To achieve this task, you can use the `customer/register` API call resource. + +- Headers + + | Key | Value | + | --------------------- | ---------------- | + | Accept | application/json | + | Content-Type | application/json | + +- Request + + `POST /api/v1/customer/register` + +- Params + + | Name | Info | Type | + | --------------------- | ---------------- | ------ | + | email | Email | String | + | first_name | First Name | String | + | last_name | Last Name | String | + | password | Password | String | + | password_confirmation | Confirm Password | String | + +### Examples + +#### 1. Let's register/create a new customer + +- Headers + + | Key | Value | + | --------------------- | ---------------- | + | Accept | application/json | + | Content-Type | application/json | + +- Request + + `POST http(s)://example.com/api/v1/customer/register` + +- Params + + | Name | Value | + | --------------------- | ------------------------- | + | email | customer@example.com | + | first_name | John | + | last_name | Doe | + | password | customer123 | + | password_confirmation | customer123 | + +::: details Response + + ~~~json + { + message: "Your account has been created successfully." + } + ~~~ + +::: + +#### 2. If customer is already in the Bagisto store with the same email address + +Now, hit the above request one more time. Now, we are going to see the following response. + +::: details Response + + ~~~json + { + "message": "The email has already been taken.", + "errors": { + "email": [ + "The email has already been taken." + ] + } +} + ~~~ + +::: + +## Authentication + +To authenticate any customer at the Bagisto store, the customer needs to have a valid email address and password. + +- Headers + + | Key | Value | + | --------------------- | ---------------- | + | Accept | application/json | + | Content-Type | application/json | + +- Request + + Now here is your choice, whether you want to use **JWT API guard** or normal **customer guard**. + + ::: tip + + If you want to know more about the JWT Authentication, please check here [JWT Authentication](./getting-started-with-the-api#_1-jwt-authentication). + + ::: + + For JWT API guard, you need to pass the token key in the query string. + + `POST /api/customer/login?token=true` + + For normal customer guard, + + `POST /api/customer/login` + +- Params + + | Name | Info | Type | + | ------------- | --------------------- | ------ | + | email | Email for customer | String | + | password | Password for customer | String | + +### Both Examples + +#### 1. Let's try the customer authentication with JWT API guard + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `POST http(s)://example.com/api/customer/login?token=true` + +- Params + + | Key | Value | + | -------- | ---------------- | + | email | john@example.com | + | password | john123 | + +::: details Response + + Once you send the request, you will get some random token string that will be used to access the API data. + + ~~~json + { + "token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC9sb2NhbGhvc3RcL2RldmVsb3BtZW50XC9iYWdpc3RvLW1hc3RlclwvcHVibGljXC9hcGlcL2N1c3RvbWVyXC9sb2dpbiIsImlhdCI6MTYxMDY5Njk2MSwiZXhwIjoxNjEwNzAwNTYxLCJuYmYiOjE2MTA2OTY5NjEsImp0aSI6IkpuMU9aUWoxd1BVaXlLaHQiLCJzdWIiOjEsInBydiI6IjhmY2EwODhhYmFlMmY5YThmODRhNWYwYmY2YTY1MjQ0OTA1NWJlMDAifQ.6mKgyRgMHxi_W6gf2cgb7Rdcut73L1YEBauYZ8soKSU", + "message": "Logged in successfully.", + "data": { + "id": 1, + "email": "john@example.com", + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "gender": null, + "date_of_birth": null, + "phone": null, + "status": 1, + "group": { + "id": 2, + "name": "General", + "created_at": null, + "updated_at": null + }, + "created_at": "2020-09-28T05:13:42.000000Z", + "updated_at": "2020-09-28T05:13:42.000000Z" + } + } + ~~~ + +::: + +#### 2. Let's try without token + +By removing the token key from request will activate the **customer guard**. + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `POST http(s)://example.com/api/customer/login` + +- Params + + | Key | Value | + | -------- | ---------------- | + | email | john@example.com | + | password | john123 | + +::: details Response + + Once you send the request, then you will get data without token because now the **customer guard** is active. + + ~~~json + { + "token": true, + "message": "Logged in successfully.", + "data": { + "id": 1, + "email": "john@example.com", + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "gender": null, + "date_of_birth": null, + "phone": null, + "status": 1, + "group": { + "id": 2, + "name": "General", + "created_at": null, + "updated_at": null + }, + "created_at": "2020-09-28T05:13:42.000000Z", + "updated_at": "2020-09-28T05:13:42.000000Z" + } + } + ~~~ + +::: + +## Details + +You can get the customer's details only for the logged-in customer. To retrieve the customer's information you can use the `customer/get` resource. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/customer/get` + +### Examples + +Let's fetch the customer data, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/customer/get` + +::: details Response + + ~~~json + { + "data": { + "id": 1, + "email": "john@example.com", + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "gender": null, + "date_of_birth": null, + "phone": null, + "status": 1, + "group": { + "id": 2, + "name": "General", + "created_at": null, + "updated_at": null + }, + "created_at": "2020-09-28T05:13:42.000000Z", + "updated_at": "2020-09-28T05:13:42.000000Z" + } + } + ~~~ + +::: + +## Details by id + +You can also get the customer information by using `customer_id` as a request payload. To achieve this, you can use the `customers/{id}` API call resource. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/customers/{id}` + +- Params + + | Name | Info | Type | + | ---- | ----------- | ------ | + | id | Customer ID | Number | + +::: warning + + This request will return the current logged in customer's details. + +::: + +### Examples + +Let's fetch the customer data, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/customers/1` + +::: details Response + + ~~~json + { + "data": { + "id": 1, + "email": "john@example.com", + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "gender": null, + "date_of_birth": null, + "phone": null, + "status": 1, + "group": { + "id": 2, + "name": "General", + "created_at": null, + "updated_at": null + }, + "created_at": "2020-09-28T05:13:42.000000Z", + "updated_at": "2020-09-28T05:13:42.000000Z" + } + } + ~~~ + +::: + +## Profile details + +To update the current logged in customer's account information, you need to use the `customer/profile` API call resource. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `PUT /api/customer/profile` + +- Params + + | Name | Info | Type | + | ------------- | ------------- | ------ | + | first_name | First Name | String | + | last_name | Last Name | String | + | gender | Gender | String | + | date_of_birth | Date Of Birth | Date | + | email | E-Mail | String | + | password | Password | String | + +### Examples + +#### 1. Updating current logged in user + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `PUT http(s)://example.com/api/customer/profile` + +- Params + + | Name | Value | + | ---------- | ---------------- | + | first_name | John | + | last_name | Doe | + | name | John Doe | + | email | john@example.com | + +::: details Response + + ~~~json + { + "message": "Your account has been updated successfully.", + "data": {...} + } + ~~~ + +::: + +## Logout + +You can logout the customer from the Bagisto store with the help of `customer/logout` resources. No need to provide any request payload in the API call. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/customer/logout` + +### Examples + +- Request + + `GET http(s)://example.com/api/customer/logout` + +::: details Response + + ~~~json + { + "message": "Logged out successfully!" + } + ~~~ + +::: + +## Reset password + +You can also use the API to reset the customer's password by providing the valid customer's email address. In this API request, you have to use the `customer/forgot-password` resource with `email` as a request payload. An email will be sent on the provided email address, only if the same email address exists in the Bagisto store. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + +- Request + + `POST /api/customer/forgot-password` + +- Params + + | Name | Info | Type | + | ------------- | ----- | ------ | + | email | Email | String | + +### Examples + +#### 1. Let's try the customer forgot password request + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/customer/forgot-password` + +- Params + + | Name | Value | + | ----- | ---------------- | + | email | john@example.com | + +::: details Response + + ~~~json + { + "message": "We have e-mailed your password reset link!" + } + ~~~ + +::: + +#### 2. In case you provide an invalid or unregistered email address, then no email will be sent to the provided email address + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/customer/forgot-password` + +- Params + + | Name | Value | + | ----- | ----------------- | + | email | peter@example.com | + +::: details Response + + ~~~json + { + "error": "We can't find a user with that e-mail address." + } + ~~~ + +::: diff --git a/docs/1.x/api/explanation.md b/docs/1.x/api/explanation.md new file mode 100644 index 00000000..2a3fd87f --- /dev/null +++ b/docs/1.x/api/explanation.md @@ -0,0 +1,63 @@ +# Explanation + +If you check all the sections in which we have used pagination, in all the responses, you will find that there are three objects key i.e. `data`, `links`, and `meta`. In this section, we will explain all the three keys. + +Let's take an example of the categories section, we have some response in which we got these three keys. + +~~~json +{ + "data": [{...},{...},...,{...}], + "links": {...}, + "meta": {...} +} +~~~ + +## 1. Data Object `data` + +In the data object key, you will find the collection of many objects which represent the Bagisto store's categories. + +## 2. Links Object `links` + +In the links object, you will find four more object keys, which will be used according to pagination, + + ~~~json + "links": { + "first": "https://example.com/api/categories?limit=5&pagination=342234&page=1", + "last": "https://example.com/api/categories?limit=5&pagination=342234&page=2", + "prev": null, + "next": "https://example.com/api/categories?limit=5&pagination=342234&page=2" + } + ~~~ + + | Name | Info | + | ------------- | ------------------------------------------------------------------------------------------------------------------- | + | first | Display the first url link of the called API with filter variable. | + | last | Display the last url link of the called API with filter variable. | + | prev | Display the previous url of the current called API url. | + | next | Display the next url of the current called API url. If no next url available then it will contain the `null` value. | + +## 3. Meta Object `meta` + +`meta` object will only used with pagination. Under meta object, you will find seven object keys, + + ~~~json + "meta": { + "current_page": 1, + "from": 1, + "last_page": 2, + "path": "https://example.com/api/categories", + "per_page": "5", + "to": 5, + "total": 10 + } + ~~~ + + | Name | Info | + | ------------- | -------------------------------------------------------------------------------------------------- | + | current_page | Display the current page number. | + | from | Display the first count of the returned data object based on the provided page and limit filters. | + | last_page | Display the last page number. | + | path | Display the current api url without input parameters. | + | per_page | Display the total of records in a single page. | + | to | Display the last count of the returned data object based on the provided page and limit filters. | + | total | Display the total number of records in the store. | \ No newline at end of file diff --git a/docs/1.x/api/getting-started-with-the-api.md b/docs/1.x/api/getting-started-with-the-api.md new file mode 100644 index 00000000..d3925186 --- /dev/null +++ b/docs/1.x/api/getting-started-with-the-api.md @@ -0,0 +1,200 @@ +# Authentication + +[[toc]] + +## Introduction + +By default the [Bagisto](https://bagisto.com) API makes use of the [JWT package](https://jwt.io/) for token-based authentication. +You can however choose either if you want to authenticate via. **JWT API guard** or with the normal **customer guard**. +When you are going through the api documentation, you will see one of the examples i.e. with or without tokens. Let discuss both of them. + +## Auth Guards + +::: warning +You are required to send a valid **User Agent** header in your request. +::: + +### JWT Authentication + +To activate the **JWT** authentication, you just need to pass one extra key-value pair in your request i.e. `token=true`. + + | Key | Value | + | ----- | ----- | + | token | true | + +This will tell the Bagisto api to use the **JWT API guard**. If you are not passing this, the normal **customer guard** will be activated. + +So, let's try to authenticate the user by using **JWT**. Please send valid **User Agent** header in your request whether you are using postman, curl or some other clients. + +::: tip Reminder + + Here we are showing just a sample of API for the usage of **JWT** token. If you are familiar with all these things you can start with the [Customer](./customers) API section. + +::: + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `POST http(s)://example.com/api/customer/login?token=true` + +- Params + + | Key | Value | + | -------- | ---------------- | + | email | john@example.com | + | password | john123 | + +- Response + + - Once you send the request, you will get some random token string that will be used to access the API data. + + ~~~json + { + "token": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC9sb2NhbGhvc3RcL2RldmVsb3BtZW50XC9iYWdpc3RvLW1hc3RlclwvcHVibGljXC9hcGlcL2N1c3RvbWVyXC9sb2dpbiIsImlhdCI6MTYxMDY5Njk2MSwiZXhwIjoxNjEwNzAwNTYxLCJuYmYiOjE2MTA2OTY5NjEsImp0aSI6IkpuMU9aUWoxd1BVaXlLaHQiLCJzdWIiOjEsInBydiI6IjhmY2EwODhhYmFlMmY5YThmODRhNWYwYmY2YTY1MjQ0OTA1NWJlMDAifQ.6mKgyRgMHxi_W6gf2cgb7Rdcut73L1YEBauYZ8soKSU", + "message": "Logged in successfully.", + "data": { + "id": 1, + "email": "john@example.com", + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "gender": null, + "date_of_birth": null, + "phone": null, + "status": 1, + "group": { + "id": 2, + "name": "General", + "created_at": null, + "updated_at": null + }, + "created_at": "2020-09-28T05:13:42.000000Z", + "updated_at": "2020-09-28T05:13:42.000000Z" + } + } + ~~~ + +### Customer Guard + +By removing the token key from your request the **customer guard** will be activated. + +#### Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `POST http(s)://example.com/api/customer/login` + +#### Params + + | Key | Value | + | -------- | ---------------- | + | email | john@example.com | + | password | john123 | + +#### Response + +Once you send the request, you will get data without any token because now the **customer guard** is active. + +~~~json +{ + "token": true, + "message": "Logged in successfully.", + "data": { + "id": 1, + "email": "john@example.com", + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "gender": null, + "date_of_birth": null, + "phone": null, + "status": 1, + "group": { + "id": 2, + "name": "General", + "created_at": null, + "updated_at": null + }, + "created_at": "2020-09-28T05:13:42.000000Z", + "updated_at": "2020-09-28T05:13:42.000000Z" + } +} +~~~ + +## Accessing Data + +Once you are authenticated, try to access the current customer data by using **JWT**, use the customer API endpoint for this, + +::: tip + +Here we are just showing a example of how to collect data from the API with the usage of a **JWT** token. +If you are familiar with all these things you can start with the [Customer](./customers) API section. + +::: + +#### Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +::: tip + +As you check the **JWT** authentication we got some token string, we just need to put that token in the request header. For e.g., + +~~~request-header + Accept:application/json + Authorization:Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9... +~~~ + +::: + +#### Request + + `GET http(s)://example.com/api/customer/get?token=true` + +::: details Response + +~~~json +{ + "data": { + "id": 1, + "email": "john@example.com", + "first_name": "John", + "last_name": "Doe", + "name": "John Doe", + "gender": null, + "date_of_birth": null, + "phone": null, + "status": 1, + "group": { + "id": 2, + "name": "General", + "created_at": null, + "updated_at": null + }, + "created_at": "2020-09-28T05:13:42.000000Z", + "updated_at": "2020-09-28T05:13:42.000000Z" + } +} +~~~ + +::: + +If you don't want to use **JWT**, then just remove the token key from the query string. + +::: warning + + You have to re-login again to access without the **JWT** token because currently it will use the **customer guard**. + +::: diff --git a/docs/1.x/api/invoices.md b/docs/1.x/api/invoices.md new file mode 100644 index 00000000..fe4d0828 --- /dev/null +++ b/docs/1.x/api/invoices.md @@ -0,0 +1,258 @@ +# Invoices + +In this section, we will check all the invoices' API. + +## Get invoices from all orders + +You can get all the invoices for the Bagisto store's orders. To get the invoices of the store, the customer must be logged-in to the Bagisto store. You can achieve this job by using the `invoices` API call resource. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/invoices(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ------------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Get invoices with pagination + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/invoices?page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/invoices` + + ::: + +::: details Response + + ~~~json + { + "data": [ + { + "id": 8, + "state": "paid", + "email_sent": 0, + "total_qty": 4, + "sub_total": "190.0000", + "base_sub_total": "190.0000", + "grand_total": "230.0000", + "order_address": {...}, + "transaction_id": null, + "items": [ + {...}, + {...} + ], + }, + {...}, + ... + {...} + ], + "links": { + "first": "https://example.com/api/invoices?page=1", + "last": "https://example.com/api/invoices?page=1", + "prev": null, + "next": null + }, + "meta": {...} + } + ~~~ + +::: + +#### 2. Get all invoices without pagination + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/invoices?pagination=0` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 8, + "state": "paid", + "email_sent": 0, + "total_qty": 4, + "sub_total": "190.0000", + "base_sub_total": "190.0000", + "grand_total": "230.0000", + "order_address": {...}, + "transaction_id": null, + "items": [ + {...}, + {...} + ], + }, + {...}, + ... + {...} + ] + } + ~~~ + +::: + +## Get invoices by order's id + +To get the details of a specific order's invoice, you have to pass an `order_id` as a query parameter like `invoices?order_id={id}` in API URL. By using this resource and query parameter, you will get only a single invoice detail regarding the provided `order_id` in response. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/invoices(?order_id,limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ------------- | -------------------------------------------- | ------ | + | order_id | Order's ID | Number | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +### Examples + +#### 1. Get all invoices by order's id + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/invoices?order_id=3&pagination=0` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 1, + "state": "paid", + "email_sent": 0, + "total_qty": 2, + "sub_total": "60.0000", + "grand_total": "80.0000", + "shipping_amount": "20.0000", + "items": [ + {...}, + {...} + ], + } + ] + } + ~~~ + +::: + +## Get invoice by id + +To get the details of a specific invoice, you have to pass an `invoice_id` as a request payload in API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/invoices/{invoice_id}` + +- Params + + | Name | Info | Type | + | ------------- | ------------ | ------ | + | invoice_id | Invoice's ID | Number | + +### Examples + +#### 1. Let's fetch specific invoice + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/invoices/2` + +::: details Response + + ~~~json + { + "data": { + "id": 2, + "state": "paid", + "email_sent": 0, + "total_qty": 4, + "sub_total": "190.0000", + "grand_total": "230.0000", + "shipping_amount": "40.0000", + "tax_amount": "0.0000", + "discount_amount": "0.0000", + "order_address": {...}, + "transaction_id": null, + "items": [ + {...}, + {...} + ], + } + } + ~~~ + +::: diff --git a/docs/1.x/api/locales.md b/docs/1.x/api/locales.md new file mode 100644 index 00000000..4094cf72 --- /dev/null +++ b/docs/1.x/api/locales.md @@ -0,0 +1,227 @@ +# Locales + +In this section, we will see all the APIs which are related to locales. + +## Get all locales + +You can get all the locales from the Bagisto store. You can achieve this job by using the `locales` API call resource. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/locales(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ---------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Records for specific page + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/locales?page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/locales` + + ::: + +::: details Response + +~~~json +{ + "data": [ + { + "id": 4, + "code": "tr", + "name": "Türkçe", + "created_at": null, + "updated_at": null + }, + { + "id": 3, + "code": "nl", + "name": "Dutch", + "created_at": null, + "updated_at": null + }, + { + "id": 2, + "code": "fr", + "name": "French", + "created_at": null, + "updated_at": null + }, + { + "id": 1, + "code": "en", + "name": "English", + "created_at": null, + "updated_at": null + } + ], + "links": { + "first": "https://example.com/api/locales?page=1", + "last": "https://example.com/api/locales?page=1", + "prev": null, + "next": null + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 1, + "links": [ + { + "url": null, + "label": "« Previous", + "active": false + }, + { + "url": "https://example.com/api/locales?page=1", + "label": "1", + "active": true + }, + { + "url": null, + "label": "Next »", + "active": false + } + ], + "path": "https://example.com/api/locales", + "per_page": 10, + "to": 4, + "total": 4 + } +} +~~~ + +::: + +#### 2. Get all locales without pagination + +You can also get all the locales at once from the Bagisto store without pagination. For this, you have to pass `pagination=0` in the query parameter with the `locales` resource in the API URL. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/public/api/locales?pagination=0` + +::: details Response + +~~~json +{ + "data": [ + { + "id": 4, + "code": "tr", + "name": "Türkçe", + "created_at": null, + "updated_at": null + }, + { + "id": 3, + "code": "nl", + "name": "Dutch", + "created_at": null, + "updated_at": null + }, + { + "id": 2, + "code": "fr", + "name": "French", + "created_at": null, + "updated_at": null + }, + { + "id": 1, + "code": "en", + "name": "English", + "created_at": null, + "updated_at": null + } + ] +} +~~~ + +::: + +## Get locale by id + +To get the specific locale details, you have to pass an `locale_id` as a request payload in the API URL. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/locales/{locale_id}` + +- Params + + | Name | Info | Type | + | --------- | ----------- | ------ | + | locale_id | Locale's ID | Number | + +### Examples + +Let's fetch specific locale, + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/locales/1` + +::: details Response + +~~~json +{ + "data": { + "id": 1, + "code": "en", + "name": "English", + "created_at": null, + "updated_at": null + } +} +~~~ + +::: diff --git a/docs/1.x/api/orders.md b/docs/1.x/api/orders.md new file mode 100644 index 00000000..37766893 --- /dev/null +++ b/docs/1.x/api/orders.md @@ -0,0 +1,355 @@ +# Orders + +In this section, we will see all the APIs which are related to order. As after order placement tracking of order is also important. + +## Get all orders + +You can get all the orders of the Bagisto store. To get the orders of the store, the customer must be logged in to the Bagisto Store. You can achieve this job by using `orders` API call resource. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/orders(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ---------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +::: tip + +If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Records for specific page + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/orders?page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/orders` + + ::: + +::: details Response + +```json +{ + "data": [ + {...}, + {...}, + ... + {...} + ], + "links": { + "first": "https://example.com/api/orders?page=1", + "last": "https://example.com/api/orders?page=2", + "prev": null, + "next": "https://example.com/api/orders?page=2" + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 2, + "path": "https://example.com/api/orders", + "per_page": 10, + "to": 10, + "total": 11 + } +} +``` + +::: + +#### 2. Records for specific page with limit + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/public/api/orders?limit=5&page=2` + +::: details Response + +```json +{ + "data": [ + {...}, + {...}, + {...}, + {...}, + {...} + ] + "links": { + "first": "https://example.com/api/orders?limit=5&page=1", + "last": "https://example.com/api/orders?limit=5&page=3", + "prev": "https://example.com/api/orders?limit=5&page=1", + "next": "https://example.com/api/orders?limit=5&page=3" + }, + "meta": { + "current_page": 2, + "from": 6, + "last_page": 3, + "path": "https://example.com/api/orders", + "per_page": "5", + "to": 10, + "total": 11 + } +} +``` + +::: + +#### 3. Get all orders without pagination, + +You can also get all the orders at once from the Bagisto store without pagination. To get the orders, the customer must be logged in to the Bagisto store. For this, you have to pass `pagination=0` in the query parameter with the `orders` resource in the API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/public/api/orders?pagination=0` + +::: details Response + +```json +{ + "data": [ + {...}, + {...}, + {...}, + ... + {...} + ] +} +``` + +![bagisto_orders_no_pag](../../assets/1.x/images/api/bagisto_orders_no_pag.jpg){:class="screenshot-dimension center"} + +::: + +## Get order by id + +To get the specific order details, you have to pass an `order_id` as a request payload in the API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/orders/{order_id}` + +- Params + + | Name | Info | Type | + | -------- | ---------- | ------ | + | order_id | Order's ID | Number | + +### Examples + +Let's fetch specific order, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/order/3` + +::: details Response + +```json +{ + "data": { + "id": 3, + "status": "pending", + "status_label": "Pending", + "channel_name": "Default", + "customer_email": "peterdoe@example.com", + "customer_first_name": "Peter", + "customer_last_name": "Doe", + "shipping_method": "flatrate_flatrate", + "shipping_title": "Flat Rate - Flat Rate", + "payment_title": "Cash On Delivery", + "total_qty_ordered": 2, + "grand_total": "80.0000", + "customer": {...}, + "shipping_address": {...}, + "billing_address": {...}, + "items": [ + {...}, + {...} + ], + "invoices": [], + "shipments": [], + } + } +} +``` + +![bagisto_orders_id](../../assets/1.x/images/api/bagisto_orders_id.jpg) + +::: + +## Get orders by customer's id + +To get all the orders of a specific customer, you have to pass a `customer_id` as a query parameter like `orders?customer_id={id}` in API URL. To use this API call customer authentication is required means that customers must be logged-in to the store. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/public/api/orders(?customer_id,limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ----------- | -------------------------------------------- | ------ | + | customer_id | Cutomer's ID | Number | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +### Examples + +#### 1. To get all the results without pagination + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/public/api/orders?customer_id=2&pagination=0` + +::: details Response + +```json +{ + "data": [ + { + "id": 3, + "status": "pending", + "customer_email": "peterdoe@webkul.com", + "customer_first_name": "Peter", + "customer_last_name": "Doe", + "shipping_method": "flatrate_flatrate", + "shipping_title": "Flat Rate - Flat Rate", + "payment_title": "Cash On Delivery", + "total_qty_ordered": 2, + "grand_total": "80.0000", + "customer": {...}, + "shipping_address": {...}, + "billing_address": {...}, + "items": [{...},{...},{...}], + }, + { + "id": 2, + "status": "pending", + "customer_email": "peterdoe@webkul.com", + "customer_first_name": "Peter", + "customer_last_name": "Doe", + "shipping_method": "flatrate_flatrate", + "shipping_title": "Flat Rate - Flat Rate", + "payment_title": "Cash On Delivery", + "total_qty_ordered": 5, + "grand_total": "400.0000", + "customer": {...}, + "shipping_address": {...}, + "billing_address": {...}, + "items": [{...},{...},{...}], + } + ] +} +``` + +::: + +#### 2. Get all orders by customer's id with pagination + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/orders?customer_id=2&limit=5&page=1` + +::: details Response + +```json +{ + "data": [ + {...} + ], + "links": { + "first": "https://example.com/api/orders?customer_id=2&limit=1&page=1", + "last": "https://example.com/api/orders?customer_id=2&limit=1&page=1", + "prev": "https://example.com/api/orders?customer_id=2&limit=1&page=1", + "next": null + }, + "meta": { + "current_page": 2, + "from": 2, + "last_page": 2, + "path": "https://example.com/api/orders", + "per_page": "1", + "to": 2, + "total": 2 + } +} +``` + +::: diff --git a/docs/1.x/api/products.md b/docs/1.x/api/products.md new file mode 100644 index 00000000..21cb91f2 --- /dev/null +++ b/docs/1.x/api/products.md @@ -0,0 +1,506 @@ +# Products + +In this section, we will use the product's API. We will start with the fetching of all products. Then we will move forward to query params and filterable query params. In last, we will check the additional and variant information. + +## Get all products + +This request will fetch all the products based on `limit` and `page`. + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `/api/products(?limit,page)` + + ::: tip + + If you didn't use the page(?page=x) filter, then it returns the data of the first page by default. + + ::: + +- Params + + | Name | Info | Type | + | ----- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + +::: tip + +If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Get products for specific page + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `http(s)://example.com/api/products?page=1` + +::: details Response + +```json +{ + "data": [ + { + "id": 3, + "type": "simple", + "name": "Lenovo IdeaPad Yoga 500 15 Hybrid (2-in-1) White", + "url_key": "lenovo-ideapad-yoga-500-15-hybrid-2-in-1-white", + "price": "600.0000", + "formated_price": "$600.00", + ... + "sku": "5626", + "images": [ + {...} + ], + "base_image": {...}, + "variants": [], + "in_stock": true, + "reviews": {...}, + "is_saved": false, + "created_at": "2020-09-09 03:31:47", + "updated_at": "2020-09-09 03:31:47" + }, + {...}, + {...} + ], + "links": {...}, + "meta": {...} +} +``` + +::: + +#### 2. Get products for specific page with limit + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `http(s)://example.com/api/products?limit=2&page=1` + +::: details Response + +```json +{ + "data": [ + {...}, + {...} + ], + "links": { + "first": "https://example.com/api/products?page=1&limit=2", + "last": "https://example.com/api/products?page=4&limit=2", + "prev": null, + "next": "https://example.com/api/products?page=2&limit=2" + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 4, + "path": "https://example.com/api/products", + "per_page": "2", // limit + "to": 2, + "total": 8 + } +} +``` + +::: + +## Get products with query parameters + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/products(?category_id,new,featured,name,sku,url_key,limit,page)` + +- Params + + | Name | Info | Type | + | ----------- | ---------------- | ------- | + | category_id | Category's ID | Number | + | new | New Product | Boolean | + | featured | Featured Product | Boolean | + | name | Name | String | + | sku | SKU | String | + | url_key | URL Key | String | + | limit | Limit | Number | + | page | Page | Number | + +### Examples + +#### 1. If you want to get the store's products those are having new condition then you can use `new=1` in the query parameter and if want to get the products without new condition then use `new=0` + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?new=1` + +#### 2. You can also use the `limit` and `page` query parameters with the `new` query parameter + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?new=1&limit=5&page=1` + + `GET http(s)://example.com/api/products?new=0&limit=5&page=1` + +#### 3. If you want to get the store's products those are featured then you can use `featured=1` query parameter + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?featured=1` + +#### 4. You can also use the `limit` and `page` in query parameters with `featured` query parameter + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?featured=1&limit=5&page=1` + + `GET http(s)://example.com/api/products?featured=0&limit=5&page=1` + +#### 5. Suppose you want to find out the data of your product in the Bagisto store, here you can use the `name` query parameter. You have to provide the product name to the `name` query parameter in the API URL + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?name='Leather Shoes'` + +#### 6. You can also get your product-related details with the help of the product's SKU. SKU will be unique for each product in the Bagisto store. For this, you have to use `sku` as a query parameter in the API URL + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?sku='1234'` + +#### 7. `url_key` is a unique field for every product in Bagisto Store. You can also find out product details by using `url_key`. For this, you have to pass `url_key` as a query parameter in the API URL + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?url_key='leather-shoes'` + +## Get products with filterable query parameters + +You can also filter your store products by using filterable attributes query parameters. These filters will only work with the `category_id` input query parameter. There are two system-defined filterable attributes in the Bagisto E-commerce framework i.e. `size` and `color`. Admin user can also create their own custom attribute and can make these custom attributes as filterable. By using these filterable attributes, customers can filter the category's products to get the desired result. + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products(?category_id,size,color,price)` + +- Params + + | Name | Info | Type | + | ----------- | ------------- | ------ | + | category_id | Category's ID | Number | + | size | Size | String | + | color | Color | String | + | price | Price | String | + +### Examples + +#### 1. You can filter Bagisto's product catalog with the help of `size` filter. `size` filter will work only on the category layout. You can pass the multiple attribute's values to the `size` filterable attributes as a query parameter in API url. Suppose you want to filter men's T-Shirt with medium and large size, then you can pass the id of both medium & large + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?category_id=2&size=6,7` + +#### 2. You can also use the limit and page in query parameters with category & size filterable parameters + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?category_id=2&size=6,7&limit=10&page=1` + + ![Bagisto Product Size](../../assets/1.x/images/api/bagisto_prod_size.jpg) + +#### 3. You can also filter the Bagisto product catalog with the help of `color` filter. `color` filter will work only on the category layout. You can pass the multiple attribute's values to the color`s filterable attributes as a query parameter in API URL. Suppose you want to filter men's T-Shirt with white and red color, then you can pass the id of both white & red + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?category_id=2&color=1,2` + +#### 4. You can also use the limit and page in query parameters with category & color filterable parameters + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?category_id=2&color=1,2&limit=10&page=1` + + ![Bagisto Product Color](../../assets/1.x/images/api/bagisto_prod_color.jpg) + +#### 5. In the case of a simple product, You can set a range of a minimum price and maximum price. Same as `size` and `color`, the `price` filter will also work on the category layout only. Suppose you want to filter products those are having price between price range from 50 to 100, then you have to pass value like `price=10,50` as the query parameter in API URL + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?category_id=2&price=50,100` + +#### 6. You can also use the `limit` and `page` in query parameters with `category` & `price` filterable parameters + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?category_id=2&price=50,100&limit=10&page=1` + + ![Bagisto Product Price Simple](../../assets/1.x/images/api/bagisto_prod_price_simple.jpg) + +#### 7. In the case of a configurable product, the `price` filter will also work with the product's variants. Suppose you want to filter products with the 40$ min and 100$ max price range. And there is a configurable product named men's T-shirts having a price 30$ and there is any variant of the same product having 45$ price, then men's T-shirts product will show you in the filtered product's list + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products?category_id=2&price=30,100` + + ![Bagisto Product Price Config](../../assets/1.x/images/api/bagisto_prod_price_config.jpg) + +::: tip + +The above-explained filter query parameters (i.e. size, color, price) can be used together. + +::: + +## Get product by id + +If you want the record of any specific product, then you have to provide the product id as an input parameter in the API URL. + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/products/{product_id}` + +- Params + + | Name | Info | Type | + | ---------- | ------------ | ------ | + | product_id | Product's ID | Number | + +### Examples + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/products/1` + +::: details Response + +```json +{ + "data": { + "id": 1, + "type": "simple", + "name": "Adorable Cream Teddy Bear", + "url_key": "adorable-cream-teddy-bear", + "price": "10.0000", + "formated_price": "$10.00", + "short_description": "

Buy Adorable Cream Teddy Bear online at best price

", + "description": "

Buy Adorable Cream Teddy Bear online at best price

", + "sku": "80971254", + "images": [ + {...} + ], + "base_image": {...}, + "variants": [], + "in_stock": true, + "reviews": {...}, + "is_saved": false, + "created_at": "2020-09-08T23:52:02.000000Z", + "updated_at": "2020-09-08T23:52:02.000000Z" + } +} +``` + +::: + +## Get product's additional information + +Additional information relates to all the attributes and their values for which admin sets the `Yes` value for the `Visible on Product View Page on Front-end`. The product's additional information means those attributes which describe the product's specification. + +![Bagisto Attribute](../../assets/1.x/images/api/bagisto_attribute.jpg) + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/product-additional-information/1` + +::: details Response + +![Bagisto Additional Info](../../assets/1.x/images/api/bagisto_add_info.jpg) + +::: + +## Get product's variants information + +You can get all the configurable attributes of a product by using `product-configurable-config` resource in API calls. It will return all the variants of a product with their `label`, `options`, `regular_price` and `final_price` also. + +Admin can set the `Yes` value for the `Use To Create Configurable Product` field under the attribute panel to make that attribute as variant. + +![Bagisto Config](../../assets/1.x/images/api/bagisto_config.jpg) + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + +- Request + + `GET http(s)://example.com/api/product-configurable-config/1` + +::: details Response + +```json +{ + "data": { + "attributes": [ + { + "id": 24, + "code": "size", + "label": "Size", + "swatch_type": null, + "options": [ + { + "id": 7, + "label": "M", + "swatch_value": null, + "products": [4] + } + ] + } + ], + "variant_prices": { + "4": { + "regular_price": { + "formated_price": "$45.00", + "price": 45 + }, + "final_price": { + "formated_price": "$45.00", + "price": 45 + } + } + } + } +} +``` + +![Bagisto Config Attributes](../../assets/1.x/images/api/bagisto_config_attr.jpg) + +::: diff --git a/docs/1.x/api/reviews.md b/docs/1.x/api/reviews.md new file mode 100644 index 00000000..04abae40 --- /dev/null +++ b/docs/1.x/api/reviews.md @@ -0,0 +1,495 @@ +# Reviews + +In this section, we will check all the reviews' API based on customers as well as products. Also we will see how to create a review. + +## Get all reviews + +You can get all the reviews of the Bagisto store. You can achieve this job by using `reviews` API call resource. There is no need of customer authentication. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/reviews(?page,limit,pagination)` + +- Params + + | Name | Info | Type | + | ---------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Get reviews for specific page + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET https://example.com/api/reviews?page=1` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 10, + "title": "Awesome Product & Service ", + "rating": "3.0", + "comment": "Awesome Product & Service ", + "name": "John Doe", + "status": "approved", + }, + { + "id": 9, + "title": "Awesome Product Quality", + "rating": "4.0", + "comment": "Awesome Product Quality", + "name": "John Doe", + "status": "approved", + }, + {...}, + {...}, + ], + "links": { + "first": "https://example.com/api/reviews?page=1", + "last": "https://example.com/api/reviews?page=2", + "prev": null, + "next": null + }, + "meta": {...} + } + ~~~ + +::: + +#### 2. Get all reviews without pagination + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET https://example.com/api/reviews?pagination=0` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 6, + "title": "Great product & Service!!!", + "rating": "4.0", + "comment": "Beautiful bangles. Better than I expected.", + "name": "John Doe", + "status": "approved", + }, + { + "id": 5, + "title": "Very good product.. Recommend to all", + "rating": "5.0", + "comment": "I have ordered 2 sets. The product i received was good, i loved it.", + "name": "Peter Doe", + "status": "approved", + }, + { + "id": 4, + "title": "Awesome Product & Service ", + "rating": "3.0", + "comment": "Awesome Product & Service ", + "name": "John Doe", + "status": "approved", + }, + {...}, + {...}, + {...} + ] + } + ~~~ + +::: + +## Get review by id + +To get the specific review detail, you have to pass a review id i.e. `id` as a request payload like `reviews/{id}` in API URL. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/reviews/{id}` + +- Params + + | Name | Info | Type | + | ---- | ------------ | ------ | + | id | Review's ID. | Number | + +### Examples + +#### 1. Get specific review by id + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET https://example.com/api/reviews/2` + +- Response + + ~~~json + { + "data": { + "id": 2, + "title": "Awesome Product & Service ", + "rating": "3.0", + "comment": "Awesome Product & Service ", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...} + } + } + ~~~ + +## Get reviews by customer's id + +This request will fetch all the reviews by customer's id. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/reviews(?customer_id,limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ----------- | -------------------------------------------- | ------ | + | customer_id | Customer's ID. | Number | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +### Examples + +#### 1. Get data of the specific page + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET https://example.com/api/reviews?customer_id=1&page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET https://example.com/api/reviews?customer_id=1` + + ::: + +::: details Response + + ~~~json + { + { + "data": [ + { + "id": 4, + "title": "Good Product", + "rating": "5.0", + "comment": "Nice...", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...}, + }, + { + "id": 3, + "title": "Value For Money", + "rating": "5.0", + "comment": "Very nice product. Made with good quality.", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...}, + } + { + "id": 2, + "title": "Great product & Service!!!", + "rating": "4.0", + "comment": "Beautiful bangles. Better than I expected.", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...} + }, + { + "id": 1, + "title": "Awesome Product & Service ", + "rating": "3.0", + "comment": "Awesome Product & Service ", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...} + }, + ], + "links": { + "first": "https://example.com/api/reviews?customer_id=1&page=1", + "last": "https://example.com/api/reviews?customer_id=1&page=1", + "prev": null, + "next": null + }, + "meta": {...} + } + } + ~~~ + +::: + +#### 2. Get all customer's reviews without pagination + +You can also get all customer's reviews of Bagisto Store in a single API call without using pagination. For this you have to pass `pagination=0` in the query parameter with the `reviews?customer_id={id}` resource in the API URL. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET https://example.com/api/reviews?customer_id=1&pagination=0` + +::: details Response + + ~~~json + { + "data": [ + { + "id": 4, + "title": "Good Product", + "rating": "5.0", + "comment": "Nice...", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...}, + }, + { + "id": 3, + "title": "Value For Money", + "rating": "5.0", + "comment": "Very nice product. Made with good quality.", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...}, + } + { + "id": 2, + "title": "Great product & Service!!!", + "rating": "4.0", + "comment": "Beautiful bangles. Better than I expected.", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...} + }, + { + "id": 1, + "title": "Awesome Product & Service ", + "rating": "3.0", + "comment": "Awesome Product & Service ", + "name": "John Doe", + "status": "approved", + "product": {...}, + "customer": {...} + } + ] + } + ~~~ + +::: + +## Get review by product's id + +To get all the reviews of a specific product, you have to pass a `product_id` as a query parameter like `reviews?product_id={id}` in API URL. To use this API call customer authentication is not required. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET /api/reviews(?product_id,limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ---------- | -------------------------------------------- | ------ | + | product_id | Product's ID. | Number | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +### Examples + +#### 1. Get data of the specific page + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `GET https://example.com/api/reviews?product_id=1&page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET https://example.com/api/reviews?product_id=1` + + ::: + +::: details Response + + ~~~json + { + "data": [ + { + "id": 4, + "title": "Great product & Service!!!", + "rating": "4.0", + "comment": "Beautiful bangles. Better than I expected.", + "name": "John Doe", + "status": "approved", + "product": {...}, + }, + { + "id": 3, + "title": "Very good product.. Recommend to all", + "rating": "5.0", + "comment": "I have ordered 2 sets. The product i received was good, i loved it..", + "name": "Peter Doe", + "status": "approved", + "product": {...}, + } + ], + "links": {...}, + "meta": {...} + } + ~~~ + +::: + +## Create products's review + +To post a review of a specific product, you have to login as a customer. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `POST /api/reviews/{product_id}/create` + +- Params + + | Name | Info | Type | + | ---------- | ------------------------------ | ------ | + | product_id | Product's ID. | Number | + | rating | Specify rating of the product. | Number | + | title | Title for review. | String | + | comment | Comments for review. | String | + +### Examples + +#### 1. Creating review for the product + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Request + + `POST https://example.com/api/reviews/1/create` + +- Params + + | Name | Value | + | ---------- | --------------------- | + | rating | 5 | + | title | Awesome Product | + | comment | Good quality product. | + +::: details Response + + ~~~json + { + "message": "Your review submitted successfully.", + "data": { + "id": 6, + "title": "Awesome Product", + "rating": "5.0", + "comment": "Good quality product.", + "name": "John Doe", + "status": "pending", + "product": {...}, + "customer": {...}, + "created_at": "2020-09-28T14:27:27.000000Z", + "updated_at": "2020-09-28T14:27:27.000000Z" + } + } + ~~~ + +::: diff --git a/docs/1.x/api/shipments.md b/docs/1.x/api/shipments.md new file mode 100644 index 00000000..4b46772b --- /dev/null +++ b/docs/1.x/api/shipments.md @@ -0,0 +1,286 @@ +# Shipments + +In this section, we will check all the shipments' API. + +## Get shipments from all orders + +You can get all the shipments of the Bagisto store. To get the shipments of the store, the customer must be logged in to the Bagisto store. You can achieve this job by using the `shipments` API call resource. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/shipments(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ---------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +::: tip + +If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Get all shipments with pagination + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/shipments?page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/shipments` + + ::: + +::: details Response + +```json +{ + "data": [ + { + "id": 1, + "total_qty": 2, + "total_weight": null, + "carrier_title": "DHL Shipping", + "track_number": "1234566", + "customer": {...}, + "inventory_source": { + "id": 1, + "name": "Default", + "contact_name": "Detroit Warehouse", + "contact_email": "warehouse@example.com", + "contact_number": "1234567899", + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + }, + "items": [{...},{...}] + } + ], + "links": {...}, + "meta": {...} +} +``` + +![bagisto_shipments](../../assets/1.x/images/api/bagisto_shipments.jpg) + +::: + +#### 2. Get all shipments without pagination + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/shipments?pagination=0` + +::: details Response + +```json +{ + "data": [ + { + "id": 1, + "total_qty": 2, + "total_weight": null, + "carrier_title": "DHL Shipping", + "track_number": "1234566", + "customer": {...}, + "inventory_source": { + "id": 1, + "name": "Default", + "contact_name": "Detroit Warehouse", + "contact_email": "warehouse@example.com", + "contact_number": "1234567899", + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + }, + "items": [{...},{...}] + }, + {...}, + {...}, + {...}, + ... + {...} + ] +} +``` + +::: + +## Get shipments by order's id + +To get the details of a specific order's shipment, you have to pass an `order_id` as a query parameter in API URL. By using this resource and query parameter, you will get only a single shipment detail in API response based on the provided `order_id`. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/shipments(?order_id,limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ---------- | -------------------------------------------- | ------ | + | order_id | Order's ID | Number | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +### Examples + +#### 1. Get all shipments by order's id + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/shipments?order_id=3&pagination=0` + +::: details Response + +```json +{ + "data": [ + { + "id": 1, + "total_qty": 2, + "total_weight": null, + "carrier_code": null, + "carrier_title": "DHL Shipping", + "track_number": "1234566", + "customer": {...}, + "inventory_source": {...}, + "items": [ + {...}, + {...} + ] + } + ], +} +``` + +::: + +#### 2. Get all shipments by order's id for specific page + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/shipments?order_id=3&page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/shipments?order_id=3` + + ::: + +::: details Response + +![bagisto_ship_order_id](../../assets/1.x/images/api/bagisto_ship_order_id.jpg) + +::: + +## Get shipment by id + +To get the details of a specific shipment, you have to pass a `shipment_id` as a request payload in the API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/shipments/{id}` + +### Examples + +#### 1. Let's fetch specific shipment + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/shipments/1` + +::: details Response + +```json +{ + "data": { + "id": 1, + "total_qty": 2, + "total_weight": null, + "carrier_code": null, + "carrier_title": "DHL Shipping", + "track_number": "1234566", + "email_sent": 0, + "customer": {...}, + "inventory_source": {...}, + "items": [ + {...}, + {...} + ] + } +} +``` + +::: diff --git a/docs/1.x/api/transactions.md b/docs/1.x/api/transactions.md new file mode 100644 index 00000000..458066bd --- /dev/null +++ b/docs/1.x/api/transactions.md @@ -0,0 +1,203 @@ +# Transactions + +In this section, we will see all the APIs which are related to transactions. In Bagisto, we save all the transactions done by the customers using the Paypal Smart Button option. + +::: warning + +These are all transactions that are saved in the database after the payment done by the customers using the Paypal Smart Button option. + +::: + +## Get all transactions + +You can get all the transaction data from the Bagisto store. To get the data from the store, the customer must be authenticated. You can achieve this job by using the `transactions` API call resource. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/transactions(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ---------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Records for specific page + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/transactions?page=1` + + ::: tip + + If you didn't use the page (?page=x) filter, then it returns the data of the first page by default. + + `GET http(s)://example.com/api/transactions` + + ::: + +::: details Response + +~~~json +{ + "data": [ + { + "id": 1, + "transaction_id": "47427618SF330010G", + "status": "COMPLETED", + "type": "CAPTURE", + "payment_method": "paypal_smart_button", + "data": "{\"0\": {\"items\": [{\"sku\": \"12\", \"name\": \"Soft Toy\", \"category\": \"PHYSICAL_GOODS\", \"quantity\": \"1\", \"unit_amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}], \"payee\": {\"merchant_id\": \"85PGX7H6T2ZLW\", \"email_address\": \"prachiwebkul-facilitator@gmail.com\"}, \"amount\": {\"value\": \"150.00\", \"breakdown\": {\"shipping\": {\"value\": \"0.00\", \"currency_code\": \"USD\"}, \"tax_total\": {\"value\": \"0.00\", \"currency_code\": \"USD\"}, \"item_total\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}, \"currency_code\": \"USD\"}, \"payments\": {\"captures\": [{\"id\": \"2U5068420K488272L\", \"links\": [{\"rel\": \"self\", \"href\": \"https://api.sandbox.paypal.com/v2/payments/captures/2U5068420K488272L\", \"method\": \"GET\"}, {\"rel\": \"refund\", \"href\": \"https://api.sandbox.paypal.com/v2/payments/captures/2U5068420K488272L/refund\", \"method\": \"POST\"}, {\"rel\": \"up\", \"href\": \"https://api.sandbox.paypal.com/v2/checkout/orders/47427618SF330010G\", \"method\": \"GET\"}], \"amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}, \"status\": \"COMPLETED\", \"create_time\": \"2021-04-09T09:28:03Z\", \"update_time\": \"2021-04-09T09:28:03Z\", \"final_capture\": true, \"seller_protection\": {\"status\": \"ELIGIBLE\", \"dispute_categories\": [\"ITEM_NOT_RECEIVED\", \"UNAUTHORIZED_TRANSACTION\"]}, \"seller_receivable_breakdown\": {\"net_amount\": {\"value\": \"143.85\", \"currency_code\": \"USD\"}, \"paypal_fee\": {\"value\": \"6.15\", \"currency_code\": \"USD\"}, \"gross_amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}}]}, \"shipping\": {\"name\": {\"full_name\": \"John Doe\"}, \"address\": {\"postal_code\": \"110045\", \"admin_area_1\": \"DL\", \"admin_area_2\": \"New Delhi\", \"country_code\": \"IN\", \"address_line_1\": \"Dwarka\"}}, \"reference_id\": \"default\", \"soft_descriptor\": \"PAYPAL *TESTFACILIT\"}, \"name\": {\"surname\": \"Doe\", \"given_name\": \"John\"}, \"address\": {\"postal_code\": \"110045\", \"admin_area_1\": \"DL\", \"admin_area_2\": \"New Delhi\", \"country_code\": \"IN\", \"address_line_1\": \"Dwarka\"}, \"payer_id\": \"8KC42JLS656PQ\", \"email_address\": \"sb-eyqoq4881652@personal.example.com\"}", + "updated_at": "2021-04-09T09:28:08.000000Z", + "created_at": "2021-04-09T09:28:08.000000Z" + } + ], + "links": { + "first": "https://example.com/api/transactions?page=1", + "last": "https://example.com/api/transactions?page=1", + "prev": null, + "next": null + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 1, + "links": [ + { + "url": null, + "label": "« Previous", + "active": false + }, + { + "url": "https://example.com/api/transactions?page=1", + "label": "1", + "active": true + }, + { + "url": null, + "label": "Next »", + "active": false + } + ], + "path": "https://example.com/api/transactions", + "per_page": 10, + "to": 1, + "total": 1 + } +} +~~~ + +::: + +#### 2. Get all transactions without pagination + +You can also get all the transaction data at once from the Bagisto store without pagination. To get the data, the customer must be authenticated. For this, you have to pass `pagination=0` in the query parameter with the `transactions` resource in the API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/public/api/transactions?pagination=0` + +::: details Response + +~~~json +{ + "data": [ + { + "id": 1, + "transaction_id": "47427618SF330010G", + "status": "COMPLETED", + "type": "CAPTURE", + "payment_method": "paypal_smart_button", + "data": "{\"0\": {\"items\": [{\"sku\": \"12\", \"name\": \"Soft Toy\", \"category\": \"PHYSICAL_GOODS\", \"quantity\": \"1\", \"unit_amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}], \"payee\": {\"merchant_id\": \"85PGX7H6T2ZLW\", \"email_address\": \"prachiwebkul-facilitator@gmail.com\"}, \"amount\": {\"value\": \"150.00\", \"breakdown\": {\"shipping\": {\"value\": \"0.00\", \"currency_code\": \"USD\"}, \"tax_total\": {\"value\": \"0.00\", \"currency_code\": \"USD\"}, \"item_total\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}, \"currency_code\": \"USD\"}, \"payments\": {\"captures\": [{\"id\": \"2U5068420K488272L\", \"links\": [{\"rel\": \"self\", \"href\": \"https://api.sandbox.paypal.com/v2/payments/captures/2U5068420K488272L\", \"method\": \"GET\"}, {\"rel\": \"refund\", \"href\": \"https://api.sandbox.paypal.com/v2/payments/captures/2U5068420K488272L/refund\", \"method\": \"POST\"}, {\"rel\": \"up\", \"href\": \"https://api.sandbox.paypal.com/v2/checkout/orders/47427618SF330010G\", \"method\": \"GET\"}], \"amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}, \"status\": \"COMPLETED\", \"create_time\": \"2021-04-09T09:28:03Z\", \"update_time\": \"2021-04-09T09:28:03Z\", \"final_capture\": true, \"seller_protection\": {\"status\": \"ELIGIBLE\", \"dispute_categories\": [\"ITEM_NOT_RECEIVED\", \"UNAUTHORIZED_TRANSACTION\"]}, \"seller_receivable_breakdown\": {\"net_amount\": {\"value\": \"143.85\", \"currency_code\": \"USD\"}, \"paypal_fee\": {\"value\": \"6.15\", \"currency_code\": \"USD\"}, \"gross_amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}}]}, \"shipping\": {\"name\": {\"full_name\": \"John Doe\"}, \"address\": {\"postal_code\": \"110045\", \"admin_area_1\": \"DL\", \"admin_area_2\": \"New Delhi\", \"country_code\": \"IN\", \"address_line_1\": \"Dwarka\"}}, \"reference_id\": \"default\", \"soft_descriptor\": \"PAYPAL *TESTFACILIT\"}, \"name\": {\"surname\": \"Doe\", \"given_name\": \"John\"}, \"address\": {\"postal_code\": \"110045\", \"admin_area_1\": \"DL\", \"admin_area_2\": \"New Delhi\", \"country_code\": \"IN\", \"address_line_1\": \"Dwarka\"}, \"payer_id\": \"8KC42JLS656PQ\", \"email_address\": \"sb-eyqoq4881652@personal.example.com\"}", + "updated_at": "2021-04-09T09:28:08.000000Z", + "created_at": "2021-04-09T09:28:08.000000Z" + } + ] +} +~~~ + +::: + +## Get transaction by id + +To get the specific transaction details, you have to pass an `transaction_id` as a request payload in the API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/transactions/{transaction_id}` + +- Params + + | Name | Info | Type | + | -------------- | ---------------- | ------ | + | transaction_id | Transaction's ID | Number | + +### Examples + +Let's fetch specific transaction, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/transactions/1` + +::: details Response + +~~~json +{ + "id": 1, + "transaction_id": "47427618SF330010G", + "status": "COMPLETED", + "type": "CAPTURE", + "payment_method": "paypal_smart_button", + "data": "{\"0\": {\"items\": [{\"sku\": \"12\", \"name\": \"Soft Toy\", \"category\": \"PHYSICAL_GOODS\", \"quantity\": \"1\", \"unit_amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}], \"payee\": {\"merchant_id\": \"85PGX7H6T2ZLW\", \"email_address\": \"prachiwebkul-facilitator@gmail.com\"}, \"amount\": {\"value\": \"150.00\", \"breakdown\": {\"shipping\": {\"value\": \"0.00\", \"currency_code\": \"USD\"}, \"tax_total\": {\"value\": \"0.00\", \"currency_code\": \"USD\"}, \"item_total\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}, \"currency_code\": \"USD\"}, \"payments\": {\"captures\": [{\"id\": \"2U5068420K488272L\", \"links\": [{\"rel\": \"self\", \"href\": \"https://api.sandbox.paypal.com/v2/payments/captures/2U5068420K488272L\", \"method\": \"GET\"}, {\"rel\": \"refund\", \"href\": \"https://api.sandbox.paypal.com/v2/payments/captures/2U5068420K488272L/refund\", \"method\": \"POST\"}, {\"rel\": \"up\", \"href\": \"https://api.sandbox.paypal.com/v2/checkout/orders/47427618SF330010G\", \"method\": \"GET\"}], \"amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}, \"status\": \"COMPLETED\", \"create_time\": \"2021-04-09T09:28:03Z\", \"update_time\": \"2021-04-09T09:28:03Z\", \"final_capture\": true, \"seller_protection\": {\"status\": \"ELIGIBLE\", \"dispute_categories\": [\"ITEM_NOT_RECEIVED\", \"UNAUTHORIZED_TRANSACTION\"]}, \"seller_receivable_breakdown\": {\"net_amount\": {\"value\": \"143.85\", \"currency_code\": \"USD\"}, \"paypal_fee\": {\"value\": \"6.15\", \"currency_code\": \"USD\"}, \"gross_amount\": {\"value\": \"150.00\", \"currency_code\": \"USD\"}}}]}, \"shipping\": {\"name\": {\"full_name\": \"John Doe\"}, \"address\": {\"postal_code\": \"110045\", \"admin_area_1\": \"DL\", \"admin_area_2\": \"New Delhi\", \"country_code\": \"IN\", \"address_line_1\": \"Dwarka\"}}, \"reference_id\": \"default\", \"soft_descriptor\": \"PAYPAL *TESTFACILIT\"}, \"name\": {\"surname\": \"Doe\", \"given_name\": \"John\"}, \"address\": {\"postal_code\": \"110045\", \"admin_area_1\": \"DL\", \"admin_area_2\": \"New Delhi\", \"country_code\": \"IN\", \"address_line_1\": \"Dwarka\"}, \"payer_id\": \"8KC42JLS656PQ\", \"email_address\": \"sb-eyqoq4881652@personal.example.com\"}", + "updated_at": "2021-04-09T09:28:08.000000Z", + "created_at": "2021-04-09T09:28:08.000000Z" +} +~~~ + +::: diff --git a/docs/1.x/api/wishlists.md b/docs/1.x/api/wishlists.md new file mode 100644 index 00000000..45e6e091 --- /dev/null +++ b/docs/1.x/api/wishlists.md @@ -0,0 +1,309 @@ +# Wishlists + +In this section, we will see how wishlists' API works. + +## Get all wishlists + +You can also get all the wishlists of store's customers. To get the wishlists, customer must be logged-in to the Bagisto store. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/wishlist(?limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ---------- | -------------------------------------------- | ------ | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +::: tip + +If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +### Examples + +#### 1. Get wishlists for specific page + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/wishlist?page=1` + +#### 2. Get wishlists for specific page with limit + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/wishlist?limit=2&page=1` + +::: details Response (Example 1 & 2) + +![bagisto_wishlist_page](../../assets/1.x/images/api/bagisto_wishlist_page.jpg) + +::: + +#### 3. Get all wishlists without pagination + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/wishlist?pagination=0` + +::: details Response + +```json +{ + "data": [ + { + "id": 9, + "product": { + "id": 5, + "type": "simple", + "name": "Home Decor Bottles", + "url_key": "home-decor-bottles", + "price": 10, + "formated_price": "$10.00", + "short_description": "

Home Decor Bottles

", + "description": "

Home Decor Bottles

", + "sku": "bottles", + } + }, + { + "id": 8, + "product": {...} + }, + { + "id": 7, + "product": {...} + } + ] +} +``` + +::: + +## Get wishlists by customer's id + +To get all wishlists of a specific customer, you have to pass a `customer_id` as a query parameter in API url. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET /api/wishlist(?customer_id,limit,page,pagination)` + +- Params + + | Name | Info | Type | + | ----------- | -------------------------------------------- | ------ | + | customer_id | Customer's ID | Number | + | limit | Maximum number of records in each request | Number | + | page | Records for specific page based on the limit | Number | + | pagination | Will display all the records if set to `0` | Number | + +### Examples + +#### 1. If you want all the wishlists by `customer_id` + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/wishlist?customer_id=1&pagination=0` + +::: details Response: + +```json +{ + "data": [ + { + "id": 7, + "product": {...}, + }, + {...}, + {...}, + {...}, + ... + {...} + ] +} +``` + +::: + +#### 2. If you want wishlists for specific page by `customer_id` + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/wishlist?customer_id=1&page=1` + +::: details Response: + +```json +{ + "data": [ + { + "id": 7, + "product": {...}, + }, + {...}, + {...}, + {...}, + ... + {...} + ], + "links": { + "first": "https://example.com/api/wishlist?customer_id=1&page=1", + "last": "https://example.com/api/wishlist?customer_id=1&page=1", + "prev": null, + "next": null + }, + "meta": { + "current_page": 1, + "from": 1, + "last_page": 1, + "path": "https://example.com/api/wishlist", + "per_page": 10, + "to": 2, + "total": 9 + } +} +``` + +::: + +## Add product to wishlist + +To add a product to customer's wishlist, you have to pass a `product_id` as a request payload like `wishlist/add/{product_id}` in API URL. + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/wishlist/add/{product_id}` + +- Params + + | Name | Info | Type | + | ---------- | ---------- | ------ | + | product_id | Product ID | Number | + +### Examples + +Let's add one product to wishlist, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/wishlist/add/11` + +::: details Response + +```json +{ + "data": { + "id": 11, + "product": { + "id": 1, + "type": "simple", + "name": "Leather Shoes", + "url_key": "leather-shoes", + "price": 50, + "formated_price": "$50.00", + "short_description": "

Leather Shoes

", + "description": "

Leather Shoes

", + "sku": "men-leather-shoes" + } + }, + "message": "Item Successfully Added To Wishlist" +} +``` + +::: + +## Remove product from wishlist + +For removing the product from the wishlist, you need to hit the same add API again. Just like a toggle. It will remove if the wishlist is already added. + +### Examples + +Hitting the same add API again, + +- Headers + + | Key | Value | Info | + | ------------- | --------------------- | ------------------------------------ | + | Accept | application/json | | + | Authorization | Bearer `token-string` | Use only when you pass `?token=true` | + +- Request + + `GET http(s)://example.com/api/wishlist/add/11` + +::: details Response + +```json +{ + "data": null, + "message": "Item removed from wishlist successfully." +} +``` + +::: diff --git a/docs/1.x/deploy/README.md b/docs/1.x/deploy/README.md new file mode 100644 index 00000000..6ca0fb29 --- /dev/null +++ b/docs/1.x/deploy/README.md @@ -0,0 +1,9 @@ +# Deploy + +this article will explain how you can deploy your Bagisto store to your production server when you have been developing your Bagisto store on your local system. + +## Deploy Bagisto with (S)FTP + +## Deploy on Cpanel + +## Deploy on Plesk diff --git a/docs/1.x/graphql-admin-api/README.md b/docs/1.x/graphql-admin-api/README.md new file mode 100644 index 00000000..6739d0e8 --- /dev/null +++ b/docs/1.x/graphql-admin-api/README.md @@ -0,0 +1,38 @@ +# Bagisto GraphQL Admin APIs + +Bagisto GraphQL Admin API is a medium to use the features of the core Bagisto Admin System. By using Bagisto GraphQL Admin API, you can integrate your application to serve the default content of Bagisto. + +**To download and contribute: [Bagisto GraphQL API GitHub](https://github.com/bagisto/headless-ecommerce/)** + + +## Key Features + +- Bagisto GraphQL API provides a complete and understandable description of the data. +- Authentication: Customer Authentication with Login Details. +- Authentication: Admin Authentication with Login Details. +- Provide access to performed CRUD operations. +- Provide the option to filter the responses based on attribute fields. +- The Framework supports the pagination which helps to increase the performance of application. +- Get many resources in a single request. + +## Request + +- `http(s)://example.com/graphql` + +## Where can I use Bagisto GraphQL APIs? + +We can use the Bagisto GraphQL APIs in different areas. Some of them are: + +- To build a PWA (Progressive Web Application) application, which uses modern web capabilities to deliver an application like experience to the users and provide more user friendly experience than a web application. + +- Use to integrate an Online-Shopping Mobile Application with the Bagisto Store to help the customers make purchase. + +- Use to integrate with CRM (Customer Relationship Management) systems Like: HubSpot, Salesforce etc. which allows you to manage the business relationships with your customers to help you grow your business. + +- To provide exactly what you need and nothing more. + +- To get Predictable result. + +- Applications using GraphQL can be quick even on slow mobile network connections. + +- Applications for devices where bandwidth usage matters. \ No newline at end of file diff --git a/docs/1.x/graphql-admin-api/attribute-families.md b/docs/1.x/graphql-admin-api/attribute-families.md new file mode 100644 index 00000000..71026ea8 --- /dev/null +++ b/docs/1.x/graphql-admin-api/attribute-families.md @@ -0,0 +1,3233 @@ +# Attribute Families + +In this section, we will see all the APIs which are related to Attribute Families. + +## Get All Attribute Families + +You can get all the Attribute Families from the Bagisto store. You can achieve this job by using the `Attribute Families` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Request Query + ~~~query + query attributeFamilies { + attributeFamilies { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + code + name + status + isUserDefined + attributeGroups { + id + name + position + isUserDefined + attributeFamilyId + customAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + products { + id + type + sku + parentId + productFlats { + id + name + status + } + } + } + } + } + ~~~ +::: details Response + +~~~json +{ + "data": { + "attributeFamilies": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true, + "attributeGroups": [ + { + "id": "1", + "name": "General", + "position": 1, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text", + "position": 1, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "1", + "locale": "en", + "name": "SKU", + "attributeId": "1" + } + ] + }, + { + "id": "27", + "code": "product_number", + "adminName": "Product Number", + "type": "text", + "position": 2, + "isRequired": false, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "27", + "locale": "en", + "name": "Product Number", + "attributeId": "27" + } + ] + }, + { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text", + "position": 3, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "2", + "locale": "en", + "name": "Name", + "attributeId": "2" + } + ] + }, + { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text", + "position": 4, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "3", + "locale": "en", + "name": "URL Key", + "attributeId": "3" + } + ] + }, + { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select", + "position": 5, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "4", + "locale": "en", + "name": "Tax Category", + "attributeId": "4" + } + ] + }, + { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean", + "position": 6, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "5", + "locale": "en", + "name": "New", + "attributeId": "5" + } + ] + }, + { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean", + "position": 7, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "6", + "locale": "en", + "name": "Featured", + "attributeId": "6" + } + ] + }, + { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean", + "position": 9, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "7", + "locale": "en", + "name": "Visible Individually", + "attributeId": "7" + } + ] + }, + { + "id": "26", + "code": "guest_checkout", + "adminName": "Guest Checkout", + "type": "boolean", + "position": 8, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "26", + "locale": "en", + "name": "Allow Guest Checkout", + "attributeId": "26" + } + ] + }, + { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean", + "position": 10, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "8", + "locale": "en", + "name": "Status", + "attributeId": "8" + } + ] + }, + { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select", + "position": 26, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [ + { + "id": "1", + "adminName": "Red", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "1", + "locale": "en", + "label": "Red", + "attributeOptionId": "1" + } + ] + }, + { + "id": "2", + "adminName": "Green", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "2", + "locale": "en", + "label": "Green", + "attributeOptionId": "2" + } + ] + }, + { + "id": "3", + "adminName": "Yellow", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "3", + "locale": "en", + "label": "Yellow", + "attributeOptionId": "3" + } + ] + }, + { + "id": "4", + "adminName": "Black", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "4", + "locale": "en", + "label": "Black", + "attributeOptionId": "4" + } + ] + }, + { + "id": "5", + "adminName": "White", + "swatchValue": null, + "sortOrder": 5, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "5", + "locale": "en", + "label": "White", + "attributeOptionId": "5" + } + ] + } + ], + "translations": [ + { + "id": "23", + "locale": "en", + "name": "Color", + "attributeId": "23" + } + ] + }, + { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select", + "position": 27, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [ + { + "id": "6", + "adminName": "S", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "6", + "locale": "en", + "label": "S", + "attributeOptionId": "6" + } + ] + }, + { + "id": "7", + "adminName": "M", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "7", + "locale": "en", + "label": "M", + "attributeOptionId": "7" + } + ] + }, + { + "id": "8", + "adminName": "L", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "8", + "locale": "en", + "label": "L", + "attributeOptionId": "8" + } + ] + }, + { + "id": "9", + "adminName": "XL", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "9", + "locale": "en", + "label": "XL", + "attributeOptionId": "9" + } + ] + } + ], + "translations": [ + { + "id": "24", + "locale": "en", + "name": "Size", + "attributeId": "24" + } + ] + }, + { + "id": "25", + "code": "brand", + "adminName": "Brand", + "type": "select", + "position": 28, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": true, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "25", + "locale": "en", + "name": "Brand", + "attributeId": "25" + } + ] + } + ] + }, + { + "id": "2", + "name": "Description", + "position": 2, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea", + "position": 11, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "9", + "locale": "en", + "name": "Short Description", + "attributeId": "9" + } + ] + }, + { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea", + "position": 12, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "10", + "locale": "en", + "name": "Description", + "attributeId": "10" + } + ] + } + ] + }, + { + "id": "3", + "name": "Meta Description", + "position": 3, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "16", + "code": "meta_title", + "adminName": "Meta Title", + "type": "textarea", + "position": 18, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "16", + "locale": "en", + "name": "Meta Description", + "attributeId": "16" + } + ] + }, + { + "id": "17", + "code": "meta_keywords", + "adminName": "Meta Keywords", + "type": "textarea", + "position": 20, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "17", + "locale": "en", + "name": "Meta Keywords", + "attributeId": "17" + } + ] + }, + { + "id": "18", + "code": "meta_description", + "adminName": "Meta Description", + "type": "textarea", + "position": 21, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "18", + "locale": "en", + "name": "Meta Description", + "attributeId": "18" + } + ] + } + ] + }, + { + "id": "4", + "name": "Price", + "position": 4, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price", + "position": 13, + "isRequired": true, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "11", + "locale": "en", + "name": "Price", + "attributeId": "11" + } + ] + }, + { + "id": "12", + "code": "cost", + "adminName": "Cost", + "type": "price", + "position": 14, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "12", + "locale": "en", + "name": "Cost", + "attributeId": "12" + } + ] + }, + { + "id": "13", + "code": "special_price", + "adminName": "Special Price", + "type": "price", + "position": 15, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "13", + "locale": "en", + "name": "Special Price", + "attributeId": "13" + } + ] + }, + { + "id": "14", + "code": "special_price_from", + "adminName": "Special Price From", + "type": "date", + "position": 16, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "14", + "locale": "en", + "name": "Special Price From", + "attributeId": "14" + } + ] + }, + { + "id": "15", + "code": "special_price_to", + "adminName": "Special Price To", + "type": "date", + "position": 17, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "15", + "locale": "en", + "name": "Special Price To", + "attributeId": "15" + } + ] + } + ] + }, + { + "id": "5", + "name": "Shipping", + "position": 5, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text", + "position": 22, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "19", + "locale": "en", + "name": "Width", + "attributeId": "19" + } + ] + }, + { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text", + "position": 23, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "20", + "locale": "en", + "name": "Height", + "attributeId": "20" + } + ] + }, + { + "id": "21", + "code": "depth", + "adminName": "Depth", + "type": "text", + "position": 24, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "21", + "locale": "en", + "name": "Depth", + "attributeId": "21" + } + ] + }, + { + "id": "22", + "code": "weight", + "adminName": "Weight", + "type": "text", + "position": 25, + "isRequired": true, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "22", + "locale": "en", + "name": "Weight", + "attributeId": "22" + } + ] + } + ] + } + ], + "products": [ + { + "id": "1", + "type": "simple", + "sku": "test-product", + "parentId": null, + "productFlats": [ + { + "id": "1", + "name": "testOutlet", + "status": true + } + ] + }, + { + "id": "3", + "type": "configurable", + "sku": "home-decor-2", + "parentId": null, + "productFlats": [ + { + "id": "3", + "name": "Home Decor-2", + "status": true + } + ] + }, + { + "id": "4", + "type": "simple", + "sku": "home-decor-1-variant-1-6", + "parentId": "3", + "productFlats": [ + { + "id": "4", + "name": "Red-S", + "status": true + } + ] + }, + { + "id": "5", + "type": "simple", + "sku": "home-decor-1-variant-2-6", + "parentId": "3", + "productFlats": [ + { + "id": "5", + "name": "Green-S", + "status": true + } + ] + }, + { + "id": "6", + "type": "virtual", + "sku": "virtual-demo", + "parentId": null, + "productFlats": [ + { + "id": "6", + "name": "Online Tuition Classes", + "status": true + } + ] + }, + { + "id": "7", + "type": "grouped", + "sku": "grouped-demo", + "parentId": null, + "productFlats": [ + { + "id": "7", + "name": "Phone Accessories", + "status": true + } + ] + }, + { + "id": "8", + "type": "downloadable", + "sku": "e-book", + "parentId": null, + "productFlats": [ + { + "id": "8", + "name": "e-book", + "status": true + } + ] + }, + { + "id": "9", + "type": "bundle", + "sku": "bundle-demo", + "parentId": null, + "productFlats": [ + { + "id": "9", + "name": "Bundle Box", + "status": true + } + ] + }, + { + "id": "10", + "type": "booking", + "sku": "appointment-booking", + "parentId": null, + "productFlats": [ + { + "id": "10", + "name": null, + "status": null + } + ] + }, + { + "id": "11", + "type": "booking", + "sku": "appointment-booking1", + "parentId": null, + "productFlats": [ + { + "id": "11", + "name": "Dr. Appointment", + "status": true + } + ] + }, + { + "id": "12", + "type": "booking", + "sku": "event-booking", + "parentId": null, + "productFlats": [ + { + "id": "12", + "name": "Music Show", + "status": true + } + ] + }, + { + "id": "13", + "type": "booking", + "sku": "ac-on-rent", + "parentId": null, + "productFlats": [ + { + "id": "13", + "name": "AC On Rent", + "status": true + } + ] + }, + { + "id": "14", + "type": "booking", + "sku": "hotel-table", + "parentId": null, + "productFlats": [ + { + "id": "14", + "name": "Hotel Table", + "status": true + } + ] + } + ] + } + ] + } + } +} +~~~ +::: + +## Get Attribute Family By ID + +To get the specific Attribute Family, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query attributeFamily { + attributeFamily(id: 1) { + id + code + name + status + isUserDefined + attributeGroups { + id + name + position + isUserDefined + attributeFamilyId + customAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true, + "attributeGroups": [ + { + "id": "1", + "name": "General", + "position": 1, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text", + "position": 1, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "1", + "locale": "en", + "name": "SKU", + "attributeId": "1" + } + ] + }, + { + "id": "27", + "code": "product_number", + "adminName": "Product Number", + "type": "text", + "position": 2, + "isRequired": false, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "27", + "locale": "en", + "name": "Product Number", + "attributeId": "27" + } + ] + }, + { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text", + "position": 3, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "2", + "locale": "en", + "name": "Name", + "attributeId": "2" + } + ] + }, + { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text", + "position": 4, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "3", + "locale": "en", + "name": "URL Key", + "attributeId": "3" + } + ] + }, + { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select", + "position": 5, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "4", + "locale": "en", + "name": "Tax Category", + "attributeId": "4" + } + ] + }, + { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean", + "position": 6, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "5", + "locale": "en", + "name": "New", + "attributeId": "5" + } + ] + }, + { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean", + "position": 7, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "6", + "locale": "en", + "name": "Featured", + "attributeId": "6" + } + ] + }, + { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean", + "position": 9, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "7", + "locale": "en", + "name": "Visible Individually", + "attributeId": "7" + } + ] + }, + { + "id": "26", + "code": "guest_checkout", + "adminName": "Guest Checkout", + "type": "boolean", + "position": 8, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "26", + "locale": "en", + "name": "Allow Guest Checkout", + "attributeId": "26" + } + ] + }, + { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean", + "position": 10, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "8", + "locale": "en", + "name": "Status", + "attributeId": "8" + } + ] + }, + { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select", + "position": 26, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [ + { + "id": "1", + "adminName": "Red", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "1", + "locale": "en", + "label": "Red", + "attributeOptionId": "1" + } + ] + }, + { + "id": "2", + "adminName": "Green", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "2", + "locale": "en", + "label": "Green", + "attributeOptionId": "2" + } + ] + }, + { + "id": "3", + "adminName": "Yellow", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "3", + "locale": "en", + "label": "Yellow", + "attributeOptionId": "3" + } + ] + }, + { + "id": "4", + "adminName": "Black", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "4", + "locale": "en", + "label": "Black", + "attributeOptionId": "4" + } + ] + }, + { + "id": "5", + "adminName": "White", + "swatchValue": null, + "sortOrder": 5, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "5", + "locale": "en", + "label": "White", + "attributeOptionId": "5" + } + ] + } + ], + "translations": [ + { + "id": "23", + "locale": "en", + "name": "Color", + "attributeId": "23" + } + ] + }, + { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select", + "position": 27, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [ + { + "id": "6", + "adminName": "S", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "6", + "locale": "en", + "label": "S", + "attributeOptionId": "6" + } + ] + }, + { + "id": "7", + "adminName": "M", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "7", + "locale": "en", + "label": "M", + "attributeOptionId": "7" + } + ] + }, + { + "id": "8", + "adminName": "L", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "8", + "locale": "en", + "label": "L", + "attributeOptionId": "8" + } + ] + }, + { + "id": "9", + "adminName": "XL", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "9", + "locale": "en", + "label": "XL", + "attributeOptionId": "9" + } + ] + } + ], + "translations": [ + { + "id": "24", + "locale": "en", + "name": "Size", + "attributeId": "24" + } + ] + }, + { + "id": "25", + "code": "brand", + "adminName": "Brand", + "type": "select", + "position": 28, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": true, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "25", + "locale": "en", + "name": "Brand", + "attributeId": "25" + } + ] + } + ] + }, + { + "id": "2", + "name": "Description", + "position": 2, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea", + "position": 11, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "9", + "locale": "en", + "name": "Short Description", + "attributeId": "9" + } + ] + }, + { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea", + "position": 12, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "10", + "locale": "en", + "name": "Description", + "attributeId": "10" + } + ] + } + ] + }, + { + "id": "3", + "name": "Meta Description", + "position": 3, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "16", + "code": "meta_title", + "adminName": "Meta Title", + "type": "textarea", + "position": 18, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "16", + "locale": "en", + "name": "Meta Description", + "attributeId": "16" + } + ] + }, + { + "id": "17", + "code": "meta_keywords", + "adminName": "Meta Keywords", + "type": "textarea", + "position": 20, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "17", + "locale": "en", + "name": "Meta Keywords", + "attributeId": "17" + } + ] + }, + { + "id": "18", + "code": "meta_description", + "adminName": "Meta Description", + "type": "textarea", + "position": 21, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "18", + "locale": "en", + "name": "Meta Description", + "attributeId": "18" + } + ] + } + ] + }, + { + "id": "4", + "name": "Price", + "position": 4, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price", + "position": 13, + "isRequired": true, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "11", + "locale": "en", + "name": "Price", + "attributeId": "11" + } + ] + }, + { + "id": "12", + "code": "cost", + "adminName": "Cost", + "type": "price", + "position": 14, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "12", + "locale": "en", + "name": "Cost", + "attributeId": "12" + } + ] + }, + { + "id": "13", + "code": "special_price", + "adminName": "Special Price", + "type": "price", + "position": 15, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "13", + "locale": "en", + "name": "Special Price", + "attributeId": "13" + } + ] + }, + { + "id": "14", + "code": "special_price_from", + "adminName": "Special Price From", + "type": "date", + "position": 16, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "14", + "locale": "en", + "name": "Special Price From", + "attributeId": "14" + } + ] + }, + { + "id": "15", + "code": "special_price_to", + "adminName": "Special Price To", + "type": "date", + "position": 17, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "15", + "locale": "en", + "name": "Special Price To", + "attributeId": "15" + } + ] + } + ] + }, + { + "id": "5", + "name": "Shipping", + "position": 5, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text", + "position": 22, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "19", + "locale": "en", + "name": "Width", + "attributeId": "19" + } + ] + }, + { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text", + "position": 23, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "20", + "locale": "en", + "name": "Height", + "attributeId": "20" + } + ] + }, + { + "id": "21", + "code": "depth", + "adminName": "Depth", + "type": "text", + "position": 24, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "21", + "locale": "en", + "name": "Depth", + "attributeId": "21" + } + ] + }, + { + "id": "22", + "code": "weight", + "adminName": "Weight", + "type": "text", + "position": 25, + "isRequired": true, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "22", + "locale": "en", + "name": "Weight", + "attributeId": "22" + } + ] + } + ] + } + ] + } + } + } + ~~~ +::: + +## Create a new Attribute Family + + To create a Attribute Family, you have to perform mutation on Attribute Family and paas the related fields in the request. + API call resource will create a new Attribute Family, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createAttributeFamily { + createAttributeFamily(input: { + code: "new_family" + name: "New Family" + attributeGroups: [{ + name: "General" + position: 1 + isUserDefined: false + customAttributes: [{ + id: 1 + }, { + id: 2 + }, { + id: 3 + }, { + id: 4 + }, { + id: 5 + }] + }, { + name: "Description" + position: 2 + isUserDefined: false + customAttributes: [{ + id: 9 + }, { + id: 10 + }] + }, { + name: "Text Group" + position: 3 + isUserDefined: true + customAttributes: [{ + id: 19 + }, { + id: 20 + }] + }] + }) { + id + code + name + status + isUserDefined + attributeGroups { + id + name + position + isUserDefined + attributeFamilyId + customAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + products { + id + type + sku + parentId + productFlats { + id + name + status + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createAttributeFamily": { + "id": "2", + "code": "new_family", + "name": "New Family", + "status": null, + "isUserDefined": null, + "attributeGroups": [ + { + "id": "7", + "name": "General", + "position": 1, + "isUserDefined": false, + "attributeFamilyId": "2", + "customAttributes": [ + { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text", + "position": 1, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "1", + "locale": "en", + "name": "SKU", + "attributeId": "1" + } + ] + }, + { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text", + "position": 3, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "2", + "locale": "en", + "name": "Name", + "attributeId": "2" + } + ] + }, + { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text", + "position": 4, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "3", + "locale": "en", + "name": "URL Key", + "attributeId": "3" + } + ] + }, + { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select", + "position": 5, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "4", + "locale": "en", + "name": "Tax Category", + "attributeId": "4" + } + ] + }, + { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean", + "position": 6, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "5", + "locale": "en", + "name": "New", + "attributeId": "5" + } + ] + } + ] + }, + { + "id": "8", + "name": "Description", + "position": 2, + "isUserDefined": false, + "attributeFamilyId": "2", + "customAttributes": [ + { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea", + "position": 11, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "9", + "locale": "en", + "name": "Short Description", + "attributeId": "9" + } + ] + }, + { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea", + "position": 12, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "10", + "locale": "en", + "name": "Description", + "attributeId": "10" + } + ] + } + ] + }, + { + "id": "9", + "name": "Text Group", + "position": 3, + "isUserDefined": true, + "attributeFamilyId": "2", + "customAttributes": [ + { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text", + "position": 22, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "19", + "locale": "en", + "name": "Width", + "attributeId": "19" + } + ] + }, + { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text", + "position": 23, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "20", + "locale": "en", + "name": "Height", + "attributeId": "20" + } + ] + } + ] + } + ], + "products": [] + } + } + } + ~~~ +::: + +## Update a Attribute Family + +By using this API call you can update the Attribute Family. To do this , you have to perform update mutation on Attribute Family and paas the related fields in the request. +API call will update a Attribute Family, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateAttributeFamily { + updateAttributeFamily(id: 2, input: { + code: "new_family" + name: "Fashion Family" + attributeGroups: [{ + name: "General" + position: 1 + isUserDefined: false + customAttributes: [{ + id: 1 + }, { + id: 2 + }, { + id: 3 + }, { + id: 4 + }, { + id: 5 + }] + }, { + name: "Description" + position: 2 + isUserDefined: false + customAttributes: [{ + id: 9 + }, { + id: 10 + }] + }, { + name: "Text Group" + position: 3 + isUserDefined: true + customAttributes: [{ + id: 19 + }, { + id: 20 + }] + }] + }) { + id + code + name + status + isUserDefined + attributeGroups { + id + name + position + isUserDefined + attributeFamilyId + customAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + products { + id + type + sku + parentId + productFlats { + id + name + status + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateAttributeFamily": { + "id": "2", + "code": "new_family", + "name": "Fashion Family", + "status": false, + "isUserDefined": true, + "attributeGroups": [ + { + "id": "10", + "name": "General", + "position": 1, + "isUserDefined": false, + "attributeFamilyId": "2", + "customAttributes": [ + { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text", + "position": 1, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "1", + "locale": "en", + "name": "SKU", + "attributeId": "1" + } + ] + }, + { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text", + "position": 3, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "2", + "locale": "en", + "name": "Name", + "attributeId": "2" + } + ] + }, + { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text", + "position": 4, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "3", + "locale": "en", + "name": "URL Key", + "attributeId": "3" + } + ] + }, + { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select", + "position": 5, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "4", + "locale": "en", + "name": "Tax Category", + "attributeId": "4" + } + ] + }, + { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean", + "position": 6, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "5", + "locale": "en", + "name": "New", + "attributeId": "5" + } + ] + } + ] + }, + { + "id": "11", + "name": "Description", + "position": 2, + "isUserDefined": false, + "attributeFamilyId": "2", + "customAttributes": [ + { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea", + "position": 11, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "9", + "locale": "en", + "name": "Short Description", + "attributeId": "9" + } + ] + }, + { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea", + "position": 12, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "10", + "locale": "en", + "name": "Description", + "attributeId": "10" + } + ] + } + ] + }, + { + "id": "12", + "name": "Text Group", + "position": 3, + "isUserDefined": true, + "attributeFamilyId": "2", + "customAttributes": [ + { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text", + "position": 22, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "19", + "locale": "en", + "name": "Width", + "attributeId": "19" + } + ] + }, + { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text", + "position": 23, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "20", + "locale": "en", + "name": "Height", + "attributeId": "20" + } + ] + } + ] + } + ], + "products": [] + } + } + } + ~~~ +::: + +## Delete a Attribute Family + +To delete a Attribute Family, you have to perform mutation on Attribute Family by passing the id of that Attribute Family. +API call will delete a Attribute Family, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteAttributeFamily { + deleteAttributeFamily(id: 2) { + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteAttributeFamily": { + "success": "Family deleted successfully." + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-admin-api/attribute-groups.md b/docs/1.x/graphql-admin-api/attribute-groups.md new file mode 100644 index 00000000..78c1436e --- /dev/null +++ b/docs/1.x/graphql-admin-api/attribute-groups.md @@ -0,0 +1,1450 @@ +# Attribute Groups + +In this section, we will see all the APIs which are related to Attribute Groups. + +## Get All Attribute Groups + +You can get all the Attribute Groups from the Bagisto store. You can achieve this job by using the `Attribute Groups` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Request Query + ~~~query + query attributeGroups { + attributeGroups { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + position + isUserDefined + attributeFamilyId + customAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + } + } + ~~~ +::: details Response + +~~~json +{ + "data": { + "attributeGroups": { + "paginatorInfo": { + "count": 5, + "currentPage": 1, + "lastPage": 1, + "total": 5 + }, + "data": [ + { + "id": "1", + "name": "General", + "position": 1, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text", + "position": 1, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "1", + "locale": "en", + "name": "SKU", + "attributeId": "1" + } + ] + }, + { + "id": "27", + "code": "product_number", + "adminName": "Product Number", + "type": "text", + "position": 2, + "isRequired": false, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "27", + "locale": "en", + "name": "Product Number", + "attributeId": "27" + } + ] + }, + { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text", + "position": 3, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "2", + "locale": "en", + "name": "Name", + "attributeId": "2" + } + ] + }, + { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text", + "position": 4, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "3", + "locale": "en", + "name": "URL Key", + "attributeId": "3" + } + ] + }, + { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select", + "position": 5, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "4", + "locale": "en", + "name": "Tax Category", + "attributeId": "4" + } + ] + }, + { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean", + "position": 6, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "5", + "locale": "en", + "name": "New", + "attributeId": "5" + } + ] + }, + { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean", + "position": 7, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "6", + "locale": "en", + "name": "Featured", + "attributeId": "6" + } + ] + }, + { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean", + "position": 9, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "7", + "locale": "en", + "name": "Visible Individually", + "attributeId": "7" + } + ] + }, + { + "id": "26", + "code": "guest_checkout", + "adminName": "Guest Checkout", + "type": "boolean", + "position": 8, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "26", + "locale": "en", + "name": "Allow Guest Checkout", + "attributeId": "26" + } + ] + }, + { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean", + "position": 10, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "8", + "locale": "en", + "name": "Status", + "attributeId": "8" + } + ] + }, + { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select", + "position": 26, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [ + { + "id": "1", + "adminName": "Red", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "1", + "locale": "en", + "label": "Red", + "attributeOptionId": "1" + } + ] + }, + { + "id": "2", + "adminName": "Green", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "2", + "locale": "en", + "label": "Green", + "attributeOptionId": "2" + } + ] + }, + { + "id": "3", + "adminName": "Yellow", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "3", + "locale": "en", + "label": "Yellow", + "attributeOptionId": "3" + } + ] + }, + { + "id": "4", + "adminName": "Black", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "4", + "locale": "en", + "label": "Black", + "attributeOptionId": "4" + } + ] + }, + { + "id": "5", + "adminName": "White", + "swatchValue": null, + "sortOrder": 5, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "5", + "locale": "en", + "label": "White", + "attributeOptionId": "5" + } + ] + } + ], + "translations": [ + { + "id": "23", + "locale": "en", + "name": "Color", + "attributeId": "23" + } + ] + }, + { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select", + "position": 27, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [ + { + "id": "6", + "adminName": "S", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "6", + "locale": "en", + "label": "S", + "attributeOptionId": "6" + } + ] + }, + { + "id": "7", + "adminName": "M", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "7", + "locale": "en", + "label": "M", + "attributeOptionId": "7" + } + ] + }, + { + "id": "8", + "adminName": "L", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "8", + "locale": "en", + "label": "L", + "attributeOptionId": "8" + } + ] + }, + { + "id": "9", + "adminName": "XL", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "9", + "locale": "en", + "label": "XL", + "attributeOptionId": "9" + } + ] + } + ], + "translations": [ + { + "id": "24", + "locale": "en", + "name": "Size", + "attributeId": "24" + } + ] + }, + { + "id": "25", + "code": "brand", + "adminName": "Brand", + "type": "select", + "position": 28, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": true, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "25", + "locale": "en", + "name": "Brand", + "attributeId": "25" + } + ] + } + ] + }, + { + "id": "2", + "name": "Description", + "position": 2, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea", + "position": 11, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "9", + "locale": "en", + "name": "Short Description", + "attributeId": "9" + } + ] + }, + { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea", + "position": 12, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "10", + "locale": "en", + "name": "Description", + "attributeId": "10" + } + ] + } + ] + }, + { + "id": "3", + "name": "Meta Description", + "position": 3, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "16", + "code": "meta_title", + "adminName": "Meta Title", + "type": "textarea", + "position": 18, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "16", + "locale": "en", + "name": "Meta Description", + "attributeId": "16" + } + ] + }, + { + "id": "17", + "code": "meta_keywords", + "adminName": "Meta Keywords", + "type": "textarea", + "position": 20, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "17", + "locale": "en", + "name": "Meta Keywords", + "attributeId": "17" + } + ] + }, + { + "id": "18", + "code": "meta_description", + "adminName": "Meta Description", + "type": "textarea", + "position": 21, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "18", + "locale": "en", + "name": "Meta Description", + "attributeId": "18" + } + ] + } + ] + }, + { + "id": "4", + "name": "Price", + "position": 4, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price", + "position": 13, + "isRequired": true, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "11", + "locale": "en", + "name": "Price", + "attributeId": "11" + } + ] + }, + { + "id": "12", + "code": "cost", + "adminName": "Cost", + "type": "price", + "position": 14, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "12", + "locale": "en", + "name": "Cost", + "attributeId": "12" + } + ] + }, + { + "id": "13", + "code": "special_price", + "adminName": "Special Price", + "type": "price", + "position": 15, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "13", + "locale": "en", + "name": "Special Price", + "attributeId": "13" + } + ] + }, + { + "id": "14", + "code": "special_price_from", + "adminName": "Special Price From", + "type": "date", + "position": 16, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "14", + "locale": "en", + "name": "Special Price From", + "attributeId": "14" + } + ] + }, + { + "id": "15", + "code": "special_price_to", + "adminName": "Special Price To", + "type": "date", + "position": 17, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "15", + "locale": "en", + "name": "Special Price To", + "attributeId": "15" + } + ] + } + ] + }, + { + "id": "5", + "name": "Shipping", + "position": 5, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text", + "position": 22, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "19", + "locale": "en", + "name": "Width", + "attributeId": "19" + } + ] + }, + { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text", + "position": 23, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "20", + "locale": "en", + "name": "Height", + "attributeId": "20" + } + ] + }, + { + "id": "21", + "code": "depth", + "adminName": "Depth", + "type": "text", + "position": 24, + "isRequired": false, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "21", + "locale": "en", + "name": "Depth", + "attributeId": "21" + } + ] + }, + { + "id": "22", + "code": "weight", + "adminName": "Weight", + "type": "text", + "position": 25, + "isRequired": true, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "22", + "locale": "en", + "name": "Weight", + "attributeId": "22" + } + ] + } + ] + } + ] + } + } +} +~~~ +::: + +## Get Attribute Group By ID + +To get the specific Attribute Group, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query attributeGroup { + attributeGroup(id: 2) { + id + name + position + isUserDefined + attributeFamilyId + customAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "attributeGroup": { + "id": "2", + "name": "Description", + "position": 2, + "isUserDefined": false, + "attributeFamilyId": "1", + "customAttributes": [ + { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea", + "position": 11, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "9", + "locale": "en", + "name": "Short Description", + "attributeId": "9" + } + ] + }, + { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea", + "position": 12, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "10", + "locale": "en", + "name": "Description", + "attributeId": "10" + } + ] + } + ] + } + } + } + ~~~ + +::: + + +## Create a new Attribute Group + + To create a Attribute Group, you have to perform mutation on Attribute Group and paas the related fields in the request. + API call resource will create a new Attribute Group, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createAttributeGroup { + createAttributeGroup(input: { + name: "Dummy Group" + position: 8 + isUserDefined: true + attributeFamilyId: 1 + }) { + id + name + position + isUserDefined + attributeFamilyId + customAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createAttributeGroup": { + "id": "6", + "name": "Dummy Group", + "position": 8, + "isUserDefined": true, + "attributeFamilyId": "1", + "customAttributes": [] + } + } + } + ~~~ +::: + +## Update a Attribute Group + +By using this API call you can update the Attribute Group. To do this , you have to perform update mutation on Attribute Group and paas the related fields in the request. +API call will update a Attribute Group, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateAttributeGroup { + updateAttributeGroup(id: 6, input: { + name: "New Group" + position: 4 + isUserDefined: true + attributeFamilyId: 1 + }) { + id + name + position + isUserDefined + attributeFamilyId + customAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateAttributeGroup": { + "id": "6", + "name": "New Group", + "position": 4, + "isUserDefined": true, + "attributeFamilyId": "1", + "customAttributes": [] + } + } + } + ~~~ +::: + +## Delete a Attribute Group + +To delete a Attribute Group, you have to perform mutation on Attribute Group by passing the id of that Attribute Group. +API call will delete a Attribute Group, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteAttributeGroup { + deleteAttributeGroup(id: 6) { + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteAttributeGroup": { + "success": "Attribute Group deleted successfully." + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-admin-api/attributes.md b/docs/1.x/graphql-admin-api/attributes.md new file mode 100644 index 00000000..6e542a12 --- /dev/null +++ b/docs/1.x/graphql-admin-api/attributes.md @@ -0,0 +1,1556 @@ +# Attributes + +In this section, we will see all the APIs which are related to Attributes. + +## Get All Attributes + +You can get all the Attributes from the Bagisto store. You can achieve this job by using the `Attributes` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query attributes { + attributes(page: 1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "attributes": { + "paginatorInfo": { + "count": 10, + "currentPage": 1, + "lastPage": 3, + "total": 27 + }, + "data": [ + { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text", + "position": 1, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "1", + "locale": "en", + "name": "SKU", + "attributeId": "1" + } + ] + }, + { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text", + "position": 3, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "2", + "locale": "en", + "name": "Name", + "attributeId": "2" + } + ] + }, + { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text", + "position": 4, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "3", + "locale": "en", + "name": "URL Key", + "attributeId": "3" + } + ] + }, + { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select", + "position": 5, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "4", + "locale": "en", + "name": "Tax Category", + "attributeId": "4" + } + ] + }, + { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean", + "position": 6, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "5", + "locale": "en", + "name": "New", + "attributeId": "5" + } + ] + }, + { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean", + "position": 7, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "6", + "locale": "en", + "name": "Featured", + "attributeId": "6" + } + ] + }, + { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean", + "position": 9, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "7", + "locale": "en", + "name": "Visible Individually", + "attributeId": "7" + } + ] + }, + { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean", + "position": 10, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "8", + "locale": "en", + "name": "Status", + "attributeId": "8" + } + ] + }, + { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea", + "position": 11, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "9", + "locale": "en", + "name": "Short Description", + "attributeId": "9" + } + ] + }, + { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea", + "position": 12, + "isRequired": true, + "isUnique": false, + "validation": null, + "valuePerLocale": true, + "valuePerChannel": true, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true, + "options": [], + "translations": [ + { + "id": "10", + "locale": "en", + "name": "Description", + "attributeId": "10" + } + ] + } + ] + } + } +} +~~~ +::: + +## Get Attribute Data By ID + +To get the specific Attribute, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query attribute { + attribute(id: 1) { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "attribute": { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text", + "position": 1, + "isRequired": true, + "isUnique": true, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": false, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [], + "translations": [ + { + "id": "1", + "locale": "en", + "name": "SKU", + "attributeId": "1" + } + ] + } + } + } + ~~~ + +::: + +## Get Filtered Attributes + +You can get the filter data from the Attributes by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query attributes { + attributes( + page: 1, + input: { + code: "size" + } + ) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "attributes": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select", + "position": 27, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false, + "options": [ + { + "id": "6", + "adminName": "S", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "6", + "locale": "en", + "label": "S", + "attributeOptionId": "6" + } + ] + }, + { + "id": "7", + "adminName": "M", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "7", + "locale": "en", + "label": "M", + "attributeOptionId": "7" + } + ] + }, + { + "id": "8", + "adminName": "L", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "8", + "locale": "en", + "label": "L", + "attributeOptionId": "8" + } + ] + }, + { + "id": "9", + "adminName": "XL", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "9", + "locale": "en", + "label": "XL", + "attributeOptionId": "9" + } + ] + } + ], + "translations": [ + { + "id": "24", + "locale": "en", + "name": "Size", + "attributeId": "24" + } + ] + } + ] + } + } + } + ~~~ +::: + + +## Create a new Attribute + + To create a Attribute, you have to perform mutation on Attribute and paas the related fields in the request. + API call resource will create a new Attribute, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createAttribute { + createAttribute(input: { + code: "multi" + type: "select" + adminName: "Multi Option Attr" + translations: [{ + code: "en" + name: "Age Validation" + }, { + code: "fr" + name: "Validation de l'âge" + }, { + code: "nl" + name: "Leeftijd validatie" + }, { + code: "tr" + name: "Yaş Doğrulaması" + }] + isRequired: true + isUnique: false + validation: "" + valuePerLocale: true + valuePerChannel: true + isFilterable: true + isConfigurable: false + isVisibleOnFront: true + useInFlat: false + isComparable: true + swatchType: "image" + options: [{ + adminName: "Option 1" + swatchValue: "http://admin1.saascust.com/cache/medium/product/572/SpKvqowiHC2dkmvRweIsTXiiqmVZAv7UamsmLl6G.jpeg" + translations: [{ + code: "en" + label: "Option 1" + }, { + code: "fr" + label: "Option 1" + }, { + code: "nl" + label: "Optie 1" + }, { + code: "tr" + label: "seçenek 1" + }] + }, { + adminName: "Option 2" + swatchValue: "http://admin1.saascust.com/cache/medium/product/571/xFs7waxcd6MSOO8mWwBX3topPN9r8bWeHOvHz4Zq.jpeg" + translations: [{ + code: "en" + label: "Option 2" + }, { + code: "fr" + label: "Option 2" + }, { + code: "nl" + label: "Optie 2" + }, { + code: "tr" + label: "seçenek 2" + }] + }] + }) { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createAttribute": { + "id": "28", + "code": "multi", + "adminName": "Multi Option Attr", + "type": "select", + "position": null, + "isRequired": true, + "isUnique": false, + "validation": "", + "valuePerLocale": null, + "valuePerChannel": true, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": true, + "isUserDefined": true, + "swatchType": "image", + "useInFlat": false, + "isComparable": true, + "options": [ + { + "id": "10", + "adminName": "Option 1", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "28", + "attribute": { + "id": "28", + "adminName": "Multi Option Attr" + }, + "translations": [ + { + "id": "10", + "locale": "en", + "label": "Option 1", + "attributeOptionId": "10" + }, + { + "id": "11", + "locale": "nl", + "label": "Optie 1", + "attributeOptionId": "10" + }, + { + "id": "12", + "locale": "tr", + "label": "seçenek 1", + "attributeOptionId": "10" + } + ] + }, + { + "id": "11", + "adminName": "Option 2", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "28", + "attribute": { + "id": "28", + "adminName": "Multi Option Attr" + }, + "translations": [ + { + "id": "13", + "locale": "en", + "label": "Option 2", + "attributeOptionId": "11" + }, + { + "id": "14", + "locale": "nl", + "label": "Optie 2", + "attributeOptionId": "11" + }, + { + "id": "15", + "locale": "tr", + "label": "seçenek 2", + "attributeOptionId": "11" + } + ] + } + ], + "translations": [ + { + "id": "28", + "locale": "en", + "name": "Age Validation", + "attributeId": "28" + }, + { + "id": "29", + "locale": "nl", + "name": "Leeftijd validatie", + "attributeId": "28" + }, + { + "id": "30", + "locale": "tr", + "name": "Yaş Doğrulaması", + "attributeId": "28" + } + ] + } + } + } + ~~~ +::: + +## Update a Attribute + +By using this API call you can update the Attribute. To do this , you have to perform update mutation on Attribute and paas the related fields in the request. +API call will update a Attribute, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateAttribute { + updateAttribute(id: 28, input: { + code: "multi" + type: "select" + adminName: "Multi Option Attr" + translations: [{ + code: "en" + name: "Age Validation" + }, { + code: "fr" + name: "Validation de l'âge" + }, { + code: "nl" + name: "Leeftijd validatie" + }, { + code: "tr" + name: "Yaş Doğrulaması" + }] + isRequired: true + isUnique: false + validation: "" + valuePerLocale: true + valuePerChannel: true + isFilterable: true + isConfigurable: false + isVisibleOnFront: true + useInFlat: false + isComparable: true + swatchType: "image" + options: [{ + adminName: "Option 1" + swatchValue: "http://admin1.saascust.com/cache/medium/product/572/SpKvqowiHC2dkmvRweIsTXiiqmVZAv7UamsmLl6G.jpeg" + translations: [{ + code: "en" + label: "Option 1" + }, { + code: "fr" + label: "Option 1" + }, { + code: "nl" + label: "Optie 1" + }, { + code: "tr" + label: "seçenek 1" + }] + }, { + adminName: "Option 2" + swatchValue: "http://admin1.saascust.com/cache/medium/product/571/xFs7waxcd6MSOO8mWwBX3topPN9r8bWeHOvHz4Zq.jpeg" + translations: [{ + code: "en" + label: "Option 2" + }, { + code: "fr" + label: "Option 2" + }, { + code: "nl" + label: "Optie 2" + }, { + code: "tr" + label: "seçenek 2" + }] + }, { + adminName: "Option 3" + swatchValue: "http://super.saascust.com/cache/medium/product/447/85Nd2GkelYxn68czxM4gW8QsBpVNcwrN9JVQsLzp.jpeg" + translations: [{ + code: "en" + label: "Option 3" + }, { + code: "fr" + label: "Option 3" + }, { + code: "nl" + label: "Optie 3" + }, { + code: "tr" + label: "seçenek 3" + }] + }] + }) { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + options { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + translations { + id + locale + name + attributeId + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateAttribute": { + "id": "28", + "code": "multi", + "adminName": "Multi Option Attr", + "type": "select", + "position": null, + "isRequired": true, + "isUnique": false, + "validation": "", + "valuePerLocale": false, + "valuePerChannel": true, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": true, + "isUserDefined": true, + "swatchType": "image", + "useInFlat": false, + "isComparable": true, + "options": [ + { + "id": "12", + "adminName": "Option 1", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "28", + "attribute": { + "id": "28", + "adminName": "Multi Option Attr" + }, + "translations": [ + { + "id": "16", + "locale": "en", + "label": "Option 1", + "attributeOptionId": "12" + }, + { + "id": "17", + "locale": "nl", + "label": "Optie 1", + "attributeOptionId": "12" + }, + { + "id": "18", + "locale": "tr", + "label": "seçenek 1", + "attributeOptionId": "12" + } + ] + }, + { + "id": "13", + "adminName": "Option 2", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "28", + "attribute": { + "id": "28", + "adminName": "Multi Option Attr" + }, + "translations": [ + { + "id": "19", + "locale": "en", + "label": "Option 2", + "attributeOptionId": "13" + }, + { + "id": "20", + "locale": "nl", + "label": "Optie 2", + "attributeOptionId": "13" + }, + { + "id": "21", + "locale": "tr", + "label": "seçenek 2", + "attributeOptionId": "13" + } + ] + }, + { + "id": "14", + "adminName": "Option 3", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "28", + "attribute": { + "id": "28", + "adminName": "Multi Option Attr" + }, + "translations": [ + { + "id": "22", + "locale": "en", + "label": "Option 3", + "attributeOptionId": "14" + }, + { + "id": "23", + "locale": "nl", + "label": "Optie 3", + "attributeOptionId": "14" + }, + { + "id": "24", + "locale": "tr", + "label": "seçenek 3", + "attributeOptionId": "14" + } + ] + } + ], + "translations": [ + { + "id": "28", + "locale": "en", + "name": "Age Validation", + "attributeId": "28" + }, + { + "id": "29", + "locale": "nl", + "name": "Leeftijd validatie", + "attributeId": "28" + }, + { + "id": "30", + "locale": "tr", + "name": "Yaş Doğrulaması", + "attributeId": "28" + } + ] + } + } + } + ~~~ +::: + +## Delete a Attribute + +To delete a Attribute, you have to perform mutation on Attribute by passing the id of that Attribute. +API call will delete a Attribute, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteAttribute { + deleteAttribute(id: 28) { + success + } + } + + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteAttribute": { + "success": "Attribute deleted successfully." + } + } + } + ~~~ +::: + +## Get All Attribute Options + +You can get all the Attribute Options from the Bagisto store. You can achieve this job by using the `Attribute Options` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query attributeOptions { + attributeOptions { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + } + } + ~~~ +::: details Response + +~~~json +{ + "data": { + "attributeOptions": { + "paginatorInfo": { + "count": 9, + "currentPage": 1, + "lastPage": 1, + "total": 9 + }, + "data": [ + { + "id": "1", + "adminName": "Red", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "1", + "locale": "en", + "label": "Red", + "attributeOptionId": "1" + } + ] + }, + { + "id": "2", + "adminName": "Green", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "2", + "locale": "en", + "label": "Green", + "attributeOptionId": "2" + } + ] + }, + { + "id": "3", + "adminName": "Yellow", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "3", + "locale": "en", + "label": "Yellow", + "attributeOptionId": "3" + } + ] + }, + { + "id": "4", + "adminName": "Black", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "4", + "locale": "en", + "label": "Black", + "attributeOptionId": "4" + } + ] + }, + { + "id": "5", + "adminName": "White", + "swatchValue": null, + "sortOrder": 5, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "5", + "locale": "en", + "label": "White", + "attributeOptionId": "5" + } + ] + }, + { + "id": "6", + "adminName": "S", + "swatchValue": null, + "sortOrder": 1, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "6", + "locale": "en", + "label": "S", + "attributeOptionId": "6" + } + ] + }, + { + "id": "7", + "adminName": "M", + "swatchValue": null, + "sortOrder": 2, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "7", + "locale": "en", + "label": "M", + "attributeOptionId": "7" + } + ] + }, + { + "id": "8", + "adminName": "L", + "swatchValue": null, + "sortOrder": 3, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "8", + "locale": "en", + "label": "L", + "attributeOptionId": "8" + } + ] + }, + { + "id": "9", + "adminName": "XL", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "24", + "attribute": { + "id": "24", + "adminName": "Size" + }, + "translations": [ + { + "id": "9", + "locale": "en", + "label": "XL", + "attributeOptionId": "9" + } + ] + } + ] + } + } +} +~~~ +::: + +## Get Attribute Option By ID + +To get the specific Attribute Option, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query attributeOption { + attributeOption(id: 4) { + id + adminName + swatchValue + sortOrder + attributeId + attribute { + id + adminName + } + translations { + id + locale + label + attributeOptionId + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "attributeOption": { + "id": "4", + "adminName": "Black", + "swatchValue": null, + "sortOrder": 4, + "attributeId": "23", + "attribute": { + "id": "23", + "adminName": "Color" + }, + "translations": [ + { + "id": "4", + "locale": "en", + "label": "Black", + "attributeOptionId": "4" + } + ] + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-admin-api/categories.md b/docs/1.x/graphql-admin-api/categories.md new file mode 100644 index 00000000..4d76f57a --- /dev/null +++ b/docs/1.x/graphql-admin-api/categories.md @@ -0,0 +1,880 @@ +# Categories + +In this section, we will see all the APIs which are related to Categories. + +## Get All Categories + +You can get all the Categories from the Bagisto store. You can achieve this job by using the `Categories` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query categories { + categories { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "categories": { + "paginatorInfo": { + "count": 2, + "currentPage": 1, + "lastPage": 1, + "total": 2 + }, + "data": [ + { + "id": "1", + "name": "Root", + "description": "Root", + "slug": "root", + "urlPath": "", + "imageUrl": null, + "metaTitle": "", + "metaDescription": "", + "metaKeywords": "", + "position": 1, + "status": true, + "displayMode": "products_and_description", + "parentId": null, + "filterableAttributes": [], + "translations": [ + { + "id": "1", + "name": "Root", + "description": "Root", + "localeId": null, + "locale": "en" + } + ], + "createdAt": "2021-05-05 15:36:44", + "updatedAt": "2021-05-05 15:36:44" + }, + { + "id": "2", + "name": "Shop", + "description": "

Test Category

", + "slug": "shop", + "urlPath": "shop", + "imageUrl": "http://localhost/graphql/public/storage/category/2/veI5gArm9nBKUFPwvvmmoRccLdtlJXhHBtaGzL4a.jpg", + "metaTitle": "", + "metaDescription": "", + "metaKeywords": "", + "position": 1, + "status": true, + "displayMode": "products_and_description", + "parentId": "1", + "filterableAttributes": [ + { + "id": "11", + "adminName": "Price", + "code": "price", + "type": "price", + "position": 13 + }, + { + "id": "23", + "adminName": "Color", + "code": "color", + "type": "select", + "position": 26 + }, + { + "id": "24", + "adminName": "Size", + "code": "size", + "type": "select", + "position": 27 + }, + { + "id": "25", + "adminName": "Brand", + "code": "brand", + "type": "select", + "position": 28 + } + ], + "translations": [ + { + "id": "2", + "name": "Shop", + "description": "

Test Category

", + "localeId": "1", + "locale": "en" + }, + { + "id": "3", + "name": "Shop", + "description": "

Test Category

", + "localeId": "3", + "locale": "nl" + }, + { + "id": "4", + "name": "Shop", + "description": "

Test Category

", + "localeId": "4", + "locale": "tr" + } + ], + "createdAt": "2021-05-27 18:06:22", + "updatedAt": "2021-05-27 18:06:23" + } + ] + } + } +} +~~~ +::: + +## Get Category Data By ID + +To get the specific Category, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query category { + category(id: 2) { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "category": { + "id": "2", + "name": "Shop", + "description": "

Test Category

", + "slug": "shop", + "urlPath": "shop", + "imageUrl": "http://localhost/graphql/public/storage/category/2/veI5gArm9nBKUFPwvvmmoRccLdtlJXhHBtaGzL4a.jpg", + "metaTitle": "", + "metaDescription": "", + "metaKeywords": "", + "position": 1, + "status": true, + "displayMode": "products_and_description", + "parentId": "1", + "filterableAttributes": [ + { + "id": "11", + "adminName": "Price", + "code": "price", + "type": "price", + "position": 13 + }, + { + "id": "23", + "adminName": "Color", + "code": "color", + "type": "select", + "position": 26 + }, + { + "id": "24", + "adminName": "Size", + "code": "size", + "type": "select", + "position": 27 + }, + { + "id": "25", + "adminName": "Brand", + "code": "brand", + "type": "select", + "position": 28 + } + ], + "translations": [ + { + "id": "2", + "name": "Shop", + "description": "

Test Category

", + "localeId": "1", + "locale": "en" + }, + { + "id": "3", + "name": "Shop", + "description": "

Test Category

", + "localeId": "3", + "locale": "nl" + }, + { + "id": "4", + "name": "Shop", + "description": "

Test Category

", + "localeId": "4", + "locale": "tr" + } + ], + "createdAt": "2021-05-27 18:06:22", + "updatedAt": "2021-05-27 18:06:23" + } + } + } + ~~~ + +::: + +## Get Filtered Categories + +You can get the filter data from the Categories by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query categories { + categories(page:1, input: { + id:2 + name:"Shop" + }) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "categories": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "2", + "name": "Shop", + "description": "

Test Category

", + "slug": "shop", + "urlPath": "shop", + "imageUrl": "http://localhost/graphql/public/storage/category/2/veI5gArm9nBKUFPwvvmmoRccLdtlJXhHBtaGzL4a.jpg", + "metaTitle": "", + "metaDescription": "", + "metaKeywords": "", + "position": 1, + "status": true, + "displayMode": "products_and_description", + "parentId": "1", + "filterableAttributes": [ + { + "id": "11", + "adminName": "Price", + "code": "price", + "type": "price", + "position": 13 + }, + { + "id": "23", + "adminName": "Color", + "code": "color", + "type": "select", + "position": 26 + }, + { + "id": "24", + "adminName": "Size", + "code": "size", + "type": "select", + "position": 27 + }, + { + "id": "25", + "adminName": "Brand", + "code": "brand", + "type": "select", + "position": 28 + } + ], + "translations": [ + { + "id": "2", + "name": "Shop", + "description": "

Test Category

", + "localeId": "1", + "locale": "en" + }, + { + "id": "3", + "name": "Shop", + "description": "

Test Category

", + "localeId": "3", + "locale": "nl" + }, + { + "id": "4", + "name": "Shop", + "description": "

Test Category

", + "localeId": "4", + "locale": "tr" + } + ], + "createdAt": "2021-05-27 18:06:22", + "updatedAt": "2021-05-27 18:06:23" + } + ] + } + } + } + ~~~ +::: + +## Get All Filterable Attributes + +You can get all the Filterable Attributes from the Bagisto store. You can achieve this job by using the `Filterable Attributes` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query filterableAttributes { + filterableAttributes { + id + code + adminName + type + position + isRequired + isUnique + validation + valuePerLocale + valuePerChannel + isFilterable + isConfigurable + isVisibleOnFront + isUserDefined + swatchType + useInFlat + isComparable + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "filterableAttributes": [ + { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price", + "position": 13, + "isRequired": true, + "isUnique": false, + "validation": "decimal", + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": false, + "isUserDefined": false, + "swatchType": null, + "useInFlat": true, + "isComparable": true + }, + { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select", + "position": 26, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false + }, + { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select", + "position": 27, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": true, + "isVisibleOnFront": false, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false + }, + { + "id": "25", + "code": "brand", + "adminName": "Brand", + "type": "select", + "position": 28, + "isRequired": false, + "isUnique": false, + "validation": null, + "valuePerLocale": false, + "valuePerChannel": false, + "isFilterable": true, + "isConfigurable": false, + "isVisibleOnFront": true, + "isUserDefined": true, + "swatchType": null, + "useInFlat": true, + "isComparable": false + } + ] + } +} +~~~ +::: + +## Create a new Category + + To create a Category, you have to perform mutation on Category and paas the related fields in the request. + API call resource will create a new Category, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createCategory { + createCategory(input: { + name:"Women's Cloths" + locale: "all" + slug: "women-cloths" + description: "demo women Cloths description" + status: false + position: 1 + displayMode: "products_and_description" + parentId: 2 + metaTitle: "demo women Cloths meta title" + metaDescription: "demo Cloths meta title" + metaKeywords: "demo women Cloths meta title" + image: "http://graphqlnew.com/storage/category/4/NnPWmwMBRDcpPSfZCIhgska892t9f4zaI10nrMDu.jpg" + }) { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createCategory": { + "id": "3", + "name": "Women's Cloths", + "description": "demo women Cloths description", + "slug": "women-cloths", + "urlPath": null, + "imageUrl": null, + "metaTitle": "demo women Cloths meta title", + "metaDescription": "demo Cloths meta title", + "metaKeywords": "demo women Cloths meta title", + "position": 1, + "status": false, + "displayMode": "products_and_description", + "parentId": "2", + "filterableAttributes": [], + "translations": [ + { + "id": "5", + "name": "Women's Cloths", + "description": "demo women Cloths description", + "localeId": "1", + "locale": "en" + }, + { + "id": "6", + "name": "Women's Cloths", + "description": "demo women Cloths description", + "localeId": "3", + "locale": "nl" + }, + { + "id": "7", + "name": "Women's Cloths", + "description": "demo women Cloths description", + "localeId": "4", + "locale": "tr" + } + ], + "createdAt": "2021-05-27 18:20:43", + "updatedAt": "2021-05-27 18:20:44" + } + } + } + ~~~ +::: + +## Update a Category + +By using this API call you can update the Category. To do this , you have to perform update mutation on Category and paas the related fields in the request. +API call will update a Category, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateCategory { + updateCategory(id: 3, input: { + name:"Women Collection" + locale: "fr" + slug: "women-cloths" + description: "Description de la Women Collection" + status: true + position: 1 + displayMode: "products_and_description" + parentId: 2 + metaTitle: "Meta titre de Women Collection" + metaDescription: "Meta description de la Women Collection" + metaKeywords: "Méta-mots-clés Women Collection" + image: "http://graphqlnew.com/storage/category/3/GVATxwzSS8nbWfiA7WWnpnjmsFQMnW9prOrItqpf.jpg" + }) { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateCategory": { + "id": "3", + "name": "Women's Cloths", + "description": "demo women Cloths description", + "slug": "women-cloths", + "urlPath": "shop/women-cloths", + "imageUrl": null, + "metaTitle": "demo women Cloths meta title", + "metaDescription": "demo Cloths meta title", + "metaKeywords": "demo women Cloths meta title", + "position": 1, + "status": true, + "displayMode": "products_and_description", + "parentId": "2", + "filterableAttributes": [], + "translations": [ + { + "id": "5", + "name": "Women's Cloths", + "description": "demo women Cloths description", + "localeId": "1", + "locale": "en" + }, + { + "id": "6", + "name": "Women's Cloths", + "description": "demo women Cloths description", + "localeId": "3", + "locale": "nl" + }, + { + "id": "7", + "name": "Women's Cloths", + "description": "demo women Cloths description", + "localeId": "4", + "locale": "tr" + } + ], + "createdAt": "2021-05-27 18:20:43", + "updatedAt": "2021-05-27 18:24:26" + } + } + } + ~~~ +::: + +## Delete a Category + +To delete a Category, you have to perform mutation on Category by passing the id of that Category. +API call will delete a Category, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteCategory { + deleteCategory(id: 3) { + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteCategory": { + "success": "Category deleted successfully." + } + } + } + ~~~ +: \ No newline at end of file diff --git a/docs/1.x/graphql-admin-api/cms.md b/docs/1.x/graphql-admin-api/cms.md new file mode 100644 index 00000000..e4939410 --- /dev/null +++ b/docs/1.x/graphql-admin-api/cms.md @@ -0,0 +1,921 @@ +## CMS Pages + +In this section, we will see all the APIs which are related to CMS Pages. + +### 1. Get all CMS Page + +You can get all the CMS Page from the Bagisto store. You can achieve this job by using the `CMS Page` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query cmspages { + cmsPages(page:1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + layout + createdAt + updatedAt + translations { + id + urlKey + metaDescription + metaTitle + pageTitle + metaKeywords + htmlContent + locale + cmsPageId + } + channels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + } + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "cmsPages": { + "paginatorInfo": { + "count": 10, + "currentPage": 1, + "lastPage": 2, + "total": 11 + }, + "data": [ + { + "id": "1", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "1", + "urlKey": "about-us", + "metaDescription": "", + "metaTitle": "about us", + "pageTitle": "About Us", + "metaKeywords": "aboutus", + "htmlContent": "
About us page content
", + "locale": "en", + "cmsPageId": "1" + } + ], + "channels": [], + "success": null + }, + { + "id": "2", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "2", + "urlKey": "return-policy", + "metaDescription": "", + "metaTitle": "return policy", + "pageTitle": "Return Policy", + "metaKeywords": "return, policy", + "htmlContent": "
Return policy page content
", + "locale": "en", + "cmsPageId": "2" + } + ], + "channels": [], + "success": null + }, + { + "id": "3", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "3", + "urlKey": "refund-policy", + "metaDescription": "", + "metaTitle": "Refund policy", + "pageTitle": "Refund Policy", + "metaKeywords": "refund, policy", + "htmlContent": "
Refund policy page content
", + "locale": "en", + "cmsPageId": "3" + } + ], + "channels": [], + "success": null + }, + { + "id": "4", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "4", + "urlKey": "terms-conditions", + "metaDescription": "", + "metaTitle": "Terms & Conditions", + "pageTitle": "Terms & Conditions", + "metaKeywords": "term, conditions", + "htmlContent": "
Terms & conditions page content
", + "locale": "en", + "cmsPageId": "4" + } + ], + "channels": [], + "success": null + }, + { + "id": "5", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "5", + "urlKey": "terms-of-use", + "metaDescription": "", + "metaTitle": "Terms of use", + "pageTitle": "Terms of use", + "metaKeywords": "term, use", + "htmlContent": "
Terms of use page content
", + "locale": "en", + "cmsPageId": "5" + } + ], + "channels": [], + "success": null + }, + { + "id": "6", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "6", + "urlKey": "contact-us", + "metaDescription": "", + "metaTitle": "Contact Us", + "pageTitle": "Contact Us", + "metaKeywords": "contact, us", + "htmlContent": "
Contact us page content
", + "locale": "en", + "cmsPageId": "6" + } + ], + "channels": [], + "success": null + }, + { + "id": "7", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "7", + "urlKey": "cutomer-service", + "metaDescription": "", + "metaTitle": "Customer Service", + "pageTitle": "Customer Service", + "metaKeywords": "customer, service", + "htmlContent": "
Customer service page content
", + "locale": "en", + "cmsPageId": "7" + } + ], + "channels": [], + "success": null + }, + { + "id": "8", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "8", + "urlKey": "whats-new", + "metaDescription": "", + "metaTitle": "What's New", + "pageTitle": "What's New", + "metaKeywords": "new", + "htmlContent": "
What's New page content
", + "locale": "en", + "cmsPageId": "8" + } + ], + "channels": [], + "success": null + }, + { + "id": "9", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "9", + "urlKey": "payment-policy", + "metaDescription": "", + "metaTitle": "Payment Policy", + "pageTitle": "Payment Policy", + "metaKeywords": "payment, policy", + "htmlContent": "
Payment Policy page content
", + "locale": "en", + "cmsPageId": "9" + } + ], + "channels": [], + "success": null + }, + { + "id": "10", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "10", + "urlKey": "shipping-policy", + "metaDescription": "", + "metaTitle": "Shipping Policy", + "pageTitle": "Shipping Policy", + "metaKeywords": "shipping, policy", + "htmlContent": "
Shipping Policy page content
", + "locale": "en", + "cmsPageId": "10" + } + ], + "channels": [], + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get CMS Page By ID + +To get the specific CMS Page, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query cmspage { + cmsPage(id:1) { + id + layout + createdAt + updatedAt + translations { + id + urlKey + metaDescription + metaTitle + pageTitle + metaKeywords + htmlContent + locale + cmsPageId + } + channels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + } + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "cmsPage": { + "id": "1", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "1", + "urlKey": "about-us", + "metaDescription": "", + "metaTitle": "about us", + "pageTitle": "About Us", + "metaKeywords": "aboutus", + "htmlContent": "
About us page content
", + "locale": "en", + "cmsPageId": "1" + } + ], + "channels": [], + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered CMS Page + +You can get the filter data from the CMS Pages by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query cmspages { + cmsPages(input: { + id:1 + }, page:1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + layout + createdAt + updatedAt + translations { + id + urlKey + metaDescription + metaTitle + pageTitle + metaKeywords + htmlContent + locale + cmsPageId + } + channels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + } + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "cmsPages": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "layout": null, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "translations": [ + { + "id": "1", + "urlKey": "about-us", + "metaDescription": "", + "metaTitle": "about us", + "pageTitle": "About Us", + "metaKeywords": "aboutus", + "htmlContent": "
About us page content
", + "locale": "en", + "cmsPageId": "1" + } + ], + "channels": [], + "success": null + } + ] + } + } + } + ~~~ + ::: + + +### 4. Get CMS Translations + +You can get the CMS Page Translations from the Bagisto store. You can achieve this job by using the `CMS Page Translations` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query cmsPageTranslations { + cmsPageTranslations(input: { + cmsPageId:1 + id:1 + }, page:1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + urlKey + metaDescription + metaTitle + pageTitle + metaKeywords + htmlContent + locale + cmsPageId + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "cmsPageTranslations": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "urlKey": "about-us", + "metaDescription": "", + "metaTitle": "about us", + "pageTitle": "About Us", + "metaKeywords": "aboutus", + "htmlContent": "
About us page content
", + "locale": "en", + "cmsPageId": "1" + } + ] + } + } +} +~~~ +::: + +### 5. Get CMS Translations By ID + +To get the specific CMS Translations, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query cmsPageTranslation { + cmsPageTranslation(id:1,input: { + cmsPageId:1 + id:1 + }) { + id + urlKey + metaDescription + metaTitle + pageTitle + metaKeywords + htmlContent + locale + cmsPageId + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "cmsPageTranslation": { + "id": "1", + "urlKey": "about-us", + "metaDescription": "", + "metaTitle": "about us", + "pageTitle": "About Us", + "metaKeywords": "aboutus", + "htmlContent": "
About us page content
", + "locale": "en", + "cmsPageId": "1" + } + } + } + ~~~ + +::: + +### 6. Create a new CMS Page + + To create a CMS Page, you have to perform mutation on CMS Page and paas the related fields in the request. + API call resource will create a new CMS Page, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createCmsPage(input:{ + pageTitle: "test" + channels:1 + htmlContent: "
About us page content
" + metaTitle: "testetest us" + urlKey: "test-us" + metaKeywords: "testsesese" + metaDescription: "teste data" + locale:"en" + }) { + id + layout + createdAt + updatedAt + translations { + id + urlKey + metaDescription + metaTitle + pageTitle + metaKeywords + htmlContent + locale + cmsPageId + } + channels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + } + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createCmsPage": { + "id": "12", + "layout": null, + "createdAt": "2021-05-25 18:32:22", + "updatedAt": "2021-05-25 18:32:22", + "translations": [ + { + "id": "12", + "urlKey": "test-us", + "metaDescription": "teste data", + "metaTitle": "testetest us", + "pageTitle": "test", + "metaKeywords": "testsesese", + "htmlContent": "
About us page content
", + "locale": "en", + "cmsPageId": "12" + }, + { + "id": "13", + "urlKey": "test-us", + "metaDescription": "teste data", + "metaTitle": "testetest us", + "pageTitle": "test", + "metaKeywords": "testsesese", + "htmlContent": "
About us page content
", + "locale": "nl", + "cmsPageId": "12" + }, + { + "id": "14", + "urlKey": "test-us", + "metaDescription": "teste data", + "metaTitle": "testetest us", + "pageTitle": "test", + "metaKeywords": "testsesese", + "htmlContent": "
About us page content
", + "locale": "tr", + "cmsPageId": "12" + } + ], + "channels": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1 + } + ], + "success": null + } + } + } + ~~~ +::: + +### 7. Update CMS Page + +By using this API call you can update the CMS Page. To do this , you have to perform update mutation on CMS Page and paas the related fields in the request. +API call will update a CMS Page, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateCmsPage(id:12,input:{ + pageTitle: "testUpdate" + channels:1 + htmlContent: "
About us page content
" + metaTitle: "testetest us" + urlKey: "test-us" + metaKeywords: "testsesese" + metaDescription: "teste data" + locale:"en" + }) { + id + layout + createdAt + updatedAt + translations { + id + urlKey + metaDescription + metaTitle + pageTitle + metaKeywords + htmlContent + locale + cmsPageId + } + channels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + } + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateCmsPage": { + "id": "12", + "layout": null, + "createdAt": "2021-05-25 18:32:22", + "updatedAt": "2021-05-25 18:32:22", + "translations": [ + { + "id": "12", + "urlKey": "test-us", + "metaDescription": "teste data", + "metaTitle": "testetest us", + "pageTitle": "testUpdate", + "metaKeywords": "testsesese", + "htmlContent": "
About us page content
", + "locale": "en", + "cmsPageId": "12" + }, + { + "id": "13", + "urlKey": "test-us", + "metaDescription": "teste data", + "metaTitle": "testetest us", + "pageTitle": "test", + "metaKeywords": "testsesese", + "htmlContent": "
About us page content
", + "locale": "nl", + "cmsPageId": "12" + }, + { + "id": "14", + "urlKey": "test-us", + "metaDescription": "teste data", + "metaTitle": "testetest us", + "pageTitle": "test", + "metaKeywords": "testsesese", + "htmlContent": "
About us page content
", + "locale": "tr", + "cmsPageId": "12" + } + ], + "channels": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1 + } + ], + "success": null + } + } + } + ~~~ +::: + +### 8. Delete a CMS Page + +To delete a CMS Page, you have to perform mutation on CMS Page by passing the id of that CMS Page. +API call will delete a CMS Page, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteCmsPage(id:12){ + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteCmsPage": { + "success": "CMS Page deleted successfully." + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-admin-api/customers.md b/docs/1.x/graphql-admin-api/customers.md new file mode 100644 index 00000000..52b5fb9d --- /dev/null +++ b/docs/1.x/graphql-admin-api/customers.md @@ -0,0 +1,1827 @@ +## Customers + +In this section, we will see all the APIs which are related to Customer's. + +### 1. Get All Customer's + +You can get all the Customer's from the Bagisto store. You can achieve this job by using the `Customers` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query customers { + customers(page:1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + firstName + lastName + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + customerGroup { + id + name + code + isUserDefined + createdAt + updatedAt + } + addresses { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + } + defaultAddress { + id + companyName + address1 + address2 + country + state + city + postcode + phone + } + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "customers": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "firstName": "Naresh", + "lastName": "Verma", + "gender": "Male", + "dateOfBirth": "1996-03-04", + "email": "naresh.verma327@webkul.com", + "phone": "0324224324343", + "password": "$2y$10$REg4zdIfJ8TgsOJst1uZCuhPn91Zl8jbju1f3jORraWuEDqz88PLy", + "apiToken": null, + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": null, + "notes": null, + "status": true, + "customerGroup": { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + "addresses": [ + { + "id": "1", + "customerId": 1, + "companyName": "Nitinv pvt ltd", + "firstName": "naresh", + "lastName": "Verma", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045", + "vatId": "", + "addressType": "customer", + "defaultAddress": true + } + ], + "defaultAddress": { + "id": "1", + "companyName": "Nitinv pvt ltd", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045" + }, + "createdAt": "2021-05-26 15:42:59", + "updatedAt": "2021-05-26 15:42:59" + } + ] + } + } +} +~~~ +::: + +### 2. Get Customer's By ID + +To get the specific Customer's, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query customer { + customer(id: 1) { + id + firstName + lastName + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + customerGroup { + id + name + code + isUserDefined + createdAt + updatedAt + } + addresses { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + } + defaultAddress { + id + companyName + address1 + address2 + country + state + city + postcode + phone + } + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "customer": { + "id": "1", + "firstName": "Naresh", + "lastName": "Verma", + "gender": "Male", + "dateOfBirth": "1996-03-04", + "email": "naresh.verma327@webkul.com", + "phone": "0324224324343", + "password": "$2y$10$REg4zdIfJ8TgsOJst1uZCuhPn91Zl8jbju1f3jORraWuEDqz88PLy", + "apiToken": null, + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": null, + "notes": null, + "status": true, + "customerGroup": { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + "addresses": [ + { + "id": "1", + "customerId": 1, + "companyName": "Nitinv pvt ltd", + "firstName": "naresh", + "lastName": "Verma", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045", + "vatId": "", + "addressType": "customer", + "defaultAddress": true + } + ], + "defaultAddress": { + "id": "1", + "companyName": "Nitinv pvt ltd", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045" + }, + "createdAt": "2021-05-26 15:42:59", + "updatedAt": "2021-05-26 15:42:59" + } + } + } + ~~~ +::: + +### 3. Get Filtered Customer's + +You can get the filter data from the Customer's by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query customers { + customers(input: { + id:1 + },page:1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + firstName + lastName + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + customerGroup { + id + name + code + isUserDefined + createdAt + updatedAt + } + addresses { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + } + defaultAddress { + id + companyName + address1 + address2 + country + state + city + postcode + phone + } + createdAt + updatedAt + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "customers": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "firstName": "Naresh", + "lastName": "Verma", + "gender": "Male", + "dateOfBirth": "1996-03-04", + "email": "naresh.verma327@webkul.com", + "phone": "0324224324343", + "password": "$2y$10$REg4zdIfJ8TgsOJst1uZCuhPn91Zl8jbju1f3jORraWuEDqz88PLy", + "apiToken": null, + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": null, + "notes": null, + "status": true, + "customerGroup": { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + "addresses": [ + { + "id": "1", + "customerId": 1, + "companyName": "Nitinv pvt ltd", + "firstName": "naresh", + "lastName": "Verma", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045", + "vatId": "", + "addressType": "customer", + "defaultAddress": true + } + ], + "defaultAddress": { + "id": "1", + "companyName": "Nitinv pvt ltd", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045" + }, + "createdAt": "2021-05-26 15:42:59", + "updatedAt": "2021-05-26 15:42:59" + } + ] + } + } + } + ~~~ +::: + +### 4. Create a new Customer + + To create a Customer, you have to perform mutation on Customer and paas the related fields in the request. + API call resource will create a new Customer, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createCustomer { + createCustomer(input: { + firstName: "Peter" + lastName: "Doe" + email: "peter@example.com" + gender: "Male" + dateOfBirth: "17/04/1994" + customerGroupId: 2 + phone: "987654321" + status: false + }) { + id + firstName + lastName + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + customerGroup { + id + name + code + isUserDefined + createdAt + updatedAt + } + addresses { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + } + defaultAddress { + id + companyName + address1 + address2 + country + state + city + postcode + phone + } + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createCustomer": { + "id": "3", + "firstName": "Peter", + "lastName": "Doe", + "gender": "Male", + "dateOfBirth": "1994-04-17", + "email": "peter@example.com", + "phone": "987654321", + "password": "$2y$10$XZdipyt7nrh3qzXF691Uiu9K.Pp2BgfSD5d651hVmlcJNycGs92E.", + "apiToken": null, + "customerGroupId": 2, + "subscribedToNewsLetter": null, + "isVerified": true, + "token": null, + "notes": null, + "status": false, + "customerGroup": { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + "addresses": [], + "defaultAddress": null, + "createdAt": "2021-05-26 15:54:52", + "updatedAt": "2021-05-26 15:54:52" + } + } + } + ~~~ +::: + +### 5. Update Customer + +By using this API call you can update the Customer. To do this , you have to perform update mutation on Customer and paas the related fields in the request. +API call will update a Customer, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateCustomer { + updateCustomer(id:3, input: { + firstName: "Kim" + lastName: "Thomson" + email: "peter1@example.com" + gender: "Female" + dateOfBirth: "2019-10-30" + customerGroupId: 1 + phone: "6543213456" + status: true + }) { + id + firstName + lastName + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + customerGroup { + id + name + code + isUserDefined + createdAt + updatedAt + } + addresses { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + } + defaultAddress { + id + companyName + address1 + address2 + country + state + city + postcode + phone + } + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateCustomer": { + "id": "3", + "firstName": "Kim", + "lastName": "Thomson", + "gender": "Female", + "dateOfBirth": "2019-10-30", + "email": "peter1@example.com", + "phone": "6543213456", + "password": "$2y$10$XZdipyt7nrh3qzXF691Uiu9K.Pp2BgfSD5d651hVmlcJNycGs92E.", + "apiToken": null, + "customerGroupId": 1, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": null, + "notes": null, + "status": true, + "customerGroup": { + "id": "1", + "name": "Guest", + "code": "guest", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + "addresses": [], + "defaultAddress": null, + "createdAt": "2021-05-26 15:54:52", + "updatedAt": "2021-05-26 15:58:32" + } + } + } + ~~~ +::: + +### 6. Delete a Customer + +To delete a Customer, you have to perform mutation on Customer by passing the id of that Customer. +API call will delete a Customer, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteCustomer { + deleteCustomer(id: 3) { + success + } + } + ~~~ + +::: details Response + ~~~json + "data": { + "deleteCustomer": { + "success": "Customer deleted successfully." + } + } + ~~~ +::: + +## Customer's Addresses + +In this section, we will see all the APIs which are related to Customer's Addresses. + +### 1. Get All Customer's Addresses + +You can get all the Customer's Addresses from the Bagisto store. You can achieve this job by using the `Customer's Addresses` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query customerAddresses { + customerAddresses { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "customerAddresses": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "customerId": 1, + "companyName": "Nitinv pvt ltd", + "firstName": "naresh", + "lastName": "Verma", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045", + "vatId": "", + "addressType": "customer", + "defaultAddress": true, + "createdAt": "2021-05-26 15:44:32", + "updatedAt": "2021-05-26 15:44:45" + } + ] + } + } +} +~~~ +::: + +### 2. Get Customer's Addresses By ID + +To get the specific Customer's Addresses, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query customerAddress { + customerAddress(id: 1) { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "customerAddress": { + "id": "1", + "customerId": 1, + "companyName": "Nitinv pvt ltd", + "firstName": "naresh", + "lastName": "Verma", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045", + "vatId": "", + "addressType": "customer", + "defaultAddress": true, + "createdAt": "2021-05-26 15:44:32", + "updatedAt": "2021-05-26 15:44:45" + } + } + } + ~~~ +::: + +### 3. Get Filtered Customer's Addresses + +You can get the filter data from the Customer's Addresses by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query customerAddresses { + customerAddresses(input: { + customerId: 1 + }) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "customerAddresses": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "customerId": 1, + "companyName": "Nitinv pvt ltd", + "firstName": "naresh", + "lastName": "Verma", + "address1": "3rd, arv", + "address2": null, + "country": "IN", + "state": "UT", + "city": "Eindhoven", + "postcode": "5642CV", + "phone": "45454545052045", + "vatId": "", + "addressType": "customer", + "defaultAddress": true, + "createdAt": "2021-05-26 15:44:32", + "updatedAt": "2021-05-26 15:44:45" + } + ] + } + } + } + ~~~ +::: + +### 4. Create a new Customer Address + + To create a Customer Address, you have to perform mutation on Customer Address and paas the related fields in the request. + API call resource will create a new Customer Address, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createCustomerAddress { + createCustomerAddress(input: { + customerId: 1 + companyName: "Webkul" + firstName: "Tom Demo" + lastName: "Martin Demo" + address1: "3180 Bluff" + address2: "Street" + country: "US" + state: "PA" + city: "GLEN CAMPBELL" + postcode: "15742" + phone: "234343544" + vatId: "INV12345678902" + defaultAddress: false + }) { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createCustomerAddress": { + "id": "2", + "customerId": 1, + "companyName": "Webkul", + "firstName": "Tom Demo", + "lastName": "Martin Demo", + "address1": "3180 Bluff", + "address2": "Street", + "country": "US", + "state": "PA", + "city": "GLEN CAMPBELL", + "postcode": "15742", + "phone": "234343544", + "vatId": "INV12345678902", + "addressType": "customer", + "defaultAddress": true, + "createdAt": "2021-05-26 16:17:48", + "updatedAt": "2021-05-26 16:17:48" + } + } + } + ~~~ +::: + +### 5. Update Customer Address + +By using this API call you can update the Customer Address. To do this , you have to perform update mutation on Customer Address and paas the related fields in the request. +API call will update a Customer Address, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateCustomerAddress { + updateCustomerAddress(id: 2, input: { + customerId: 1 + companyName: "Velocity" + firstName: "Tom" + lastName: "Martin" + address1: "3180 Bluff Street" + address2: "" + country: "IN" + state: "UP" + city: "Noida" + postcode: "201301" + phone: "1234123455" + vatId: "INV12342278902" + }) { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateCustomerAddress": { + "id": "2", + "customerId": 1, + "companyName": "Velocity", + "firstName": "Tom", + "lastName": "Martin", + "address1": "3180 Bluff Street", + "address2": "", + "country": "IN", + "state": "UP", + "city": "Noida", + "postcode": "201301", + "phone": "1234123455", + "vatId": "INV12342278902", + "addressType": "customer", + "defaultAddress": false, + "createdAt": "2021-05-26 16:17:48", + "updatedAt": "2021-05-26 16:19:58" + } + } + } + ~~~ +::: + +### 6. Delete a Customer Address + +To delete a Customer Address, you have to perform mutation on Customer Address by passing the id of that Customer Address. +API call will delete a Customer Address, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteCustomerAddress { + deleteCustomerAddress(id: 1) { + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteCustomerAddress": { + "success": "Customer's Address deleted successfully." + } + } + } + ~~~ +::: + +## Customer Groups + +In this section, we will see all the APIs which are related to Customer Groups. + +### 1. Get All Customer Groups + +You can get all the Customer Groups from the Bagisto store. You can achieve this job by using the `Customer Groups` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query customerGroups { + customerGroups { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + code + isUserDefined + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "customerGroups": { + "paginatorInfo": { + "count": 3, + "currentPage": 1, + "lastPage": 1, + "total": 3 + }, + "data": [ + { + "id": "1", + "name": "Guest", + "code": "guest", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "3", + "name": "Wholesale", + "code": "wholesale", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Customer Group By ID + +To get the specific Customer Group, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query customerGroup { + customerGroup(id: 2) { + id + name + code + isUserDefined + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "customerGroup": { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + } + } + } + ~~~ +::: + +### 3. Get Filtered Customer Groups + +You can get the filter data from the Customer Groups by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query customerGroups { + customerGroups(input: { + code: "general" + }) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + code + isUserDefined + createdAt + updatedAt + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "customerGroups": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + } + ] + } + } + } + ~~~ +::: + +### 4. Create a new Customer Group + + To create a Customer Group, you have to perform mutation on Customer Group and paas the related fields in the request. + API call resource will create a new Customer Group, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createCustomerGroup { + createCustomerGroup(input: { + name: "VIP Group" + code: "vip" + isUserDefined: false + }) { + id + name + code + isUserDefined + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createCustomerGroup": { + "id": "4", + "name": "VIP Group", + "code": "vip", + "isUserDefined": false, + "createdAt": "2021-05-26 16:32:06", + "updatedAt": "2021-05-26 16:32:06" + } + } + } + ~~~ +::: + +### 5. Update Customer Group + +By using this API call you can update the Customer Group. To do this , you have to perform update mutation on Customer Group and paas the related fields in the request. +API call will update a Customer Group, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateCustomerGroup { + updateCustomerGroup(id: 4, input: { + name: "VIP Customers" + code: "vip" + isUserDefined: false + }) { + id + name + code + isUserDefined + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateCustomerGroup": { + "id": "4", + "name": "VIP Customers", + "code": "vip", + "isUserDefined": false, + "createdAt": "2021-05-26 16:32:06", + "updatedAt": "2021-05-26 16:33:57" + } + } + } + ~~~ +::: + +### 6. Delete a Customer Group + +To delete a Customer Group, you have to perform mutation on Customer Group by passing the id of that Customer Group. +API call will delete a Customer Group, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteCustomerGroup { + deleteCustomerGroup(id: 4) { + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteCustomerGroup": { + "success": "Customer group deleted successfully." + } + } + } + ~~~ +::: + +## Subscribers + +In this section, we will see all the APIs which are related to Subscribers. + +### 1. Get All Newsletter Subscribers + +You can get all the Newsletter Subscribers from the Bagisto store. You can achieve this job by using the `Newsletter Subscribers` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query newsletterSubscribers { + newsletterSubscribers { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + email + isSubscribed + token + channelId + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "newsletterSubscribers": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "email": "gagan@exmaple.com", + "isSubscribed": true, + "token": "60ae2f20a2b4e", + "channelId": 1, + "createdAt": "2021-05-26 16:51:08", + "updatedAt": "2021-05-26 16:51:08" + } + ] + } + } +} +~~~ +::: + +### 2. Get Newsletter Subscriber By ID + +To get the specific Newsletter Subscribers, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query newsletterSubscriber { + newsletterSubscriber(id: 1) { + id + email + isSubscribed + token + channelId + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "newsletterSubscriber": { + "id": "1", + "email": "gagan@exmaple.com", + "isSubscribed": true, + "token": "60ae2f20a2b4e", + "channelId": 1, + "createdAt": "2021-05-26 16:51:08", + "updatedAt": "2021-05-26 16:51:08" + } + } + } + ~~~ +::: + + +### 3. Add a new Newsletter Subscriber + + To add a Newsletter Subscriber, you have to perform mutation on Newsletter Subscriber and paas the related fields in the request. + API call resource will add a new Newsletter Subscriber, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation subscribe { + subscribe(input: { + email: "gagan1@exmaple.com" + }) { + email + isSubscribed + token + channelId + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "subscribe": { + "email": "gagan1@exmaple.com", + "isSubscribed": true, + "token": "60ae30df240a2", + "channelId": 1, + "createdAt": "2021-05-26 16:58:35", + "updatedAt": "2021-05-26 16:58:35" + } + } + } + ~~~ +::: + +### 4. unsubscribe a Newsletter Subscriber + +By using this API call you can unsubscribe the Newsletter Subscriber. To do this , you have to perform unsubscribe mutation on Newsletter Subscriber and paas the related fields in the request. +API call will unsubscribe a Newsletter Subscriber, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation unSubscribe { + unSubscribe(token: "60ae30df240a2") { + id + email + isSubscribed + token + channelId + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "unSubscribe": { + "id": "2", + "email": "gagan1@exmaple.com", + "isSubscribed": false, + "token": "60ae30df240a2", + "channelId": 1, + "createdAt": "2021-05-26 16:58:35", + "updatedAt": "2021-05-26 17:01:18" + } + } + } + ~~~ +::: + +### 5. Delete a Newsletter Subscriber + +To delete a Newsletter Subscriber, you have to perform mutation on Newsletter Subscriber by passing the id of that Newsletter Subscriber. +API call will delete a Newsletter Subscriber, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteSubscriber { + deleteSubscriber(email: "gagan1@exmaple.com") { + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteSubscriber": { + "success": "Subscriber deleted successfully." + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-admin-api/explanation.md b/docs/1.x/graphql-admin-api/explanation.md new file mode 100644 index 00000000..536008c9 --- /dev/null +++ b/docs/1.x/graphql-admin-api/explanation.md @@ -0,0 +1,78 @@ +# Explanation + +If you check all the sections in which we have used paginatorInfo, in all the responses, you will find that there are four objects key i.e. `count`, `currentPage`, and `lastPage` and `total`. In this section, we will explain all the four keys. + +Let's take an example of the user section, we have some response in which we got these four keys. + +~~~json +{ + "paginatorInfo": { + "count": {...}, + "currentPage": {...}, + "lastPage": {...}, + "total": {...} + }, +} +~~~ + +## 1. Count Object `count` + +In the count object key, you will find the count of many objects which represent the Bagisto admin users. + +## 2. CurrentPage Object `currentPage` + +In the currentPage object, you will find the current page number. + +## 3. lastPage Object `lastPage` + +`lastPage` object will only used with pagination. you will find the last page number. + +## 3. Total Object `total` + +`total` object will only used with pagination. you will find the total page number. + +By defining the page number you can get the data of that perticular page. + +Let's take an example of the user section, + +- Request +~~~query + query users{ + users(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + name + } + } + } + } +~~~ + +- Response + +~~~json + { + "data": { + "users": { + "paginatorInfo": { + "count": 2, + "currentPage": 1, + "lastPage": 1, + "total": 2 + }, + "data": [ + { + "id": "1", + "name": "Example", + } + ] + } + } + } +~~~ \ No newline at end of file diff --git a/docs/1.x/graphql-admin-api/getting-started-with-the-api.md b/docs/1.x/graphql-admin-api/getting-started-with-the-api.md new file mode 100644 index 00000000..7234175a --- /dev/null +++ b/docs/1.x/graphql-admin-api/getting-started-with-the-api.md @@ -0,0 +1,437 @@ +# Authentication + +[[toc]] + +## Introduction + +By default the [Bagisto](https://bagisto.com) GraphQL API makes use of the [JWT package](https://jwt.io/) for token-based authentication. + +So, let's try to authenticate the Admin by using **JWT**. Please send valid **User Agent** header in your request whether you are using postman, curl or some other clients. + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + + + +- Query + + ~~~query + mutation { + userLogin(input : { + email: "test@webkul.com" + password: "admin123" + }) + { + status + success + accessToken + tokenType + expiresIn + user { + id + name + email + password + apiToken + roleId + status + createdAt + updatedAt + } + } + } + ~~~ + +- Response + + - Once you send the request, you will get some random token string that will be used to access the API data. + + ~~~json + { + "data": { + "userLogin": { + "status": true, + "success": "Success: User login successfuly.", + "accessToken": "Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC9iYWdzYWFzLmNvbVwvZ3JhcGhxbCIsImlhdCI6MTYyMDA0NTYyMywiZXhwIjoxNjIwMDQ5MjIzLCJuYmYiOjE2MjAwNDU2MjMsImp0aSI6Ikc5M09uck53WVdxNVlPSHUiLCJzdWIiOjksInBydiI6ImQ5MDA0NmUwMDg0MmQ1ZDMzMjA2OTMyNmVmMzhlMzIyMTJmMDhlMTQifQ.uenKsESWx3qhdkB4jcTofmG9EegNhwvAN6KcMZG1GBs", + "tokenType": "Bearer", + "expiresIn": 3600, + "user": { + "id": "9", + "name": "admin test", + "email": "test@webkul.com", + "password": "$2y$10$Iasq3fDPQ14E4/ZCF.l6qOYkq0ODtdIrAiq3i7McMsBDBug7EyqgS", + "apiToken": null, + "roleId": 9, + "status": true, + "createdAt": "2021-02-23 13:47:20", + "updatedAt": "2021-02-23 13:47:20" + } + } + } + } + ~~~ + +## Get Users + +Once you are authenticated, try to access the current Admin data by using **JWT**, use the Single GraphQL API endpoint for this, + +::: tip + +Here we are just showing a example of how to collect data from the GraphQL API with the usage of a **JWT** token. + +::: + +#### Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +::: tip + +As you check the **JWT** authentication we got some token string, we just need to put that token in the request header. For e.g., + +~~~request-header + Accept:application/json + Authorization:Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9... +~~~ + +::: + +- Query + ~~~query + query users{ + users(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + name + email + password + apiToken + roleId + status + role{id} + createdAt + updatedAt + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "users": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "Example", + "email": "admin@example.com", + "password": "$2y$10$2wE6y44/8NLpL3oiEXb4F.YfcmBYI2SsDUn43eNKxKj7cNOffi5hu", + "apiToken": "VsB2TagdY8Ea2ZdCyr3MTliyGc5fDHNrWraMnjQt5MlYa0o6GdhU5sKZpYl73gHYXgWeljbjddLw22t9", + "roleId": 1, + "status": true, + "role": { + "id": "1" + }, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "success": null + } + ] + } + } +} +~~~ + +::: + +## Get User By ID + +To get the specific user, you have to pass an `id` on query .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Query + ~~~Query + query users{ + user(id:1){ + id + name + email + password + apiToken + roleId + status + role{id} + createdAt + updatedAt + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "user": { + "id": "1", + "name": "Example", + "email": "admin@example.com", + "password": "$2y$10$2wE6y44/8NLpL3oiEXb4F.YfcmBYI2SsDUn43eNKxKj7cNOffi5hu", + "apiToken": "VsB2TagdY8Ea2ZdCyr3MTliyGc5fDHNrWraMnjQt5MlYa0o6GdhU5sKZpYl73gHYXgWeljbjddLw22t9", + "roleId": 1, + "status": true, + "role": { + "id": "1" + }, + "createdAt": "2021-05-05 15:36:49", + "updatedAt": "2021-05-05 15:36:49", + "success": null + } + } + } + ~~~ + + ::: + + ## Create a new User + + To create a user, you have to perform mutation on users and paas users fields in the request. + API call resource will create a new user, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createUser(input:{ + name:"naresh" + email:"naresh.verma327@webkul.com" + password:"admin123" + passwordConfirmation:"admin123" + roleId:1 + status:true + }){ + id + name + email + password + apiToken + roleId + status + role{id} + createdAt + updatedAt + success + } + } + ~~~ + + ::: details Response + ~~~json + { + "data": { + "createUser": { + "id": "3", + "name": "naresh", + "email": "naresh.verma327@webkul.com", + "password": "$2y$10$zpAn6jjtD/22jDAPpzCeeuYVehzfuyOotdCZVD6ZxnP97t9jH7y3G", + "apiToken": "lPxwBwxUrwiEfLF2zSWdUHCD3BQt6CuqCGwBGW07wO0mvf7ROdoD5361bWVgHWtnnTIvrP9tsLzVyrM1", + "roleId": 1, + "status": true, + "role": { + "id": "1" + }, + "createdAt": "2021-05-05 17:32:54", + "updatedAt": "2021-05-05 17:32:54", + "success": null + } + } + } + ~~~ +::: + + ## Update a User + + To update a user, you have to perform mutation on users by passing the id of that user and users fields in the request query. + API call resource will create a new user, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateUser(id:3,input:{ + name:"nareshverma" + email:"naresh.verma327@webkul.com" + password:"admin123" + passwordConfirmation:"admin123" + roleId:1 + status:true + }) + { + id + name + email + password + apiToken + roleId + status + role{id} + createdAt + updatedAt + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateUser": { + "id": "3", + "name": "nareshverma", + "email": "naresh.verma327@webkul.com", + "password": "$2y$10$h/p4.yOWgLxKj3Twsc4IFek1KOnSeb.j8VWxRRB.D23rABz1pYP2y", + "apiToken": "lPxwBwxUrwiEfLF2zSWdUHCD3BQt6CuqCGwBGW07wO0mvf7ROdoD5361bWVgHWtnnTIvrP9tsLzVyrM1", + "roleId": 1, + "status": true, + "role": { + "id": "1" + }, + "createdAt": "2021-05-05 17:32:54", + "updatedAt": "2021-05-05 17:40:26", + "success": null + } + } + } + ~~~ +::: + +## Delete a User + +To delete a user, you have to perform mutation on users by passing the id of that user. +API call resource will create a new user, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteUser(id:3){ + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteUser": { + "success": "Admin deleted successfully." + } + } + } + ~~~ +::: + +## Logout + +You can logout the admin by performing the logout mutaion on user. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + + - Request Mutation + ~~~Mutation + mutation{ + userLogout{ + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "userLogout": { + "status": true, + "success": "Success: User logout successfully." + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-admin-api/installation.md b/docs/1.x/graphql-admin-api/installation.md new file mode 100644 index 00000000..6bffc471 --- /dev/null +++ b/docs/1.x/graphql-admin-api/installation.md @@ -0,0 +1,48 @@ + +# Installation: + +* You can clone the package from the GitHub [open-source headless laravel](https://bagisto.com/en/headless-ecommerce/) repository. + +~~~ +composer require bagisto/graphql-api dev-main +~~~ + +* Add the below-line inside the **modules** index in **config/concord.php** file: + +~~~ +\Webkul\GraphQLAPI\Providers\ModuleServiceProvider::class, +~~~ + +* Find a file **app/Http/Kernel.php** from root and add these two **middlewares** inside the **$middleware** array: + +~~~ +\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class, +\Illuminate\Session\Middleware\StartSession::class, +~~~ + +* Add the **JWT_TTL (JWT time to live)** & **JWT_SHOW_BLACKLIST_EXCEPTION** entries in the **.env** file: + +~~~ +JWT_TTL=525600 +JWT_SHOW_BLACKLIST_EXCEPTION=true +~~~ + +#### To install and publish the assests and configurations, run below command from the root in terminal: + +~~~ +php artisan bagisto-graphql:install +~~~ + +### Now to use the graphql-playground for testing the APIs: + +~~~ +http://your-domain.com/graphql-playground +~~~ + +### Or you can also use the Postmen for testing the APIs: + +~~~ +http://your-domain.com/graphql +~~~ + +> That's it, now just execute the project on your specified domain. diff --git a/docs/1.x/graphql-admin-api/products.md b/docs/1.x/graphql-admin-api/products.md new file mode 100644 index 00000000..28e79e67 --- /dev/null +++ b/docs/1.x/graphql-admin-api/products.md @@ -0,0 +1,9487 @@ +# Products + +In this section, we will see all the APIs which are related to Products. + +## Get All Products + +You can get all the Products from the Bagisto store. You can achieve this job by using the `Products` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: No need to pass the all fields with the request, Pass the fields that you want in response. + +- Query + ~~~query + query products { + products { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + attributeValues { + id + productId + attributeId + locale + channel + textValue + booleanValue + integerValue + floatValue + dateTimeValue + dateValue + jsonValue + attribute { + id + code + adminName + type + } + } + superAttributes { + id + code + adminName + type + position + } + categories { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + customerName + createdAt + updatedAt + } + groupedProducts { + id + qty + sortOrder + productId + associatedProductId + associatedProduct { + id + type + attributeFamilyId + sku + parentId + } + } + downloadableSamples { + id + url + file + fileName + type + sortOrder + productId + createdAt + updatedAt + translations { + id + locale + title + productDownloadableSampleId + } + } + downloadableLinks { + id + title + price + url + file + fileName + type + sampleUrl + sampleFile + sampleFileName + sampleType + sortOrder + productId + downloads + translations { + id + locale + title + productDownloadableLinkId + } + } + bundleOptions { + id + type + isRequired + sortOrder + productId + bundleOptionProducts { + id + qty + isUserDefined + sortOrder + isDefault + productBundleOptionId + productId + } + translations { + id + locale + label + productBundleOptionId + } + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "products": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "productFlats": [ + { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 4.5, + "maxPrice": 4.5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "variants": [], + "parent": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + ], + "variants": [], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "attributeValues": [ + { + "id": "1", + "productId": "1", + "attributeId": "9", + "locale": "en", + "channel": "default", + "textValue": "

testOutlet

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea" + } + }, + { + "id": "2", + "productId": "1", + "attributeId": "10", + "locale": "en", + "channel": "default", + "textValue": "

testOutlet

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea" + } + }, + { + "id": "3", + "productId": "1", + "attributeId": "1", + "locale": null, + "channel": null, + "textValue": "test-product", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text" + } + }, + { + "id": "4", + "productId": "1", + "attributeId": "2", + "locale": "en", + "channel": "default", + "textValue": "testOutlet", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text" + } + }, + { + "id": "5", + "productId": "1", + "attributeId": "3", + "locale": null, + "channel": null, + "textValue": "testoutlet", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text" + } + }, + { + "id": "6", + "productId": "1", + "attributeId": "4", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": 0, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select" + } + }, + { + "id": "7", + "productId": "1", + "attributeId": "5", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean" + } + }, + { + "id": "8", + "productId": "1", + "attributeId": "6", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean" + } + }, + { + "id": "9", + "productId": "1", + "attributeId": "7", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean" + } + }, + { + "id": "10", + "productId": "1", + "attributeId": "8", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean" + } + }, + { + "id": "11", + "productId": "1", + "attributeId": "23", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 1, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select" + } + }, + { + "id": "12", + "productId": "1", + "attributeId": "24", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 6, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select" + } + }, + { + "id": "13", + "productId": "1", + "attributeId": "26", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "26", + "code": "guest_checkout", + "adminName": "Guest Checkout", + "type": "boolean" + } + }, + { + "id": "14", + "productId": "1", + "attributeId": "27", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "27", + "code": "product_number", + "adminName": "Product Number", + "type": "text" + } + }, + { + "id": "15", + "productId": "1", + "attributeId": "16", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "16", + "code": "meta_title", + "adminName": "Meta Title", + "type": "textarea" + } + }, + { + "id": "16", + "productId": "1", + "attributeId": "17", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "17", + "code": "meta_keywords", + "adminName": "Meta Keywords", + "type": "textarea" + } + }, + { + "id": "17", + "productId": "1", + "attributeId": "18", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "18", + "code": "meta_description", + "adminName": "Meta Description", + "type": "textarea" + } + }, + { + "id": "18", + "productId": "1", + "attributeId": "11", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": 5, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price" + } + }, + { + "id": "19", + "productId": "1", + "attributeId": "12", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "12", + "code": "cost", + "adminName": "Cost", + "type": "price" + } + }, + { + "id": "20", + "productId": "1", + "attributeId": "13", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "13", + "code": "special_price", + "adminName": "Special Price", + "type": "price" + } + }, + { + "id": "21", + "productId": "1", + "attributeId": "14", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "14", + "code": "special_price_from", + "adminName": "Special Price From", + "type": "date" + } + }, + { + "id": "22", + "productId": "1", + "attributeId": "15", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "15", + "code": "special_price_to", + "adminName": "Special Price To", + "type": "date" + } + }, + { + "id": "23", + "productId": "1", + "attributeId": "19", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text" + } + }, + { + "id": "24", + "productId": "1", + "attributeId": "20", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text" + } + }, + { + "id": "25", + "productId": "1", + "attributeId": "21", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "21", + "code": "depth", + "adminName": "Depth", + "type": "text" + } + }, + { + "id": "26", + "productId": "1", + "attributeId": "22", + "locale": null, + "channel": null, + "textValue": "3", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "22", + "code": "weight", + "adminName": "Weight", + "type": "text" + } + } + ], + "superAttributes": [], + "categories": [], + "inventories": [ + { + "id": "1", + "qty": 3, + "productId": "1", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "2", + "qty": 0, + "productId": "1", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [], + "reviews": [], + "groupedProducts": [], + "downloadableSamples": [], + "downloadableLinks": [], + "bundleOptions": [], + "customerGroupPrices": [], + "booking": null + } + ] + } + } +} +~~~ +::: + +## Get Product By ID + +To get the specific Product, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can Pass all the fields of the above request. + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query product { + product(id: 1) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + customerName + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "catalogRule": { + "id": "1", + "name": "test rule", + "description": "test rule", + "startsFrom": "2021-05-25", + "endsTill": "2021-05-27", + "status": true, + "conditionType": true, + "conditions": "null", + "endOtherRules": true, + "actionType": "by_percent", + "discountAmount": 10, + "sortOrder": 1, + "createdAt": "2021-05-26 17:28:54", + "updatedAt": "2021-05-26 17:28:54", + "channels": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "locales": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$" + } + ], + "inventorySources": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null + }, + { + "id": "2", + "code": "newca", + "name": "nerty", + "description": "ajsyg", + "theme": "gdg", + "homePageContent": "fhg", + "footerContent": "fh", + "hostname": "http://bag1.com", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"gfyj\", \"meta_keywords\": \"gvgh\", \"meta_description\": \"gcg\"}", + "locales": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$" + } + ], + "inventorySources": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null + } + ], + "customerGroups": [ + { + "id": "1", + "name": "Guest", + "code": "guest", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "3", + "name": "Wholesale", + "code": "wholesale", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "4", + "name": "VIP Customers", + "code": "vip", + "isUserDefined": false, + "createdAt": "2021-05-26 16:32:06", + "updatedAt": "2021-05-26 16:33:57" + } + ], + "catalogRuleProducts": [], + "catalogRuleProductPrices": [] + } + } + } + ~~~ +::: + +### 3. Get Filtered Products + +You can get the filter data from the Products by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query products { + products(input:{ + type: "simple" + id: "1" + sku: "test-product" + },page:1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + customerName + createdAt + updatedAt + } + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "products": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "productFlats": [ + { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 4.5, + "maxPrice": 4.5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + ], + "inventories": [ + { + "id": "1", + "qty": 3, + "productId": "1", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "2", + "qty": 0, + "productId": "1", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [], + "reviews": [] + } + ] + } + } + } + ~~~ +::: + + +### 4. Delete a Product + +To delete a Product, you have to perform mutation on Product by passing the id of that Product. +API call will delete a Product, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteProduct { + deleteProduct(id: 2) { + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteProduct": { + "success": "Product deleted successfully." + } + } + } + ~~~ +::: + +## Simple Products + +In this section, we will see all the APIs which are related to Simple Products. + +### 1. Create a new Simple Product + + To create a Simple Product, you have to perform mutation on Product and paas the related fields in the request. + API call resource will create a new Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "simple" + attributeFamilyId: 1 + sku: "men-cloths" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + attributeValues { + id + productId + attributeId + locale + channel + textValue + booleanValue + integerValue + floatValue + dateTimeValue + dateValue + jsonValue + attribute { + id + code + adminName + type + } + } + superAttributes { + id + code + adminName + type + position + } + categories { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + customerName + createdAt + updatedAt + } + groupedProducts { + id + qty + sortOrder + productId + associatedProductId + associatedProduct { + id + type + attributeFamilyId + sku + parentId + } + } + downloadableSamples { + id + url + file + fileName + type + sortOrder + productId + createdAt + updatedAt + translations { + id + locale + title + productDownloadableSampleId + } + } + downloadableLinks { + id + title + price + url + file + fileName + type + sampleUrl + sampleFile + sampleFileName + sampleType + sortOrder + productId + downloads + translations { + id + locale + title + productDownloadableLinkId + } + } + bundleOptions { + id + type + isRequired + sortOrder + productId + bundleOptionProducts { + id + qty + isUserDefined + sortOrder + isDefault + productBundleOptionId + productId + } + translations { + id + locale + label + productBundleOptionId + } + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "2", + "type": "simple", + "attributeFamilyId": 1, + "sku": "men-cloths", + "parentId": null, + "productFlats": [ + { + "id": "2", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "2", + "parentId": null, + "minPrice": null, + "maxPrice": null, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-26 20:55:15", + "updatedAt": "2021-05-26 20:55:15" + } + ], + "variants": [], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "attributeValues": [], + "superAttributes": [], + "categories": [], + "inventories": [], + "images": [], + "orderedInventories": [], + "reviews": [], + "groupedProducts": [], + "downloadableSamples": [], + "downloadableLinks": [], + "bundleOptions": [], + "customerGroupPrices": [], + "booking": null + } + } + } + ~~~ +::: + +### 2. Update Product + +By using this API call you can update the Product. To do this , you have to perform update mutation on Product and paas the related fields in the request. +API call will update a Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds with request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 2, input: { + channel: "default" + locale: "en" + sku: "men-cloths" + name: "Men Cloths" + urlKey: "men-cloths" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + width: 30 + height: 24 + depth: 11 + weight: 5.20 + customerGroupPrices: [{ + customerGroupId: 2 + qty: 2 + valueType: "fixed" + value: 10 + }, { + customerGroupId: 3 + qty: 3 + valueType: "discount" + value: 2 + }] + inventories: [{ + inventorySourceId: 1 + qty: 111 + }, { + inventorySourceId: 2 + qty: 222 + }] + categories: 1 + channels: [1] + upSell: [1] + images: [ + "http://graphqlnew.com/themes/velocity/assets/images/banner.png", + "http://graphqlnew.com/themes/velocity/assets/images/kids.png", + "http://graphqlnew.com/themes/velocity/assets/images/headphones.png" + ] + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + customerName + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "2", + "type": "simple", + "attributeFamilyId": 1, + "sku": "men-cloths", + "parentId": null, + "productFlats": [ + { + "id": "2", + "sku": "men-cloths", + "name": "Men Cloths", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "men-cloths", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "2", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "createdAt": "2021-05-26 20:55:15", + "updatedAt": "2021-05-26 20:55:15" + } + ], + "inventories": [ + { + "id": "3", + "qty": 111, + "productId": "2", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "4", + "qty": 222, + "productId": "2", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [], + "reviews": [] + } + } + } + ~~~ +::: + + +## Configurable Products + +In this section, we will see all the APIs which are related to Configurable Products. + +### 1. Create a new Configurable Product + + To create a Configurable Product, you have to perform mutation on Configurable Product and paas the related fields in the request. + API call resource will create a new Configurable Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "configurable" + attributeFamilyId: 1 + sku: "home-decor-2" + # use super_attributes and family index in configurable type product only + superAttributes: [{ + attributeCode: "color" + values: [1, 2] + }, { + attributeCode: "size" + values: [6] + }] + family: 1 + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + attributeValues { + id + productId + attributeId + locale + channel + textValue + booleanValue + integerValue + floatValue + dateTimeValue + dateValue + jsonValue + attribute { + id + code + adminName + type + } + } + superAttributes { + id + code + adminName + type + position + } + categories { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + customerName + createdAt + updatedAt + } + groupedProducts { + id + qty + sortOrder + productId + associatedProductId + associatedProduct { + id + type + attributeFamilyId + sku + parentId + } + } + downloadableSamples { + id + url + file + fileName + type + sortOrder + productId + createdAt + updatedAt + translations { + id + locale + title + productDownloadableSampleId + } + } + downloadableLinks { + id + title + price + url + file + fileName + type + sampleUrl + sampleFile + sampleFileName + sampleType + sortOrder + productId + downloads + translations { + id + locale + title + productDownloadableLinkId + } + } + bundleOptions { + id + type + isRequired + sortOrder + productId + bundleOptionProducts { + id + qty + isUserDefined + sortOrder + isDefault + productBundleOptionId + productId + } + translations { + id + locale + label + productBundleOptionId + } + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "3", + "type": "configurable", + "attributeFamilyId": 1, + "sku": "home-decor-2", + "parentId": null, + "productFlats": [ + { + "id": "3", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "3", + "parentId": null, + "minPrice": 0, + "maxPrice": null, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [ + { + "id": "4", + "sku": "home-decor-2-variant-1-6", + "name": "", + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": true, + "visibleIndividually": null, + "thumbnail": null, + "price": 0, + "locale": "en", + "channel": "default", + "productId": "4", + "parentId": 3 + }, + { + "id": "5", + "sku": "home-decor-2-variant-2-6", + "name": "", + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": true, + "visibleIndividually": null, + "thumbnail": null, + "price": 0, + "locale": "en", + "channel": "default", + "productId": "5", + "parentId": 3 + } + ], + "parent": null, + "createdAt": "2021-05-27 10:40:11", + "updatedAt": "2021-05-27 10:40:11" + } + ], + "variants": [ + { + "id": "4", + "type": "simple", + "attributeFamilyId": 1, + "sku": "home-decor-2-variant-1-6", + "parentId": "3" + }, + { + "id": "5", + "type": "simple", + "attributeFamilyId": 1, + "sku": "home-decor-2-variant-2-6", + "parentId": "3" + } + ], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "attributeValues": [], + "superAttributes": [ + { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select", + "position": 26 + }, + { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select", + "position": 27 + } + ], + "categories": [], + "inventories": [], + "images": [], + "orderedInventories": [], + "reviews": [], + "groupedProducts": [], + "downloadableSamples": [], + "downloadableLinks": [], + "bundleOptions": [], + "customerGroupPrices": [], + "booking": null + } + } + } + ~~~ +::: + +### 2. Update Configurable Product + +By using this API call you can update the Configurable Product. To do this , you have to perform update mutation on Configurable Product and paas the related fields in the request. +API call will update a Configurable Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 3, input: { + channel: "default" + locale: "en" + sku: "home-decor-2" + name: "Home Decor-2" + urlKey: "home-decor-2" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + width: 30 + height: 24 + depth: 11 + weight: 5.20 + customerGroupPrices: [{ + customerGroupId: 2 + qty: 2 + valueType: "fixed" + value: 10 + }, { + customerGroupId: 3 + qty: 3 + valueType: "discount" + value: 2 + }] + inventories: [{ + inventorySourceId: 1 + qty: 111 + }, { + inventorySourceId: 2 + qty: 222 + }] + channels: [1] + upSell: [1] + images: [ + "http://graphqlnew.com/themes/velocity/assets/images/banner.png", + "http://graphqlnew.com/themes/velocity/assets/images/kids.png", + "http://graphqlnew.com/themes/velocity/assets/images/headphones.png" + ] + # variants index passed only in case of configurable type product + variants: [{ + variantId: 4 + sku: "home-decor-1-variant-1-6" + name: "Red-S" + color: 1 + size: 6 + inventories: [{ + inventorySourceId: 1 + qty: 111 + }, { + inventorySourceId: 2 + qty: 222 + }] + price: 10.0000 + weight: 1 + status: true + }, { + variantId: 5 + sku: "home-decor-1-variant-2-6" + name: "Green-S" + color: 2 + size: 6 + inventories: [{ + inventorySourceId: 1 + qty: 23 + }, { + inventorySourceId: 2 + qty: 32 + }] + price: 7.5000 + weight: 1.45 + status: true + }] + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + attributeValues { + id + productId + attributeId + locale + channel + textValue + booleanValue + integerValue + floatValue + dateTimeValue + dateValue + jsonValue + attribute { + id + code + adminName + type + } + } + superAttributes { + id + code + adminName + type + position + } + categories { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + customerName + createdAt + updatedAt + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "3", + "type": "configurable", + "attributeFamilyId": 1, + "sku": "home-decor-2", + "parentId": null, + "productFlats": [ + { + "id": "3", + "sku": "home-decor-2", + "name": "Home Decor-2", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "home-decor-2", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "3", + "parentId": null, + "minPrice": 0, + "maxPrice": 0, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "variants": [ + { + "id": "4", + "sku": "home-decor-1-variant-1-6", + "name": "Red-S", + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": true, + "visibleIndividually": null, + "thumbnail": null, + "price": 10, + "locale": "en", + "channel": "default", + "productId": "4", + "parentId": 3 + }, + { + "id": "5", + "sku": "home-decor-1-variant-2-6", + "name": "Green-S", + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": true, + "visibleIndividually": null, + "thumbnail": null, + "price": 7.5, + "locale": "en", + "channel": "default", + "productId": "5", + "parentId": 3 + } + ], + "parent": null, + "createdAt": "2021-05-27 10:40:11", + "updatedAt": "2021-05-27 10:40:11" + } + ], + "variants": [ + { + "id": "4", + "type": "simple", + "attributeFamilyId": 1, + "sku": "home-decor-1-variant-1-6", + "parentId": "3" + }, + { + "id": "5", + "type": "simple", + "attributeFamilyId": 1, + "sku": "home-decor-1-variant-2-6", + "parentId": "3" + } + ], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "attributeValues": [ + { + "id": "76", + "productId": "3", + "attributeId": "9", + "locale": "en", + "channel": "default", + "textValue": "

Home Decor Short Description

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea" + } + }, + { + "id": "77", + "productId": "3", + "attributeId": "10", + "locale": "en", + "channel": "default", + "textValue": "

Home Decor Description

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea" + } + }, + { + "id": "78", + "productId": "3", + "attributeId": "1", + "locale": null, + "channel": null, + "textValue": "home-decor-2", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text" + } + }, + { + "id": "79", + "productId": "3", + "attributeId": "2", + "locale": "en", + "channel": "default", + "textValue": "Home Decor-2", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text" + } + }, + { + "id": "80", + "productId": "3", + "attributeId": "3", + "locale": null, + "channel": null, + "textValue": "home-decor-2", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text" + } + }, + { + "id": "81", + "productId": "3", + "attributeId": "4", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": 1, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select" + } + }, + { + "id": "82", + "productId": "3", + "attributeId": "5", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean" + } + }, + { + "id": "83", + "productId": "3", + "attributeId": "6", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean" + } + }, + { + "id": "84", + "productId": "3", + "attributeId": "7", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean" + } + }, + { + "id": "85", + "productId": "3", + "attributeId": "8", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean" + } + }, + { + "id": "86", + "productId": "3", + "attributeId": "23", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 3, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select" + } + }, + { + "id": "87", + "productId": "3", + "attributeId": "24", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 9, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select" + } + }, + { + "id": "88", + "productId": "3", + "attributeId": "26", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "26", + "code": "guest_checkout", + "adminName": "Guest Checkout", + "type": "boolean" + } + }, + { + "id": "89", + "productId": "3", + "attributeId": "16", + "locale": "en", + "channel": "default", + "textValue": "Home Decor Meta Title", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "16", + "code": "meta_title", + "adminName": "Meta Title", + "type": "textarea" + } + }, + { + "id": "90", + "productId": "3", + "attributeId": "17", + "locale": "en", + "channel": "default", + "textValue": "Home Decor Meta Keywords", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "17", + "code": "meta_keywords", + "adminName": "Meta Keywords", + "type": "textarea" + } + }, + { + "id": "91", + "productId": "3", + "attributeId": "18", + "locale": "en", + "channel": "default", + "textValue": "Home Decor Meta Description", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "18", + "code": "meta_description", + "adminName": "Meta Description", + "type": "textarea" + } + }, + { + "id": "92", + "productId": "3", + "attributeId": "11", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": 12.55, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price" + } + }, + { + "id": "93", + "productId": "3", + "attributeId": "12", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": 11.5, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "12", + "code": "cost", + "adminName": "Cost", + "type": "price" + } + }, + { + "id": "94", + "productId": "3", + "attributeId": "13", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": 11.3, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "13", + "code": "special_price", + "adminName": "Special Price", + "type": "price" + } + }, + { + "id": "95", + "productId": "3", + "attributeId": "14", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": "2021-02-08", + "jsonValue": null, + "attribute": { + "id": "14", + "code": "special_price_from", + "adminName": "Special Price From", + "type": "date" + } + }, + { + "id": "96", + "productId": "3", + "attributeId": "15", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": "2021-02-28", + "jsonValue": null, + "attribute": { + "id": "15", + "code": "special_price_to", + "adminName": "Special Price To", + "type": "date" + } + }, + { + "id": "97", + "productId": "3", + "attributeId": "19", + "locale": null, + "channel": null, + "textValue": "30", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text" + } + }, + { + "id": "98", + "productId": "3", + "attributeId": "20", + "locale": null, + "channel": null, + "textValue": "24", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text" + } + }, + { + "id": "99", + "productId": "3", + "attributeId": "21", + "locale": null, + "channel": null, + "textValue": "11", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "21", + "code": "depth", + "adminName": "Depth", + "type": "text" + } + }, + { + "id": "100", + "productId": "3", + "attributeId": "22", + "locale": null, + "channel": null, + "textValue": "5.2", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "22", + "code": "weight", + "adminName": "Weight", + "type": "text" + } + } + ], + "superAttributes": [ + { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select", + "position": 26 + }, + { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select", + "position": 27 + } + ], + "categories": [], + "inventories": [ + { + "id": "5", + "qty": 111, + "productId": "3", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "6", + "qty": 222, + "productId": "3", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [], + "reviews": [], + "customerGroupPrices": [ + { + "id": "9", + "qty": 2, + "valueType": "fixed", + "value": 10, + "productId": "3", + "customerGroupId": "2", + "createdAt": "2021-05-27 11:35:35", + "updatedAt": "2021-05-27 11:35:35" + }, + { + "id": "10", + "qty": 3, + "valueType": "discount", + "value": 2, + "productId": "3", + "customerGroupId": "3", + "createdAt": "2021-05-27 11:35:35", + "updatedAt": "2021-05-27 11:35:35" + } + ], + } + } + } + ~~~ +::: + +## Virtual Products + +In this section, we will see all the APIs which are related to Virtual Products. + +### 1. Create a new Virtual Product + + To create a Virtual Product, you have to perform mutation on Virtual Product and paas the related fields in the request. + API call resource will create a new Virtual Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "virtual" + attributeFamilyId: 1 + sku: "virtual-demo" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "6", + "type": "virtual", + "attributeFamilyId": 1, + "sku": "virtual-demo", + "parentId": null, + "productFlats": [ + { + "id": "6", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "6", + "parentId": null, + "minPrice": null, + "maxPrice": null, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 12:07:19", + "updatedAt": "2021-05-27 12:07:19" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [], + "images": [], + "orderedInventories": [], + "reviews": [], + "customerGroupPrices": [], + } + } + } + ~~~ +::: + +### 2. Update Virtual Product + +By using this API call you can update the Virtual Product. To do this , you have to perform update mutation on Virtual Product and paas the related fields in the request. +API call will update a Virtual Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 6, input: { + channel: "default" + locale: "en" + sku: "virtual-demo" + name: "Online Tuition Classes" + urlKey: "online-tuition-classes" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 0 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + customerGroupPrices: [{ + customerGroupId: null + qty: 2 + valueType: "fixed" + value: 5 + }] + inventories: [{ + inventorySourceId: 1 + qty: 111 + }, { + inventorySourceId: 2 + qty: 222 + }] + channels: [1] + upSell: 1 + images: [ + "https://cdn.pixabay.com/photo/2021/02/01/12/28/fisherman-5970480_960_720.jpg", + "http://graphqlnew.com/themes/velocity/assets/images/kids.png", + "http://graphqlnew.com/themes/velocity/assets/images/headphones.png" + ] + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "6", + "type": "virtual", + "attributeFamilyId": 1, + "sku": "virtual-demo", + "parentId": null, + "productFlats": [ + { + "id": "6", + "sku": "virtual-demo", + "name": "Online Tuition Classes", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "online-tuition-classes", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 0, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": null, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "6", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 12:07:19", + "updatedAt": "2021-05-27 12:07:19" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [ + { + "id": "11", + "qty": 111, + "productId": "6", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "12", + "qty": 222, + "productId": "6", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [ + { + "id": "2", + "type": null, + "path": "product/6/fisherman-5970480_960_720.jpg", + "productId": "6" + } + ], + "orderedInventories": [], + "customerGroupPrices": [ + { + "id": "12", + "qty": 2, + "valueType": "fixed", + "value": 5, + "productId": "6", + "customerGroupId": null, + "createdAt": "2021-05-27 12:17:34", + "updatedAt": "2021-05-27 12:17:34" + } + ] + } + } + ~~~ +::: + +## Grouped Products + +In this section, we will see all the APIs which are related to Grouped Products. + +### 1. Create a new Grouped Product + + To create a Grouped Product, you have to perform mutation on Grouped Product and paas the related fields in the request. + API call resource will create a new Grouped Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "grouped" + attributeFamilyId: 1 + sku: "grouped-demo" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + images { + id + type + path + productId + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "7", + "type": "grouped", + "attributeFamilyId": 1, + "sku": "grouped-demo", + "parentId": null, + "productFlats": [ + { + "id": "7", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "7", + "parentId": null, + "minPrice": 0, + "maxPrice": 0, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 12:29:56", + "updatedAt": "2021-05-27 12:29:56" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "images": [], + } + } + } + ~~~ +::: + +### 2. Update Grouped Product + +By using this API call you can update the Grouped Product. To do this , you have to perform update mutation on Grouped Product and paas the related fields in the request. +API call will update a Grouped Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 7, input: { + channel: "default" + locale: "en" + sku: "grouped-demo" + name: "Phone Accessories" + urlKey: "phone-accessories" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 0 + links: [{ + associatedProductId: 1 + qty: 3 + sortOrder: 0 + }] + channels: [1] + upSell: 1 + images: [ + "https://cdn.pixabay.com/photo/2016/12/19/08/39/mobile-phone-1917737_960_720.jpg", + "https://cdn.pixabay.com/photo/2014/08/05/10/27/iphone-410311_960_720.jpg" + ] + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + groupedProducts { + id + qty + sortOrder + productId + associatedProductId + associatedProduct { + id + type + attributeFamilyId + sku + parentId + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "7", + "type": "grouped", + "attributeFamilyId": 1, + "sku": "grouped-demo", + "parentId": null, + "productFlats": [ + { + "id": "7", + "sku": "grouped-demo", + "name": "Phone Accessories", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "phone-accessories", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 0, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "7", + "parentId": null, + "minPrice": 4.5, + "maxPrice": 4.5, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 12:29:56", + "updatedAt": "2021-05-27 12:29:56" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [], + "images": [ + { + "id": "5", + "type": null, + "path": "product/7/mobile-phone-1917737_960_720.jpg", + "productId": "7" + }, + { + "id": "6", + "type": null, + "path": "product/7/iphone-410311_960_720.jpg", + "productId": "7" + } + ], + "orderedInventories": [], + "groupedProducts": [ + { + "id": "4", + "qty": 3, + "sortOrder": 0, + "productId": "7", + "associatedProductId": "1", + "associatedProduct": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null + } + } + ] + } + } + ~~~ +::: + +## Downloadable Products + +In this section, we will see all the APIs which are related to Downloadable Products. + +### 1. Create a new Downloadable Product + + To create a Downloadable Product, you have to perform mutation on Downloadable Product and paas the related fields in the request. + API call resource will create a new Downloadable Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "downloadable" + attributeFamilyId: 1 + sku: "e-book" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "8", + "type": "downloadable", + "attributeFamilyId": 1, + "sku": "e-book", + "parentId": null, + "productFlats": [ + { + "id": "8", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "8", + "parentId": null, + "minPrice": null, + "maxPrice": null, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 12:52:39", + "updatedAt": "2021-05-27 12:52:39" + } + ] + } + } + } + ~~~ +::: + +### 2. Update Downloadable Product + +By using this API call you can update the Downloadable Product. To do this , you have to perform update mutation on Downloadable Product and paas the related fields in the request. +API call will update a Downloadable Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 8, input: { + channel: "default" + locale: "en" + sku: "e-book" + name: "e-book" + urlKey: "e-book" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + width: 30 + height: 24 + depth: 11 + weight: 5.20 + customerGroupPrices: [{ + customerGroupId: 2 + qty: 2 + valueType: "fixed" + value: 10 + }, { + customerGroupId: 3 + qty: 3 + valueType: "discount" + value: 2 + }] + inventories: [{ + inventorySourceId: 1 + qty: 111 + }, { + inventorySourceId: 2 + qty: 222 + }] + channels: [1] + images: [ + "https://cdn.pixabay.com/photo/2015/05/07/11/02/guitar-756326_960_720.jpg" + ] + downloadableLinks: [{ + locales: { + code: "en" + title: "Link 1" + } + price: 2 + type: "url" + url: "https://cdn.pixabay.com/photo/2015/07/14/12/46/hot-air-balloon-844872__340.jpg" + sampleType: "url" + sampleUrl: "https://cdn.pixabay.com/photo/2019/12/17/13/11/manipulation-4701594__340.jpg" + downloads: 5 + sortOrder: 0 + }, { + locales: { + code: "en" + title: "Link 2" + } + price: 4 + type: "url" + url: "https://cdn.pixabay.com/photo/2015/01/20/13/13/ipad-605439_960_720.jpg" + sampleType: "url" + sampleUrl: "https://cdn.pixabay.com/photo/2015/05/07/11/02/guitar-756326_960_720.jpg" + downloads: 8 + sortOrder: 1 + }, { + locales: { + code: "en" + title: "Link 3" + } + price: 6 + type: "url" + url: "https://cdn.pixabay.com/photo/2021/02/01/13/37/cars-5970663_960_720.png" + sampleType: "url" + sampleUrl: "" + downloads: 3 + sortOrder: 2 + }] + downloadableSamples: [{ + locales: { + code: "en" + title: "Sample 1" + } + type: "url" + url: "https://cdn.pixabay.com/photo/2015/06/08/15/09/photography-801891_960_720.jpg" + sortOrder: 0 + }] + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + downloadableSamples { + id + url + file + fileName + type + sortOrder + productId + createdAt + updatedAt + translations { + id + locale + title + productDownloadableSampleId + } + } + downloadableLinks { + id + title + price + url + file + fileName + type + sampleUrl + sampleFile + sampleFileName + sampleType + sortOrder + productId + downloads + translations { + id + locale + title + productDownloadableLinkId + } + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "8", + "type": "downloadable", + "attributeFamilyId": 1, + "sku": "e-book", + "parentId": null, + "productFlats": [ + { + "id": "8", + "sku": "e-book", + "name": "e-book", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "e-book", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "8", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 12:52:39", + "updatedAt": "2021-05-27 12:52:39" + } + ], + "variants": [], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [ + { + "id": "13", + "qty": 111, + "productId": "8", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "14", + "qty": 222, + "productId": "8", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [ + { + "id": "8", + "type": null, + "path": "product/8/guitar-756326_960_720.jpg", + "productId": "8" + } + ], + "orderedInventories": [], + "downloadableSamples": [ + { + "id": "2", + "url": "https://cdn.pixabay.com/photo/2015/06/08/15/09/photography-801891_960_720.jpg", + "file": null, + "fileName": null, + "type": "url", + "sortOrder": 0, + "productId": "8", + "createdAt": "2021-05-27 13:04:03", + "updatedAt": "2021-05-27 13:04:03", + "translations": [ + { + "id": "2", + "locale": "en", + "title": "Sample 1", + "productDownloadableSampleId": "2" + } + ] + } + ], + "downloadableLinks": [ + { + "id": "4", + "title": "Link 3", + "price": 6, + "url": "https://cdn.pixabay.com/photo/2021/02/01/13/37/cars-5970663_960_720.png", + "file": null, + "fileName": null, + "type": "url", + "sampleUrl": "", + "sampleFile": null, + "sampleFileName": null, + "sampleType": "url", + "sortOrder": 2, + "productId": "8", + "downloads": 3, + "translations": [ + { + "id": "4", + "locale": "en", + "title": "Link 3", + "productDownloadableLinkId": "4" + } + ] + }, + { + "id": "5", + "title": "Link 2", + "price": 4, + "url": "https://cdn.pixabay.com/photo/2015/01/20/13/13/ipad-605439_960_720.jpg", + "file": null, + "fileName": null, + "type": "url", + "sampleUrl": "https://cdn.pixabay.com/photo/2015/05/07/11/02/guitar-756326_960_720.jpg", + "sampleFile": null, + "sampleFileName": null, + "sampleType": "url", + "sortOrder": 1, + "productId": "8", + "downloads": 8, + "translations": [ + { + "id": "5", + "locale": "en", + "title": "Link 2", + "productDownloadableLinkId": "5" + } + ] + } + ], + "customerGroupPrices": [ + { + "id": "15", + "qty": 2, + "valueType": "fixed", + "value": 10, + "productId": "8", + "customerGroupId": "2", + "createdAt": "2021-05-27 13:04:03", + "updatedAt": "2021-05-27 13:04:03" + }, + { + "id": "16", + "qty": 3, + "valueType": "discount", + "value": 2, + "productId": "8", + "customerGroupId": "3", + "createdAt": "2021-05-27 13:04:03", + "updatedAt": "2021-05-27 13:04:03" + } + ] + } + } + } + ~~~ +::: + +## Bundle Products + +In this section, we will see all the APIs which are related to Bundle Products. + +### 1. Create a new Bundle Product + + To create a Bundle Product, you have to perform mutation on Bundle Product and paas the related fields in the request. + API call resource will create a new Bundle Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "bundle" + attributeFamilyId: 1 + sku: "bundle-demo" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + bundleOptions { + id + type + isRequired + sortOrder + productId + bundleOptionProducts { + id + qty + isUserDefined + sortOrder + isDefault + productBundleOptionId + productId + } + translations { + id + locale + label + productBundleOptionId + } + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "9", + "type": "bundle", + "attributeFamilyId": 1, + "sku": "bundle-demo", + "parentId": null, + "productFlats": [ + { + "id": "9", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "9", + "parentId": null, + "minPrice": 0, + "maxPrice": 0, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 13:11:58", + "updatedAt": "2021-05-27 13:11:58" + } + ], + "variants": [], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "groupedProducts": [], + } + } + } + ~~~ +::: + +### 2. Update Bundle Product + +By using this API call you can update the Bundle Product. To do this , you have to perform update mutation on Bundle Product and paas the related fields in the request. +API call will update a Bundle Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 9, input: { + channel: "default" + locale: "en" + sku: "bundle-demo" + name: "Bundle Box" + urlKey: "bundle-demo" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + width: 30 + height: 24 + depth: 11 + weight: 5.20 + customerGroupPrices: [{ + customerGroupId: 2 + qty: 2 + valueType: "fixed" + value: 10 + }, { + customerGroupId: 3 + qty: 3 + valueType: "discount" + value: 2 + }] + inventories: [{ + inventorySourceId: 1 + qty: 111 + }, { + inventorySourceId: 2 + qty: 222 + }] + channels: [1] + upSell: 1 + images: [ + "https://cdn.pixabay.com/photo/2021/02/01/13/37/cars-5970663_960_720.png" + ] + bundleOptions: [{ + locales: { + code: "en" + label: "Select 1" + } + type: "select" + isRequired: true + sortOrder: 0 + products: [{ + isDefault: true + productId: 1 + qty: 1 + sortOrder: 1 + }] + }, { + + locales: { + code: "en" + label: "Radio 1" + } + type: "radio" + isRequired: true + sortOrder: 1 + products: [{ + productId: 1 + qty: 2 + sortOrder: 1 + }] + }, { + locales: { + code: "en" + label: "Checkbox 1" + } + type: "checkbox" + isRequired: false + sortOrder: 3 + products: [{ + productId: 1 + qty: 4 + sortOrder: 2 + }] + }, { + locales: { + code: "en" + label: "Multi Select 1" + } + type: "multiselect" + isRequired: true + sortOrder: 4 + products: [{ + productId: 1 + qty: 1 + sortOrder: 3 + }] + }] + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + bundleOptions { + id + type + isRequired + sortOrder + productId + bundleOptionProducts { + id + qty + isUserDefined + sortOrder + isDefault + productBundleOptionId + productId + } + translations { + id + locale + label + productBundleOptionId + } + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "9", + "type": "bundle", + "attributeFamilyId": 1, + "sku": "bundle-demo", + "parentId": null, + "productFlats": [ + { + "id": "9", + "sku": "bundle-demo", + "name": "Bundle Box", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "bundle-demo", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "9", + "parentId": null, + "minPrice": 13.5, + "maxPrice": 31.5, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 13:11:58", + "updatedAt": "2021-05-27 13:11:58" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [ + { + "id": "15", + "qty": 111, + "productId": "9", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "16", + "qty": 222, + "productId": "9", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [ + { + "id": "10", + "type": null, + "path": "product/9/cars-5970663_960_720.png", + "productId": "9" + } + ], + "orderedInventories": [], + "bundleOptions": [ + { + "id": "10", + "type": "checkbox", + "isRequired": false, + "sortOrder": 3, + "productId": "9", + "bundleOptionProducts": [ + { + "id": "14", + "qty": 4, + "isUserDefined": true, + "sortOrder": 2, + "isDefault": false, + "productBundleOptionId": "10", + "productId": "1" + } + ], + "translations": [ + { + "id": "10", + "locale": "en", + "label": "Checkbox 1", + "productBundleOptionId": "10" + } + ] + }, + { + "id": "11", + "type": "radio", + "isRequired": true, + "sortOrder": 1, + "productId": "9", + "bundleOptionProducts": [ + { + "id": "15", + "qty": 2, + "isUserDefined": true, + "sortOrder": 1, + "isDefault": true, + "productBundleOptionId": "11", + "productId": "1" + } + ], + "translations": [ + { + "id": "11", + "locale": "en", + "label": "Radio 1", + "productBundleOptionId": "11" + } + ] + }, + { + "id": "12", + "type": "multiselect", + "isRequired": true, + "sortOrder": 4, + "productId": "9", + "bundleOptionProducts": [ + { + "id": "16", + "qty": 1, + "isUserDefined": true, + "sortOrder": 3, + "isDefault": true, + "productBundleOptionId": "12", + "productId": "1" + } + ], + "translations": [ + { + "id": "12", + "locale": "en", + "label": "Multi Select 1", + "productBundleOptionId": "12" + } + ] + } + ], + "customerGroupPrices": [ + { + "id": "29", + "qty": 2, + "valueType": "fixed", + "value": 10, + "productId": "9", + "customerGroupId": "2", + "createdAt": "2021-05-27 13:37:23", + "updatedAt": "2021-05-27 13:37:23" + }, + { + "id": "30", + "qty": 3, + "valueType": "discount", + "value": 2, + "productId": "9", + "customerGroupId": "3", + "createdAt": "2021-05-27 13:37:23", + "updatedAt": "2021-05-27 13:37:23" + } + ] + } + } + } + ~~~ +::: + +## Booking Products + +In this section, we will see all the APIs which are related to Booking Products. + +### 1. Create a new Booking Product + + To create a Booking Product, you have to perform mutation on Booking Product and paas the related fields in the request. + API call resource will create a new Booking Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "booking" + attributeFamilyId: 1 + sku: "appointment-booking1" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + orderedInventories { + id + qty + productId + channelId + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "11", + "type": "booking", + "attributeFamilyId": 1, + "sku": "appointment-booking1", + "parentId": null, + "productFlats": [ + { + "id": "11", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "11", + "parentId": null, + "minPrice": null, + "maxPrice": null, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 15:32:06", + "updatedAt": "2021-05-27 15:32:06" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "orderedInventories": [], + "booking": null + } + } + } + ~~~ +::: + +### 2. Update Default Booking Product + +By using this API call you can update the Default Booking Product. To do this , you have to perform update mutation on Default Booking Product and paas the related fields in the request. +API call will update a Default Booking Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 11, input: { + channel: "default" + locale: "en" + sku: "booking-prod" + name: "Appointment" + urlKey: "appointment" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + width: 30 + height: 24 + depth: 11 + weight: 5.20 + customerGroupPrices: [{ + customerGroupId: 2 + qty: 2 + valueType: "fixed" + value: 10 + }, { + customerGroupId: 3 + qty: 3 + valueType: "discount" + value: 2 + }] + channels: [1] + images: [ + "https://cdn.pixabay.com/photo/2015/11/03/08/58/meeting-1019875_960_720.jpg" + ] + booking: { + type: "default" + location: "Noida" + qty: 120 + availableFrom: "2021-02-10 12:00:00" + availableTo: "2021-02-28 12:00:00" + bookingType: "one" + slots: [{ + fromDay: 1 + from: "09:00" + toDay: 5 + to: "12:00" + }, { + fromDay: 1 + from: "12:30" + toDay: 5 + to: "15:00" + }, { + fromDay: 4 + from: "17:00" + toDay: 6 + to: "20:00" + }] + } + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + orderedInventories { + id + qty + productId + channelId + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "11", + "type": "booking", + "attributeFamilyId": 1, + "sku": "booking-prod", + "parentId": null, + "productFlats": [ + { + "id": "11", + "sku": "booking-prod", + "name": "Appointment", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "appointment", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "11", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 15:32:06", + "updatedAt": "2021-05-27 15:37:06" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "superAttributes": [], + "categories": [], + "inventories": [], + "images": [ + { + "id": "12", + "type": null, + "path": "product/11/meeting-1019875_960_720.jpg", + "productId": "11" + } + ], + "orderedInventories": [], + "reviews": [], + "groupedProducts": [], + "downloadableSamples": [], + "downloadableLinks": [], + "bundleOptions": [], + "customerGroupPrices": [ + { + "id": "33", + "qty": 2, + "valueType": "fixed", + "value": 10, + "productId": "11", + "customerGroupId": "2", + "createdAt": "2021-05-27 15:46:37", + "updatedAt": "2021-05-27 15:46:37" + }, + { + "id": "34", + "qty": 3, + "valueType": "discount", + "value": 2, + "productId": "11", + "customerGroupId": "3", + "createdAt": "2021-05-27 15:46:37", + "updatedAt": "2021-05-27 15:46:37" + } + ], + "booking": { + "id": "1", + "type": "default", + "qty": 120, + "location": "Noida", + "showLocation": false, + "availableEveryWeek": null, + "availableFrom": "2021-02-10 12:00:00", + "availableTo": "2021-02-28 12:00:00", + "productId": "11", + "defaultSlot": { + "id": "1", + "bookingType": "one", + "duration": null, + "breakTime": null, + "slots": [ + { + "to": "12:00", + "toDay": 5, + "from": "09:00", + "fromDay": 1 + }, + { + "to": "15:00", + "toDay": 5, + "from": "12:30", + "fromDay": 1 + }, + { + "to": "20:00", + "toDay": 6, + "from": "17:00", + "fromDay": 4 + } + ], + "bookingProductId": "1" + }, + "appointmentSlot": null + } + } + } + } + ~~~ +::: + +### 3. Update Appointment Booking Product + +By using this API call you can update the Appointment Booking Product. To do this , you have to perform update mutation on Appointment Booking Product and paas the related fields in the request. +API call will update a Appointment Booking Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 11, input: { + channel: "default" + locale: "en" + sku: "appointment-booking1" + name: "Dr. Appointment" + urlKey: "dr-appointment" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + width: 30 + height: 24 + depth: 11 + weight: 5.20 + customerGroupPrices: [{ + customerGroupId: 2 + qty: 2 + valueType: "fixed" + value: 10 + }] + channels: [1] + images: [ + "https://cdn.pixabay.com/photo/2015/11/03/08/58/meeting-1019875_960_720.jpg" + ] + booking: { + type: "appointment" + location: "Dehradun" + qty: 14 + availableEveryWeek: false + availableFrom: "2021-02-10 12:00:00" + availableTo: "2021-02-28 12:00:00" + duration: 45 + breakTime: 15 + + # # In case same_slot_all_days: set to true + # same_slot_all_days: true + # slots: [{ + # from: "09:00" + # to: "09:45" + # }, { + # from: "10:00" + # to: "10:45" + # }, { + # from: "11:00" + # to: "11:45" + # }, { + # from: "14:00" + # to: "14:45" + # }] + + # In case same_slot_all_days: set to false + sameSlotAllDays: false + slots: [{ + day: 0 + from: "09:00" + to: "09:45" + }, { + day: 0 + from: "10:00" + to: "10:45" + }, { + day: 1 + from: "11:00" + to: "11:45" + }, { + day: 5 + from: "09:00" + to: "09:45" + }, { + day: 5 + from: "11:00" + to: "11:45" + }, { + day: 5 + from: "12:00" + to: "12:45" + }] + } + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + id + from + to + } + bookingProductId + } + } + sameDaySlots { + id + day + from + to + } + differentDaySlots { + id + day + from + to + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "11", + "type": "booking", + "attributeFamilyId": 1, + "sku": "appointment-booking1", + "parentId": null, + "productFlats": [ + { + "id": "11", + "sku": "appointment-booking1", + "name": "Dr. Appointment", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "dr-appointment", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "11", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 15:32:06", + "updatedAt": "2021-05-27 15:51:37" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [], + "images": [ + { + "id": "13", + "type": null, + "path": "product/11/meeting-1019875_960_720.jpg", + "productId": "11" + } + ], + "orderedInventories": [], + "customerGroupPrices": [ + { + "id": "37", + "qty": 2, + "valueType": "fixed", + "value": 10, + "productId": "11", + "customerGroupId": "2", + "createdAt": "2021-05-27 15:52:03", + "updatedAt": "2021-05-27 15:52:03" + } + ], + "booking": { + "id": "1", + "type": "appointment", + "qty": 14, + "location": "Dehradun", + "showLocation": false, + "availableEveryWeek": false, + "availableFrom": "2021-02-10 12:00:00", + "availableTo": "2021-02-28 12:00:00", + "productId": "11", + "appointmentSlot": { + "id": "1", + "duration": 45, + "breakTime": 15, + "sameSlotAllDays": false, + "slots": [ + { + "id": null, + "from": null, + "to": null + }, + { + "id": null, + "from": null, + "to": null + }, + { + "id": null, + "from": null, + "to": null + }, + { + "id": null, + "from": null, + "to": null + }, + { + "id": null, + "from": null, + "to": null + }, + { + "id": null, + "from": null, + "to": null + }, + { + "id": null, + "from": null, + "to": null + } + ], + "bookingProductId": "1" + } + }, + "sameDaySlots": [], + "differentDaySlots": [ + { + "id": "0_slot_0", + "day": 0, + "from": "09:00", + "to": "09:45" + }, + { + "id": "0_slot_1", + "day": 0, + "from": "10:00", + "to": "10:45" + }, + { + "id": "1_slot_0", + "day": 1, + "from": "11:00", + "to": "11:45" + }, + { + "id": "5_slot_0", + "day": 5, + "from": "09:00", + "to": "09:45" + }, + { + "id": "5_slot_1", + "day": 5, + "from": "11:00", + "to": "11:45" + }, + { + "id": "5_slot_2", + "day": 5, + "from": "12:00", + "to": "12:45" + } + ] + } + } + } + ~~~ +::: + +### 4. Create a new Event Booking Product + + To create a Event Booking Product, you have to perform mutation on Booking Product and paas the related fields in the request. + API call resource will create a new Event Booking Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "booking" + attributeFamilyId: 1 + sku: "event-booking" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "12", + "type": "booking", + "attributeFamilyId": 1, + "sku": "event-booking", + "parentId": null, + "productFlats": [ + { + "id": "12", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "12", + "parentId": null, + "minPrice": null, + "maxPrice": null, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 16:04:24", + "updatedAt": "2021-05-27 16:04:24" + } + ], + "variants": [], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [], + "images": [], + "orderedInventories": [], + "customerGroupPrices": [], + "booking": null + } + } + } + ~~~ +::: + +### 5. Update Event Booking Product + +By using this API call you can update the Event Booking Product. To do this , you have to perform update mutation on Event Booking Product and paas the related fields in the request. +API call will update a Event Booking Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 12, input: { + channel: "default" + locale: "en" + sku: "event-booking" + name: "Music Show" + urlKey: "music-show" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + width: 30 + height: 24 + depth: 11 + weight: 5.20 + customerGroupPrices: [{ + customerGroupId: 2 + qty: 2 + valueType: "fixed" + value: 10 + }] + channels: [1] + images: [ + "https://cdn.pixabay.com/photo/2015/11/03/08/58/meeting-1019875_960_720.jpg" + ] + booking: { + type: "event" + location: "Meerut" + availableFrom: "2021-02-10 12:00:00" + availableTo: "2021-02-28 12:00:00" + tickets: [{ + locales: { + locale: "en" + name: "First Show" + description: "First Music Show " + } + price: 4 + qty: 50 + }, { + locales: { + locale: "en" + name: "Evening Show" + description: "Evening Music Show" + } + price: 7 + qty: 40 + }] + } + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + location + showLocation + availableFrom + availableTo + productId + eventTickets { + id + price + qty + translations { + locale + name + description + } + bookingProductId + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "12", + "type": "booking", + "attributeFamilyId": 1, + "sku": "event-booking", + "parentId": null, + "productFlats": [ + { + "id": "12", + "sku": "event-booking", + "name": "Music Show", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "music-show", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "12", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 16:04:24", + "updatedAt": "2021-05-27 16:04:24" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [], + "images": [ + { + "id": "15", + "type": null, + "path": "product/12/meeting-1019875_960_720.jpg", + "productId": "12" + } + ], + "orderedInventories": [], + "customerGroupPrices": [ + { + "id": "39", + "qty": 2, + "valueType": "fixed", + "value": 10, + "productId": "12", + "customerGroupId": "2", + "createdAt": "2021-05-27 16:18:30", + "updatedAt": "2021-05-27 16:18:30" + } + ], + "booking": { + "id": "2", + "type": "event", + "location": "Meerut", + "showLocation": false, + "availableFrom": "2021-02-10 12:00:00", + "availableTo": "2021-02-28 12:00:00", + "productId": "12", + "eventTickets": [ + { + "id": "3", + "price": 4, + "qty": 50, + "translations": [ + { + "locale": "en", + "name": "First Show", + "description": "First Music Show" + } + ], + "bookingProductId": "2" + }, + { + "id": "4", + "price": 7, + "qty": 40, + "translations": [ + { + "locale": "en", + "name": "Evening Show", + "description": "Evening Music Show" + } + ], + "bookingProductId": "2" + } + ] + } + } + } + } + ~~~ +::: + +### 6. Create a new Rental Booking Product + + To create a Event Rental Booking Product, you have to perform mutation on Rental Booking Product and paas the related fields in the request. + API call resource will create a new Event Rental Booking Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "booking" + attributeFamilyId: 1 + sku: "ac-on-rent" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "13", + "type": "booking", + "attributeFamilyId": 1, + "sku": "ac-on-rent", + "parentId": null, + "productFlats": [ + { + "id": "13", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "13", + "parentId": null, + "minPrice": null, + "maxPrice": null, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 16:30:11", + "updatedAt": "2021-05-27 16:30:11" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [], + "images": [], + "orderedInventories": [], + "customerGroupPrices": [], + "booking": null + } + } + } + ~~~ +::: + +### 7. Update Rental Booking Product + +By using this API call you can update the Rental Booking Product. To do this , you have to perform update mutation on Rental Booking Product and paas the related fields in the request. +API call will update a Rental Booking Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 13, input: { + channel: "default" + locale: "en" + sku: "ac-on-rent" + name: "AC On Rent" + urlKey: "ac-on-rent" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + width: 30 + height: 24 + depth: 11 + weight: 5.20 + inventories: [{ + inventorySourceId: 1 + qty: 111 + }] + channels: [1] + images: [ + "http://graphqlnew.com/themes/velocity/assets/images/kids.png", + ] + booking: { + type: "rental" + location: "UK" + qty: 23 + availableEveryWeek: false + availableFrom: "2021-02-10 12:00:00" + availableTo: "2021-02-28 12:00:00" + sameSlotAllDays: false + rentalSlot: { + rentingType: "hourly" + dailyPrice: null + hourlyPrice: 4.20 + slots: [{ + day: 0 + from: "09:00" + to: "09:45" + }, { + day: 0 + from: "10:00" + to: "10:45" + }, { + day: 2 + from: "11:00" + to: "11:45" + }, { + day: 2 + from: "12:00" + to: "12:45" + }] + } + } + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + location + showLocation + availableFrom + availableTo + productId + eventTickets { + id + price + qty + translations { + locale + name + description + } + bookingProductId + } + } + sameDaySlots { + id + day + from + to + } + differentDaySlots { + id + day + from + to + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "13", + "type": "booking", + "attributeFamilyId": 1, + "sku": "ac-on-rent", + "parentId": null, + "productFlats": [ + { + "id": "13", + "sku": "ac-on-rent", + "name": "AC On Rent", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "ac-on-rent", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "13", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 16:30:11", + "updatedAt": "2021-05-27 16:30:11" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [ + { + "id": "17", + "qty": 111, + "productId": "13", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [], + "customerGroupPrices": [], + "booking": { + "type": "rental", + "location": "UK", + "qty": 23, + "availableEveryWeek": false, + "availableFrom": "2021-02-10 12:00:00", + "availableTo": "2021-02-28 12:00:00", + "rentalSlot": { + "rentingType": "hourly", + "dailyPrice": null, + "hourlyPrice": 4.2, + "slots": [ + { + "from": null, + "to": null + }, + { + "from": null, + "to": null + } + ] + } + }, + "sameDaySlots": [], + "differentDaySlots": [ + { + "id": null, + "day": 0, + "from": "09:00", + "to": "09:45" + }, + { + "id": null, + "day": 0, + "from": "10:00", + "to": "10:45" + }, + { + "id": null, + "day": 2, + "from": "11:00", + "to": "11:45" + }, + { + "id": null, + "day": 2, + "from": "12:00", + "to": "12:45" + } + ] + } + } + } + ~~~ +::: + +### 8. Create a new Table Booking Product + + To create a Event Table Booking Product, you have to perform mutation on Table Booking Product and paas the related fields in the request. + API call resource will create a new Event Table Booking Product, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: Here you can pass Only those filed with the request that you want in the response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createProduct { + createProduct(input: { + type: "booking" + attributeFamilyId: 1 + sku: "hotel-table" + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + ~~~ +::: details Response + ~~~json + { + "data": { + "createProduct": { + "id": "14", + "type": "booking", + "attributeFamilyId": 1, + "sku": "hotel-table", + "parentId": null, + "productFlats": [ + { + "id": "14", + "sku": "", + "name": null, + "description": null, + "shortDescription": null, + "urlKey": null, + "new": null, + "featured": null, + "status": null, + "visibleIndividually": null, + "thumbnail": null, + "price": null, + "cost": null, + "weight": null, + "color": null, + "colorLabel": null, + "size": null, + "sizeLabel": null, + "locale": "en", + "channel": "default", + "productId": "14", + "parentId": null, + "minPrice": null, + "maxPrice": null, + "metaTitle": null, + "metaKeywords": null, + "metaDescription": null, + "width": null, + "height": null, + "depth": null, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 16:45:57", + "updatedAt": "2021-05-27 16:45:57" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [], + "images": [], + "orderedInventories": [], + "customerGroupPrices": [], + "booking": null + } + } + } + ~~~ +::: + +### 7. Update Table Booking Product + +By using this API call you can update the Table Booking Product. To do this , you have to perform update mutation on Table Booking Product and paas the related fields in the request. +API call will update a Table Booking Product, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateProduct { + updateProduct(id: 14, input: { + channel: "default" + locale: "en" + sku: "hotel-table" + name: "Hotel Table" + urlKey: "hotel-table" + taxCategoryId: 1 + new: true + featured: true + visibleIndividually: true + status: true + guestCheckout: true + color: 3 + size: 9 + shortDescription: "

Home Decor Short Description

" + description: "

Home Decor Description

" + metaTitle: "Home Decor Meta Title" + metaKeywords: "Home Decor Meta Keywords" + metaDescription: "Home Decor Meta Description" + price: 12.55 + cost: 11.50 + specialPrice: 11.30 + specialPriceFrom: "2021-02-08" + specialPriceTo: "2021-02-28" + width: 30 + height: 24 + depth: 11 + weight: 5.20 + customerGroupPrices: [{ + customerGroupId: 2 + qty: 2 + valueType: "fixed" + value: 10 + }] + inventories: [{ + inventorySourceId: 1 + qty: 111 + }, { + inventorySourceId: 2 + qty: 222 + }] + channels: [1] + images: [ + "http://graphqlnew.com/themes/velocity/assets/images/headphones.png" + ] + booking: { + type: "table" + location: "Hisar" + qty: 5 + duration: 45 + breakTime: 15 + availableEveryWeek: true + availableFrom: "2021-02-11 12:00:00" + availableTo: "2021-02-18 12:00:00" + sameSlotAllDays: true + tableSlot: { + priceType: "guest" + guestLimit: 5 + preventSchedulingBefore: 3 + slots: [{ + day: 0 + from: "09:00" + to: "09:45" + }, { + day: 1 + from: "10:00" + to: "10:45" + }, { + day: 2 + from: "11:00" + to: "11:45" + }, { + day: 3 + from: "12:00" + to: "12:45" + }] + } + } + }) { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + attributeFamily { + id + code + name + status + isUserDefined + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + location + showLocation + availableFrom + availableTo + productId + eventTickets { + id + price + qty + translations { + locale + name + description + } + bookingProductId + } + } + sameDaySlots { + id + day + from + to + } + differentDaySlots { + id + day + from + to + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateProduct": { + "id": "14", + "type": "booking", + "attributeFamilyId": 1, + "sku": "hotel-table", + "parentId": null, + "productFlats": [ + { + "id": "14", + "sku": "hotel-table", + "name": "Hotel Table", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "hotel-table", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "14", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 16:45:57", + "updatedAt": "2021-05-27 16:45:57" + } + ], + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "inventories": [ + { + "id": "19", + "qty": 111, + "productId": "14", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "20", + "qty": 222, + "productId": "14", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [], + "customerGroupPrices": [ + { + "id": "42", + "qty": 2, + "valueType": "fixed", + "value": 10, + "productId": "14", + "customerGroupId": "2", + "createdAt": "2021-05-27 16:51:26", + "updatedAt": "2021-05-27 16:51:26" + } + ], + "booking": { + "type": "table", + "location": "Hisar", + "qty": 5, + "availableEveryWeek": true, + "availableFrom": "2021-02-11 12:00:00", + "availableTo": "2021-02-18 12:00:00", + "tableSlot": { + "priceType": "guest", + "guestLimit": 5, + "duration": 45, + "breakTime": 15, + "sameSlotAllDays": true, + "preventSchedulingBefore": true, + "slots": [ + { + "from": "09:00", + "to": "09:45" + }, + { + "from": "10:00", + "to": "10:45" + }, + { + "from": "11:00", + "to": "11:45" + }, + { + "from": "12:00", + "to": "12:45" + } + ] + } + }, + "sameDaySlots": [ + { + "id": null, + "day": 0, + "from": "09:00", + "to": "09:45" + }, + { + "id": null, + "day": 1, + "from": "10:00", + "to": "10:45" + }, + { + "id": null, + "day": 2, + "from": "11:00", + "to": "11:45" + }, + { + "id": null, + "day": 3, + "from": "12:00", + "to": "12:45" + } + ], + "differentDaySlots": [] + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-admin-api/promotions.md b/docs/1.x/graphql-admin-api/promotions.md new file mode 100644 index 00000000..ce5b05d9 --- /dev/null +++ b/docs/1.x/graphql-admin-api/promotions.md @@ -0,0 +1,2197 @@ +## Catalog Rules + +In this section, we will see all the APIs which are related to Catalog Rules. + +### 1. Get All Catalog Rules + +You can get all the Catalog Rules from the Bagisto store. You can achieve this job by using the `Catalog Rules` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query catalogRules { + catalogRules { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + description + startsFrom + endsTill + status + conditionType + conditions + endOtherRules + actionType + discountAmount + sortOrder + createdAt + updatedAt + channels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales { + id + name + code + direction + } + defaultLocale + currencies { + id + name + code + symbol + } + inventorySources { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + baseCurrency + rootCategory + logoUrl + faviconUrl + } + customerGroups { + id + name + code + isUserDefined + createdAt + updatedAt + } + catalogRuleProducts { + id + startsFrom + endsTill + discountAmount + actionType + endOtherRules + sortOrder + catalogRuleId + channelId + customerGroupId + productId + product { + id + type + attributeFamilyId + sku + parentId + variants { + id + type + attributeFamilyId + sku + parentId + } + } + } + catalogRuleProductPrices { + id + price + ruleDate + startsFrom + endsTill + productId + catalogRuleId + channelId + customerGroupId + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "catalogRules": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "test rule", + "description": "test rule", + "startsFrom": "2021-05-25", + "endsTill": "2021-05-27", + "status": true, + "conditionType": true, + "conditions": "null", + "endOtherRules": true, + "actionType": "by_percent", + "discountAmount": 10, + "sortOrder": 1, + "createdAt": "2021-05-26 17:28:54", + "updatedAt": "2021-05-26 17:28:54", + "channels": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "locales": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$" + } + ], + "inventorySources": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null + }, + { + "id": "2", + "code": "newca", + "name": "nerty", + "description": "ajsyg", + "theme": "gdg", + "homePageContent": "fhg", + "footerContent": "fh", + "hostname": "http://bag1.com", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"gfyj\", \"meta_keywords\": \"gvgh\", \"meta_description\": \"gcg\"}", + "locales": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$" + } + ], + "inventorySources": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null + } + ], + "customerGroups": [ + { + "id": "1", + "name": "Guest", + "code": "guest", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "3", + "name": "Wholesale", + "code": "wholesale", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "4", + "name": "VIP Customers", + "code": "vip", + "isUserDefined": false, + "createdAt": "2021-05-26 16:32:06", + "updatedAt": "2021-05-26 16:33:57" + } + ], + "catalogRuleProducts": [], + "catalogRuleProductPrices": [] + } + ] + } + } +} +~~~ +::: + +### 2. Get Catalog Rule By ID + +To get the specific Catalog Rule, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query catalogRule { + catalogRule(id: 1) { + id + name + description + startsFrom + endsTill + status + conditionType + conditions + endOtherRules + actionType + discountAmount + sortOrder + createdAt + updatedAt + channels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales { + id + name + code + direction + } + defaultLocale + currencies { + id + name + code + symbol + } + inventorySources { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + baseCurrency + rootCategory + logoUrl + faviconUrl + } + customerGroups { + id + name + code + isUserDefined + createdAt + updatedAt + } + catalogRuleProducts { + id + startsFrom + endsTill + discountAmount + actionType + endOtherRules + sortOrder + catalogRuleId + channelId + customerGroupId + productId + product { + id + type + attributeFamilyId + sku + parentId + variants { + id + type + attributeFamilyId + sku + parentId + } + } + } + catalogRuleProductPrices { + id + price + ruleDate + startsFrom + endsTill + productId + catalogRuleId + channelId + customerGroupId + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "catalogRule": { + "id": "1", + "name": "test rule", + "description": "test rule", + "startsFrom": "2021-05-25", + "endsTill": "2021-05-27", + "status": true, + "conditionType": true, + "conditions": "null", + "endOtherRules": true, + "actionType": "by_percent", + "discountAmount": 10, + "sortOrder": 1, + "createdAt": "2021-05-26 17:28:54", + "updatedAt": "2021-05-26 17:28:54", + "channels": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "locales": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$" + } + ], + "inventorySources": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null + }, + { + "id": "2", + "code": "newca", + "name": "nerty", + "description": "ajsyg", + "theme": "gdg", + "homePageContent": "fhg", + "footerContent": "fh", + "hostname": "http://bag1.com", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"gfyj\", \"meta_keywords\": \"gvgh\", \"meta_description\": \"gcg\"}", + "locales": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$" + } + ], + "inventorySources": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null + } + ], + "customerGroups": [ + { + "id": "1", + "name": "Guest", + "code": "guest", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "3", + "name": "Wholesale", + "code": "wholesale", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + { + "id": "4", + "name": "VIP Customers", + "code": "vip", + "isUserDefined": false, + "createdAt": "2021-05-26 16:32:06", + "updatedAt": "2021-05-26 16:33:57" + } + ], + "catalogRuleProducts": [], + "catalogRuleProductPrices": [] + } + } + } + ~~~ +::: + +### 3. Get Filtered Catalog Rule + +You can get the filter data from the Catalog Rule by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query catalogRules { + catalogRules(input:{ + id:1 + name: "test rule" + start: "2021-05-25" + end: "2021-05-27" + status: true + priority:1 + }) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + description + startsFrom + endsTill + status + conditionType + conditions + endOtherRules + actionType + discountAmount + sortOrder + createdAt + updatedAt + catalogRuleProducts { + id + startsFrom + endsTill + discountAmount + actionType + endOtherRules + sortOrder + catalogRuleId + channelId + customerGroupId + productId + product { + id + type + attributeFamilyId + sku + parentId + variants { + id + type + attributeFamilyId + sku + parentId + } + } + } + catalogRuleProductPrices { + id + price + ruleDate + startsFrom + endsTill + productId + catalogRuleId + channelId + customerGroupId + } + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "catalogRules": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "test rule", + "description": "test rule", + "startsFrom": "2021-05-25", + "endsTill": "2021-05-27", + "status": true, + "conditionType": true, + "conditions": "null", + "endOtherRules": true, + "actionType": "by_percent", + "discountAmount": 10, + "sortOrder": 1, + "createdAt": "2021-05-26 17:28:54", + "updatedAt": "2021-05-26 17:28:54", + "catalogRuleProducts": [ + { + "id": "1", + "startsFrom": "2021-05-25 00:00:01", + "endsTill": "2021-05-27 23:59:59", + "discountAmount": 10, + "actionType": "by_percent", + "endOtherRules": true, + "sortOrder": 1, + "catalogRuleId": "1", + "channelId": "1", + "customerGroupId": "2", + "productId": "1", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "variants": [] + } + } + ], + "catalogRuleProductPrices": [ + { + "id": "1", + "price": 4.5, + "ruleDate": "2021-05-26", + "startsFrom": "2021-05-25 00:00:01", + "endsTill": "2021-05-27 23:59:59", + "productId": "1", + "catalogRuleId": "1", + "channelId": "1", + "customerGroupId": "1" + }, + ] + } + ] + } + } + } + ~~~ +::: + +### 4. Get Catalog Rule Products + +You can get the Catalog Rule Products from the Bagisto store. You can achieve this job by using the `Catalog Rules` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query catalogRuleProducts { + catalogRuleProducts(input: { + catalogRuleId: 1 + }) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + startsFrom + endsTill + discountAmount + actionType + endOtherRules + sortOrder + catalogRuleId + channelId + customerGroupId + productId + product { + id + type + attributeFamilyId + sku + parentId + variants { + id + type + attributeFamilyId + sku + parentId + } + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "catalogRuleProducts": { + "paginatorInfo": { + "count": 8, + "currentPage": 1, + "lastPage": 1, + "total": 8 + }, + "data": [ + { + "id": "1", + "startsFrom": "2021-05-25 00:00:01", + "endsTill": "2021-05-27 23:59:59", + "discountAmount": 10, + "actionType": "by_percent", + "endOtherRules": true, + "sortOrder": 1, + "catalogRuleId": "1", + "channelId": "1", + "customerGroupId": "2", + "productId": "1", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "variants": [] + } + } + ] + } + } +} +~~~ +::: + + + +### 5. Get Catalog Rule Product By Id + +You can get the Catalog Rule Products By Id from the Bagisto store. You can achieve this job by using the `Catalog Rule Product` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query catalogRuleProduct { + catalogRuleProduct( + id: 1, + input: { + catalogRuleId: 1 + } + ) { + id + startsFrom + endsTill + discountAmount + actionType + endOtherRules + sortOrder + catalogRuleId + channelId + customerGroupId + productId + product { + id + type + attributeFamilyId + sku + parentId + variants { + id + type + attributeFamilyId + sku + parentId + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "catalogRuleProduct": { + "id": "1", + "startsFrom": "2021-05-25 00:00:01", + "endsTill": "2021-05-27 23:59:59", + "discountAmount": 10, + "actionType": "by_percent", + "endOtherRules": true, + "sortOrder": 1, + "catalogRuleId": "1", + "channelId": "1", + "customerGroupId": "2", + "productId": "1", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "variants": [] + } + } + } +} +~~~ +::: + +### 6. Get Catalog Rule Products Prices + +You can get the Catalog Rule Products Prices from the Bagisto store. You can achieve this job by using the `Catalog Rule Products Price` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query catalogRuleProductPrices { + catalogRuleProductPrices(input: { + catalogRuleId: 1, + productId: 1, + customerGroupId: 1, + channelId: 1 + }) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + price + ruleDate + startsFrom + endsTill + productId + catalogRuleId + channelId + customerGroupId + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "catalogRuleProductPrices": { + "paginatorInfo": { + "count": 3, + "currentPage": 1, + "lastPage": 1, + "total": 3 + }, + "data": [ + { + "id": "1", + "price": 4.5, + "ruleDate": "2021-05-26", + "startsFrom": "2021-05-25 00:00:01", + "endsTill": "2021-05-27 23:59:59", + "productId": "1", + "catalogRuleId": "1", + "channelId": "1", + "customerGroupId": "1" + }, + { + "id": "2", + "price": 4.5, + "ruleDate": "2021-05-25", + "startsFrom": "2021-05-25 00:00:01", + "endsTill": "2021-05-27 23:59:59", + "productId": "1", + "catalogRuleId": "1", + "channelId": "1", + "customerGroupId": "1" + }, + { + "id": "3", + "price": 4.5, + "ruleDate": "2021-05-27", + "startsFrom": "2021-05-25 00:00:01", + "endsTill": "2021-05-27 23:59:59", + "productId": "1", + "catalogRuleId": "1", + "channelId": "1", + "customerGroupId": "1" + } + ] + } + } +} +~~~ +::: + + + +### 7. Get Catalog Rule Product Prices By Id + +You can get the Catalog Rule Product Prices By Id from the Bagisto store. You can achieve this job by using the `Catalog Rule Product Price` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query catalogRuleProductPrice { + catalogRuleProductPrice( + id: 1, + input: { + catalogRuleId: 1, + productId: 1, + customerGroupId: 1, + channelId: 1 + } + ) { + id + price + ruleDate + startsFrom + endsTill + productId + catalogRuleId + channelId + customerGroupId + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "catalogRuleProductPrice": { + "id": "1", + "price": 4.5, + "ruleDate": "2021-05-26", + "startsFrom": "2021-05-25 00:00:01", + "endsTill": "2021-05-27 23:59:59", + "productId": "1", + "catalogRuleId": "1", + "channelId": "1", + "customerGroupId": "1" + } + } +} +~~~ +::: + +### 8. Create a new Catalog Rule + + To create a Catalog Rule, you have to perform mutation on Catalog Rule and paas the related fields in the request. + API call resource will create a new Catalog Rule, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createCatalogRule { + createCatalogRule(input: { + name: "test1" + status:true + description: "testetsetste" + channels:1 + customerGroups:1 + startsFrom: "2021-05-26 17:28:54" + endsTill: "2021-05-27 17:28:54" + conditionType: 1 + sortOrder:1 + actionType: "by_percent" + discountAmount: 10 + endOtherRules:false + }) { + id + name + description + startsFrom + endsTill + status + conditionType + conditions + endOtherRules + actionType + discountAmount + sortOrder + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createCatalogRule": { + "id": "2", + "name": "test1", + "description": "testetsetste", + "startsFrom": "2021-05-26", + "endsTill": "2021-05-27", + "status": true, + "conditionType": true, + "conditions": "null", + "endOtherRules": false, + "actionType": "by_percent", + "discountAmount": 10, + "sortOrder": 1, + "createdAt": "2021-05-26 19:35:43", + "updatedAt": "2021-05-26 19:35:43" + } + } + } + ~~~ +::: + +### 9. Update Catalog Rule + +By using this API call you can update the Catalog Rule. To do this , you have to perform update mutation on Catalog Rule and paas the related fields in the request. +API call will update a Catalog Rule, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateCatalogRule { + updateCatalogRule(id: 2,input: { + name: "testupdated" + status:true + description: "testetsetste" + channels:1 + customerGroups:1 + startsFrom: "2021-05-26 17:28:54" + endsTill: "2021-05-27 17:28:54" + conditionType: 1 + sortOrder:1 + actionType: "by_percent" + discountAmount: 10 + endOtherRules:false + }) { + id + name + description + startsFrom + endsTill + status + conditionType + conditions + endOtherRules + actionType + discountAmount + sortOrder + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateCatalogRule": { + "id": "2", + "name": "test1", + "description": "testetsetste", + "startsFrom": "2021-05-26", + "endsTill": "2021-05-27", + "status": true, + "conditionType": true, + "conditions": "null", + "endOtherRules": false, + "actionType": "by_percent", + "discountAmount": 10, + "sortOrder": 1, + "createdAt": "2021-05-26 19:35:43", + "updatedAt": "2021-05-26 19:35:43" + } + } + } + ~~~ +::: + +### 10. Delete a Catalog Rule + +To delete a Catalog Rule, you have to perform mutation on Catalog Rule by passing the id of that Catalog Rule. +API call will delete a Catalog Rule, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteCatalogRule { + deleteCatalogRule(id: 2) { + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteCatalogRule": { + "success": "Catalog Rule deleted successfully." + } + } + } + ~~~ +::: + +## Cart Rules + +In this section, we will see all the APIs which are related to Catalog Rules. + +### 1. Get All Cart Rules + +You can get all the Cart Rules from the Bagisto store. You can achieve this job by using the `Cart Rules` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query cartRules { + cartRules { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + description + startsFrom + endsTill + status + couponType + useAutoGeneration + usagePerCustomer + usesPerCoupon + timesUsed + conditionType + conditions + actions + endOtherRules + usesAttributeConditions + actionType + discountAmount + discountQuantity + discountStep + applyToShipping + freeShipping + sortOrder + createdAt + updatedAt + cartRuleChannels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales { + id + name + code + direction + } + defaultLocale + currencies { + id + name + code + symbol + } + inventorySources { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + baseCurrency + rootCategory + logoUrl + faviconUrl + } + cartRuleCustomerGroups { + id + name + code + isUserDefined + createdAt + updatedAt + } + cartRuleCoupon { + id + code + usageLimit + usagePerCustomer + isPrimary + timesUsed + expiredAt + type + cartRuleId + createdAt + updatedAt + couponUsage { + id + timesUsed + cartRuleCouponId + } + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "cartRules": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "test cartrule", + "description": "test cartrule", + "startsFrom": "2021-05-26 12:00:00", + "endsTill": "2021-05-27 12:00:00", + "status": true, + "couponType": 1, + "useAutoGeneration": false, + "usagePerCustomer": 2, + "usesPerCoupon": 2, + "timesUsed": 0, + "conditionType": "1", + "conditions": null, + "actions": null, + "endOtherRules": false, + "usesAttributeConditions": false, + "actionType": "by_percent", + "discountAmount": 10, + "discountQuantity": 1, + "discountStep": 1, + "applyToShipping": false, + "freeShipping": false, + "sortOrder": 1, + "createdAt": "2021-05-26 19:49:08", + "updatedAt": "2021-05-26 19:49:08", + "cartRuleChannels": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "locales": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$" + } + ], + "inventorySources": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null + }, + { + "id": "2", + "code": "newca", + "name": "nerty", + "description": "ajsyg", + "theme": "gdg", + "homePageContent": "fhg", + "footerContent": "fh", + "hostname": "http://bag1.com", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"gfyj\", \"meta_keywords\": \"gvgh\", \"meta_description\": \"gcg\"}", + "locales": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$" + } + ], + "inventorySources": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null + } + ], + "cartRuleCustomerGroups": [ + { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + } + ], + "cartRuleCoupon": { + "id": "1", + "code": "TEST", + "usageLimit": 2, + "usagePerCustomer": 2, + "isPrimary": true, + "timesUsed": 0, + "expiredAt": "2021-05-27", + "type": 0, + "cartRuleId": "1", + "createdAt": "2021-05-26 19:49:09", + "updatedAt": "2021-05-26 19:49:09", + "couponUsage": [] + } + } + ] + } + } +} +~~~ +::: + +### 2. Get Cart Rule By ID + +To get the specific Cart Rule, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query cartRule { + cartRule(id: 1) { + id + name + description + startsFrom + endsTill + status + couponType + useAutoGeneration + usagePerCustomer + usesPerCoupon + timesUsed + conditionType + conditions + actions + endOtherRules + usesAttributeConditions + actionType + discountAmount + discountQuantity + discountStep + applyToShipping + freeShipping + sortOrder + createdAt + updatedAt + cartRuleChannels { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "cartRule": { + "id": "1", + "name": "test cartrule", + "description": "test cartrule", + "startsFrom": "2021-05-26 12:00:00", + "endsTill": "2021-05-27 12:00:00", + "status": true, + "couponType": 1, + "useAutoGeneration": false, + "usagePerCustomer": 2, + "usesPerCoupon": 2, + "timesUsed": 0, + "conditionType": "1", + "conditions": null, + "actions": null, + "endOtherRules": false, + "usesAttributeConditions": false, + "actionType": "by_percent", + "discountAmount": 10, + "discountQuantity": 1, + "discountStep": 1, + "applyToShipping": false, + "freeShipping": false, + "sortOrder": 1, + "createdAt": "2021-05-26 19:49:08", + "updatedAt": "2021-05-26 19:49:08", + "cartRuleChannels": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}" + }, + { + "id": "2", + "code": "newca", + "name": "nerty", + "description": "ajsyg", + "theme": "gdg", + "footerContent": "fh", + "hostname": "http://bag1.com", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"gfyj\", \"meta_keywords\": \"gvgh\", \"meta_description\": \"gcg\"}" + } + ] + } + } + } + ~~~ +::: + +### 3. Get Filtered Cart Rule + +You can get the filter data from the Cart Rule by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query cartRules { + cartRules(input: { + id:1 + name: "test cartrule" + }, page: 1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + name + description + startsFrom + endsTill + status + couponType + useAutoGeneration + usagePerCustomer + usesPerCoupon + timesUsed + conditionType + conditions + actions + endOtherRules + usesAttributeConditions + actionType + discountAmount + discountQuantity + discountStep + applyToShipping + freeShipping + sortOrder + createdAt + updatedAt + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "cartRules": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "test cartrule", + "description": "test cartrule", + "startsFrom": "2021-05-26 12:00:00", + "endsTill": "2021-05-27 12:00:00", + "status": true, + "couponType": 1, + "useAutoGeneration": false, + "usagePerCustomer": 2, + "usesPerCoupon": 2, + "timesUsed": 0, + "conditionType": "1", + "conditions": null, + "actions": null, + "endOtherRules": false, + "usesAttributeConditions": false, + "actionType": "by_percent", + "discountAmount": 10, + "discountQuantity": 1, + "discountStep": 1, + "applyToShipping": false, + "freeShipping": false, + "sortOrder": 1, + "createdAt": "2021-05-26 19:49:08", + "updatedAt": "2021-05-26 19:49:08" + } + ] + } + } + } + ~~~ +::: + + +### 8. Create a new Cart Rule + + To create a Cart Rule, you have to perform mutation on Cart Rule and paas the related fields in the request. + API call resource will create a new Cart Rule, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createCartRule { + createCartRule(input: { + name: "cartrule1" + description: "cartrule1" + channels:1 + customerGroups:1 + startsFrom: "2021-05-26 19:49:08" + endsTill: "2021-05-27 19:49:08" + status: true + couponType: 1 + useAutoGeneration:true + usagePerCustomer:1 + usesPerCoupon:1 + timesUsed:1 + conditionType:false + endOtherRules:false + usesAttributeConditions: false + actionType: "by_percent" + discountAmount: 10 + discountQuantity: 1 + discountStep: 1 + applyToShipping:false + freeShipping: true + sortOrder:1 + couponCode: "CARTTEsT" + }) { + id + name + description + startsFrom + endsTill + status + couponType + useAutoGeneration + usagePerCustomer + usesPerCoupon + timesUsed + conditionType + conditions + actions + endOtherRules + usesAttributeConditions + actionType + discountAmount + discountQuantity + discountStep + applyToShipping + freeShipping + sortOrder + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createCartRule": { + "id": "2", + "name": "cartrule1", + "description": "cartrule1", + "startsFrom": "2021-05-26 19:49:08", + "endsTill": "2021-05-27 19:49:08", + "status": true, + "couponType": 1, + "useAutoGeneration": true, + "usagePerCustomer": 1, + "usesPerCoupon": 1, + "timesUsed": 1, + "conditionType": "", + "conditions": null, + "actions": null, + "endOtherRules": false, + "usesAttributeConditions": false, + "actionType": "by_percent", + "discountAmount": 10, + "discountQuantity": 1, + "discountStep": 1, + "applyToShipping": false, + "freeShipping": true, + "sortOrder": 1, + "createdAt": "2021-05-26 20:09:03", + "updatedAt": "2021-05-26 20:09:03" + } + } + } + ~~~ +::: + +### 9. Update Cart Rule + +By using this API call you can update the Cart Rule. To do this , you have to perform update mutation on Cart Rule and paas the related fields in the request. +API call will update a Cart Rule, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateCartRule { + updateCartRule(id: 2,input: { + name: "cartrule1upadted" + description: "cartrule1upadted" + channels:1 + customerGroups:1 + startsFrom: "2021-05-26 19:49:08" + endsTill: "2021-05-27 19:49:08" + status: true + couponType: 1 + useAutoGeneration:true + usagePerCustomer:1 + usesPerCoupon:1 + timesUsed:1 + conditionType:false + endOtherRules:false + usesAttributeConditions: false + actionType: "by_percent" + discountAmount: 10 + discountQuantity: 1 + discountStep: 1 + applyToShipping:false + freeShipping: true + sortOrder:1 + couponCode: "CARTTEsT" + }) { + id + name + description + startsFrom + endsTill + status + couponType + useAutoGeneration + usagePerCustomer + usesPerCoupon + timesUsed + conditionType + conditions + actions + endOtherRules + usesAttributeConditions + actionType + discountAmount + discountQuantity + discountStep + applyToShipping + freeShipping + sortOrder + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateCartRule": { + "id": "2", + "name": "cartrule1", + "description": "cartrule1", + "startsFrom": "2021-05-26 19:49:08", + "endsTill": "2021-05-27 19:49:08", + "status": true, + "couponType": 1, + "useAutoGeneration": true, + "usagePerCustomer": 1, + "usesPerCoupon": 1, + "timesUsed": 1, + "conditionType": "0", + "conditions": null, + "actions": null, + "endOtherRules": false, + "usesAttributeConditions": false, + "actionType": "by_percent", + "discountAmount": 10, + "discountQuantity": 1, + "discountStep": 1, + "applyToShipping": false, + "freeShipping": true, + "sortOrder": 1, + "createdAt": "2021-05-26 20:09:03", + "updatedAt": "2021-05-26 20:09:03" + } + } + } + ~~~ +::: + +### 10. Delete a Cart Rule + +To delete a Cart Rule, you have to perform mutation on Cart Rule by passing the id of that Cart Rule. +API call will delete a Cart Rule, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteCartRule { + deleteCartRule(id: 2) { + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteCartRule": { + "success": "Cart Rule deleted successfully." + } + } + } + ~~~ +::: \ No newline at end of file diff --git a/docs/1.x/graphql-admin-api/sales.md b/docs/1.x/graphql-admin-api/sales.md new file mode 100644 index 00000000..6619d16b --- /dev/null +++ b/docs/1.x/graphql-admin-api/sales.md @@ -0,0 +1,1771 @@ +# Orders + +In this section, we will see all the APIs which are related to Orders. + +## Get All Orders + +You can get all the Orders from the Bagisto store. You can achieve this job by using the `Orders` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query orders { + orders(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + billingAddress{id} + shippingAddress{id} + refunds{ + id + incrementId + state + emailSent + totalQty + } + addresses{ + id + } + items{ + id + } + comments{ + id + } + shipments{ + id + status + totalQty + totalWeight + carrierCode + carrierTitle + } + invoices{ + id + incrementId + state + } + customer{ + id + } + payment{ + id + } + channel{ + id + } + cart{ + id + } + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "orders": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": 1, + "incrementId": "1", + "status": "pending", + "channelName": "Default", + "isGuest": 1, + "customerEmail": "naresh.verma3271@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "grandTotalInvoiced": 0, + "baseGrandTotalInvoiced": 0, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 4.5, + "baseSubTotal": 4.5, + "subTotalInvoiced": 0, + "baseSubTotalInvoiced": 0, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 0, + "baseShippingInvoiced": 0, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": null, + "customerType": null, + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "1", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-27 19:45:28", + "updatedAt": "2021-05-27 19:45:28", + "billingAddress": { + "id": 6 + }, + "shippingAddress": { + "id": 5 + }, + "refunds": [], + "addresses": [ + { + "id": 5 + }, + { + "id": 6 + } + ], + "items": [ + { + "id": "1" + } + ], + "comments": [], + "shipments": [], + "invoices": [], + "customer": null, + "payment": { + "id": "1" + }, + "channel": { + "id": "1" + }, + "cart": { + "id": "1" + }, + "success": null + } + ] + } + } +} +~~~ +::: + +## Get Order By ID + +To get the specific Order, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query order { + order(id:1){ + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + billingAddress{id} + shippingAddress{id} + refunds{ + id + incrementId + state + emailSent + totalQty + } + addresses{ + id + } + items{ + id + } + comments{ + id + } + shipments{ + id + status + totalQty + totalWeight + carrierCode + carrierTitle + } + invoices{ + id + incrementId + state + } + customer{ + id + } + payment{ + id + } + channel{ + id + } + cart{ + id + } + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "order": { + "id": 1, + "incrementId": "1", + "status": "pending", + "channelName": "Default", + "isGuest": 1, + "customerEmail": "naresh.verma3271@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "grandTotalInvoiced": 0, + "baseGrandTotalInvoiced": 0, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 4.5, + "baseSubTotal": 4.5, + "subTotalInvoiced": 0, + "baseSubTotalInvoiced": 0, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 0, + "baseShippingInvoiced": 0, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": null, + "customerType": null, + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "1", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-27 19:45:28", + "updatedAt": "2021-05-27 19:45:28", + "billingAddress": { + "id": 6 + }, + "shippingAddress": { + "id": 5 + }, + "refunds": [], + "addresses": [ + { + "id": 5 + }, + { + "id": 6 + } + ], + "items": [ + { + "id": "1" + } + ], + "comments": [], + "shipments": [], + "invoices": [], + "customer": null, + "payment": { + "id": "1" + }, + "channel": { + "id": "1" + }, + "cart": { + "id": "1" + }, + "success": null + } + } + } + ~~~ + +::: + +## Get Filtered Orders + +You can get the filter data from the Orders by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response for Filter Data. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query orders { + orders(page:1, input: { + status: "pending" + }){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + billingAddress{id} + shippingAddress{id} + refunds{ + id + incrementId + state + emailSent + totalQty + } + addresses{ + id + } + items{ + id + } + comments{ + id + } + shipments{ + id + status + totalQty + totalWeight + carrierCode + carrierTitle + } + invoices{ + id + incrementId + state + } + customer{ + id + } + payment{ + id + } + channel{ + id + } + cart{ + id + } + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "orders": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": 1, + "incrementId": "1", + "status": "pending", + "channelName": "Default", + "isGuest": 1, + "customerEmail": "naresh.verma3271@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "grandTotalInvoiced": 0, + "baseGrandTotalInvoiced": 0, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 4.5, + "baseSubTotal": 4.5, + "subTotalInvoiced": 0, + "baseSubTotalInvoiced": 0, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 0, + "baseShippingInvoiced": 0, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": null, + "customerType": null, + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "1", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-27 19:45:28", + "updatedAt": "2021-05-27 19:45:28", + "billingAddress": { + "id": 6 + }, + "shippingAddress": { + "id": 5 + }, + "refunds": [], + "addresses": [ + { + "id": 5 + }, + { + "id": 6 + } + ], + "items": [ + { + "id": "1" + } + ], + "comments": [], + "shipments": [], + "invoices": [], + "customer": null, + "payment": { + "id": "1" + }, + "channel": { + "id": "1" + }, + "cart": { + "id": "1" + }, + "success": null + } + ] + } + } + } + ~~~ +::: + + +## Get All Invoices + +You can get all the Invoices from the Bagisto store. You can achieve this job by using the `Invoices` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query invoices{ + invoices(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountAmount + baseDiscountAmount + orderId + orderAddressId + createdAt + updatedAt + transactionId + items{ + id + sku + } + order{ + id + + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "invoices": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": 1, + "incrementId": null, + "state": "paid", + "emailSent": 0, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "subTotal": 4.5, + "baseSubTotal": 4.5, + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 1, + "orderAddressId": 6, + "createdAt": "2021-05-27 19:56:11", + "updatedAt": "2021-05-27 19:56:11", + "transactionId": null, + "items": [ + { + "id": "1", + "sku": "test-product" + } + ], + "order": { + "id": 1 + } + } + ] + } + } +} +~~~ +::: + +## Get Invoice By ID + +To get the specific Invoice, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query invoice{ + invoice(id:1){ + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountAmount + baseDiscountAmount + orderId + orderAddressId + createdAt + updatedAt + transactionId + items{ + id + sku + } + order{ + id + + } + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "invoice": { + "id": 1, + "incrementId": null, + "state": "paid", + "emailSent": 0, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "subTotal": 4.5, + "baseSubTotal": 4.5, + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 1, + "orderAddressId": 6, + "createdAt": "2021-05-27 19:56:11", + "updatedAt": "2021-05-27 19:56:11", + "transactionId": null, + "items": [ + { + "id": "1", + "sku": "test-product" + } + ], + "order": { + "id": 1 + } + } + } + } + ~~~ + +::: + + +## Create a new Order Invoice + + To create a Order Invoice , you have to perform mutation on Order Invoice and paas the related fields in the request. + API call resource will create a new Order Invoice , only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createInvoice{ + createInvoice(input:{ + orderId: 1 + invoiceData: { + orderItemId:1 + quantity:1 + } + }){ + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountAmount + baseDiscountAmount + orderId + orderAddressId + createdAt + updatedAt + transactionId + items{id} + order{id} + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createInvoice": { + "id": 1, + "incrementId": null, + "state": "paid", + "emailSent": null, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "subTotal": 4.5, + "baseSubTotal": 4.5, + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 1, + "orderAddressId": 6, + "createdAt": "2021-05-27 19:56:11", + "updatedAt": "2021-05-27 19:56:11", + "transactionId": null, + "items": [ + { + "id": "1" + } + ], + "order": { + "id": 1 + } + } + } + } + ~~~ +::: + + +## Get All Shipments + +You can get all the Shipments from the Bagisto store. You can achieve this job by using the `Shipments` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query shipments { + shipments(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + status + totalQty + totalWeight + carrierCode + carrierTitle + trackNumber + emailSent + customerId + customerType + orderId + orderAddressId + createdAt + updatedAt + inventorySourceId + inventorySourceName + order{ + id + } + items{ + id + } + inventorySource{ + id + code + name + } + customer{ + id + firstName + lastName + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "shipments": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": 1, + "status": null, + "totalQty": 1, + "totalWeight": null, + "carrierCode": null, + "carrierTitle": "newship", + "trackNumber": "7nh6354", + "emailSent": 0, + "customerId": null, + "customerType": null, + "orderId": 1, + "orderAddressId": 5, + "createdAt": "2021-05-27 20:17:30", + "updatedAt": "2021-05-27 20:17:31", + "inventorySourceId": 1, + "inventorySourceName": "Default", + "order": { + "id": 1 + }, + "items": [ + { + "id": 1 + } + ], + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default" + }, + "customer": null + } + ] + } + } +} +~~~ +::: + +## Get Shipment By ID + +To get the specific Shipment, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query shipment { + shipment(id:1){ + id + status + totalQty + totalWeight + carrierCode + carrierTitle + trackNumber + emailSent + customerId + customerType + orderId + orderAddressId + createdAt + updatedAt + inventorySourceId + inventorySourceName + order{ + id + } + items{ + id + } + inventorySource{ + id + code + name + } + customer{ + id + firstName + lastName + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "shipment": { + "id": 1, + "status": null, + "totalQty": 1, + "totalWeight": null, + "carrierCode": null, + "carrierTitle": "newship", + "trackNumber": "7nh6354", + "emailSent": 0, + "customerId": null, + "customerType": null, + "orderId": 1, + "orderAddressId": 5, + "createdAt": "2021-05-27 20:17:30", + "updatedAt": "2021-05-27 20:17:31", + "inventorySourceId": 1, + "inventorySourceName": "Default", + "order": { + "id": 1 + }, + "items": [ + { + "id": 1 + } + ], + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default" + }, + "customer": null + } + } + } + ~~~ + +::: + +## Create a new Order Shipment + + To create a Order Shipment , you have to perform mutation on Order Shipment and paas the related fields in the request. + API call resource will create a new Order Shipment , only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createShipment(input:{ + orderId:1 + carrierTitle:"newship" + trackNumber:"7nh6354" + inventorySourceId:1 + shipmentData:{ + orderItemId:1 + quantity:1 + } + }){ + id + status + totalQty + totalWeight + carrierCode + carrierTitle + trackNumber + emailSent + customerId + customerType + orderId + orderAddressId + createdAt + updatedAt + inventorySourceId + inventorySourceName + order{id} + items{id} + inventorySource{id} + customer{id} + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createShipment": { + "id": 1, + "status": null, + "totalQty": 1, + "totalWeight": null, + "carrierCode": null, + "carrierTitle": "newship", + "trackNumber": "7nh6354", + "emailSent": null, + "customerId": null, + "customerType": null, + "orderId": 1, + "orderAddressId": 5, + "createdAt": "2021-05-27 20:17:30", + "updatedAt": "2021-05-27 20:17:31", + "inventorySourceId": 1, + "inventorySourceName": "Default", + "order": { + "id": 1 + }, + "items": [ + { + "id": 1 + } + ], + "inventorySource": { + "id": "1" + }, + "customer": null + } + } + } + ~~~ +::: + +## Get All Refunds + +You can get all the Refunds from the Bagisto store. You can achieve this job by using the `Refunds` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query refunds { + refunds(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + adjustmentRefund + baseAdjustmentRefund + adjustmentFee + baseAdjustmentFee + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + orderId + createdAt + updatedAt + items{ + id + } + order{ + id + } + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "refunds": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": 1, + "incrementId": null, + "state": "refunded", + "emailSent": 0, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "adjustmentRefund": 0, + "baseAdjustmentRefund": 0, + "adjustmentFee": 0, + "baseAdjustmentFee": 0, + "subTotal": 4.5, + "baseSubTotal": 4.5, + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 1, + "createdAt": "2021-05-27 20:27:29", + "updatedAt": "2021-05-27 20:27:29", + "items": [ + { + "id": 1 + } + ], + "order": { + "id": 1 + }, + "success": null + } + ] + } + } +} +~~~ +::: + +## Get Refund By ID + +To get the specific Refund, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query refund { + refund(id:1){ + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + adjustmentRefund + baseAdjustmentRefund + adjustmentFee + baseAdjustmentFee + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + orderId + createdAt + updatedAt + items{ + id + } + order{ + id + } + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "refund": { + "id": 1, + "incrementId": null, + "state": "refunded", + "emailSent": 0, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "adjustmentRefund": 0, + "baseAdjustmentRefund": 0, + "adjustmentFee": 0, + "baseAdjustmentFee": 0, + "subTotal": 4.5, + "baseSubTotal": 4.5, + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 1, + "createdAt": "2021-05-27 20:27:29", + "updatedAt": "2021-05-27 20:27:29", + "items": [ + { + "id": 1 + } + ], + "order": { + "id": 1 + }, + "success": null + } + } + } + ~~~ + +::: + +## Create a new Order Refund + + To create a Order Refund , you have to perform mutation on Order Refund and paas the related fields in the request. + API call resource will create a new Order Refund , only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createRefund(input:{ + orderId:1 + refundShipping:10 + adjustmentRefund:0 + adjustmentFee:0 + refundData:{ + orderItemId:1 + quantity:1 + } + }){ + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + adjustmentRefund + baseAdjustmentRefund + adjustmentFee + baseAdjustmentFee + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + orderId + createdAt + updatedAt + items{id} + order{id} + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "createRefund": { + "id": 1, + "incrementId": null, + "state": "refunded", + "emailSent": null, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "adjustmentRefund": 0, + "baseAdjustmentRefund": 0, + "adjustmentFee": 0, + "baseAdjustmentFee": 0, + "subTotal": 4.5, + "baseSubTotal": 4.5, + "grandTotal": 14.5, + "baseGrandTotal": 14.5, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": null, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 1, + "createdAt": "2021-05-27 20:27:29", + "updatedAt": "2021-05-27 20:27:29", + "items": [ + { + "id": 1 + } + ], + "order": { + "id": 1 + }, + "success": "Refund created successfully." + } + } + } + ~~~ +::: + +## Cancel an Order + + To Cancel an Order , you have to perform mutation on Order and paas the related fields in the request. + API call resource will Cancel an Order , only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation cancelORder{ + cancelOrder(id:2) + {success} + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "cancelOrder": { + "success": "Order canceled successfully." + } + } + } + ~~~ +::: \ No newline at end of file diff --git a/docs/1.x/graphql-admin-api/settings.md b/docs/1.x/graphql-admin-api/settings.md new file mode 100644 index 00000000..fcb3be7d --- /dev/null +++ b/docs/1.x/graphql-admin-api/settings.md @@ -0,0 +1,3578 @@ +## Locales + +In this section, we will see all the APIs which are related to locales. + +### 1. Get all locales + +You can get all the locales from the Bagisto store. You can achieve this job by using the `locales` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query locales{ + locales(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + name + code + direction + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "locales": { + "paginatorInfo": { + "count": 4, + "currentPage": 1, + "lastPage": 1, + "total": 4 + }, + "data": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr", + "success": null + }, + { + "id": "2", + "name": "French", + "code": "fr", + "direction": "ltr", + "success": null + }, + { + "id": "3", + "name": "Dutch", + "code": "nl", + "direction": "ltr", + "success": null + }, + { + "id": "4", + "name": "Türkçe", + "code": "tr", + "direction": "ltr", + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Locale By ID + +To get the specific Locale, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query locales{ + locale(id:1){ + id + name + code + direction + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "locale": { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr", + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered Locale + +You can get the filter data from the Locales by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query locales{ + locales(input: { + code: "en" + name: "English" + direction: "ltr" + }){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + name + code + direction + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "locales": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "English", + "code": "en", + "direction": "ltr", + "success": null + } + ] + } + } + } + ~~~ + ::: + +### 4. Create a new Locale + + To create a Locale, you have to perform mutation on Locale and paas the related fields in the request. + API call resource will create a new Locale, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createChannel(input:{ + code:"newca" + name:"nerty" + description:"ajsyg" + theme:"gdg" + homePageContent:"fhg" + footerContent:"fh" + hostname:"http://bag1.com" + defaultLocaleId:1 + baseCurrencyId:1 + rootCategoryId:1 + locales:1 + currencies:1 + inventorySources:1 + seoTitle:"gfyj" + seoDescription:"gcg" + seoKeywords:"gvgh" + }) + { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales{id} + defaultLocale + currencies{id} + inventorySources{id} + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createChannel": { + "id": "2", + "code": "newca", + "name": "nerty", + "description": "ajsyg", + "theme": "gdg", + "homePageContent": "fhg", + "footerContent": "fh", + "hostname": "http://bag1.com", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\":\"gfyj\",\"meta_description\":\"gcg\",\"meta_keywords\":\"gvgh\"}", + "locales": [ + { + "id": "1" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1" + } + ], + "inventorySources": [ + { + "id": "1" + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + } + ~~~ +::: + +### 5. Update Locale + +By using this API call you can update the Locale. To do this , you have to perform update mutation on Locale and paas the related fields in the request. +API call will update a Locale, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateLocale(id:2,input:{ + code:"trr" + name:"Türkçe" + direction:"LTR" + }){ + id + name + code + direction + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateLocale": { + "id": "2", + "name": "Türkçe", + "code": "trr", + "direction": "LTR", + "success": null + } + } + } + ~~~ +::: + +### 6. Delete a Locale + +To delete a Locale, you have to perform mutation on Locale by passing the id of that Locale. +API call will delete a Locale, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteLocale(id:2){ + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteLocale": { + "success": "Locale deleted successfully." + } + } + } + ~~~ +::: + + + +## Currency + +In this section, we will see all the APIs which are related to Currencies. + +### 1. Get all Currencies + +You can get all the Currencies from the Bagisto store. You can achieve this job by using the `Currencies` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query currencies{ + currencies(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + name + code + symbol + exchangeRate { + id + targetCurrency + rate + createdAt + updatedAt + currency { + name + code + symbol + } + success + } + createdAt + updatedAt + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "currencies": { + "paginatorInfo": { + "count": 2, + "currentPage": 1, + "lastPage": 1, + "total": 2 + }, + "data": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$", + "exchangeRate": null, + "createdAt": null, + "updatedAt": null, + "success": null + }, + { + "id": "2", + "name": "Euro", + "code": "EUR", + "symbol": "€", + "exchangeRate": null, + "createdAt": null, + "updatedAt": null, + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Currency By ID + +To get the specific Currency, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query currency{ + currency(id:1){ + id + name + code + symbol + exchangeRate { + id + targetCurrency + rate + createdAt + updatedAt + + success + } + createdAt + updatedAt + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "currency": { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$", + "exchangeRate": null, + "createdAt": null, + "updatedAt": null, + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered Currency + +You can get the filter data from the Currencies by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query currencies{ + currencies(input:{ + id: 1 + code: "USD" + }){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + name + code + symbol + exchangeRate { + id + targetCurrency + rate + createdAt + updatedAt + currency { + name + code + symbol + } + success + } + createdAt + updatedAt + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "currencies": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "US Dollar", + "code": "USD", + "symbol": "$", + "exchangeRate": null, + "createdAt": null, + "updatedAt": null, + "success": null + } + ] + } + } + } + ~~~ + ::: + +### 4. Create a new Currency + + To create a Currency, you have to perform mutation on Currency and paas the related fields in the request. + API call will create a new Currency, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createCurrency(input:{ + name:"newcurrency" + code:"new" + symbol:"%" + }){ + id + name + code + symbol + exchangeRate{id} + createdAt + updatedAt + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createCurrency": { + "id": "3", + "name": "newcurrency", + "code": "NEW", + "symbol": "%", + "exchangeRate": null, + "createdAt": "2021-05-21 11:11:18", + "updatedAt": "2021-05-21 11:11:18", + "success": null + } + } + } + ~~~ +::: + +### 5. Update Currency + +By using this API call you can update the Currency. To do this , you have to perform update mutation on Currency and paas the related fields in the request. +API call will update a Currency, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateCurrency(id:3,input:{ + name:"ind" + code:"IND" + symbol:"&" + }) + { + id + name + code + symbol + exchangeRate{id} + createdAt + updatedAt + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateCurrency": { + "id": "3", + "name": "ind", + "code": "IND", + "symbol": "&", + "exchangeRate": null, + "createdAt": "2021-05-21 11:11:18", + "updatedAt": "2021-05-21 11:15:49", + "success": null + } + } + } + ~~~ +::: + +### 6. Delete a Currency + +To delete a Currency, you have to perform mutation on Currency by passing the id of that Currency. +API call will delete a Currency, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteCurrency(id:3) + { + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteCurrency": { + "success": "Currency deleted successfully." + } + } + } + ~~~ +::: + + + +## Exchange Rates + +In this section, we will see all the APIs which are related to Exchange Rates. + +### 1. Get all Exchange Rates + +You can get all the Exchange Rates from the Bagisto store. You can achieve this job by using the `Exchange Rates` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query exchangeRates{ + exchangeRates(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + targetCurrency + rate + createdAt + updatedAt + currency { + id + name + code + symbol + success + } + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "exchangeRates": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "targetCurrency": 2, + "rate": 1.5, + "createdAt": "2021-05-21 11:57:49", + "updatedAt": "2021-05-21 11:57:49", + "currency": { + "id": "2", + "name": "Euro", + "code": "EUR", + "symbol": "€", + "success": null + }, + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Exchange Rate By ID + +To get the specific Exchange Rate, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query exchangeRate{ + exchangeRate(id:1){ + + id + targetCurrency + rate + createdAt + updatedAt + currency { + id + name + code + symbol + success + } + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "exchangeRate": { + "id": "1", + "targetCurrency": 2, + "rate": 1.5, + "createdAt": "2021-05-21 11:57:49", + "updatedAt": "2021-05-21 11:57:49", + "currency": { + "id": "2", + "name": "Euro", + "code": "EUR", + "symbol": "€", + "success": null + }, + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered Exchange Rates + +You can get the filter data from the Exchange Rates by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query exchangeRates{ + exchangeRates(input: { + id : 1 + currency: "EUR" + }, page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + targetCurrency + rate + createdAt + updatedAt + currency { + id + name + code + symbol + success + } + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "exchangeRates": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "targetCurrency": 2, + "rate": 1.5, + "createdAt": "2021-05-21 11:57:49", + "updatedAt": "2021-05-21 11:57:49", + "currency": { + "id": "2", + "name": "Euro", + "code": "EUR", + "symbol": "€", + "success": null + }, + "success": null + } + ] + } + } + ~~~ + ::: + +### 4. Create a new Exchange Rate + + To create a Exchange Rate, you have to perform mutation on Exchange Rate and paas the related fields in the request. + API call will create a new Exchange Rate, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createExchangeRate(input:{ + targetCurrency:2 + rate:5 + }){ + id + targetCurrency + rate + createdAt + updatedAt + # currency{id} + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createExchangeRate": { + "id": "2", + "targetCurrency": 2, + "rate": 5, + "createdAt": "2021-05-21 13:09:42", + "updatedAt": "2021-05-21 13:09:42", + "success": null + } + } + } + ~~~ +::: + +### 5. Update Exchange Rate + +By using this API call you can update the Exchange Rate. To do this , you have to perform update mutation on Exchange Rate and paas the related fields in the request. +API call will update a Exchange Rate, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateExchangeRate(id:2,input:{ + targetCurrency:2 + rate:2.5 + }){ + id + targetCurrency + rate + createdAt + updatedAt + currency{id} + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateExchangeRate": { + "id": "2", + "targetCurrency": 2, + "rate": 2.5, + "createdAt": "2021-05-21 13:09:42", + "updatedAt": "2021-05-21 13:22:17", + "currency": { + "id": "2" + }, + "success": null + } + } + } + ~~~ +::: + +### 6. Delete a Exchange Rate + +To delete a Exchange Rate, you have to perform mutation on Exchange Rate by passing the id of that Exchange Rate. +API call will delete a Exchange Rate, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteExchangeRate(id:2){ + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteExchangeRate": { + "success": "Exchange Rate deleted successfully." + } + } + } + ~~~ +::: + +## Inventory Sources + +In this section, we will see all the APIs which are related to Inventory Sources. + +### 1. Get all Inventory Sources + +You can get all the Inventory Sources from the Bagisto store. You can achieve this job by using the `invetory-sources` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query inventorySources{ + inventorySources(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "inventorySources": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true, + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Inventory Source By ID + +To get the specific Inventory Source, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query inventorySource{ + inventorySource(id:1){ + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true, + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered Inventory Source + +You can get the filter data from the Inventory Sources by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query inventorySources{ + inventorySources(input: { + id: 1 + code: "default" + name: "Default" + priority: 0 + status: true + },page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "inventorySources": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true, + "success": null + } + ] + } + } + } + ~~~ + ::: + +### 4. Create a new Inventory Source + + To create a Inventory Source, you have to perform mutation on Inventory Source and paas the related fields in the request. + API call resource will create a new Inventory Source, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createInventorySource(input:{ + code:"demo" + name:"demoinventory" + description:"demo" + contactName:"naresh.verma" + contactEmail:"naresh.verma327@webkul.com" + contactNumber:"7252756566" + country:"IN" + state:"UK" + city:"nainital" + street:"ramnagar" + postcode:"263140" + priority:1 + status:true + }){ + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createInventorySource": { + "id": "3", + "code": "demo", + "name": "demoinventory", + "description": "demo", + "contactName": "naresh.verma", + "contactEmail": "naresh.verma327@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UK", + "city": "nainital", + "street": "ramnagar", + "postcode": "263140", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true, + "success": null + } + } + } + ~~~ +::: + +### 5. Update Inventory Source + +By using this API call you can update the Inventory Source. To do this , you have to perform update mutation on Inventory Source and paas the related fields in the request. +API call will update a Inventory Source, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateInventorySource(id:3,input:{ + code:"demoupdate" + name:"demoinventory" + description:"demo" + contactName:"naresh.verma" + contactEmail:"naresh.verma327@webkul.com" + contactNumber:"7252756566" + country:"IN" + state:"UK" + city:"nainital" + street:"ramnagar" + postcode:"263140" + priority:1 + status:true + }){ + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateInventorySource": { + "id": "3", + "code": "demoupdate", + "name": "demoinventory", + "description": "demo", + "contactName": "naresh.verma", + "contactEmail": "naresh.verma327@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UK", + "city": "nainital", + "street": "ramnagar", + "postcode": "263140", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true, + "success": null + } + } + } + ~~~ +::: + +### 6. Delete a Inventory Source + +To delete a Inventory Source, you have to perform mutation on Inventory Source by passing the id of that Inventory Source. +API call will delete a Inventory Source, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteInventorySource(id:3){ + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteInventorySource": { + "success": "Inventory source deleted successfully." + } + } + } + ~~~ +::: + +## Channels + +In this section, we will see all the APIs which are related to channels. + +### 1. Get all channels + +You can get all the channels from the Bagisto store. You can achieve this job by using the `channels` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query channels{ + channels(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales{id} + defaultLocale + currencies{id} + inventorySources{id} + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } + } + ~~~ +::: tip + + You can use all fields to get the all related data. like here we have used `locales` field and and under this resource we have user id , so you can get all the related fields to locale here by defining the locale fields in the request query. + +::: + +::: details Response + +~~~json +{ + "data": { + "channels": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "locales": [ + { + "id": "1" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1" + } + ], + "inventorySources": [ + { + "id": "1" + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Channel By ID + +To get the specific channel, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query channels{ + channel(id:1){ + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales{id} + defaultLocale + currencies{id} + inventorySources{id} + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "channel": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "locales": [ + { + "id": "1" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1" + } + ], + "inventorySources": [ + { + "id": "1" + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered Channels + +You can get the filter data from the channels by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query +query channels{ + channels(input: { + id: 1 + code: "default" + hostname: "http://localhost/graphql/public" + }){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales{ + id + } + defaultLocale + currencies{ + id + } + inventorySources{ + id + } + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } +} +~~~ + +::: details Response + ~~~json + { + "data": { + "channels": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "locales": [ + { + "id": "1" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1" + } + ], + "inventorySources": [ + { + "id": "1" + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + ] + } + } + } + ~~~ + ::: + +### 4. Create a new Channel + + To create a Channel, you have to perform mutation on Channel and paas the related fields in the request. + API call resource will create a new Channel, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createChannel(input:{ + code:"newca" + name:"nerty" + description:"ajsyg" + theme:"gdg" + homePageContent:"fhg" + footerContent:"fh" + hostname:"http://bag1.com" + defaultLocaleId:1 + baseCurrencyId:1 + rootCategoryId:1 + locales:1 + currencies:1 + inventorySources:1 + seoTitle:"gfyj" + seoDescription:"gcg" + seoKeywords:"gvgh" + }) + { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales{id} + defaultLocale + currencies{id} + inventorySources{id} + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createChannel": { + "id": "2", + "code": "newca", + "name": "nerty", + "description": "ajsyg", + "theme": "gdg", + "homePageContent": "fhg", + "footerContent": "fh", + "hostname": "http://bag1.com", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\":\"gfyj\",\"meta_description\":\"gcg\",\"meta_keywords\":\"gvgh\"}", + "locales": [ + { + "id": "1" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1" + } + ], + "inventorySources": [ + { + "id": "1" + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + } + ~~~ +::: + +### 5. Update Channel + +By using this API call you can update the channel. To do this , you have to perform update mutation on Channel and paas the related fields in the request. + API call resource will update a Channel, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateChannel(id:3,input:{ + code:"newca" + name:"newchannel" + description:"fjy" + theme:"default" + homePageContent:"wfedh" + footerContent:"wygdeyjufw" + hostname:"http:newhost" + defaultLocaleId:1 + baseCurrencyId:1 + rootCategoryId:1 + locales:1 + currencies:1 + inventorySources:1 + seoTitle:"hghefd" + seoDescription:"whfj" + seoKeywords:"wedf" + }) + { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + locales{id} + defaultLocale + currencies{id} + inventorySources{id} + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateChannel": { + "id": "3", + "code": "newchannel", + "name": "newchannel", + "description": "fjy", + "theme": "default", + "homePageContent": "wfedh", + "footerContent": "wygdeyjufw", + "hostname": "http:newhost", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\":\"hghefd\",\"meta_description\":\"whfj\",\"meta_keywords\":\"wedf\"}", + "locales": [ + { + "id": "1" + } + ], + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "currencies": [ + { + "id": "1" + } + ], + "inventorySources": [ + { + "id": "1" + } + ], + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":14,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + } + ~~~ +::: + +### 6. Delete a Channel + +To delete a Channel, you have to perform mutation on Channel by passing the id of that Channel. +API call resource will channel a Channel, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteChannel(id:3) + { + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteChannel": { + "success": "Channel deleted successfully." + } + } + } + ~~~ +::: + +## Sliders + +In this section, we will see all the APIs which are related to Slider. + +### 1. Get all Slider + +You can get all the Slider from the Bagisto store. You can achieve this job by using the `slider` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query sliders{ + sliders(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + title + path + content + channelId + locale + sliderPath + imgPath + channel{ + id + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "sliders": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "title": "testslider", + "path": "slider_images/Default/1L0uZrZrMaadZGRh8pNCLcKXNhrhQugs84AXRkui.jpg", + "content": "

testcontent

", + "channelId": "1", + "locale": "en", + "sliderPath": "test", + "imgPath": null, + "channel": { + "id": "1" + } + } + ] + } + } +} +~~~ +::: + +### 2. Get Slider By ID + +To get the specific Slider, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query slider{ + slider(id:1){ + id + title + path + content + channelId + locale + sliderPath + imgPath + channel{ + id + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "slider": { + "id": "1", + "title": "testslider", + "path": "slider_images/Default/1L0uZrZrMaadZGRh8pNCLcKXNhrhQugs84AXRkui.jpg", + "content": "

testcontent

", + "channelId": "1", + "locale": "en", + "sliderPath": "test", + "imgPath": null, + "channel": { + "id": "1" + } + } + } + } + ~~~ + +::: + +### 3. Get Filtered Sliders + +You can get the filter data from the Sliders by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query sliders{ + sliders(input: { + id:1 + title: "testslider" + locale: "en" + },page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + title + path + content + channelId + locale + sliderPath + imgPath + channel{ + id + } + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "sliders": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "title": "testslider", + "path": "slider_images/Default/1L0uZrZrMaadZGRh8pNCLcKXNhrhQugs84AXRkui.jpg", + "content": "

testcontent

", + "channelId": "1", + "locale": "en", + "sliderPath": "test", + "imgPath": null, + "channel": { + "id": "1" + } + } + ] + } + } + } + ~~~ +::: + +## User Roles + +In this section, we will see all the APIs which are related to User Roles. + +### 1. Get all User Roles + +You can get all the User Roles from the Bagisto store. You can achieve this job by using the `user roles` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query roles{ + roles(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + name + description + permissionType + permissions + createdAt + updatedAt + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "roles": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "Administrator", + "description": "Administrator role", + "permissionType": "all", + "permissions": null, + "createdAt": null, + "updatedAt": null, + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get User Roles By ID + +To get the specific User Roles, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query role{ + role(id:1){ + id + name + description + permissionType + permissions + createdAt + updatedAt + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "role": { + "id": "1", + "name": "Administrator", + "description": "Administrator role", + "permissionType": "all", + "permissions": null, + "createdAt": null, + "updatedAt": null, + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered User Roles + +You can get the filter data from the User Roles by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query roles{ + roles(input: { + name: "Administrator" + permissionType: "all" + }, page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + name + description + permissionType + permissions + createdAt + updatedAt + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "roles": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "name": "Administrator", + "description": "Administrator role", + "permissionType": "all", + "permissions": null, + "createdAt": null, + "updatedAt": null, + "success": null + } + ] + } + } + } + ~~~ +::: + +### 4. Create a new User Roles + + To create a User Roles, you have to perform mutation on User Roles and paas the related fields in the request. + API call resource will create a new User Roles, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createRole(input:{ + name:"custom" + description:"rle description fo user" + permissionType:"Custom" + permissions:["dashboard","sales","sales.orders"] + }){ + id + name + description + permissionType + permissions + createdAt + updatedAt + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createRole": { + "id": "2", + "name": "custom", + "description": "rle description fo user", + "permissionType": "Custom", + "permissions": [ + "dashboard", + "sales", + "sales.orders" + ], + "createdAt": "2021-05-21 17:35:21", + "updatedAt": "2021-05-21 17:35:21", + "success": null + } + } + } + ~~~ +::: + +### 5. Update User Roles + +By using this API call you can update the User Roles. To do this , you have to perform update mutation on User Roles and paas the related fields in the request. + API call resource will update a User Roles, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateRole(id:2,input:{ + name:"custom" + description:"hsdh" + permissionType:"Custom" + permissions:["Dashboard","Sales","Sales.Orders","Sales.Invoice","Sales.Shipment"] + }) + { + id + name + description + permissionType + permissions + createdAt + updatedAt + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateRole": { + "id": "2", + "name": "custom", + "description": "hsdh", + "permissionType": "Custom", + "permissions": [ + "Dashboard", + "Sales", + "Sales.Orders", + "Sales.Invoice", + "Sales.Shipment" + ], + "createdAt": "2021-05-21 17:35:21", + "updatedAt": "2021-05-21 17:38:35", + "success": null + } + } + } + ~~~ +::: + +### 6. Delete a User Roles + +To delete a User Roles, you have to perform mutation on User Roles by passing the id of that User Roles. +API call resource will User Roles a User Roles, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteRole(id:2){ + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteRole": { + "success": "Role deleted successfully." + } + } + } + ~~~ +::: + +## Tax Rates + +In this section, we will see all the APIs which are related to Tax Rates. + +### 1. Get all Tax Rates + +You can get all the Tax Rates from the Bagisto store. You can achieve this job by using the `tax rates` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query taxRates{ + taxRates(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + identifier + isZip + zipCode + zipFrom + zipTo + state + country + taxRate + taxCategories{ + id + code + name + } + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "taxRates": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "identifier": "test", + "isZip": 1, + "zipCode": null, + "zipFrom": "46077", + "zipTo": "46080", + "state": "KL", + "country": "IN", + "taxRate": 3, + "taxCategories": [], + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Tax Rates By ID + +To get the specific Tax Rates, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query taxRate{ + taxRate(id:1){ + id + identifier + isZip + zipCode + zipFrom + zipTo + state + country + taxRate + taxCategories{ + id + code + name + } + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "taxRate": { + "id": "1", + "identifier": "test", + "isZip": 1, + "zipCode": null, + "zipFrom": "46077", + "zipTo": "46080", + "state": "KL", + "country": "IN", + "taxRate": 3, + "taxCategories": [], + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered Tax Rates + +You can get the filter data from the Tax Rates by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query taxRates{ + taxRates(input: { + id: 1 + identifier: "test" + isZip: 1 + }, page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + identifier + isZip + zipCode + zipFrom + zipTo + state + country + taxRate + taxCategories{ + id + code + name + } + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "taxRates": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "identifier": "test", + "isZip": 1, + "zipCode": null, + "zipFrom": "46077", + "zipTo": "46080", + "state": "KL", + "country": "IN", + "taxRate": 3, + "taxCategories": [], + "success": null + } + ] + } + } + } + ~~~ +::: + +### 4. Create a new Tax Rate + + To create a Tax Rate, you have to perform mutation on Tax Rate and paas the related fields in the request. + API call resource will create a new Tax Rate, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createTaxRate(input:{ + identifier:"taxrate3" + isZip:1 + zipFrom:"201301" + zipTo:"273003" + state:"UP" + country:"IN" + taxRate:5 + }){ + id + identifier + isZip + zipCode + zipFrom + zipTo + state + country + taxRate + taxCategories{id} + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createTaxRate": { + "id": "2", + "identifier": "taxrate3", + "isZip": 1, + "zipCode": null, + "zipFrom": "201301", + "zipTo": "273003", + "state": "UP", + "country": "IN", + "taxRate": 5, + "taxCategories": [], + "success": null + } + } + } + ~~~ +::: + +### 5. Update Tax Rate + +By using this API call you can update the Tax Rate. To do this , you have to perform update mutation on Tax Rate and paas the related fields in the request. + API call resource will update a Tax Rate, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateTaxRate(id:2,input:{ + identifier:"NEW" + isZip:1 + zipCode:"0" + zipFrom:"201301" + zipTo:"273003" + state:"UP" + country:"IN" + taxRate:2 + }){ + id + identifier + isZip + zipCode + zipFrom + zipTo + state + country + taxRate + taxCategories{id} + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateTaxRate": { + "id": "2", + "identifier": "NEW", + "isZip": 1, + "zipCode": "0", + "zipFrom": "201301", + "zipTo": "273003", + "state": "UP", + "country": "IN", + "taxRate": 2, + "taxCategories": [], + "success": null + } + } + } + ~~~ +::: + +### 6. Delete a Tax Rate + +To delete a Tax Rate, you have to perform mutation on Tax Rate by passing the id of that Tax Rate. +API call resource will Tax Rate a Tax Rate, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteTaxRate(id:2){ + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteTaxRate": { + "success": "Tax Rate deleted successfully." + } + } + } + ~~~ +::: + +## Tax Categories + +In this section, we will see all the APIs which are related to Tax Categories. + +### 1. Get all Tax Categories + +You can get all the Tax Categories from the Bagisto store. You can achieve this job by using the `tax categories` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query taxCategories{ + taxCategories(page:1){ + paginatorInfo { + count + currentPage + lastPage + total + } + data{ + id + code + name + description + taxRates{id} + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "taxCategories": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "code": "test1", + "name": "testCategory", + "description": "testCategory", + "taxRates": [ + { + "id": "1" + } + ], + "success": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Tax Category By ID + +To get the specific Tax Category, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query taxCategory{ + taxCategory(id:1){ + id + code + name + description + taxRates{ + id + identifier + isZip + zipCode + zipFrom + zipTo + state + country + taxRate + } + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "taxCategory": { + "id": "1", + "code": "test1", + "name": "testCategory", + "description": "testCategory", + "taxRates": [ + { + "id": "1", + "identifier": "test", + "isZip": 1, + "zipCode": null, + "zipFrom": "46077", + "zipTo": "46080", + "state": "KL", + "country": "IN", + "taxRate": 3 + } + ], + "success": null + } + } + } + ~~~ + +::: + +### 3. Get Filtered Tax Categories + +You can get the filter data from the Tax Categories by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query taxCategories{ + taxCategories(input: { + id: 1 + code: "test1" + name: "testCategory" + },page:1){ + paginatorInfo { + count + currentPage + lastPage + total + + } + data{ + id + code + name + description + taxRates{id} + success + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "taxCategories": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "code": "test1", + "name": "testCategory", + "description": "testCategory", + "taxRates": [ + { + "id": "1" + } + ], + "success": null + } + ] + } + } + } + ~~~ +::: + +### 4. Create a new Tax Category + + To create a Tax Category, you have to perform mutation on Tax Category and paas the related fields in the request. + API call resource will create a new Tax Category, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + createTaxCategory(input:{ + code:"taxablegoods" + name:"TaxableGoods" + description:"hgasgsja" + taxrates:1 + }) + { + id + code + name + description + taxRates{id} + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createTaxCategory": { + "id": "2", + "code": "taxablegoods", + "name": "TaxableGoods", + "description": "hgasgsja", + "taxRates": [ + { + "id": "1" + } + ], + "success": null + } + } + } + ~~~ +::: + +### 5. Update Tax Category + +By using this API call you can update the Tax Category. To do this , you have to perform update mutation on Tax Category and paas the related fields in the request. + API call resource will update a Tax Category, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateTaxCategory(id:2,input:{ + code:"taxable" + name:"TaxableGoods" + description:"adding taxrate" + taxrates:1 + + }){ + id + code + name + description + taxRates{id} + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateTaxCategory": { + "id": "2", + "code": "taxable", + "name": "TaxableGoods", + "description": "adding taxrate", + "taxRates": [ + { + "id": "1" + } + ], + "success": null + } + } + } + ~~~ +::: + +### 6. Delete a Tax Category + +To delete a Tax Category, you have to perform mutation on Tax Category by passing the id of that Tax Category. +API call resource will Tax Category a Tax Category, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + deleteTaxCategory(id:2){ + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteTaxCategory": { + "success": "Tax Category deleted successfully." + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-admin-api/velocity.md b/docs/1.x/graphql-admin-api/velocity.md new file mode 100644 index 00000000..8f575069 --- /dev/null +++ b/docs/1.x/graphql-admin-api/velocity.md @@ -0,0 +1,897 @@ +## Meta Data + +In this section, we will see all the APIs which are related to Velocity Meta Data. + +### 1. Get MetaData + +You can get all the MetaData from the Bagisto store. You can achieve this job by using the `MetaData` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query velocityMetaData { + velocityMetaData(page: 1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + homePageContent + footerLeftContent + footerMiddleContent + slider + advertisement + sidebarCategoryCount + featuredProductCount + newProductsCount + subscriptionBarContent + productViewImages + productPolicy + locale + channel + headerContentCount + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "velocityMetaData": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "homePageContent": "

@include('shop::home.advertisements.advertisement-four')@include('shop::home.featured-products') @include('shop::home.product-policy') @include('shop::home.advertisements.advertisement-three') @include('shop::home.new-products') @include('shop::home.advertisements.advertisement-two')

", + "footerLeftContent": "

We love to craft softwares and solve the real world problems with the binaries. We are highly committed to our goals. We invest our resources to create world class easy to use softwares and applications for the enterprise business with the top notch, on the edge technology expertise.

", + "footerMiddleContent": "", + "slider": true, + "advertisement": "null", + "sidebarCategoryCount": 9, + "featuredProductCount": 10, + "newProductsCount": 10, + "subscriptionBarContent": "", + "productViewImages": null, + "productPolicy": "
Free Shipping on Order $20 or More
Product Replace & Return Available
Product Exchange and EMI Available
", + "locale": "en", + "channel": "default", + "headerContentCount": "5", + "createdAt": null, + "updatedAt": null + } + ] + } + } +} +~~~ +::: + +### 2. Get Meta Data By ID + +To get the specific Meta Data, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query metaData { + metaData(id: 1){ + id + homePageContent + footerLeftContent + footerMiddleContent + slider + advertisement + sidebarCategoryCount + featuredProductCount + newProductsCount + subscriptionBarContent + productViewImages + productPolicy + locale + channel + headerContentCount + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "metaData": { + "id": "1", + "homePageContent": "

@include('shop::home.advertisements.advertisement-four')@include('shop::home.featured-products') @include('shop::home.product-policy') @include('shop::home.advertisements.advertisement-three') @include('shop::home.new-products') @include('shop::home.advertisements.advertisement-two')

", + "footerLeftContent": "

We love to craft softwares and solve the real world problems with the binaries. We are highly committed to our goals. We invest our resources to create world class easy to use softwares and applications for the enterprise business with the top notch, on the edge technology expertise.

", + "footerMiddleContent": "", + "slider": true, + "advertisement": "null", + "sidebarCategoryCount": 9, + "featuredProductCount": 10, + "newProductsCount": 10, + "subscriptionBarContent": "", + "productViewImages": null, + "productPolicy": "
Free Shipping on Order $20 or More
Product Replace & Return Available
Product Exchange and EMI Available
", + "locale": "en", + "channel": "default", + "headerContentCount": "5", + "createdAt": null, + "updatedAt": null + } + } + } + ~~~ + +::: + +### 3. Update Meta Data + +By using this API call you can update the Meta Data. To do this , you have to perform update mutation on Meta Data and paas the related fields in the request. +API call will update a Meta Data, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation{ + updateMetaData(id:1,input:{ + homePageContent: "

@include('shop::home.advertisements.advertisement-four')@include('shop::home.featured-products') @include('shop::home.product-policy') @include('shop::home.advertisements.advertisement-three') @include('shop::home.new-products') @include('shop::home.advertisements.advertisement-two')

", + footerLeftContent: "

We love to craft softwares and solve the real world problems with the binaries. We are highly committed to our goals. We invest our resources to create world class easy to use softwares and applications for the enterprise business with the top notch, on the edge technology expertise.

", + footerMiddleContent: "", + slider: true, + sidebarCategoryCount: 9, + featuredProductCount: 5, + newProductsCount: 5, + subscriptionBarContent: "", + productPolicy: "
Free Shipping on Order $20 or More
Product Replace & Return Available
Product Exchange and EMI Available
", + locale: "en", + channel: "default", + headerContentCount: 9, + images: { + advertisementFour: [ + "https://demo.bagisto.com/bagisto-182-75-44-194/cache/large/product/157/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + "https://demo.bagisto.com/bagisto-182-75-44-194/cache/large/product/157/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + ] + advertisementThree: [ + "https://demo.bagisto.com/bagisto-182-75-44-194/cache/large/product/157/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + "https://demo.bagisto.com/stripe-common/themes/velocity/assets/images/big-sale-banner.png" + ] + advertisementTwo: [ + "https://demo.bagisto.com/bagisto-182-75-44-194/cache/large/product/157/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + "https://demo.bagisto.com/bagisto-182-75-44-194/cache/large/product/157/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + ] + } + }) { + id + homePageContent + footerLeftContent + footerMiddleContent + slider + advertisement + sidebarCategoryCount + featuredProductCount + newProductsCount + subscriptionBarContent + productViewImages + productPolicy + locale + channel + headerContentCount + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateMetaData": { + "id": "1", + "homePageContent": "

@include('shop::home.advertisements.advertisement-four')@include('shop::home.featured-products') @include('shop::home.product-policy') @include('shop::home.advertisements.advertisement-three') @include('shop::home.new-products') @include('shop::home.advertisements.advertisement-two')

", + "footerLeftContent": "

We love to craft softwares and solve the real world problems with the binaries. We are highly committed to our goals. We invest our resources to create world class easy to use softwares and applications for the enterprise business with the top notch, on the edge technology expertise.

", + "footerMiddleContent": "", + "slider": true, + "advertisement": "null", + "sidebarCategoryCount": 9, + "featuredProductCount": 5, + "newProductsCount": 5, + "subscriptionBarContent": "", + "productViewImages": null, + "productPolicy": "
Free Shipping on Order $20 or More
Product Replace & Return Available
Product Exchange and EMI Available
", + "locale": "en", + "channel": "default", + "headerContentCount": "9", + "createdAt": null, + "updatedAt": "2021-05-26 13:22:10" + } + } + } + ~~~ +::: + +## Header Content + +In this section, we will see all the APIs which are related to Velocity Meta Data. + +### 1. Get Header Content + +You can get all the Header Content from the Bagisto store. You can achieve this job by using the `Header Content` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note**: You can pass all the related fileds that you want in response. + +- Query + ~~~query + query headerContents { + headerContents { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + contentType + position + status + translations { + id + contentId + title + customTitle + customHeading + pageLink + linkTarget + catalogType + products + description + locale + createdAt + updatedAt + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "headerContents": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "contentType": "category", + "position": 1, + "status": true, + "translations": [ + { + "id": "1", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": "test", + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "en", + "createdAt": null, + "updatedAt": null + }, + { + "id": "2", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "nl", + "createdAt": null, + "updatedAt": null + }, + { + "id": "3", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "tr", + "createdAt": null, + "updatedAt": null + } + ] + } + ] + } + } +} +~~~ +::: + +### 2. Get Header Content By ID + +To get the specific Header Content, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query headerContent { + headerContent(id: 1) { + id + contentType + position + status + translations { + id + contentId + title + customTitle + customHeading + pageLink + linkTarget + catalogType + products + description + locale + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "headerContent": { + "id": "1", + "contentType": "category", + "position": 1, + "status": true, + "translations": [ + { + "id": "1", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": "test", + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "en", + "createdAt": null, + "updatedAt": null + }, + { + "id": "2", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "nl", + "createdAt": null, + "updatedAt": null + }, + { + "id": "3", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "tr", + "createdAt": null, + "updatedAt": null + } + ] + } + } + } + ~~~ +::: + +### 3. Get Filtered Header Content + +You can get the filter data from the Header Content by passing the input fileds in the request and that you want in the response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +**Note**: You can pass all the related fileds that you want in response. + +### Examples + +Let's take an example, + +- Request Query + +~~~query + query headerContents { + headerContents(input: { + id:1 + contentType: "category" + }, page: 1) { + paginatorInfo { + count + currentPage + lastPage + total + } + data { + id + contentType + position + status + translations { + id + contentId + title + customTitle + customHeading + pageLink + linkTarget + catalogType + products + description + locale + createdAt + updatedAt + } + } + } + } +~~~ + +::: details Response + ~~~json + { + "data": { + "headerContents": { + "paginatorInfo": { + "count": 1, + "currentPage": 1, + "lastPage": 1, + "total": 1 + }, + "data": [ + { + "id": "1", + "contentType": "category", + "position": 1, + "status": true, + "translations": [ + { + "id": "1", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": "test", + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "en", + "createdAt": null, + "updatedAt": null + }, + { + "id": "2", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "nl", + "createdAt": null, + "updatedAt": null + }, + { + "id": "3", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "tr", + "createdAt": null, + "updatedAt": null + } + ] + } + ] + } + } + } + ~~~ +::: + +### 4. Create a new Header Content + + To create a Header Content, you have to perform mutation on Header Content and paas the related fields in the request. + API call resource will create a new Header Content, only if the admin has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createHeaderContent { + createHeaderContent(input: { + title: "Test" + position: 2 + status: false + contentType: "category" + locale: "en" + pageLink: "test" + linkTarget: true + }) { + id + contentType + position + status + translations { + id + contentId + title + customTitle + customHeading + pageLink + linkTarget + catalogType + products + description + locale + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createHeaderContent": { + "id": "2", + "contentType": "category", + "position": 2, + "status": false, + "translations": [ + { + "id": "4", + "contentId": "2", + "title": "Test", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "en", + "createdAt": null, + "updatedAt": null + }, + { + "id": "5", + "contentId": "2", + "title": "Test", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "nl", + "createdAt": null, + "updatedAt": null + }, + { + "id": "6", + "contentId": "2", + "title": "Test", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "tr", + "createdAt": null, + "updatedAt": null + } + ] + } + } + } + ~~~ +::: + +### 5. Update Header Content + +By using this API call you can update the Header Content. To do this , you have to perform update mutation on Header Content and paas the related fields in the request. +API call will update a Header Content, only if the admin has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateHeaderContent { + updateHeaderContent( + id: 1, + input: { + title: "Test" + position: 2 + status: true + contentType: "category" + locale: "en" + pageLink: "test" + linkTarget: false + } + ) { + id + contentType + position + status + translations { + id + contentId + title + customTitle + customHeading + pageLink + linkTarget + catalogType + products + description + locale + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateHeaderContent": { + "id": "1", + "contentType": "category", + "position": 2, + "status": true, + "translations": [ + { + "id": "1", + "contentId": "1", + "title": "Test", + "customTitle": null, + "customHeading": null, + "pageLink": "test", + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "en", + "createdAt": null, + "updatedAt": null + }, + { + "id": "2", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "nl", + "createdAt": null, + "updatedAt": null + }, + { + "id": "3", + "contentId": "1", + "title": "Test Header Content", + "customTitle": null, + "customHeading": null, + "pageLink": null, + "linkTarget": false, + "catalogType": null, + "products": null, + "description": null, + "locale": "tr", + "createdAt": null, + "updatedAt": null + } + ] + } + } + } + ~~~ +::: + +### 6. Delete a Header Content + +To delete a Header Content, you have to perform mutation on Header Content by passing the id of that Header Content. +API call will delete a Header Content, only if the admin has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteHeaderContent { + deleteHeaderContent(id: 1) { + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteHeaderContent": { + "success": "Header Content deleted successfully." + } + } + } + ~~~ +: \ No newline at end of file diff --git a/docs/1.x/graphql-shop-api/README.md b/docs/1.x/graphql-shop-api/README.md new file mode 100644 index 00000000..a07c400a --- /dev/null +++ b/docs/1.x/graphql-shop-api/README.md @@ -0,0 +1,38 @@ +# Bagisto GraphQL Shop APIs + +Bagisto GraphQL Shop API is a medium to use the features of the core Bagisto Shop System. By using Bagisto GraphQL Shop API, you can integrate your application to serve the default content of Bagisto. + +**To download and contribute: [Bagisto GraphQL API GitHub](https://github.com/bagisto/headless-ecommerce/)** + + +## Key Features + +- Bagisto GraphQL API provides a complete and understandable description of the data. +- Authentication: Customer Authentication with Login Details. +- Authentication: Admin Authentication with Login Details. +- Provide access to performed CRUD operations. +- Provide the option to filter the responses based on attribute fields. +- The Framework supports the pagination which helps to increase the performance of application. +- Get many resources in a single request. + +## Request + +- `http(s)://example.com/graphql` + +## Where can I use Bagisto GraphQL APIs? + +We can use the Bagisto GraphQL APIs in different areas. Some of them are: + +- To build a PWA (Progressive Web Application) application, which uses modern web capabilities to deliver an application like experience to the users and provide more user friendly experience than a web application. + +- Use to integrate an Online-Shopping Mobile Application with the Bagisto Store to help the customers make purchase. + +- Use to integrate with CRM (Customer Relationship Management) systems Like: HubSpot, Salesforce etc. which allows you to manage the business relationships with your customers to help you grow your business. + +- To provide exactly what you need and nothing more. + +- To get Predictable result. + +- Applications using GraphQL can be quick even on slow mobile network connections. + +- Applications for devices where bandwidth usage matters. \ No newline at end of file diff --git a/docs/1.x/graphql-shop-api/addresses.md b/docs/1.x/graphql-shop-api/addresses.md new file mode 100644 index 00000000..753b5e9f --- /dev/null +++ b/docs/1.x/graphql-shop-api/addresses.md @@ -0,0 +1,368 @@ +# Customer Addresses + +In this section, we will see all the APIs which are related to Customer Addresses. + +## Get Customer Addresses + +You can get all the Customer Addresses from the Bagisto store. You can achieve this job by using the `Customer Addresses` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query addresses { + addresses { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "addresses": [ + { + "id": "11", + "customerId": 5, + "companyName": "Webkul", + "firstName": "Tom Demo", + "lastName": "Martin Demo", + "address1": "3180 Bluff", + "address2": "Street", + "country": "US", + "state": "PA", + "city": "GLEN CAMPBELL", + "postcode": "15742", + "phone": "234343544", + "vatId": "INV12345678904", + "addressType": "customer", + "defaultAddress": false, + "createdAt": "2021-05-28 12:59:29", + "updatedAt": "2021-05-28 12:59:29" + }, + { + "id": "12", + "customerId": 5, + "companyName": "Webkul2", + "firstName": "Tom Demo2", + "lastName": "Martin Demo2", + "address1": "3180 Bluff", + "address2": "Street", + "country": "US", + "state": "PA", + "city": "GLEN CAMPBELL", + "postcode": "15742222222", + "phone": "234343544", + "vatId": "INV12345678904", + "addressType": "customer", + "defaultAddress": false, + "createdAt": "2021-05-28 12:59:46", + "updatedAt": "2021-05-28 12:59:46" + } + ] + } +} +~~~ +::: + +## Get Customer Address By ID + +To get the specific Customer Address, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query address { + address(id: 11) { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "address": { + "id": "11", + "customerId": 5, + "companyName": "Webkul", + "firstName": "Tom Demo", + "lastName": "Martin Demo", + "address1": "3180 Bluff", + "address2": "Street", + "country": "US", + "state": "PA", + "city": "GLEN CAMPBELL", + "postcode": "15742", + "phone": "234343544", + "vatId": "INV12345678904", + "addressType": "customer", + "defaultAddress": false, + "createdAt": "2021-05-28 12:59:29", + "updatedAt": "2021-05-28 12:59:29" + } + } + } + ~~~ +::: + + +## Create a new Customer Address + + To create a Customer Address, you have to perform mutation on Customer Address and paas the related fields in the request. + API call resource will create a new Customer Address, only if the Customer has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createAddress { + createAddress(input: { + companyName: "Webkul2" + firstName: "Tom Demo2" + lastName: "Martin Demo2" + address1: "3180 Bluff" + address2: "Street" + country: "US" + state: "PA" + city: "GLEN CAMPBELL" + postcode: "15742222222" + phone: "234343544" + vatId: "INV12345678904" + }) { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createAddress": { + "id": "12", + "customerId": 5, + "companyName": "Webkul2", + "firstName": "Tom Demo2", + "lastName": "Martin Demo2", + "address1": "3180 Bluff", + "address2": "Street", + "country": "US", + "state": "PA", + "city": "GLEN CAMPBELL", + "postcode": "15742222222", + "phone": "234343544", + "vatId": "INV12345678904", + "addressType": "customer", + "defaultAddress": false, + "createdAt": "2021-05-28 12:59:46", + "updatedAt": "2021-05-28 12:59:46" + } + } + } + ~~~ +::: + +## Update Customer Address + +By using this API call you can update the Customer Address. To do this , you have to perform update mutation on Customer Address and paas the related fields in the request. +API call will update a Customer Address, only if the customer has logged in. + + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateAddress { + updateAddress(id: 11, input: { + companyName: "Velocity" + firstName: "Tom" + lastName: "Martin" + address1: "3180 Bluff Street" + address2: "" + country: "IN" + state: "UP" + city: "Noida" + postcode: "201301" + phone: "1234123455" + vatId: "INV12342278902" + }) { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + defaultAddress + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateAddress": { + "id": "11", + "customerId": 5, + "companyName": "Velocity", + "firstName": "Tom", + "lastName": "Martin", + "address1": "3180 Bluff Street", + "address2": "", + "country": "IN", + "state": "UP", + "city": "Noida", + "postcode": "201301", + "phone": "1234123455", + "vatId": "INV12342278902", + "addressType": "customer", + "defaultAddress": false, + "createdAt": "2021-05-28 12:59:29", + "updatedAt": "2021-05-28 13:07:52" + } + } + } + ~~~ +::: + +## Delete a Customer Address + +To delete a Customer Address, you have to perform mutation on Customer Address by passing the id of that Customer Address. +API call will delete a Customer Address, only if the customer has logged in. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteAddress { + deleteAddress(id: 11) { + success + } + } + + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteCustomerAddress": { + "success": "Customer's Address deleted successfully." + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-shop-api/cart.md b/docs/1.x/graphql-shop-api/cart.md new file mode 100644 index 00000000..9d6f02ae --- /dev/null +++ b/docs/1.x/graphql-shop-api/cart.md @@ -0,0 +1,3822 @@ +# Cart + +In this section, we will see all the APIs which are related to Customer Cart. + +## Get Cart + +You can get all the Cart from the Bagisto store. You can achieve this job by using the `Cart` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query cartDetail { + cartDetail { + id + customerEmail + customerFirstName + customerLastName + shippingMethod + couponCode + isGift + itemsCount + itemsQty + exchangeRate + globalCurrencyCode + baseCurrencyCode + channelCurrencyCode + cartCurrencyCode + grandTotal + baseGrandTotal + subTotal + baseSubTotal + taxTotal + baseTaxTotal + discountAmount + baseDiscountAmount + checkoutMethod + isGuest + isActive + conversionTime + customerId + channelId + appliedCartRuleIds + createdAt + updatedAt + items { + id + quantity + sku + type + name + couponCode + weight + totalWeight + baseTotalWeight + price + basePrice + total + baseTotal + taxPercent + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + additional + parentId + productId + cartId + taxCategoryId + customPrice + appliedCartRuleIds + createdAt + updatedAt + product { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + attributeValues { + id + productId + attributeId + locale + channel + textValue + booleanValue + integerValue + floatValue + dateTimeValue + dateValue + jsonValue + attribute { + id + code + adminName + type + } + } + superAttributes { + id + code + adminName + type + position + } + categories { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + createdAt + updatedAt + } + groupedProducts { + id + qty + sortOrder + productId + associatedProductId + associatedProduct { + id + type + attributeFamilyId + sku + parentId + } + } + downloadableSamples { + id + url + file + fileName + type + sortOrder + productId + createdAt + updatedAt + translations { + id + locale + title + productDownloadableSampleId + } + } + downloadableLinks { + id + title + price + url + file + fileName + type + sampleUrl + sampleFile + sampleFileName + sampleType + sortOrder + productId + downloads + translations { + id + locale + title + productDownloadableLinkId + } + } + bundleOptions { + id + type + isRequired + sortOrder + productId + bundleOptionProducts { + id + qty + isUserDefined + sortOrder + isDefault + productBundleOptionId + productId + } + translations { + id + locale + label + productBundleOptionId + } + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "cartDetail": { + "id": "6", + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "shippingMethod": null, + "couponCode": null, + "isGift": false, + "itemsCount": 1, + "itemsQty": 1, + "exchangeRate": null, + "globalCurrencyCode": "USD", + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "cartCurrencyCode": "USD", + "grandTotal": 5, + "baseGrandTotal": 5, + "subTotal": 5, + "baseSubTotal": 5, + "taxTotal": 0, + "baseTaxTotal": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "checkoutMethod": null, + "isGuest": false, + "isActive": true, + "conversionTime": null, + "customerId": "5", + "channelId": "1", + "appliedCartRuleIds": "", + "createdAt": "2021-05-28 17:25:25", + "updatedAt": "2021-05-28 17:25:26", + "items": [ + { + "id": "6", + "quantity": 1, + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "couponCode": null, + "weight": 3, + "totalWeight": 3, + "baseTotalWeight": 3, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "taxPercent": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "additional": "{\"quantity\":1,\"product_id\":\"1\"}", + "parentId": null, + "productId": "1", + "cartId": "6", + "taxCategoryId": null, + "customPrice": null, + "appliedCartRuleIds": "", + "createdAt": "2021-05-28 17:25:25", + "updatedAt": "2021-05-28 17:25:26", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "productFlats": [ + { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "variants": [], + "parent": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + ], + "variants": [], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "attributeValues": [ + { + "id": "1", + "productId": "1", + "attributeId": "9", + "locale": "en", + "channel": "default", + "textValue": "

testOutlet

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea" + } + }, + { + "id": "2", + "productId": "1", + "attributeId": "10", + "locale": "en", + "channel": "default", + "textValue": "

testOutlet

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea" + } + }, + { + "id": "3", + "productId": "1", + "attributeId": "1", + "locale": null, + "channel": null, + "textValue": "test-product", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text" + } + }, + { + "id": "4", + "productId": "1", + "attributeId": "2", + "locale": "en", + "channel": "default", + "textValue": "testOutlet", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text" + } + }, + { + "id": "5", + "productId": "1", + "attributeId": "3", + "locale": null, + "channel": null, + "textValue": "testoutlet", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text" + } + }, + { + "id": "6", + "productId": "1", + "attributeId": "4", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": 0, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select" + } + }, + { + "id": "7", + "productId": "1", + "attributeId": "5", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean" + } + }, + { + "id": "8", + "productId": "1", + "attributeId": "6", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean" + } + }, + { + "id": "9", + "productId": "1", + "attributeId": "7", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean" + } + }, + { + "id": "10", + "productId": "1", + "attributeId": "8", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean" + } + }, + { + "id": "11", + "productId": "1", + "attributeId": "23", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 1, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select" + } + }, + { + "id": "12", + "productId": "1", + "attributeId": "24", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 6, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select" + } + }, + { + "id": "13", + "productId": "1", + "attributeId": "26", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "26", + "code": "guest_checkout", + "adminName": "Guest Checkout", + "type": "boolean" + } + }, + { + "id": "14", + "productId": "1", + "attributeId": "27", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "27", + "code": "product_number", + "adminName": "Product Number", + "type": "text" + } + }, + { + "id": "15", + "productId": "1", + "attributeId": "16", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "16", + "code": "meta_title", + "adminName": "Meta Title", + "type": "textarea" + } + }, + { + "id": "16", + "productId": "1", + "attributeId": "17", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "17", + "code": "meta_keywords", + "adminName": "Meta Keywords", + "type": "textarea" + } + }, + { + "id": "17", + "productId": "1", + "attributeId": "18", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "18", + "code": "meta_description", + "adminName": "Meta Description", + "type": "textarea" + } + }, + { + "id": "18", + "productId": "1", + "attributeId": "11", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": 5, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price" + } + }, + { + "id": "19", + "productId": "1", + "attributeId": "12", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "12", + "code": "cost", + "adminName": "Cost", + "type": "price" + } + }, + { + "id": "20", + "productId": "1", + "attributeId": "13", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "13", + "code": "special_price", + "adminName": "Special Price", + "type": "price" + } + }, + { + "id": "21", + "productId": "1", + "attributeId": "14", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "14", + "code": "special_price_from", + "adminName": "Special Price From", + "type": "date" + } + }, + { + "id": "22", + "productId": "1", + "attributeId": "15", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "15", + "code": "special_price_to", + "adminName": "Special Price To", + "type": "date" + } + }, + { + "id": "23", + "productId": "1", + "attributeId": "19", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text" + } + }, + { + "id": "24", + "productId": "1", + "attributeId": "20", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text" + } + }, + { + "id": "25", + "productId": "1", + "attributeId": "21", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "21", + "code": "depth", + "adminName": "Depth", + "type": "text" + } + }, + { + "id": "26", + "productId": "1", + "attributeId": "22", + "locale": null, + "channel": null, + "textValue": "3", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "22", + "code": "weight", + "adminName": "Weight", + "type": "text" + } + } + ], + "superAttributes": [], + "categories": [], + "inventories": [ + { + "id": "1", + "qty": 3, + "productId": "1", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "2", + "qty": 0, + "productId": "1", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [ + { + "id": "1", + "qty": 0, + "productId": "1", + "channelId": "1" + } + ], + "reviews": [ + { + "id": "1", + "title": "Where does it come from?", + "rating": 4, + "comment": "Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old.", + "status": true, + "productId": "1", + "customerId": "5", + "createdAt": "2021-05-28 15:41:51", + "updatedAt": "2021-05-28 15:41:51" + } + ], + "groupedProducts": [], + "downloadableSamples": [], + "downloadableLinks": [], + "bundleOptions": [], + "customerGroupPrices": [], + "booking": null + } + } + ] + } + } +} +~~~ +::: + +## Get Cart Items + +You can get all the Cart Items from the Bagisto store. You can achieve this job by using the `Cart Items` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query cartItems { + cartItems { + id + quantity + sku + type + name + couponCode + weight + totalWeight + baseTotalWeight + price + basePrice + total + baseTotal + taxPercent + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + additional + parentId + productId + cartId + taxCategoryId + customPrice + appliedCartRuleIds + createdAt + updatedAt + product { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + attributeValues { + id + productId + attributeId + locale + channel + textValue + booleanValue + integerValue + floatValue + dateTimeValue + dateValue + jsonValue + attribute { + id + code + adminName + type + } + } + superAttributes { + id + code + adminName + type + position + } + categories { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + createdAt + updatedAt + } + groupedProducts { + id + qty + sortOrder + productId + associatedProductId + associatedProduct { + id + type + attributeFamilyId + sku + parentId + } + } + downloadableSamples { + id + url + file + fileName + type + sortOrder + productId + createdAt + updatedAt + translations { + id + locale + title + productDownloadableSampleId + } + } + downloadableLinks { + id + title + price + url + file + fileName + type + sampleUrl + sampleFile + sampleFileName + sampleType + sortOrder + productId + downloads + translations { + id + locale + title + productDownloadableLinkId + } + } + bundleOptions { + id + type + isRequired + sortOrder + productId + bundleOptionProducts { + id + qty + isUserDefined + sortOrder + isDefault + productBundleOptionId + productId + } + translations { + id + locale + label + productBundleOptionId + } + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + } + ~~~ +::: details Response + +~~~json +{ + "data": { + "cartItems": [ + { + "id": "6", + "quantity": 1, + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "couponCode": null, + "weight": 3, + "totalWeight": 3, + "baseTotalWeight": 3, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "taxPercent": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "additional": "{\"quantity\":1,\"product_id\":\"1\"}", + "parentId": null, + "productId": "1", + "cartId": "6", + "taxCategoryId": null, + "customPrice": null, + "appliedCartRuleIds": "", + "createdAt": "2021-05-28 17:25:25", + "updatedAt": "2021-05-28 17:25:26", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "productFlats": [ + { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "variants": [], + "parent": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + ], + "variants": [], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "attributeValues": [ + { + "id": "1", + "productId": "1", + "attributeId": "9", + "locale": "en", + "channel": "default", + "textValue": "

testOutlet

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea" + } + }, + { + "id": "2", + "productId": "1", + "attributeId": "10", + "locale": "en", + "channel": "default", + "textValue": "

testOutlet

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea" + } + }, + { + "id": "3", + "productId": "1", + "attributeId": "1", + "locale": null, + "channel": null, + "textValue": "test-product", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text" + } + }, + { + "id": "4", + "productId": "1", + "attributeId": "2", + "locale": "en", + "channel": "default", + "textValue": "testOutlet", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text" + } + }, + { + "id": "5", + "productId": "1", + "attributeId": "3", + "locale": null, + "channel": null, + "textValue": "testoutlet", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text" + } + }, + { + "id": "6", + "productId": "1", + "attributeId": "4", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": 0, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select" + } + }, + { + "id": "7", + "productId": "1", + "attributeId": "5", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean" + } + }, + { + "id": "8", + "productId": "1", + "attributeId": "6", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean" + } + }, + { + "id": "9", + "productId": "1", + "attributeId": "7", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean" + } + }, + { + "id": "10", + "productId": "1", + "attributeId": "8", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean" + } + }, + { + "id": "11", + "productId": "1", + "attributeId": "23", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 1, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select" + } + }, + { + "id": "12", + "productId": "1", + "attributeId": "24", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 6, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select" + } + }, + { + "id": "13", + "productId": "1", + "attributeId": "26", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "26", + "code": "guest_checkout", + "adminName": "Guest Checkout", + "type": "boolean" + } + }, + { + "id": "14", + "productId": "1", + "attributeId": "27", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "27", + "code": "product_number", + "adminName": "Product Number", + "type": "text" + } + }, + { + "id": "15", + "productId": "1", + "attributeId": "16", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "16", + "code": "meta_title", + "adminName": "Meta Title", + "type": "textarea" + } + }, + { + "id": "16", + "productId": "1", + "attributeId": "17", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "17", + "code": "meta_keywords", + "adminName": "Meta Keywords", + "type": "textarea" + } + }, + { + "id": "17", + "productId": "1", + "attributeId": "18", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "18", + "code": "meta_description", + "adminName": "Meta Description", + "type": "textarea" + } + }, + { + "id": "18", + "productId": "1", + "attributeId": "11", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": 5, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price" + } + }, + { + "id": "19", + "productId": "1", + "attributeId": "12", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "12", + "code": "cost", + "adminName": "Cost", + "type": "price" + } + }, + { + "id": "20", + "productId": "1", + "attributeId": "13", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "13", + "code": "special_price", + "adminName": "Special Price", + "type": "price" + } + }, + { + "id": "21", + "productId": "1", + "attributeId": "14", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "14", + "code": "special_price_from", + "adminName": "Special Price From", + "type": "date" + } + }, + { + "id": "22", + "productId": "1", + "attributeId": "15", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "15", + "code": "special_price_to", + "adminName": "Special Price To", + "type": "date" + } + }, + { + "id": "23", + "productId": "1", + "attributeId": "19", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text" + } + }, + { + "id": "24", + "productId": "1", + "attributeId": "20", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text" + } + }, + { + "id": "25", + "productId": "1", + "attributeId": "21", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "21", + "code": "depth", + "adminName": "Depth", + "type": "text" + } + }, + { + "id": "26", + "productId": "1", + "attributeId": "22", + "locale": null, + "channel": null, + "textValue": "3", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "22", + "code": "weight", + "adminName": "Weight", + "type": "text" + } + } + ], + "superAttributes": [], + "categories": [], + "inventories": [ + { + "id": "1", + "qty": 3, + "productId": "1", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "2", + "qty": 0, + "productId": "1", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [ + { + "id": "1", + "qty": 0, + "productId": "1", + "channelId": "1" + } + ], + "reviews": [ + { + "id": "1", + "title": "Where does it come from?", + "rating": 4, + "comment": "Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old.", + "status": true, + "productId": "1", + "customerId": "5", + "createdAt": "2021-05-28 15:41:51", + "updatedAt": "2021-05-28 15:41:51" + } + ], + "groupedProducts": [], + "downloadableSamples": [], + "downloadableLinks": [], + "bundleOptions": [], + "customerGroupPrices": [], + "booking": null + } + } + ] + } +} +~~~ +::: + + +## Get Cart Item By Id + +You can get the Specific Cart Items from the Bagisto store by passing the `id` field with the request. You can achieve this job by using the `Cart Items` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query cartItem { + cartItem(id: 8) { + id + quantity + sku + type + name + couponCode + weight + totalWeight + baseTotalWeight + price + basePrice + total + baseTotal + taxPercent + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + additional + parentId + productId + cartId + taxCategoryId + customPrice + appliedCartRuleIds + createdAt + updatedAt + product { + id + type + attributeFamilyId + sku + parentId + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + variants { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + locale + channel + productId + parentId + } + parent { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + } + createdAt + updatedAt + } + variants { + id + type + attributeFamilyId + sku + parentId + } + parent { + id + type + attributeFamilyId + sku + parentId + } + attributeFamily { + id + code + name + status + isUserDefined + } + attributeValues { + id + productId + attributeId + locale + channel + textValue + booleanValue + integerValue + floatValue + dateTimeValue + dateValue + jsonValue + attribute { + id + code + adminName + type + } + } + superAttributes { + id + code + adminName + type + position + } + categories { + id + name + description + slug + urlPath + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + filterableAttributes { + id + adminName + code + type + position + } + translations { + id + name + description + localeId + locale + } + createdAt + updatedAt + } + inventories { + id + qty + productId + inventorySourceId + vendorId + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + status + } + } + images { + id + type + path + productId + } + orderedInventories { + id + qty + productId + channelId + } + reviews { + id + title + rating + comment + status + productId + customerId + createdAt + updatedAt + } + groupedProducts { + id + qty + sortOrder + productId + associatedProductId + associatedProduct { + id + type + attributeFamilyId + sku + parentId + } + } + downloadableSamples { + id + url + file + fileName + type + sortOrder + productId + createdAt + updatedAt + translations { + id + locale + title + productDownloadableSampleId + } + } + downloadableLinks { + id + title + price + url + file + fileName + type + sampleUrl + sampleFile + sampleFileName + sampleType + sortOrder + productId + downloads + translations { + id + locale + title + productDownloadableLinkId + } + } + bundleOptions { + id + type + isRequired + sortOrder + productId + bundleOptionProducts { + id + qty + isUserDefined + sortOrder + isDefault + productBundleOptionId + productId + } + translations { + id + locale + label + productBundleOptionId + } + } + customerGroupPrices { + id + qty + valueType + value + productId + customerGroupId + createdAt + updatedAt + } + booking { + id + type + qty + location + showLocation + availableEveryWeek + availableFrom + availableTo + productId + defaultSlot { + id + bookingType + duration + breakTime + slots { + to + toDay + from + fromDay + } + bookingProductId + } + appointmentSlot { + id + duration + breakTime + sameSlotAllDays + slots { + from + to + } + bookingProductId + } + } + } + } + } + ~~~ +::: details Response + +~~~json +{ + "data": { + "cartItem": { + "id": "8", + "quantity": 1, + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "couponCode": null, + "weight": 3, + "totalWeight": 3, + "baseTotalWeight": 3, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "taxPercent": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "additional": "{\"quantity\":1,\"product_id\":\"1\"}", + "parentId": null, + "productId": "1", + "cartId": "8", + "taxCategoryId": null, + "customPrice": null, + "appliedCartRuleIds": "", + "createdAt": "2021-05-28 18:06:51", + "updatedAt": "2021-05-28 18:06:52", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "productFlats": [ + { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "variants": [], + "parent": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + ], + "variants": [], + "parent": null, + "attributeFamily": { + "id": "1", + "code": "default", + "name": "Default", + "status": false, + "isUserDefined": true + }, + "attributeValues": [ + { + "id": "1", + "productId": "1", + "attributeId": "9", + "locale": "en", + "channel": "default", + "textValue": "

testOutlet

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "9", + "code": "short_description", + "adminName": "Short Description", + "type": "textarea" + } + }, + { + "id": "2", + "productId": "1", + "attributeId": "10", + "locale": "en", + "channel": "default", + "textValue": "

testOutlet

", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "10", + "code": "description", + "adminName": "Description", + "type": "textarea" + } + }, + { + "id": "3", + "productId": "1", + "attributeId": "1", + "locale": null, + "channel": null, + "textValue": "test-product", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "1", + "code": "sku", + "adminName": "SKU", + "type": "text" + } + }, + { + "id": "4", + "productId": "1", + "attributeId": "2", + "locale": "en", + "channel": "default", + "textValue": "testOutlet", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "2", + "code": "name", + "adminName": "Name", + "type": "text" + } + }, + { + "id": "5", + "productId": "1", + "attributeId": "3", + "locale": null, + "channel": null, + "textValue": "testoutlet", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "3", + "code": "url_key", + "adminName": "URL Key", + "type": "text" + } + }, + { + "id": "6", + "productId": "1", + "attributeId": "4", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": 0, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "4", + "code": "tax_category_id", + "adminName": "Tax Category", + "type": "select" + } + }, + { + "id": "7", + "productId": "1", + "attributeId": "5", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "5", + "code": "new", + "adminName": "New", + "type": "boolean" + } + }, + { + "id": "8", + "productId": "1", + "attributeId": "6", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "6", + "code": "featured", + "adminName": "Featured", + "type": "boolean" + } + }, + { + "id": "9", + "productId": "1", + "attributeId": "7", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "7", + "code": "visible_individually", + "adminName": "Visible Individually", + "type": "boolean" + } + }, + { + "id": "10", + "productId": "1", + "attributeId": "8", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "8", + "code": "status", + "adminName": "Status", + "type": "boolean" + } + }, + { + "id": "11", + "productId": "1", + "attributeId": "23", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 1, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select" + } + }, + { + "id": "12", + "productId": "1", + "attributeId": "24", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": 6, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select" + } + }, + { + "id": "13", + "productId": "1", + "attributeId": "26", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": true, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "26", + "code": "guest_checkout", + "adminName": "Guest Checkout", + "type": "boolean" + } + }, + { + "id": "14", + "productId": "1", + "attributeId": "27", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "27", + "code": "product_number", + "adminName": "Product Number", + "type": "text" + } + }, + { + "id": "15", + "productId": "1", + "attributeId": "16", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "16", + "code": "meta_title", + "adminName": "Meta Title", + "type": "textarea" + } + }, + { + "id": "16", + "productId": "1", + "attributeId": "17", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "17", + "code": "meta_keywords", + "adminName": "Meta Keywords", + "type": "textarea" + } + }, + { + "id": "17", + "productId": "1", + "attributeId": "18", + "locale": "en", + "channel": "default", + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "18", + "code": "meta_description", + "adminName": "Meta Description", + "type": "textarea" + } + }, + { + "id": "18", + "productId": "1", + "attributeId": "11", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": 5, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price" + } + }, + { + "id": "19", + "productId": "1", + "attributeId": "12", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "12", + "code": "cost", + "adminName": "Cost", + "type": "price" + } + }, + { + "id": "20", + "productId": "1", + "attributeId": "13", + "locale": null, + "channel": null, + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "13", + "code": "special_price", + "adminName": "Special Price", + "type": "price" + } + }, + { + "id": "21", + "productId": "1", + "attributeId": "14", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "14", + "code": "special_price_from", + "adminName": "Special Price From", + "type": "date" + } + }, + { + "id": "22", + "productId": "1", + "attributeId": "15", + "locale": null, + "channel": "default", + "textValue": null, + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "15", + "code": "special_price_to", + "adminName": "Special Price To", + "type": "date" + } + }, + { + "id": "23", + "productId": "1", + "attributeId": "19", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "19", + "code": "width", + "adminName": "Width", + "type": "text" + } + }, + { + "id": "24", + "productId": "1", + "attributeId": "20", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "20", + "code": "height", + "adminName": "Height", + "type": "text" + } + }, + { + "id": "25", + "productId": "1", + "attributeId": "21", + "locale": null, + "channel": null, + "textValue": "", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "21", + "code": "depth", + "adminName": "Depth", + "type": "text" + } + }, + { + "id": "26", + "productId": "1", + "attributeId": "22", + "locale": null, + "channel": null, + "textValue": "3", + "booleanValue": null, + "integerValue": null, + "floatValue": null, + "dateTimeValue": null, + "dateValue": null, + "jsonValue": null, + "attribute": { + "id": "22", + "code": "weight", + "adminName": "Weight", + "type": "text" + } + } + ], + "superAttributes": [], + "categories": [], + "inventories": [ + { + "id": "1", + "qty": 3, + "productId": "1", + "inventorySourceId": "1", + "vendorId": 0, + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null, + "status": true + } + }, + { + "id": "2", + "qty": 0, + "productId": "1", + "inventorySourceId": "2", + "vendorId": 0, + "inventorySource": { + "id": "2", + "code": "new", + "name": "demoinventory", + "description": "demo", + "contactName": "jyoti", + "contactEmail": "jyoti@webkul.com", + "contactNumber": "7252756566", + "contactFax": null, + "country": "IN", + "state": "UP", + "city": "Gorakhpur", + "street": "d-54", + "postcode": "273003", + "priority": 1, + "latitude": null, + "longitude": null, + "status": true + } + } + ], + "images": [], + "orderedInventories": [ + { + "id": "1", + "qty": 0, + "productId": "1", + "channelId": "1" + } + ], + "reviews": [ + { + "id": "1", + "title": "Where does it come from?", + "rating": 4, + "comment": "Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old.", + "status": true, + "productId": "1", + "customerId": "5", + "createdAt": "2021-05-28 15:41:51", + "updatedAt": "2021-05-28 15:41:51" + } + ], + "groupedProducts": [], + "downloadableSamples": [], + "downloadableLinks": [], + "bundleOptions": [], + "customerGroupPrices": [], + "booking": null + } + } + } +} +~~~ +::: + + +## Add Item To Cart + +You can Add a product to Cart. You can achieve this job by using the `Cart` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + mutation addItemToCart { + addItemToCart(input: { + productId: 1 + quantity: 1 + + # Only use while adding configurable product to cart + # selectedConfigurableOption: 4 + # superAttribute: [{ + # attributeId: 23 + # attributeOptionId: 4 + # }, { + # attributeId: 24 + # attributeOptionId: 6 + # }] + + # Only use while adding grouped product to cart + # qty: [{ + # productId: 5 + # quantity: 3 + # }, { + # productId: 1 + # quantity: 2 + # }] + + # Only use while adding downloadable product to cart + # links: [6, 8] + + # Only use while adding bundled product to cart + # bundleOptions: [{ + # bundleOptionId: 9 + # bundleOptionProductId: [8] + # qty: 2 + # }, { + # bundleOptionId: 10 + # bundleOptionProductId: [10] + # qty: 3 + # }, { + # bundleOptionId: 11 + # bundleOptionProductId: [11, 12] + # }, { + # bundleOptionId: 13 + # bundleOptionProductId: [15] + # }] + + # Only use while adding booking(default, appointment, rental, table) product to cart + # booking: { + # date: "2021-02-15" + # slot: { + # from: 1613374200 + # to: 1613376900 + # } + # note: "Booking Table" + + # # Only use while adding booking(event) product to cart + # qty: [{ + # ticketId: 11 + # quantity: 2 + # }, { + # ticketId: 12 + # quantity: 1 + # }] + # } + }) { + success + cart { + id + customerEmail + customerFirstName + customerLastName + shippingMethod + couponCode + isGift + itemsCount + itemsQty + exchangeRate + globalCurrencyCode + baseCurrencyCode + channelCurrencyCode + cartCurrencyCode + grandTotal + baseGrandTotal + subTotal + baseSubTotal + taxTotal + baseTaxTotal + discountAmount + baseDiscountAmount + checkoutMethod + isGuest + isActive + conversionTime + customerId + channelId + appliedCartRuleIds + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "addToWishlist": { + "success": "Item Successfully Added To Wishlist", + "wishlist": { + "id": "1", + "channelId": "1", + "productId": "1", + "customerId": "5", + "itemOptions": null, + "additional": "null", + "movedToCart": null, + "shared": null, + "timeOfMoving": null, + "createdAt": "2021-05-28 15:59:00", + "updatedAt": "2021-05-28 15:59:00", + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + }, + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "channel": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":16,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + } + } +} +~~~ +::: + +## Update Cart Item + +To Update Cart Item You need to pass the cart item id and quantityt with the request. You can achieve this job by using the `CartUpdate` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + mutation updateItemToCart { + updateItemToCart(input: { + qty: [{ + cartItemId: 6 + quantity: 3 + }] + }) { + success + cart { + id + customerEmail + customerFirstName + customerLastName + shippingMethod + couponCode + isGift + itemsCount + itemsQty + exchangeRate + globalCurrencyCode + baseCurrencyCode + channelCurrencyCode + cartCurrencyCode + grandTotal + baseGrandTotal + subTotal + baseSubTotal + taxTotal + baseTaxTotal + discountAmount + baseDiscountAmount + checkoutMethod + isGuest + isActive + conversionTime + customerId + channelId + appliedCartRuleIds + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "addToWishlist": { + "success": "Item Successfully Added To Wishlist", + "wishlist": { + "id": "1", + "channelId": "1", + "productId": "1", + "customerId": "5", + "itemOptions": null, + "additional": "null", + "movedToCart": null, + "shared": null, + "timeOfMoving": null, + "createdAt": "2021-05-28 15:59:00", + "updatedAt": "2021-05-28 15:59:00", + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + }, + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "channel": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":16,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + } + } +} +~~~ +::: + +## Remove Cart Item + +To remove a Cart Item , you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + mutation removeCartItem { + removeCartItem(id: 6) { + success + cart { + id + customerEmail + customerFirstName + customerLastName + shippingMethod + couponCode + isGift + itemsCount + itemsQty + exchangeRate + globalCurrencyCode + baseCurrencyCode + channelCurrencyCode + cartCurrencyCode + grandTotal + baseGrandTotal + subTotal + baseSubTotal + taxTotal + baseTaxTotal + discountAmount + baseDiscountAmount + checkoutMethod + isGuest + isActive + conversionTime + customerId + channelId + appliedCartRuleIds + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "removeCartItem": { + "success": "Success: Cart item has been removed successfully.", + "cart": null + } + } + } + ~~~ +::: + +## Move To Wishlist + +You can move a cart item from cart to wishlist from the Bagisto store. You can achieve this job by using the `Move To Wishlist` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + mutation moveToWishlist { + moveToWishlist(id: 7) { + success + cart { + id + customerEmail + customerFirstName + customerLastName + shippingMethod + couponCode + isGift + itemsCount + itemsQty + exchangeRate + globalCurrencyCode + baseCurrencyCode + channelCurrencyCode + cartCurrencyCode + grandTotal + baseGrandTotal + subTotal + baseSubTotal + taxTotal + baseTaxTotal + discountAmount + baseDiscountAmount + checkoutMethod + isGuest + isActive + conversionTime + customerId + channelId + appliedCartRuleIds + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "moveToWishlist": { + "success": "Success: Cart item moved to wishlist successfully.", + "cart": null + } + } + } + ~~~ +::: \ No newline at end of file diff --git a/docs/1.x/graphql-shop-api/checkout.md b/docs/1.x/graphql-shop-api/checkout.md new file mode 100644 index 00000000..427461dc --- /dev/null +++ b/docs/1.x/graphql-shop-api/checkout.md @@ -0,0 +1,525 @@ +# Checkout + +In this section, we will see all the APIs which are related to Checkout Process. + +**Note** Make sure customer have item in the cart. + +## Get Checkout addresses + +You can get all the Checkout addresses from the Bagisto store. You can achieve this job by using the `checkoutAddresses` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query checkoutAddresses { + checkoutAddresses { + success + isGuest + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + addresses { + id + address + } + addressList { + id + customerId + companyName + firstName + lastName + address1 + address2 + country + state + city + postcode + phone + vatId + addressType + createdAt + updatedAt + } + cartCount + defaultCountry + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "checkoutAddresses": { + "success": "Success: Customer's addresses fetched successfully.", + "isGuest": false, + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + }, + "addresses": [ + { + "id": 12, + "address": "Naresh Verma\n 3180 Bluff, GLEN CAMPBELL, PA, US, \n 15742222222\n T: 234343544" + } + ], + "addressList": [ + { + "id": "12", + "customerId": 5, + "companyName": "Webkul2", + "firstName": "Tom Demo2", + "lastName": "Martin Demo2", + "address1": "3180 Bluff", + "address2": "Street", + "country": "US", + "state": "PA", + "city": "GLEN CAMPBELL", + "postcode": "15742222222", + "phone": "234343544", + "vatId": "INV12345678904", + "addressType": "customer", + "createdAt": "2021-05-28 12:59:46", + "updatedAt": "2021-05-28 12:59:46" + } + ], + "cartCount": 1, + "defaultCountry": "IN" + } + } +} +~~~ +::: + +## Get Shipping Methods + +After you get the checkout addresses you need to select the address for checkout or you can pass the billing and shipping address for the checkout. You can achieve this job by using the `shippingMethods` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +**Note** No need to save the shipping method for `Virtual` and `Downloadable` and `Booking` type Product. You can jump to `savePayment` Mutation. [Save Payment API](#save-payment-methods) + +- Query + ~~~query + mutation shippingMethods { + shippingMethods(input: { + billingAddressId: 12 + shippingAddressId: 12 + billing: { + companyName: "C. Trades" + firstName: "Doug" + lastName: "D Nelson" + email: "doug@example.com" + address1: "836 Hog" + address2: " Camp Road" + city: "Wheeling" + country: "US" + state: "Illinois" + postcode: "60090" + phone: "708-491-5303" + useForShipping: false + saveAsAddress: true + } + shipping: { + companyName: "C. Trades" + firstName: "Doug" + lastName: "D Nelson" + email: "doug@example.com" + address1: "2252 Charmaine Lane" + address2: "" + city: "ROCKLEDGE" + country: "US" + state: "Georgia" + postcode: "30454" + phone: "806-494-1788" + saveAsAddress: true + } + }) { + success + cartTotal + cartCount + shippingMethods { + title + methods { + code + label + price + formattedPrice + basePrice + formattedBasePrice + } + } + paymentMethods { + method + method_title + description + sort + } + jumpToSection + } + } + ~~~ +::: details Response + +~~~json +{ + "data": { + "shippingMethods": { + "success": "Success: Cart address save successfully.", + "cartTotal": "$10.00", + "cartCount": 1, + "shippingMethods": [ + { + "title": "Flat Rate", + "methods": { + "code": "flatrate_flatrate", + "label": "Flat Rate", + "price": 20, + "formattedPrice": "$20.00", + "basePrice": 20, + "formattedBasePrice": "$20.00" + } + }, + { + "title": "Free Shipping", + "methods": { + "code": "free_free", + "label": "Free Shipping", + "price": 0, + "formattedPrice": "$0.00", + "basePrice": 0, + "formattedBasePrice": "$0.00" + } + } + ], + "paymentMethods": null, + "jumpToSection": "shipping" + } + } +} +~~~ +::: + + +## Get Payment Methods + +Ater You selected the address for checkout and get the list of shipping methods, now you can call the paymentMethods mutation to select the shipping method and to get the list of the payment methods. You can achieve this job by using the `paymentMethods` API call. + +**Note** You need to pass the shipping method `code` with the request to select that shipping method. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +- Query + ~~~query + mutation paymentMethods { + paymentMethods(input: { + shippingMethod: "flatrate_flatrate" + }) { + success + cartTotal + cartCount + paymentMethods { + method + method_title + description + sort + } + jumpToSection + } + } + ~~~ +::: details Response + +~~~json +{ + "data": { + "paymentMethods": { + "success": "Success: Shipment has been selected successfully.", + "cartTotal": "$10.00", + "cartCount": 1, + "paymentMethods": [ + { + "method": "paypal_smart_button", + "method_title": "PayPal Smart Button", + "description": "PayPal", + "sort": 0 + }, + { + "method": "cashondelivery", + "method_title": "Cash On Delivery", + "description": "Cash On Delivery", + "sort": 1 + }, + { + "method": "moneytransfer", + "method_title": "Money Transfer", + "description": "Money Transfer", + "sort": 2 + }, + { + "method": "paypal_standard", + "method_title": "PayPal Standard", + "description": "PayPal Standard", + "sort": 3 + } + ], + "jumpToSection": "payment" + } + } +} +~~~ +::: + + +## Save Payment Methods + +Ater You selected the shipping methods for checkout and get the list of Payment methods, now you can call the savePayment mutation to select the payment method and to get checkout review. You can achieve this job by using the `savePayment` API call. + +**Note** You need to pass the payment `method` with the request to select that payment method. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +- Query + ~~~query + mutation savePayment { + savePayment(input: { + payment: { + method: "cashondelivery" + } + }) { + success + jumpToSection + cart { + id + customerEmail + customerFirstName + customerLastName + shippingMethod + couponCode + isGift + itemsCount + itemsQty + exchangeRate + globalCurrencyCode + baseCurrencyCode + channelCurrencyCode + cartCurrencyCode + grandTotal + baseGrandTotal + subTotal + baseSubTotal + taxTotal + baseTaxTotal + discountAmount + baseDiscountAmount + checkoutMethod + isGuest + isActive + conversionTime + customerId + channelId + appliedCartRuleIds + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "savePayment": { + "success": "Success: Payment method selected successfully.", + "jumpToSection": "review", + "cart": { + "id": "10", + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "shippingMethod": "flatrate_flatrate", + "couponCode": null, + "isGift": false, + "itemsCount": 1, + "itemsQty": 2, + "exchangeRate": null, + "globalCurrencyCode": "USD", + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "cartCurrencyCode": "USD", + "grandTotal": 30, + "baseGrandTotal": 30, + "subTotal": 10, + "baseSubTotal": 10, + "taxTotal": 0, + "baseTaxTotal": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "checkoutMethod": null, + "isGuest": false, + "isActive": true, + "conversionTime": null, + "customerId": "5", + "channelId": "1", + "appliedCartRuleIds": "", + "createdAt": "2021-05-28 18:39:13", + "updatedAt": "2021-05-28 18:54:39" + } + } + } +} +~~~ +::: + +## Apply Coupon + +After saving the payment method for checkout you can apply coupon code for checkout process. You can achieve this job by using the `applyCoupon` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +- Query + ~~~query + mutation applyCoupon { + applyCoupon(input: { + code: "C84U8FTR4TEM" + }) { + success + message + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "applyCoupon": { + "success": false, + "message": "Coupon code is invalid." + } + } +} +~~~ +::: + +## Place Order + +After Following all the above checkout process steps place your order. to perform this action you have to call the `placeOrder` API. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + mutation placeOrder { + placeOrder { + success + redirectUrl + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "placeOrder": { + "success": "1", + "redirectUrl": null + } + } + } + ~~~ +::: \ No newline at end of file diff --git a/docs/1.x/graphql-shop-api/compare.md b/docs/1.x/graphql-shop-api/compare.md new file mode 100644 index 00000000..313825bc --- /dev/null +++ b/docs/1.x/graphql-shop-api/compare.md @@ -0,0 +1,589 @@ +# Compare + +In this section, we will see all the APIs which are related to Customer Compare Products. + +## Get Compare Products + +You can get all the Compare Products from the Bagisto store. You can achieve this job by using the `Compare Products` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note** You can pass all the input fields to filter the Compare Product data. + + +- Query + ~~~query + query compareProducts { + compareProducts(input: { + page: 1 + limit: 10 + # id: 2 + # productFlatId: 49 + # productName: "Music Show" + # price: 11.30 + }) { + id + productFlatId + customerId + createdAt + updatedAt + productFlat { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "compareProducts": [ + { + "id": "1", + "productFlatId": "1", + "customerId": "5", + "createdAt": "2021-05-28 16:33:03", + "updatedAt": "2021-05-28 16:33:03", + "productFlat": { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + } + } + ] + } +} +~~~ +::: + +## Get Compare Product By ID + +To get the specific Compare Product, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query compareProduct { + compareProduct(id: 1) { + id + productFlatId + customerId + createdAt + updatedAt + productFlat { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "compareProduct": { + "id": "1", + "productFlatId": "1", + "customerId": "5", + "createdAt": "2021-05-28 16:33:03", + "updatedAt": "2021-05-28 16:33:03", + "productFlat": { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + } + } + } + } + ~~~ +::: + + + +## Add To Compare + +You can Add a product to Compare. You can achieve this job by using the `Compare` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + mutation addToCompare { + addToCompare(input: { + productFlatId: 1 + }) { + success + compareProduct { + id + productFlatId + customerId + createdAt + updatedAt + productFlat { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "addToCompare": { + "success": "Item successfully added to compare list", + "compareProduct": { + "id": "1", + "productFlatId": "1", + "customerId": "5", + "createdAt": "2021-05-28 16:33:03", + "updatedAt": "2021-05-28 16:33:03", + "productFlat": { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + } + } + } + } +} +~~~ +::: + +## Remove Product From Compare + +To remove a product from the Compare, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + mutation removeFromCompareProduct { + removeFromCompareProduct(input: { + productFlatId: 1 + }) { + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "removeFromCompareProduct": { + "status": true, + "success": "Item successfully removed from compare list" + } + } + } + ~~~ +: + +## Remove All Product From Compare + +To remove all product from the Compare, you have to pass related fields with query request . + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + mutation removeAllCompareProducts { + removeAllCompareProducts { + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "removeAllCompareProducts": { + "status": true, + "success": "All Items successfully removed from compare list" + } + } + } + ~~~ +::: \ No newline at end of file diff --git a/docs/1.x/graphql-shop-api/downloadable-links.md b/docs/1.x/graphql-shop-api/downloadable-links.md new file mode 100644 index 00000000..ae04a397 --- /dev/null +++ b/docs/1.x/graphql-shop-api/downloadable-links.md @@ -0,0 +1,549 @@ +# Downloadable Links + +In this section, we will see all the APIs which are related to Customer Downloadable Links. + +## Get All Downloadable Links + +You can get all the Downloadable Links from the Bagisto store. You can achieve this job by using the `Downloadable Links` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note** You can pass all the input fields to filter the Downloadable link data. + + +- Query + ~~~query + query downloadableLinkPurchases { + downloadableLinkPurchases(input: { + page: 1 + limit: 10 + # id: 1 + # orderId: 3 + # orderItemId: 9 + # productName: "e-book" + # linkName: "link 1" + # status: "available" + # downloadBought: 3 + # downloadUsed: 1 + }) { + id + productName + name + url + file + fileName + type + downloadBought + downloadUsed + status + customerId + orderId + orderItemId + createdAt + updatedAt + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + } + order { + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + } + orderItem { + id + sku + type + name + couponCode + weight + totalWeight + qtyOrdered + qtyShipped + qtyInvoiced + qtyCanceled + qtyRefunded + price + basePrice + total + baseTotal + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "downloadableLinkPurchases": [ + { + "id": "1", + "productName": "e-book", + "name": "Link 3", + "url": "https://cdn.pixabay.com/photo/2021/02/01/13/37/cars-5970663_960_720.png", + "file": null, + "fileName": null, + "type": "url", + "downloadBought": 3, + "downloadUsed": 0, + "status": true, + "customerId": "5", + "orderId": "4", + "orderItemId": "4", + "createdAt": "2021-05-28 17:03:10", + "updatedAt": "2021-05-28 17:03:35", + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true + }, + "order": { + "id": 4, + "incrementId": "4", + "status": "completed", + "channelName": "Default", + "isGuest": 0, + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": null, + "shippingTitle": null, + "shippingDescription": null, + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 18.55, + "baseGrandTotal": 18.55, + "grandTotalInvoiced": 18.55, + "baseGrandTotalInvoiced": 18.55, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 18.55, + "baseSubTotal": 18.55, + "subTotalInvoiced": 18.55, + "baseSubTotalInvoiced": 18.55, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 0, + "baseShippingAmount": 0, + "shippingInvoiced": 0, + "baseShippingInvoiced": 0, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "5", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-28 17:03:10", + "updatedAt": "2021-05-28 17:03:35" + }, + "orderItem": { + "id": "4", + "sku": "e-book", + "type": "downloadable", + "name": "e-book", + "couponCode": null, + "weight": 5.2, + "totalWeight": 5.2, + "qtyOrdered": 1, + "qtyShipped": 0, + "qtyInvoiced": 1, + "qtyCanceled": 0, + "qtyRefunded": 0, + "price": 18.55, + "basePrice": 18.55, + "total": 18.55, + "baseTotal": 18.55 + } + } + ] + } +} +~~~ +::: + +## Get Downloadable Link By ID + +To get the specific Downloadable Link, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query downloadableLinkPurchase { + downloadableLinkPurchase(id: 1) { + id + productName + name + url + file + fileName + type + downloadBought + downloadUsed + status + customerId + orderId + orderItemId + createdAt + updatedAt + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + } + order { + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + } + orderItem { + id + sku + type + name + couponCode + weight + totalWeight + qtyOrdered + qtyShipped + qtyInvoiced + qtyCanceled + qtyRefunded + price + basePrice + total + baseTotal + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "downloadableLinkPurchase": { + "id": "1", + "productName": "e-book", + "name": "Link 3", + "url": "https://cdn.pixabay.com/photo/2021/02/01/13/37/cars-5970663_960_720.png", + "file": null, + "fileName": null, + "type": "url", + "downloadBought": 3, + "downloadUsed": 0, + "status": true, + "customerId": "5", + "orderId": "4", + "orderItemId": "4", + "createdAt": "2021-05-28 17:03:10", + "updatedAt": "2021-05-28 17:03:35", + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true + }, + "order": { + "id": 4, + "incrementId": "4", + "status": "completed", + "channelName": "Default", + "isGuest": 0, + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": null, + "shippingTitle": null, + "shippingDescription": null, + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 18.55, + "baseGrandTotal": 18.55, + "grandTotalInvoiced": 18.55, + "baseGrandTotalInvoiced": 18.55, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 18.55, + "baseSubTotal": 18.55, + "subTotalInvoiced": 18.55, + "baseSubTotalInvoiced": 18.55, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 0, + "baseShippingAmount": 0, + "shippingInvoiced": 0, + "baseShippingInvoiced": 0, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "5", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-28 17:03:10", + "updatedAt": "2021-05-28 17:03:35" + }, + "orderItem": { + "id": "4", + "sku": "e-book", + "type": "downloadable", + "name": "e-book", + "couponCode": null, + "weight": 5.2, + "totalWeight": 5.2, + "qtyOrdered": 1, + "qtyShipped": 0, + "qtyInvoiced": 1, + "qtyCanceled": 0, + "qtyRefunded": 0, + "price": 18.55, + "basePrice": 18.55, + "total": 18.55, + "baseTotal": 18.55 + } + } + } + } + ~~~ +::: \ No newline at end of file diff --git a/docs/1.x/graphql-shop-api/getting-started-with-the-api.md b/docs/1.x/graphql-shop-api/getting-started-with-the-api.md new file mode 100644 index 00000000..c46fc2b6 --- /dev/null +++ b/docs/1.x/graphql-shop-api/getting-started-with-the-api.md @@ -0,0 +1,429 @@ +# Authentication + +[[toc]] + +## Introduction + +By default the [Bagisto](https://bagisto.com) GraphQL API makes use of the [JWT package](https://jwt.io/) for token-based authentication. + +So, let's try to authenticate the Customer by using **JWT**. Please send valid **User Agent** header in your request whether you are using postman, curl or some other clients. + +To check the customer's API (front APIs), you have to put all the shop schemas at the end in the schema file (i.e. packages/Webkul/GraphQLAPI/graphql/schema.graphql). + +**Note** Put all shop schemas #import /shop/*/*.graphql after #import /promotion/*.graphql this line. + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +- Headers + + | Key | Value | + | ------ | ---------------- | + | Accept | application/json | + + + +- Query + + ~~~query + mutation customerLogin { + customerLogin(input: { + email: "test@webkul.com" + password: "admin123" + }) { + status + success + accessToken + tokenType + expiresIn + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + } + } + ~~~ + +- Response + + - Once you send the request, you will get some random token string that will be used to access the API data. + + ~~~json + { + "data": { + "customerLogin": { + "status": true, + "success": "Success: Customer login successfully.", + "accessToken": "Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJodHRwOlwvXC9sb2NhbGhvc3RcL2dyYXBocWxcL3B1YmxpY1wvZ3JhcGhxbCIsImlhdCI6MTYyMjE4NDAyNywiZXhwIjoxNjUzNzIwMDI3LCJuYmYiOjE2MjIxODQwMjcsImp0aSI6ImRTa3JpSjZqU2d1QTBQVG4iLCJzdWIiOjMsInBydiI6IjhmY2EwODhhYmFlMmY5YThmODRhNWYwYmY2YTY1MjQ0OTA1NWJlMDAifQ.YXUdp9S1cDCGUkLdv7NijMgx0bcX5KbokcjSIMwEE0U", + "tokenType": "Bearer", + "expiresIn": 31536000, + "customer": { + "id": "3", + "firstName": "test", + "lastName": "test", + "name": "Test Test", + "gender": null, + "dateOfBirth": null, + "email": "test@webkul.com", + "phone": null, + "password": "$2y$10$QSz44sL1TcKwNYBHcX6go.OIMjxN1eakuJnHYrB.Rj0jyM172yfXW", + "apiToken": "wWFsZbvoXPdL0NdWxK4cR23SAd6UJnVDDqsMrBgYmUeJvoCzEJDl4b9rn7eR9ckFC5mIaZmVg9vmXamd", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "4274363173b91b41790653255c037bbd", + "notes": null, + "status": true, + "createdAt": "2021-05-28 11:59:21", + "updatedAt": "2021-05-28 11:59:21" + } + } + } + } + ~~~ + +## Get Customer Details + +Once you are authenticated, try to access the current User data by using **JWT**, use the Single GraphQL API endpoint for this, + +::: tip + +Here we are just showing a example of how to collect data from the GraphQL API with the usage of a **JWT** token. + +::: + +#### Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +::: tip + +As you check the **JWT** authentication we got some token string, we just need to put that token in the request header. For e.g., + +~~~request-header + Accept:application/json + Authorization:Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9... +~~~ + +::: + +- Query + ~~~query + query accountInfo { + accountInfo { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "accountInfo": { + "id": "3", + "firstName": "test", + "lastName": "test", + "name": "Test Test", + "gender": null, + "dateOfBirth": null, + "email": "test@webkul.com", + "phone": null, + "password": "$2y$10$QSz44sL1TcKwNYBHcX6go.OIMjxN1eakuJnHYrB.Rj0jyM172yfXW", + "apiToken": "wWFsZbvoXPdL0NdWxK4cR23SAd6UJnVDDqsMrBgYmUeJvoCzEJDl4b9rn7eR9ckFC5mIaZmVg9vmXamd", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "4274363173b91b41790653255c037bbd", + "notes": null, + "status": true, + "createdAt": "2021-05-28 11:59:21", + "updatedAt": "2021-05-28 11:59:21" + } + } +} +~~~ + +::: + + +## Register a new Customer + + To Register a new Customer, you have to perform mutation on customer and paas related fields in the request. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation customerRegister { + customerRegister(input: { + firstName: "John" + lastName: "Doe" + email: "john@example.com" + password: "demo12345" + passwordConfirmation: "demo12345" + }) { + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "customerRegister": { + "status": true, + "success": "Account created successfully." + } + } + } + ~~~ +::: + +## Update a Customer + + To update a Customer, you have to perform mutation on Customer by passing related fields of logged in customer in the request query. + API call resource will update a Customer, only if the customer has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation updateAccount { + updateAccount(input: { + firstName: "John" + lastName: "Doe" + email: "john@example.com" + gender: "Male" + dateOfBirth: "2019-10-30" + phone: "345789876" + oldpassword: "demo12345" + password: "demo123456" + passwordConfirmation: "demo123456" + }) { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "updateAccount": { + "id": "4", + "firstName": "John", + "lastName": "Doe", + "name": "John Doe", + "gender": "Male", + "dateOfBirth": "2019-10-30", + "email": "john@example.com", + "phone": "345789876", + "password": "$2y$10$u8P14NRoevQmJM0VVO.7hOKX98hrtArPd9WawkL7ljHywJtYMS/QS", + "apiToken": "7LaahSQCR9tQYVy894pZ7C79C9uIksxGbks0svVG5fzqjP023532jIWoMR2oW0McnQdpIBQttHbn2J2d", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "e043dc2f63147521a14bb9109f779247", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:18:22", + "updatedAt": "2021-05-28 12:24:51" + } + } + } + ~~~ +::: + +## Forgot Password + +If you Forgot Password, you have to perform mutation on Customer by passing the registered email of that Customer. and a mail will be received on that email id. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation forgotPassword { + forgotPassword(input: { + email: "john@example.com" + }) { + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "forgotPassword": { + "status": true, + "success": "We have e-mailed your reset password link." + } + } + } + ~~~ +::: + +## Delete a Customer + +To delete a Customer, you have to perform mutation on Customer by passing the Password of that Customer. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation deleteAccount { + deleteAccount(input: { + password: "demo123456" + }) { + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "deleteAccount": { + "status": true, + "success": "Customer deleted successfully." + } + } + } + ~~~ +::: + +## Logout + +You can logout the Customer by performing the logout mutaion on customer. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + + ### Examples + + Let's take an example, + + - Request Mutation + ~~~Mutation + mutation customerLogout { + customerLogout { + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "customerLogout": { + "status": true, + "success": "Success: Customer logout successfully." + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-shop-api/homepage.md b/docs/1.x/graphql-shop-api/homepage.md new file mode 100644 index 00000000..36ff1d9e --- /dev/null +++ b/docs/1.x/graphql-shop-api/homepage.md @@ -0,0 +1,706 @@ +# Home Page Content + +In this section, we will see all the APIs which are related to Home Page Content. + +## Get New Products + +You can get New Products of home page from the Bagisto store by passing the count of products. You can achieve this job by using the `newProducts` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +- Query + ~~~query + query newProducts{ + newProducts(count:3){ + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + product{ + id + } + variants { + id + } + parent { + id + } + createdAt + updatedAt + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "newProducts": [ + { + "id": "8", + "sku": "e-book", + "name": "e-book", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "e-book", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "8", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "product": { + "id": "8" + }, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 12:52:39", + "updatedAt": "2021-05-27 12:52:39" + }, + { + "id": "12", + "sku": "event-booking", + "name": "Music Show", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "music-show", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "12", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "product": { + "id": "12" + }, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 16:04:24", + "updatedAt": "2021-05-27 16:04:24" + }, + { + "id": "9", + "sku": "bundle-demo", + "name": "Bundle Box", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "bundle-demo", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "9", + "parentId": null, + "minPrice": 13.5, + "maxPrice": 31.5, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "product": { + "id": "9" + }, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 13:11:58", + "updatedAt": "2021-05-27 13:11:58" + } + ] + } +} +~~~ +::: + +## Get Featured Products + +You can get Featured Products Products of home page from the Bagisto store by passing the count of products. You can achieve this job by using the `featuredProducts` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +- Query + ~~~query + query featuredProducts{ + featuredProducts(count:3){ + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + product{ + id + } + variants { + id + } + parent { + id + } + createdAt + updatedAt + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "featuredProducts": [ + { + "id": "8", + "sku": "e-book", + "name": "e-book", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "e-book", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "8", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "product": { + "id": "8" + }, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 12:52:39", + "updatedAt": "2021-05-27 12:52:39" + }, + { + "id": "12", + "sku": "event-booking", + "name": "Music Show", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "music-show", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "12", + "parentId": null, + "minPrice": 11.295, + "maxPrice": 11.295, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "product": { + "id": "12" + }, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 16:04:24", + "updatedAt": "2021-05-27 16:04:24" + }, + { + "id": "9", + "sku": "bundle-demo", + "name": "Bundle Box", + "description": "

Home Decor Description

", + "shortDescription": "

Home Decor Short Description

", + "urlKey": "bundle-demo", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 12.55, + "cost": 11.5, + "specialPrice": 11.3, + "specialPriceFrom": "2021-02-08", + "specialPriceTo": "2021-02-28", + "weight": 5.2, + "color": 3, + "colorLabel": "Yellow", + "size": 9, + "sizeLabel": "XL", + "locale": "en", + "channel": "default", + "productId": "9", + "parentId": null, + "minPrice": 13.5, + "maxPrice": 31.5, + "metaTitle": "Home Decor Meta Title", + "metaKeywords": "Home Decor Meta Keywords", + "metaDescription": "Home Decor Meta Description", + "width": 30, + "height": 24, + "depth": 11, + "product": { + "id": "9" + }, + "variants": [], + "parent": null, + "createdAt": "2021-05-27 13:11:58", + "updatedAt": "2021-05-27 13:11:58" + } + ] + } +} +~~~ +::: + +## Get Home Sliders + +To get the Home Page Slider you have to call the `homeSliders` API. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + +Let's take an example, + +- Request Query + ~~~Query + query homeSliders{ + homeSliders(count:10){ + id + title + path + content + channelId + locale + sliderPath + imgPath + channel { + id + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "homeSliders": [ + { + "id": "1", + "title": "testslider", + "path": "slider_images/Default/1L0uZrZrMaadZGRh8pNCLcKXNhrhQugs84AXRkui.jpg", + "content": "

testcontent

", + "channelId": "1", + "locale": "en", + "sliderPath": "test", + "imgPath": null, + "channel": { + "id": "1" + } + } + ] + } + } + ~~~ +::: + + +## Get Advertisements + +To get the Advertisements you have to call the `advertisements` API. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + +Let's take an example, + +- Request Query + ~~~Query + query advertisements{ + advertisements{ + advertisementFour { + path + } + advertisementThree { + path + } + advertisementTwo { + path + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "advertisements": [ + { + "advertisementFour": [ + { + "path": "velocity/images/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + }, + { + "path": "velocity/images/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + } + ], + "advertisementThree": [ + { + "path": "velocity/images/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + }, + { + "path": "velocity/images/big-sale-banner.png" + } + ], + "advertisementTwo": [ + { + "path": "velocity/images/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + }, + { + "path": "velocity/images/tnyNbLh4GDwMy0P3qwbP5OcFU0nr9g9j0zhNyFiA.jpeg" + } + ] + } + ] + } + } + ~~~ +::: + +## Get Home Category + +To get the Home Category you have to call the `homeCategories` API. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + +Let's take an example, + +- Request Query + ~~~Query + query homeCategories{ + homeCategories{ + id + name + description + slug + urlPath + image + imageUrl + metaTitle + metaDescription + metaKeywords + position + status + displayMode + parentId + additional + filterableAttributes { + id + code + adminName + type + validation + position + isFilterable + } + translations { + id + name + slug + description + metaTitle + metaDescription + metaKeywords + category_id + locale + localeId + urlPath + } + createdAt + updatedAt + count + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "homeCategories": [ + { + "id": "2", + "name": "Shop", + "description": "

Test Category

", + "slug": "shop", + "urlPath": "shop", + "image": "category/2/veI5gArm9nBKUFPwvvmmoRccLdtlJXhHBtaGzL4a.jpg", + "imageUrl": "http://localhost/graphql/public/storage/category/2/veI5gArm9nBKUFPwvvmmoRccLdtlJXhHBtaGzL4a.jpg", + "metaTitle": "", + "metaDescription": "", + "metaKeywords": "", + "position": 1, + "status": true, + "displayMode": "products_and_description", + "parentId": "1", + "additional": null, + "filterableAttributes": [ + { + "id": "11", + "code": "price", + "adminName": "Price", + "type": "price", + "validation": "decimal", + "position": 13, + "isFilterable": 1 + }, + { + "id": "23", + "code": "color", + "adminName": "Color", + "type": "select", + "validation": null, + "position": 26, + "isFilterable": 1 + }, + { + "id": "24", + "code": "size", + "adminName": "Size", + "type": "select", + "validation": null, + "position": 27, + "isFilterable": 1 + }, + { + "id": "25", + "code": "brand", + "adminName": "Brand", + "type": "select", + "validation": null, + "position": 28, + "isFilterable": 1 + } + ], + "translations": [ + { + "id": "2", + "name": "Shop", + "slug": "shop", + "description": "

Test Category

", + "metaTitle": "", + "metaDescription": "", + "metaKeywords": "", + "category_id": "2", + "locale": "en", + "localeId": "1", + "urlPath": "shop" + }, + { + "id": "3", + "name": "Shop", + "slug": "shop", + "description": "

Test Category

", + "metaTitle": "", + "metaDescription": "", + "metaKeywords": "", + "category_id": "2", + "locale": "nl", + "localeId": "3", + "urlPath": "shop" + }, + { + "id": "4", + "name": "Shop", + "slug": "shop", + "description": "

Test Category

", + "metaTitle": "", + "metaDescription": "", + "metaKeywords": "", + "category_id": "2", + "locale": "tr", + "localeId": "4", + "urlPath": "shop" + } + ], + "createdAt": "2021-05-27 18:06:22", + "updatedAt": "2021-05-27 18:06:23", + "count": 0, + "success": null + } + ] + } + } + ~~~ +::: + diff --git a/docs/1.x/graphql-shop-api/orders.md b/docs/1.x/graphql-shop-api/orders.md new file mode 100644 index 00000000..4a776cf1 --- /dev/null +++ b/docs/1.x/graphql-shop-api/orders.md @@ -0,0 +1,2600 @@ +# Orders + +In this section, we will see all the APIs which are related to Customer Orders. + +## Get Customer Orders + +You can get all the Customer Orders from the Bagisto store. You can achieve this job by using the `Customer Orders` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + query ordersList { + ordersList(input: { + page: 1 + limit: 10 + }) { + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + billingAddress { + id + customerId + cartId + orderId + firstName + lastName + gender + companyName + address1 + address2 + postcode + city + state + country + email + phone + vatId + defaultAddress + } + shippingAddress { + id + customerId + cartId + orderId + firstName + lastName + gender + companyName + address1 + address2 + postcode + city + state + country + email + phone + vatId + defaultAddress + } + items { + id + sku + type + name + couponCode + weight + totalWeight + qtyOrdered + qtyShipped + qtyInvoiced + qtyCanceled + qtyRefunded + price + basePrice + total + baseTotal + totalInvoiced + baseTotalInvoiced + amountRefunded + baseAmountRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxPercent + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + productId + productType + orderId + parentId + additional + createdAt + updatedAt + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + } + child { + id + sku + type + name + couponCode + weight + totalWeight + qtyOrdered + qtyShipped + qtyInvoiced + qtyCanceled + qtyRefunded + price + basePrice + total + baseTotal + totalInvoiced + baseTotalInvoiced + } + invoiceItems { + id + sku + type + name + description + qty + price + basePrice + total + baseTotal + taxAmount + baseTaxAmount + productId + productType + orderItemId + invoiceId + parentId + } + shipmentItems { + id + name + description + sku + qty + weight + price + basePrice + total + baseTotal + productId + productType + orderItemId + shipmentId + } + refundItems { + id + name + description + sku + qty + price + basePrice + total + baseTotal + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + productId + productType + orderItemId + refundId + parentId + } + } + shipments { + id + status + totalQty + totalWeight + carrierCode + carrierTitle + trackNumber + emailSent + customerId + customerType + orderId + orderAddressId + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "ordersList": [ + { + "id": 3, + "incrementId": "3", + "status": "pending", + "channelName": "Default", + "isGuest": 0, + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 15, + "baseGrandTotal": 15, + "grandTotalInvoiced": 0, + "baseGrandTotalInvoiced": 0, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 5, + "baseSubTotal": 5, + "subTotalInvoiced": 0, + "baseSubTotalInvoiced": 0, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 0, + "baseShippingInvoiced": 0, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "3", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 14:28:51", + "billingAddress": { + "id": 16, + "customerId": 5, + "cartId": null, + "orderId": 3, + "firstName": "Tom Demo2", + "lastName": "Martin Demo2", + "gender": null, + "companyName": "Webkul2", + "address1": "3180 Bluff", + "address2": "Street", + "postcode": "15742222222", + "city": "GLEN CAMPBELL", + "state": "PA", + "country": "US", + "email": "naresh.verma327@webkul.com", + "phone": "234343544", + "vatId": "INV12345678904", + "defaultAddress": 0 + }, + "shippingAddress": { + "id": 15, + "customerId": 5, + "cartId": null, + "orderId": 3, + "firstName": "Tom Demo2", + "lastName": "Martin Demo2", + "gender": null, + "companyName": "Webkul2", + "address1": "3180 Bluff", + "address2": "Street", + "postcode": "15742222222", + "city": "GLEN CAMPBELL", + "state": "PA", + "country": "US", + "email": "naresh.verma327@webkul.com", + "phone": "234343544", + "vatId": "INV12345678904", + "defaultAddress": 0 + }, + "items": [ + { + "id": "3", + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "couponCode": null, + "weight": 3, + "totalWeight": 3, + "qtyOrdered": 1, + "qtyShipped": 0, + "qtyInvoiced": 0, + "qtyCanceled": 0, + "qtyRefunded": 0, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "totalInvoiced": 0, + "baseTotalInvoiced": 0, + "amountRefunded": 0, + "baseAmountRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxPercent": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "productId": "1", + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderId": "3", + "parentId": null, + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 14:28:51", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "child": null, + "invoiceItems": [], + "shipmentItems": [], + "refundItems": [] + } + ], + "shipments": [] + } + ] + } +} +~~~ +::: + +## Get Customer Order By ID + +To get the specific Customer Order, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query orderDetail { + orderDetail(id: 3) { + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + billingAddress { + id + customerId + cartId + orderId + firstName + lastName + gender + companyName + address1 + address2 + postcode + city + state + country + email + phone + vatId + defaultAddress + } + shippingAddress { + id + customerId + cartId + orderId + firstName + lastName + gender + companyName + address1 + address2 + postcode + city + state + country + email + phone + vatId + defaultAddress + } + items { + id + sku + type + name + couponCode + weight + totalWeight + qtyOrdered + qtyShipped + qtyInvoiced + qtyCanceled + qtyRefunded + price + basePrice + total + baseTotal + totalInvoiced + baseTotalInvoiced + amountRefunded + baseAmountRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxPercent + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + productId + productType + orderId + parentId + additional + createdAt + updatedAt + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + } + child { + id + sku + type + name + couponCode + weight + totalWeight + qtyOrdered + qtyShipped + qtyInvoiced + qtyCanceled + qtyRefunded + price + basePrice + total + baseTotal + totalInvoiced + baseTotalInvoiced + } + invoiceItems { + id + sku + type + name + description + qty + price + basePrice + total + baseTotal + taxAmount + baseTaxAmount + productId + productType + orderItemId + invoiceId + parentId + } + shipmentItems { + id + name + description + sku + qty + weight + price + basePrice + total + baseTotal + productId + productType + orderItemId + shipmentId + } + refundItems { + id + name + description + sku + qty + price + basePrice + total + baseTotal + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + productId + productType + orderItemId + refundId + parentId + } + } + shipments { + id + status + totalQty + totalWeight + carrierCode + carrierTitle + trackNumber + emailSent + customerId + customerType + orderId + orderAddressId + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "orderDetail": { + "id": 3, + "incrementId": "3", + "status": "pending", + "channelName": "Default", + "isGuest": 0, + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 15, + "baseGrandTotal": 15, + "grandTotalInvoiced": 0, + "baseGrandTotalInvoiced": 0, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 5, + "baseSubTotal": 5, + "subTotalInvoiced": 0, + "baseSubTotalInvoiced": 0, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 0, + "baseShippingInvoiced": 0, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "3", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 14:28:51", + "billingAddress": { + "id": 16, + "customerId": 5, + "cartId": null, + "orderId": 3, + "firstName": "Tom Demo2", + "lastName": "Martin Demo2", + "gender": null, + "companyName": "Webkul2", + "address1": "3180 Bluff", + "address2": "Street", + "postcode": "15742222222", + "city": "GLEN CAMPBELL", + "state": "PA", + "country": "US", + "email": "naresh.verma327@webkul.com", + "phone": "234343544", + "vatId": "INV12345678904", + "defaultAddress": 0 + }, + "shippingAddress": { + "id": 15, + "customerId": 5, + "cartId": null, + "orderId": 3, + "firstName": "Tom Demo2", + "lastName": "Martin Demo2", + "gender": null, + "companyName": "Webkul2", + "address1": "3180 Bluff", + "address2": "Street", + "postcode": "15742222222", + "city": "GLEN CAMPBELL", + "state": "PA", + "country": "US", + "email": "naresh.verma327@webkul.com", + "phone": "234343544", + "vatId": "INV12345678904", + "defaultAddress": 0 + }, + "items": [ + { + "id": "3", + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "couponCode": null, + "weight": 3, + "totalWeight": 3, + "qtyOrdered": 1, + "qtyShipped": 0, + "qtyInvoiced": 0, + "qtyCanceled": 0, + "qtyRefunded": 0, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "totalInvoiced": 0, + "baseTotalInvoiced": 0, + "amountRefunded": 0, + "baseAmountRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxPercent": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "productId": "1", + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderId": "3", + "parentId": null, + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 14:28:51", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "child": null, + "invoiceItems": [], + "shipmentItems": [], + "refundItems": [] + } + ], + "shipments": [] + } + } + } + ~~~ +::: + + + +## Get Customer Invoices + +You can get all the Customer Invoices from the Bagisto store. You can achieve this job by using the `Customer Invoices` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note** You can pass all the input fields to filter the invoice data. + +- Query + ~~~query + query viewInvoices { + viewInvoices(input: { + page: 1 + limit: 10 + # id: 1 + # orderId: 3 + # quantity: 1 + # grandTotal: 5.35 + # baseGrandTotal: 5.35 + # invoiceDate: "2021-02-12 20:36:26" + }) { + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountAmount + baseDiscountAmount + orderId + orderAddressId + createdAt + updatedAt + transactionId + items { + id + sku + type + name + description + qty + price + basePrice + total + baseTotal + taxAmount + baseTaxAmount + productId + productType + orderItemId + invoiceId + parentId + additional + discountPercent + discountAmount + baseDiscountAmount + createdAt + updatedAt + orderItem { + id + sku + type + name + couponCode + weight + totalWeight + qtyOrdered + qtyShipped + qtyInvoiced + qtyCanceled + qtyRefunded + price + basePrice + total + baseTotal + totalInvoiced + baseTotalInvoiced + amountRefunded + baseAmountRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxPercent + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + productId + productType + orderId + parentId + additional + createdAt + updatedAt + } + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "viewInvoices": [ + { + "id": 2, + "incrementId": null, + "state": "paid", + "emailSent": 0, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "subTotal": 5, + "baseSubTotal": 5, + "grandTotal": 15, + "baseGrandTotal": 15, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 3, + "orderAddressId": 16, + "createdAt": "2021-05-28 14:30:32", + "updatedAt": "2021-05-28 14:30:32", + "transactionId": null, + "items": [ + { + "id": "2", + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "description": null, + "qty": 1, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "taxAmount": 0, + "baseTaxAmount": 0, + "productId": "1", + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderItemId": "3", + "invoiceId": "2", + "parentId": null, + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "createdAt": "2021-05-28 14:30:32", + "updatedAt": "2021-05-28 14:30:32", + "orderItem": { + "id": "3", + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "couponCode": null, + "weight": 3, + "totalWeight": 3, + "qtyOrdered": 1, + "qtyShipped": 1, + "qtyInvoiced": 1, + "qtyCanceled": 0, + "qtyRefunded": 0, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "totalInvoiced": 5, + "baseTotalInvoiced": 5, + "amountRefunded": 0, + "baseAmountRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxPercent": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "productId": "1", + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderId": "3", + "parentId": null, + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 14:31:00" + }, + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + } + ] + } + ] + } +} +~~~ +::: + +## Get Customer Invoice By ID + +To get the specific Customer Order Invoice, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query viewInvoice { + viewInvoice(id: 2) { + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountAmount + baseDiscountAmount + orderId + orderAddressId + createdAt + updatedAt + transactionId + items { + id + sku + type + name + description + qty + price + basePrice + total + baseTotal + taxAmount + baseTaxAmount + productId + productType + orderItemId + invoiceId + parentId + additional + discountPercent + discountAmount + baseDiscountAmount + createdAt + updatedAt + orderItem { + id + sku + type + name + couponCode + weight + totalWeight + qtyOrdered + qtyShipped + qtyInvoiced + qtyCanceled + qtyRefunded + price + basePrice + total + baseTotal + totalInvoiced + baseTotalInvoiced + amountRefunded + baseAmountRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxPercent + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + productId + productType + orderId + parentId + additional + createdAt + updatedAt + } + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "viewInvoice": { + "id": 2, + "incrementId": null, + "state": "paid", + "emailSent": 0, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "subTotal": 5, + "baseSubTotal": 5, + "grandTotal": 15, + "baseGrandTotal": 15, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 3, + "orderAddressId": 16, + "createdAt": "2021-05-28 14:30:32", + "updatedAt": "2021-05-28 14:30:32", + "transactionId": null, + "items": [ + { + "id": "2", + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "description": null, + "qty": 1, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "taxAmount": 0, + "baseTaxAmount": 0, + "productId": "1", + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderItemId": "3", + "invoiceId": "2", + "parentId": null, + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "createdAt": "2021-05-28 14:30:32", + "updatedAt": "2021-05-28 14:30:32", + "orderItem": { + "id": "3", + "sku": "test-product", + "type": "simple", + "name": "testOutlet", + "couponCode": null, + "weight": 3, + "totalWeight": 3, + "qtyOrdered": 1, + "qtyShipped": 1, + "qtyInvoiced": 1, + "qtyCanceled": 0, + "qtyRefunded": 0, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "totalInvoiced": 5, + "baseTotalInvoiced": 5, + "amountRefunded": 0, + "baseAmountRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxPercent": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "productId": "1", + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderId": "3", + "parentId": null, + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 14:31:00" + }, + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + } + ] + } + } + } + ~~~ +::: + +## Get Customer Shipments + +You can get all the Customer Shipments from the Bagisto store. You can achieve this job by using the `Customer Shipments` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note** You can pass all the input fields to filter the shipment data. + +- Query + ~~~query + query viewShipments { + viewShipments(input: { + page: 1 + limit: 10 + # orderId: 3 + # carrierTitle: "DHL" + # trackNumber: "3333" + # shipmentDateFrom: "2021-02-16 00:00:01" + # shipmentDateTo: "2021-02-16 23:00:00" + # shipmentDate: "2021-02-16 19:17:21" + }) { + id + status + totalQty + totalWeight + carrierCode + carrierTitle + trackNumber + emailSent + customerId + customerType + orderId + orderAddressId + createdAt + updatedAt + inventorySourceId + inventorySourceName + order { + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + } + items { + id + name + description + sku + qty + weight + price + basePrice + total + baseTotal + productId + productType + orderItemId + shipmentId + additional + createdAt + updatedAt + } + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + } + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + customerGroup { + id + name + code + isUserDefined + createdAt + updatedAt + } + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "viewShipments": [ + { + "id": 2, + "status": null, + "totalQty": 1, + "totalWeight": null, + "carrierCode": null, + "carrierTitle": "FEDEX", + "trackNumber": "32414zx", + "emailSent": 0, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "orderId": 3, + "orderAddressId": 15, + "createdAt": "2021-05-28 14:31:00", + "updatedAt": "2021-05-28 14:31:00", + "inventorySourceId": 1, + "inventorySourceName": "Default", + "order": { + "id": 3, + "incrementId": "3", + "status": "completed", + "channelName": "Default", + "isGuest": 0, + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 15, + "baseGrandTotal": 15, + "grandTotalInvoiced": 15, + "baseGrandTotalInvoiced": 15, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 5, + "baseSubTotal": 5, + "subTotalInvoiced": 5, + "baseSubTotalInvoiced": 5, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 10, + "baseShippingInvoiced": 10, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "3", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 14:31:00" + }, + "items": [ + { + "id": 2, + "name": "testOutlet", + "description": null, + "sku": "test-product", + "qty": 1, + "weight": 3, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "productId": "1", + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderItemId": "3", + "shipmentId": "2", + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "createdAt": "2021-05-28 14:31:00", + "updatedAt": "2021-05-28 14:31:00" + } + ], + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null + }, + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "customerGroup": { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + } + } + ] + } +} +~~~ +::: + +## Get Customer Shipment By ID + +To get the specific Customer Order Shipment, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query viewShipment { + viewShipment(id: 2) { + id + status + totalQty + totalWeight + carrierCode + carrierTitle + trackNumber + emailSent + customerId + customerType + orderId + orderAddressId + createdAt + updatedAt + inventorySourceId + inventorySourceName + order { + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + } + items { + id + name + description + sku + qty + weight + price + basePrice + total + baseTotal + productId + productType + orderItemId + shipmentId + additional + createdAt + updatedAt + } + inventorySource { + id + code + name + description + contactName + contactEmail + contactNumber + contactFax + country + state + city + street + postcode + priority + latitude + longitude + } + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + customerGroup { + id + name + code + isUserDefined + createdAt + updatedAt + } + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "viewShipment": { + "id": 2, + "status": null, + "totalQty": 1, + "totalWeight": null, + "carrierCode": null, + "carrierTitle": "FEDEX", + "trackNumber": "32414zx", + "emailSent": 0, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "orderId": 3, + "orderAddressId": 15, + "createdAt": "2021-05-28 14:31:00", + "updatedAt": "2021-05-28 14:31:00", + "inventorySourceId": 1, + "inventorySourceName": "Default", + "order": { + "id": 3, + "incrementId": "3", + "status": "completed", + "channelName": "Default", + "isGuest": 0, + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 15, + "baseGrandTotal": 15, + "grandTotalInvoiced": 15, + "baseGrandTotalInvoiced": 15, + "grandTotalRefunded": 0, + "baseGrandTotalRefunded": 0, + "subTotal": 5, + "baseSubTotal": 5, + "subTotalInvoiced": 5, + "baseSubTotalInvoiced": 5, + "subTotalRefunded": 0, + "baseSubTotalRefunded": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 10, + "baseShippingInvoiced": 10, + "shippingRefunded": 0, + "baseShippingRefunded": 0, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "3", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 14:31:00" + }, + "items": [ + { + "id": 2, + "name": "testOutlet", + "description": null, + "sku": "test-product", + "qty": 1, + "weight": 3, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "productId": "1", + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderItemId": "3", + "shipmentId": "2", + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "createdAt": "2021-05-28 14:31:00", + "updatedAt": "2021-05-28 14:31:00" + } + ], + "inventorySource": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "contactName": "Detroit Warehouse", + "contactEmail": "warehouse@example.com", + "contactNumber": "1234567899", + "contactFax": null, + "country": "US", + "state": "MI", + "city": "Detroit", + "street": "12th Street", + "postcode": "48127", + "priority": 0, + "latitude": null, + "longitude": null + }, + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "customerGroup": { + "id": "2", + "name": "General", + "code": "general", + "isUserDefined": false, + "createdAt": null, + "updatedAt": null + }, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + } + } + } + } + ~~~ +::: + +## Get Customer Refunds + +You can get all the Customer Refunds from the Bagisto store. You can achieve this job by using the `Customer Refunds` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note** You can pass all the input fields to filter the refund data. + +- Query + ~~~query + query viewRefunds { + viewRefunds(input: { + page: 1 + limit: 10 + # id: 1 + # orderId: 1 + # quantity: 2 + # adjustmentRefund: 1.22 + # adjustmentFee: 3.45 + # shippingAmount: 47.50 + # taxAmount: 1.13 + # discountAmount: 1.45 + # grandTotal: 5.35 + # baseGrandTotal: 5.35 + # refundDate: "2021-02-12 20:36:26" + }) { + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + adjustmentRefund + baseAdjustmentRefund + adjustmentFee + baseAdjustmentFee + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + orderId + createdAt + updatedAt + items { + id + name + description + sku + qty + price + basePrice + total + baseTotal + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + productId + productType + orderItemId + refundId + parentId + additional + createdAt + updatedAt + } + order { + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "viewRefunds": [ + { + "id": 2, + "incrementId": null, + "state": "refunded", + "emailSent": 0, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "adjustmentRefund": 0, + "baseAdjustmentRefund": 0, + "adjustmentFee": 0, + "baseAdjustmentFee": 0, + "subTotal": 5, + "baseSubTotal": 5, + "grandTotal": 15, + "baseGrandTotal": 15, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 3, + "createdAt": "2021-05-28 15:22:34", + "updatedAt": "2021-05-28 15:22:34", + "items": [ + { + "id": 2, + "name": "testOutlet", + "description": null, + "sku": "test-product", + "qty": 1, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "productId": 1, + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderItemId": 3, + "refundId": 2, + "parentId": null, + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "createdAt": "2021-05-28 15:22:34", + "updatedAt": "2021-05-28 15:22:34" + } + ], + "order": { + "id": 3, + "incrementId": "3", + "status": "closed", + "channelName": "Default", + "isGuest": 0, + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 15, + "baseGrandTotal": 15, + "grandTotalInvoiced": 15, + "baseGrandTotalInvoiced": 15, + "grandTotalRefunded": 15, + "baseGrandTotalRefunded": 15, + "subTotal": 5, + "baseSubTotal": 5, + "subTotalInvoiced": 5, + "baseSubTotalInvoiced": 5, + "subTotalRefunded": 5, + "baseSubTotalRefunded": 5, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 10, + "baseShippingInvoiced": 10, + "shippingRefunded": 10, + "baseShippingRefunded": 10, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "3", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 15:22:34" + } + } + ] + } +} +~~~ +::: + +## Get Customer Refund By ID + +To get the specific Customer Order Refund, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query viewRefund { + viewRefund(id: 2) { + id + incrementId + state + emailSent + totalQty + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + adjustmentRefund + baseAdjustmentRefund + adjustmentFee + baseAdjustmentFee + subTotal + baseSubTotal + grandTotal + baseGrandTotal + shippingAmount + baseShippingAmount + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + orderId + createdAt + updatedAt + items { + id + name + description + sku + qty + price + basePrice + total + baseTotal + taxAmount + baseTaxAmount + discountPercent + discountAmount + baseDiscountAmount + productId + productType + orderItemId + refundId + parentId + additional + createdAt + updatedAt + } + order { + id + incrementId + status + channelName + isGuest + customerEmail + customerFirstName + customerLastName + customerCompanyName + customerVatId + shippingMethod + shippingTitle + shippingDescription + couponCode + isGift + totalItemCount + totalQtyOrdered + baseCurrencyCode + channelCurrencyCode + orderCurrencyCode + grandTotal + baseGrandTotal + grandTotalInvoiced + baseGrandTotalInvoiced + grandTotalRefunded + baseGrandTotalRefunded + subTotal + baseSubTotal + subTotalInvoiced + baseSubTotalInvoiced + subTotalRefunded + baseSubTotalRefunded + discountPercent + discountAmount + baseDiscountAmount + discountInvoiced + baseDiscountInvoiced + discountRefunded + baseDiscountRefunded + taxAmount + baseTaxAmount + taxAmountInvoiced + baseTaxAmountInvoiced + taxAmountRefunded + baseTaxAmountRefunded + shippingAmount + baseShippingAmount + shippingInvoiced + baseShippingInvoiced + shippingRefunded + baseShippingRefunded + customerId + customerType + channelId + channelType + cartId + appliedCartRuleIds + shippingDiscountAmount + baseShippingDiscountAmount + createdAt + updatedAt + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "viewRefund": { + "id": 2, + "incrementId": null, + "state": "refunded", + "emailSent": 0, + "totalQty": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "adjustmentRefund": 0, + "baseAdjustmentRefund": 0, + "adjustmentFee": 0, + "baseAdjustmentFee": 0, + "subTotal": 5, + "baseSubTotal": 5, + "grandTotal": 15, + "baseGrandTotal": 15, + "shippingAmount": 10, + "baseShippingAmount": 10, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "orderId": 3, + "createdAt": "2021-05-28 15:22:34", + "updatedAt": "2021-05-28 15:22:34", + "items": [ + { + "id": 2, + "name": "testOutlet", + "description": null, + "sku": "test-product", + "qty": 1, + "price": 5, + "basePrice": 5, + "total": 5, + "baseTotal": 5, + "taxAmount": 0, + "baseTaxAmount": 0, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "productId": 1, + "productType": "Webkul\\GraphQLAPI\\Models\\Catalog\\Product", + "orderItemId": 3, + "refundId": 2, + "parentId": null, + "additional": "{\"_token\":\"CdIv16Fyz7kXgGr6zs8P3brDWldnU5U0jsCZOGdI\",\"locale\":\"en\",\"quantity\":\"1\",\"product_id\":\"1\"}", + "createdAt": "2021-05-28 15:22:34", + "updatedAt": "2021-05-28 15:22:34" + } + ], + "order": { + "id": 3, + "incrementId": "3", + "status": "closed", + "channelName": "Default", + "isGuest": 0, + "customerEmail": "naresh.verma327@webkul.com", + "customerFirstName": "Naresh", + "customerLastName": "Verma", + "customerCompanyName": null, + "customerVatId": null, + "shippingMethod": "flatrate_flatrate", + "shippingTitle": "Flat Rate - Flat Rate", + "shippingDescription": "Flat Rate Shipping", + "couponCode": null, + "isGift": 0, + "totalItemCount": 1, + "totalQtyOrdered": 1, + "baseCurrencyCode": "USD", + "channelCurrencyCode": "USD", + "orderCurrencyCode": "USD", + "grandTotal": 15, + "baseGrandTotal": 15, + "grandTotalInvoiced": 15, + "baseGrandTotalInvoiced": 15, + "grandTotalRefunded": 15, + "baseGrandTotalRefunded": 15, + "subTotal": 5, + "baseSubTotal": 5, + "subTotalInvoiced": 5, + "baseSubTotalInvoiced": 5, + "subTotalRefunded": 5, + "baseSubTotalRefunded": 5, + "discountPercent": 0, + "discountAmount": 0, + "baseDiscountAmount": 0, + "discountInvoiced": 0, + "baseDiscountInvoiced": 0, + "discountRefunded": 0, + "baseDiscountRefunded": 0, + "taxAmount": 0, + "baseTaxAmount": 0, + "taxAmountInvoiced": 0, + "baseTaxAmountInvoiced": 0, + "taxAmountRefunded": 0, + "baseTaxAmountRefunded": 0, + "shippingAmount": 10, + "baseShippingAmount": 10, + "shippingInvoiced": 10, + "baseShippingInvoiced": 10, + "shippingRefunded": 10, + "baseShippingRefunded": 10, + "customerId": 5, + "customerType": "Webkul\\Customer\\Models\\Customer", + "channelId": 1, + "channelType": "Webkul\\Core\\Models\\Channel", + "cartId": "3", + "appliedCartRuleIds": "", + "shippingDiscountAmount": 0, + "baseShippingDiscountAmount": 0, + "createdAt": "2021-05-28 14:28:51", + "updatedAt": "2021-05-28 15:22:34" + } + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-shop-api/reviews.md b/docs/1.x/graphql-shop-api/reviews.md new file mode 100644 index 00000000..53580746 --- /dev/null +++ b/docs/1.x/graphql-shop-api/reviews.md @@ -0,0 +1,482 @@ +# Reviews + +In this section, we will see all the APIs which are related to Customer Reviews. + +## Get Customer Reviews + +You can get all the Customer Reviews from the Bagisto store. You can achieve this job by using the `Customer Reviews` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note** You can pass all the input fields to filter the Review data. + +- Query + ~~~query + query reviewsList { + reviewsList(input: { + page: 1 + limit: 10 + # id: 3 + # title: "Why do we use it?" + # rating: 3 + # customerName: "Anna Gole" + # productName: "e-book" + # productId: 9 + # status: "approved" + }) { + id + title + rating + comment + status + createdAt + updatedAt + productId + customerId + customerName + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "reviewsList": [ + { + "id": "1", + "title": "Where does it come from?", + "rating": 4, + "comment": "Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old.", + "status": true, + "createdAt": "2021-05-28 15:41:51", + "updatedAt": "2021-05-28 15:41:51", + "productId": "1", + "customerId": "5", + "customerName": "Naresh Verma", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12", + "productFlats": [ + { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + ] + } + } + ] + } +} +~~~ +::: + +## Get Customer Review By ID + +To get the specific Customer Review, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query reviewDetail { + reviewDetail(id: 1) { + id + title + rating + comment + status + createdAt + updatedAt + productId + customerId + customerName + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "reviewDetail": { + "id": "1", + "title": "Where does it come from?", + "rating": 4, + "comment": "Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old.", + "status": true, + "createdAt": "2021-05-28 15:41:51", + "updatedAt": "2021-05-28 15:41:51", + "productId": "1", + "customerId": "5", + "customerName": "Naresh Verma", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12", + "productFlats": [ + { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + ] + } + } + } + } + ~~~ +::: + + + +## Create a new Review + + To create a Review, you have to perform mutation on Review and paas the related fields in the request. + API call resource will create a new Review, only if the Customer has logged in. + + - Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + + Let's take an example, + +- Request Mutation + ~~~Mutation + mutation createReview { + createReview(input: { + name: "Ruby J So" + title: "Where does it come from?" + rating: 4 + comment: "Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old." + productId: 1 + }) { + success + review { + id + title + rating + comment + status + createdAt + updatedAt + productId + customerId + customerName + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + productFlats { + id + sku + name + description + shortDescription + urlKey + new + featured + status + visibleIndividually + thumbnail + price + cost + specialPrice + specialPriceFrom + specialPriceTo + weight + color + colorLabel + size + sizeLabel + locale + channel + productId + parentId + minPrice + maxPrice + metaTitle + metaKeywords + metaDescription + width + height + depth + createdAt + updatedAt + } + } + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "createReview": { + "success": "Product Review submitted successfully.", + "review": { + "id": "1", + "title": "Where does it come from?", + "rating": 4, + "comment": "Contrary to popular belief, Lorem Ipsum is not simply random text. It has roots in a piece of classical Latin literature from 45 BC, making it over 2000 years old.", + "status": true, + "createdAt": "2021-05-28 15:41:51", + "updatedAt": "2021-05-28 15:41:51", + "productId": "1", + "customerId": "5", + "customerName": "Naresh Verma", + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12", + "productFlats": [ + { + "id": "1", + "sku": "test-product", + "name": "testOutlet", + "description": "

testOutlet

", + "shortDescription": "

testOutlet

", + "urlKey": "testoutlet", + "new": true, + "featured": true, + "status": true, + "visibleIndividually": true, + "thumbnail": null, + "price": 5, + "cost": null, + "specialPrice": null, + "specialPriceFrom": null, + "specialPriceTo": null, + "weight": 3, + "color": 1, + "colorLabel": "Red", + "size": 6, + "sizeLabel": "S", + "locale": "en", + "channel": "default", + "productId": "1", + "parentId": null, + "minPrice": 5, + "maxPrice": 5, + "metaTitle": "", + "metaKeywords": "", + "metaDescription": "", + "width": 0, + "height": 0, + "depth": 0, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + } + ] + } + } + } + } + } + ~~~ +::: diff --git a/docs/1.x/graphql-shop-api/wishlists.md b/docs/1.x/graphql-shop-api/wishlists.md new file mode 100644 index 00000000..bfa17147 --- /dev/null +++ b/docs/1.x/graphql-shop-api/wishlists.md @@ -0,0 +1,622 @@ +# Wishlists + +In this section, we will see all the APIs which are related to Customer Product Wishlists. + +## Get Wishlists + +You can get all the Wishlists from the Bagisto store. You can achieve this job by using the `Wishlists` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +**Note** You can pass all the input fields to filter the Wishlist data. + + +- Query + ~~~query + query wishlists { + wishlists(input: { + page: 1 + limit: 10 + # id: 3 + # productId: 16 + # productName: "Music Show" + # channelId: 1 + }) { + id + channelId + productId + customerId + itemOptions + additional + movedToCart + shared + timeOfMoving + createdAt + updatedAt + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + } + channel { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + defaultLocale + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "wishlists": [ + { + "id": "1", + "channelId": "1", + "productId": "1", + "customerId": "5", + "itemOptions": null, + "additional": "null", + "movedToCart": null, + "shared": null, + "timeOfMoving": null, + "createdAt": "2021-05-28 15:59:00", + "updatedAt": "2021-05-28 15:59:00", + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + }, + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "channel": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":16,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + ] + } +} +~~~ +::: + +## Get Wishlist By ID + +To get the specific Wishlist, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + query wishlist { + wishlist(id: 1) { + id + channelId + productId + customerId + itemOptions + additional + movedToCart + shared + timeOfMoving + createdAt + updatedAt + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + } + channel { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + defaultLocale + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "wishlist": { + "id": "1", + "channelId": "1", + "productId": "1", + "customerId": "5", + "itemOptions": null, + "additional": "null", + "movedToCart": null, + "shared": null, + "timeOfMoving": null, + "createdAt": "2021-05-28 15:59:00", + "updatedAt": "2021-05-28 15:59:00", + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + }, + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "channel": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":16,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + } + } + ~~~ +::: + + + +## Add To Wishlist + +You can Add a product to wishlist. You can achieve this job by using the `Wishlist` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + mutation addToWishlist { + addToWishlist(input: { + productId: 1 + }) { + success + wishlist { + id + channelId + productId + customerId + itemOptions + additional + movedToCart + shared + timeOfMoving + createdAt + updatedAt + customer { + id + firstName + lastName + name + gender + dateOfBirth + email + phone + password + apiToken + customerGroupId + subscribedToNewsLetter + isVerified + token + notes + status + createdAt + updatedAt + } + product { + id + type + attributeFamilyId + sku + parentId + createdAt + updatedAt + } + channel { + id + code + name + description + theme + homePageContent + footerContent + hostname + defaultLocaleId + baseCurrencyId + rootCategoryId + homeSeo + defaultLocale + baseCurrency + rootCategory + logoUrl + faviconUrl + success + } + } + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "addToWishlist": { + "success": "Item Successfully Added To Wishlist", + "wishlist": { + "id": "1", + "channelId": "1", + "productId": "1", + "customerId": "5", + "itemOptions": null, + "additional": "null", + "movedToCart": null, + "shared": null, + "timeOfMoving": null, + "createdAt": "2021-05-28 15:59:00", + "updatedAt": "2021-05-28 15:59:00", + "customer": { + "id": "5", + "firstName": "Naresh", + "lastName": "Verma", + "name": "Naresh Verma", + "gender": null, + "dateOfBirth": null, + "email": "naresh.verma327@webkul.com", + "phone": null, + "password": "$2y$10$tIP1ciRlUCI0ahjsYsjHsenTvXen1PBQKfRu0OklpufOAjf/ruC2O", + "apiToken": "r1bxG3wNl2No0mbTEEJnD6hWkADKcsMA8jnHDnA0zteEw2RRhaqAuUxehzqx7pARAS6WA9jLG3sanFhg", + "customerGroupId": 2, + "subscribedToNewsLetter": false, + "isVerified": true, + "token": "d5308d5f06d01d3393501cb6ebf4ae06", + "notes": null, + "status": true, + "createdAt": "2021-05-28 12:54:56", + "updatedAt": "2021-05-28 12:54:56" + }, + "product": { + "id": "1", + "type": "simple", + "attributeFamilyId": 1, + "sku": "test-product", + "parentId": null, + "createdAt": "2021-05-26 17:43:12", + "updatedAt": "2021-05-26 17:43:12" + }, + "channel": { + "id": "1", + "code": "default", + "name": "Default", + "description": null, + "theme": "velocity", + "homePageContent": "\n

@include(\"shop::home.slider\") @include(\"shop::home.featured-products\") @include(\"shop::home.new-products\")

\n
\n
\n \"test\"\n
\n
\n \"test\"\n \"test\"\n
\n
\n ", + "footerContent": "\n \n
\n Connect With Us\n \n
\n ", + "hostname": "http://localhost/graphql/public", + "defaultLocaleId": 1, + "baseCurrencyId": 1, + "rootCategoryId": 1, + "homeSeo": "{\"meta_title\": \"Demo store\", \"meta_keywords\": \"Demo store meta keyword\", \"meta_description\": \"Demo store meta description\"}", + "defaultLocale": "{\"id\":1,\"code\":\"en\",\"name\":\"English\",\"created_at\":null,\"updated_at\":null,\"direction\":\"ltr\",\"locale_image\":null}", + "baseCurrency": "{\"id\":1,\"code\":\"USD\",\"name\":\"US Dollar\",\"created_at\":null,\"updated_at\":null,\"symbol\":\"$\"}", + "rootCategory": "{\"id\":1,\"position\":1,\"image\":null,\"status\":1,\"_lft\":1,\"_rgt\":16,\"parent_id\":null,\"created_at\":\"2021-05-05T10:06:44.000000Z\",\"updated_at\":\"2021-05-05T10:06:44.000000Z\",\"display_mode\":\"products_and_description\",\"category_icon_path\":null,\"additional\":null,\"name\":\"Root\",\"description\":\"Root\",\"slug\":\"root\",\"url_path\":\"\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"translations\":[{\"id\":1,\"name\":\"Root\",\"slug\":\"root\",\"description\":\"Root\",\"meta_title\":\"\",\"meta_description\":\"\",\"meta_keywords\":\"\",\"category_id\":1,\"locale\":\"en\",\"locale_id\":null,\"url_path\":\"\"}]}", + "logoUrl": null, + "faviconUrl": null, + "success": null + } + } + } + } +} +~~~ +::: + +## Remove From Wishlist + +To remove a product from the wishlist, you have to pass an `id` field with query request .By using this resource and request payload, you will get only a single object under the `data` object in response. + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + mutation removeFromWishlist { + removeFromWishlist(input: { + productId: 1 + }) { + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "removeFromWishlist": { + "status": true, + "success": "Item Successfully Removed From Wishlist" + } + } + } + ~~~ +: + +## Remove All From Wishlist + +To remove all product from the wishlist, you have to pass related fields with query request . + +- Headers + + | Key | Value | + | ------------- | --------------------- | + | Accept | application/json | + | Authorization | Bearer `token-string` | + +### Examples + +Let's take an example, + +- Request Query + ~~~Query + mutation removeAllWishlists { + removeAllWishlists { + status + success + } + } + ~~~ + +::: details Response + ~~~json + { + "data": { + "removeAllWishlists": { + "status": true, + "success": "All The Items From Your Wishlist Have Been Removed" + } + } + } + ~~~ +: + +## Move To Cart From Wishlist + +You can move a product from wishlist to cart from the Bagisto store. You can achieve this job by using the `Move To Cart From Wishlist` API call. + +- Headers + + | Key | Value | + | ------------- | ---------------- | + | Accept | application/json | + +- Single Request Endpoint + + `POST http(s)://example.com/graphql` + +::: tip + + If you are using pagination and want to know more info about responses then check the [explanation](./explanation) portion. + +::: + +- Query + ~~~query + mutation moveToCart { + moveToCart(id: 2) { + status + success + } + } + ~~~ + +::: details Response + +~~~json +{ + "data": { + "moveToCart": { + "status": true, + "success": "Item successfully moved To cart" + } + } +} +~~~ +::: + diff --git a/docs/1.x/introduction/README.md b/docs/1.x/introduction/README.md new file mode 100644 index 00000000..9e78c2d3 --- /dev/null +++ b/docs/1.x/introduction/README.md @@ -0,0 +1,18 @@ +# Introduction +**Bagisto** is a E-Commerce framework built on top of the hottest opensource technologies such as [Laravel](https://laravel.com), a [PHP](https://php.net) framework and [Vue.js](https://vuejs.org/), a progressive Javascript framework. + +**Bagisto** is a viable option to reduce your time, cost and workforce for building online stores or migrating from a physical store to an online platform. + +It is suitable for all small or large E-Commerce business demands using a simple set-up procedure. +Built on top of [Laravel](https://laravel.com) and equipped with an easy product information management. + +The framework is very flexible and easy to use even for non-tech users. +**Bagisto** features an administration panel with a dashboard, sales data, a catalog for products and customer management. + +To learn more about **Bagisto's** features and try a demo, check out our website [https://bagisto.com](https://bagisto.com). +Get quickly updated on the current version and recently released features, see [Bagisto roadmap](https://bagisto.com/roadmap/). +You can get started with the source code by checking out the repo on GitHub at [bagisto/bagisto](https://github.com/bagisto/bagisto). + + + + diff --git a/docs/1.x/introduction/docker.md b/docs/1.x/introduction/docker.md new file mode 100644 index 00000000..b935b09c --- /dev/null +++ b/docs/1.x/introduction/docker.md @@ -0,0 +1,206 @@ +# Docker + +[[toc]] + +## Introduction +[Docker](https://www.docker.com/) is an open platform for developing, shipping, and running applications. Docker enables you to separate your applications from your infrastructure so you can deliver software quickly. With Docker, you can manage your infrastructure in the same ways you manage your applications. Docker can also be used for defining and running multi-container Docker applications using Docker-Compose tool. + +With the help of docker-compose, you can define containers to be build, their configuration, links, volumes, ports etc in a single file and it gets launched by a single command. +You can also add multiple servers and services just by adding them to docker-compose configuration file. This configuration file is in [YAML](https://en.wikipedia.org/wiki/YAML) format. + +#### Application Data and Database Volume Persistance +It is recommended to keep your application files and database data volume on the docker host and mount them on the running container, this to ensure that the application and database data persistance even in the case of containers' failure or termination, In this way even if you destroy containers, your data won't get lost unless you remove them forcefully. +This compose configuration file mounts the application directory `app` and database volume `dbvolume` from host to running docker containers at the time of containers launch. + +## Installation & Setup + +### First steps +Before you can launch Bagisto in a docker environment you need to install the latest version of Docker and Docker Compose. + +- [Docker](https://docs.docker.com/install/) +- [Docker-compose](https://docs.docker.com/compose/install/) +- [Composer](https://getcomposer.org) (optional) + +### Configure the docker container +Once Docker and docker-compose have been installed, we need to create a **docker-compose.yml** file. +The **docker-compose.yml** configuration file requires following inputs from the user: + +#### Webserver configuration +In the `web_server` service block, assign your system working user uid to the `USER_UID` enviroment variable. +Run the following command `id -u` on linux or Macos to get your user id +```shell +id -u +``` + +#### Database configuration +In the `database_server` service block, assign mysql database name, mysql database user name, mysql database user password and mysql root password to `MYSQL_DATABASE`, `MYSQL_USER`, `MYSQL_PASSWORD` and `MYSQL_ROOT_PASSWORD` environment. + + +#### Clone configuration from Github +You can make use of our repository from Github by cloning this in your new directory +```shell +git clone https://github.com/bagisto/bagisto-docker.git . +``` +#### Configure manually +- Create a new folder for example **bagisto-docker** and create **docker-compose.yml** manually inside it. +- Add the following content to **docker-compose.yml** +```yml +version: '3' + +services: + + web_server: + image: webkul/apache-php:latest + container_name: apache2 + restart: always + volumes: + - ./app:/var/www/html + working_dir: /var/www/html/ + environment: + USER_UID: 'mention your system user ID here. ex: 1001, 1000, 33, etc' + networks: + - bagisto-network + ports: + - '80:80' + expose: + - '80' + depends_on: + - database_server + links: + - database_server + + database_server: + image: mysql:5.7 + container_name: mysql + restart: always + environment: + MYSQL_DATABASE: 'mention the name of the database to be created here. eg: mydatabase' + MYSQL_USER: 'mention database user here. eg: mydatabase_user' + MYSQL_PASSWORD: 'mention database user password here. ex: mystrongPassword' + MYSQL_ROOT_PASSWORD: 'mention mysql root password here. ex: mysqlstrongpass' + MYSQL_ROOT_HOST: '%' + networks: + - bagisto-network + ports: + - '3306:3306' + expose: + - '3306' + volumes: + - ./dbvolume:/var/lib/mysql + +volumes: + dbvolume: + app: + +networks: + bagisto-network: + ``` + +#### Download the docker image +The following command will download the docker images for apache-php version 7.3 and mysql version 5.7. +```shell +docker-compose pull +``` + +### Launching the docker container +The following command will create a network, launch a webserver and database containers with names `apache2` and `mysql`. +It will also create a new `app` and `dbvolume` directory inside your current directory and mount it to respective docker containers as mentioned in docker-compose.yml. +It binds your `host port 80` with the apache2 container port 80 and `host port 3306` with mysql container port 3306. If you want to run containers on ports other than 80 and 3306, modify their values in **docker-compose.yml** file. + +``` +docker-compose up -d +``` + +### Monitor your container(s): +Check your running docker containers with the following commands + +`docker ps` OR `docker-compose ps` +```shell +CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +62a10346b84a webkul/apache-php:latest "/usr/bin/supervisord" About an hour ago Up About an hour 0.0.0.0:80->80/tcp apache2 +90a0a2e0e46b mysql:5.7 "docker-entrypoint.s…" About an hour ago Up About an hour 0.0.0.0:3306->3306/tcp, 33060/tcp mysql +``` + +## Configuring Bagisto +Once our environment is ready we can start installing Bagisto. You can either install Bagisto from [Github](#install-without-composer) or with [composer](#install-with-composer) + +### Install without composer +Download the [latest release](https://bagisto.com/en/download) inside `app/bagisto` directory. +Open the `.env` file inside **app/bagisto** and set the following environment variables listed below: + +```editorconfig +APP_URL=https://127.0.0.1 +DB_CONNECTION=mysql +DB_HOST=mysql +DB_PORT=3306 +DB_DATABASE= +DB_USERNAME= +DB_PASSWORD= +``` + +Run the following commands to install Bagisto. +```shell +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan migrate'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan db:seed'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan vendor:publish'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan storage:link'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'composer dump-autoload -d bagisto'" +``` + +Mention the database details same as docker-compose.yml and admin details. + + +### Install with composer +The following commands will be exexcuted within the docker container +```shell +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'composer create-project bagisto/bagisto'" +``` + +Open the .env file inside `app/bagisto` directory and set the following environment variables listed below: + +```editorconfig +APP_URL=https://127.0.0.1 +DB_CONNECTION=mysql +DB_HOST=mysql +DB_PORT=3306 +DB_DATABASE= +DB_USERNAME= +DB_PASSWORD= +``` + +Run the following commands to install Bagisto. +```shell +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan migrate'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan db:seed'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan vendor:publish'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'php bagisto/artisan storage:link'" +docker exec -i apache2 bash -c "su - www-data -s /bin/bash -c 'composer dump-autoload -d bagisto'" +``` + +Bagisto has been installed and is ready. Browse your server IP address or domain name on the web browser. + +### Configure Apache +The Apache documentroot is by default assigned to **/var/www/html/public_html**. while the **app** directory on host is mapped with the **html** directory inside the container. +We need to create a symlink of `bagisto/public` in `app` directory to `/var/www/html/public_html`. + +Run the following command on Linux or MacOS +```bash +cd app; ln -snf bagisto/public public_html +``` + +Run the following command on Windows +```command-line +cd app +mklink bagisto/public public_html +``` +### Ready + +#### Login as a administrator: +You can directly visit the admin interface [http://your_server_endpoint/admin](http://your_server_endpoint/admin/) and authenticate with the following credentials. + +| Email | Password | +| --------- | ------- | +| admin@example.com | admin123 | + +#### Login as a customer +You can directly visit your store on [http://your_server_endpoint/](http://your_server_endpoint/). diff --git a/docs/1.x/introduction/installation.md b/docs/1.x/introduction/installation.md new file mode 100644 index 00000000..39f65503 --- /dev/null +++ b/docs/1.x/introduction/installation.md @@ -0,0 +1,72 @@ +# Installation + +## Use Our GUI Installer +1. [Download Bagisto](https://bagisto.com/en/download/) +2. Extract the contents of the zip file. +3. Point your HTTP server to the public/ directory of the project and open it on your browser.
For example: + - `https://example.com/` +4. This will detect Bagisto and start the installer. + +## Install Bagisto Using _composer_ + +``` +composer create-project bagisto/bagisto +``` + +- Start the installation script. +```sh +php artisan bagisto:install +``` + +### Features of above installation command +::: warning +It will check existence of the .env file, if it exists then please update the file manually with the below details. +::: + +``` +- APP_TIMEZONE +- APP_LOCALE +- LOG_CHANNEL +- APP_CURRENCY +- DB_DATABASE +- DB_USERNAME +- DB_PASSWORD +``` + +::: warning +If the .env file does not exists then it will ask to provide the details on command prompts. + +::: +- To start the installation, provide the details of the following command prompts: +```sh +- Please select the default locale or press enter to continue [en]: +- Please enter the default timezone [Asia/Kolkata]: +- Please enter the default currency [USD]: +- What is the database name to be used by Bagisto?: +- What is your database username?: +- What is your database password?: +``` + +# Start Using Bagisto + +### On a production server + +- Open your domain on the browser.
For example: + - `https://example.com/` + +### On your local device + +```sh +php artisan serve +``` + +### How to log in to your domain as an admin + +Go to `https://example.com/admin/`, in case `php artisan bagisto:install` is opted, use the following credentials. +``` +email: admin@example.com +password: admin123 +``` + +### How to log in to your domain as a customer +You can directly register on `https://example.com/customer/register` as a customer, and then log in to your domain. diff --git a/docs/1.x/introduction/requirements.md b/docs/1.x/introduction/requirements.md new file mode 100644 index 00000000..cb379927 --- /dev/null +++ b/docs/1.x/introduction/requirements.md @@ -0,0 +1,42 @@ +# Requirements + +Before installing Bagisto, make sure the server meets the following requirements: + +## Server configuration + +- **SERVER**: Apache 2 or NGINX +- **RAM**: 4GB or higher +- **Node**: 8.11.3 LTS or higher +- **PHP**: 7.4 or higher +- **Composer**: 1.6.5 or higher + +## PHP Extensions + +Make sure the following extensions are installed and enabled. You can check using the `phpinfo()` page or the `php -m` command. + +- php-intl extension + +- php-gd extension + + ::: tip + You must install the `php-gd` extension properly otherwise, the image does not work properly in the project. + ::: + +## PHP Configuration + +Open your php configuration file **php.ini** and change the following settings. + + ~~~ini + memory_limit = 4G + max_execution_time = 360 + date.timezone = Europe/Brussels <- Change this to your own timezone. + ~~~ + +::: tip Restart your web server + Whenever you make changes to the PHP configuration file, you must restart Apache or NGINX. +::: + +## Supported Database Servers + +- **MySQL**: 5.7.23 or higher +- **MariaDB**: 10.2.7 or higher diff --git a/docs/1.x/introduction/upgrade-to-latest-bagisto.md b/docs/1.x/introduction/upgrade-to-latest-bagisto.md new file mode 100644 index 00000000..deca615e --- /dev/null +++ b/docs/1.x/introduction/upgrade-to-latest-bagisto.md @@ -0,0 +1,138 @@ +# Upgrade to the latest version of Bagisto + +To upgrade your current version to the latest version of Bagisto, you need to follow some steps, + +- First, you need to download the latest version of Bagisto. + +- You can download Bagisto from the following links, + + - [Download From Official Bagisto Site](https://bagisto.com/en/download/) + - [Download From Github](https://github.com/bagisto/bagisto) + +- After downloading the Bagisto zip file, you need to extract where you want to deploy it. +- After extract the file, you need to go to the root folder of the extracted folder and run the below command in the terminal. + + ~~~sh + composer create-project + ~~~ + +- After the command has been executed, now go to your `.env` file, provide your old project database credentials for which you want to upgrade Bagisto, and run the following command, + + ~~~sh + php artisan optimize + + # -- OR + + php artisan config:cache + ~~~ + +- Now, your new changes have been cached and now your project is ready to run the migrate command, + + ~~~sh + php artisan migrate + ~~~ + + ::: danger + Here we have not provided you the seeder command because the seeder command always resets all the settings, categories and etc. If some tables need default settings then we advise you to add manually. + ::: + +- Now, its time to create a symlink so that public assets can be linked to storage, + + ~~~sh + php artisan storage:link + ~~~ + +- Copy all the content of the previous version's folder (e.g. `old-project/storage/app/public`) to the latest version's folder (e.g. `new-project/storage/app/public`). + + ::: tip + If your existing project also depends on some local storage, or you have changed some paths, or you want previous logs also then make sure you add all those also. + ::: + +- Once this is finished run the following command to publish your new files, + + ~~~sh + php artisan vendor:publish --all + ~~~ + + ::: warning + Don't use the `--force` flag, this will reset all your views. Use only when you know what you are doing. + ::: + +You are now at the latest version. Still, we want to mention that if you have done a lot of customizations then that portion of compatibility should be handled at your end. + +## Bagisto Changes + +### These are the changes from the version 1.3.3 to 1.4.0 + +#### Added one composer dependency (High Severity) + +- Added `diglactic/laravel-breadcrumbs` for breadcrumbs in the frontend shop. Make sure to run the `composer install`, if you are upgrading the existing project. +- Moved all the old APIs to a separate package i.e. `bagisto/legacy-api`. If you are getting exceptions then just go to `bootstrap/cache` and delete all the files and then run `composer install`. After the installation, run `php artisan optimize`. + +#### Changes from the datagrid (High Severity) + +- Implemented the ajaxified datagrid, see [#5756](https://github.com/bagisto/bagisto/pull/5756) + +#### Revamped admin theme (High Severity) + +- Added a new admin theme with features of multi-locale switcher, real time notification for admin upon order creation or updation and dark theme for admin panel. + +#### Changes in factories (Medium Severity) + +- Dropped laravel legacy factories dependencies and refactored all models to use Laravel 8 class factories. If you have used it in modules try to upgrade or just install the dependency when needed. + +#### Changes in routes (Medium Severity) + +- In admin, shop and velocity packages, this file `packages/Webkul//src/Http/routes.php` is moved to `packages/Webkul//src/Routes/web.php` this path. So if you are upgrading the existing project just make sure the provider registry is updated. + +### These are the changes from the version 1.3.1 to 1.3.2 + +#### Changes from the web vital (Medium Severity) + +- For the velocity theme, the `velocity.js` file is divided into two files i.e. `velocity-core.js` and the `velocity.js` file. In `velocity-core.js`, all core dependencies like jQuery, bootstrap js, Vue js are added and in `velocity.js` all the components are present which is bootstrapped by the `velocity-core.js`. + +- All these components are minified now, `quantity-changer`, `mini-cart`, `slider-component`, and `searchbar-component`. + +- These components are added `hot-categories`, `popular-categories`, `sidebar-header`, `right-side-header` and `mobile-header`. + +- In `velocity.js`, this component `VueToast` has been removed. As no traces were found in the core. If you are using this then make sure you add it to your module dependencies. + +- This folder i.e. `packages/Webkul/Velocity/src/Resources/views/shop/UI` is completely removed. The files inside this folder contain the components which are already minified so not needed. Make sure if you included these files in your modules, use the direct component rather than including the file. + +- In this folder i.e. `packages/Webkul/Velocity/src/Resources/views/shop/layouts/particals` three files (`compare.blade.php`, `wishlist.blade.php` and `search-bar.blade.php`) are given. All these files are having individual components. For `compare.blade.php` and `wislist.blade.php`, you can use the `isText` prop to disable the text for mobile. + +- Reference PR: [#5020](https://github.com/bagisto/bagisto/pull/5020) + +#### Changes from security fixes (High Severity) + +- These routes i.e. `address.delete`, `customer.orders.cancel`, `customer.review.delete`, `customer.review.deleteall`, `shop.movetowishlist`, `customer.wishlist.add`, `customer.wishlist.remove` and `customer.wishlist.removeall` methods are changed from `GET` to `DELETE` and `POST` respectively. `GET` is only use for retrieving data. + +- Maybe if you forgot to change then surely this will impact your project. Make sure it should be updated and also run `php artisan optimize` command. + +- Reference PR: [#4996](https://github.com/bagisto/bagisto/pull/4996), [#4998](https://github.com/bagisto/bagisto/pull/4998) and [#5052](https://github.com/bagisto/bagisto/pull/5052) + +#### Downloadable product medias are moved to private disk (Medium Severity) + +- If someone facing broken downloadale links, this is because of the privatization of the paid links, in this case move your downloadable links folder to a private disk, and the broken link got fixed. + +- If still broken then take a reference from the below PR and adjust the storage data. + +- Reference PR: [#4966](https://github.com/bagisto/bagisto/pull/4966) + +#### Changes from invoice prefixes (Medium Severity) + +- Moved sequencer class from shop package to sales package, as orders and invoices are part of the sales. This will not impact as there is only one key and that one is in the repository. + +- Enhanced and scaled the `Sequencer` class. + +- As per the existing project perspective, `increment_id` by default is going null, so for displaying portion it will first check `increment_id` if not found then it will give the actual `id`. + +- In the core config, moved all the invoice settings to the new tab name `Invoice Settings` so make sure reset the value for the `Invoice Slip Design`. + +- Reference PR: [#4956](https://github.com/bagisto/bagisto/pull/4956) + +#### Changes from `.env` (Low Severity) + +- Just capitalized the `fixer_api_key` in `.env` to have consistency and `.env` standard. + +- If you have this key in your `.env` and you are using this just make sure you capitalize your key also. diff --git a/docs/1.x/packages/README.md b/docs/1.x/packages/README.md new file mode 100644 index 00000000..08bfc691 --- /dev/null +++ b/docs/1.x/packages/README.md @@ -0,0 +1,63 @@ +# Package development + +A package is a unit added to your application for enhancement which includes routes, controllers, views, and configuration specifically. Packages are created to manage your large applications into smaller units. + +In Bagisto, we have created plenty of packages at path `packages/Webkul/`. You can find a basic tree-structure of the package below: + +~~~directory-structure +- ACME/HelloWorld/ + - publishable/assets + - css/ + - images/ + - js/ + - src/ + - Config/ + - acl.php + - admin-menu.php + - Console/ + - Commands/ + - Contracts/ + - Database/ + - Migrations/ + - Seeders/ + - Events/ + - Http/ + - Controllers/ + - Admin/ + - HelloWorldController.php + - Shop/ + - HelloWorldController.php + - Middleware/ + - Requests/ + - admin-routes.php + - shop-routes.php + - Listeners/ + - Mail/ + - Models/ + - Providers/ + - HelloWorldServiceProvider.php + - ModuleServiceProvider.php + - Repositories/ + - Resources/ + - assets/ + - images/ + - js/ + - app.js + - sass/ + - admin.scss + - default.scss + - velocity.scss + - lang/ + - views/ + - admin/ + - layouts/ + - style.blade.php + - index.blade.php + - shop/ + - default/ + - index.blade.php + - velocity/ + - index.blade.php + - package.json + - webpack.mix.js +~~~ diff --git a/docs/1.x/packages/add-menu-in-admin.md b/docs/1.x/packages/add-menu-in-admin.md new file mode 100644 index 00000000..a3f5b34d --- /dev/null +++ b/docs/1.x/packages/add-menu-in-admin.md @@ -0,0 +1,70 @@ +# Add menu in admin + +- In your package's source directory i.e. `packages/ACME/HelloWorld/src`, create the `Config` folder and create a file named `admin-menu.php`. + +~~~php + 'helloworld', + 'name' => 'Hello World', + 'route' => 'helloworld.admin.index', + 'sort' => 1, + 'icon-class' => 'dashboard-icon', + ] +]; +~~~ + +- In this file, we provide the name of the menu, route & its icon. + +| Params | Description | +| ---------- | --------------------------------------------------- | +| key | Unique key for menu icon. | +| name | Name of menu icon. | +| route | Route name for your menu icon. | +| sort | Sort number on which your menu icon should display. | +| icon-class | Class for menu icon. | + +- For the route, just add the named route which specified above i.e. `helloworld.admin.index`, + + ~~~php + Route::view('/admin/hello-world', 'helloworld::admin.index')->name('helloworld.admin.index'); + ~~~ + +- After that, we need to merge this `menu.php` folder with a core menu file. For this, we use the method `mergeConfigFrom()` in the register method of the service provider. + + ~~~php + mergeConfigFrom( + dirname(__DIR__) . '/Config/admin-menu.php', 'menu.admin' + ); + } + } + ~~~ + +- Run this command i.e. `php artisan optimize`. + +- Now, the menu will display in the admin panel. You can change the icon according to your needs. + +![Admin Menu Output](../../assets/1.x/images/package-development/admin-menu-output.png) \ No newline at end of file diff --git a/docs/1.x/packages/create-acl.md b/docs/1.x/packages/create-acl.md new file mode 100644 index 00000000..34abd04f --- /dev/null +++ b/docs/1.x/packages/create-acl.md @@ -0,0 +1,79 @@ +# Access control list + +In addition to providing authentication services out of the box, Bagisto also provides a functionality **ACL** (Access Control List). + +With this feature the administrator can allow/disallow other users to access parts of Bagisto. + +## Create a new ACL file + +Create a new file named `acl.php` in your package **Config** folder, for example, `packages/ACME/HelloWorld/src/Config` and add the following code. + +~~~php + 'helloworld', + 'name' => 'HelloWorld', + 'route' => 'helloworld.admin.index', + 'sort' => 2 + ] +]; +~~~ + +If you check the above code we have created an array for an individual's menu with the parameters (key, name, route & sort). + +Just like that, we need to define the menu here which we want to include in our ACL. + +## Merge configuration + +After that, we need to merge the ACL config also just like we have done with menu items, + + ~~~php + mergeConfigFrom( + dirname(__DIR__) . '/Config/admin-menu.php', 'menu.admin' + ); + + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/acl.php', 'acl' + ); + } + } + ~~~ + +After setting up, just run this command `php artisan optimize` to cached the latest changes. + +Now check the latest ACL. + +![Admin ACL Output](../../assets/1.x/images/package-development/admin-acl-output.png) + +## Checking roles and permissions + +- If you check the `Admin` model in the namespace `Webkul\User\Models`, you will see the relationship binding with the `Role` model in the same namespace. From here you can grab all the permissions of the current user. + +- We have provided the `bouncer()` helper, which helps you to check the permissions. Let's check the current user has permission or not, + + ~~~php + bouncer()->hasPermission($permission) + ~~~ diff --git a/docs/1.x/packages/create-custom-configuration.md b/docs/1.x/packages/create-custom-configuration.md new file mode 100644 index 00000000..7ad5ccd9 --- /dev/null +++ b/docs/1.x/packages/create-custom-configuration.md @@ -0,0 +1,267 @@ +# Create custom configuration + +Creating a custom configuration ease the task for a developer or any non-developer person. Generally, in Bagisto, you can find it in admin panel **Configuration Menu**. + +## Steps to create custom configuration + +- To create a custom configuration for your application, you just need to create a `system.php` file in the `Config` folder of your package. + +- Inside the file, you can include the code below, + + ~~~php + 'helloworld', + 'name' => 'Hello World', + 'sort' => 1 + ], [ + 'key' => 'helloworld.settings', + 'name' => 'Custom Settings', + 'sort' => 1, + ], [ + 'key' => 'helloworld.settings.settings', + 'name' => 'Custom Groupings', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'status', + 'title' => 'Status', + 'type' => 'boolean', + 'channel_based' => true, + 'locale_based' => false + ] + ] + ] + ]; + ~~~ + +### Explanation for the keys + +- **key** : This key accept the unique value and nested with '.' (dot) operator. + +- **name** : This key accept the value as a placeholder for your configuration. Generally, in Bagisto, we consider writing it using translation. + +- **sort** : This key accept the sort position for the configuration menu. + +- **fields** : This key accept the array for the value of the custom configuration. + +- We need to merge these custom config also, + + ~~~php + mergeConfigFrom( + dirname(__DIR__) . '/Config/admin-menu.php', 'menu.admin' + ); + + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/acl.php', 'acl' + ); + + $this->mergeConfigFrom( + dirname(__DIR__) . '/Config/system.php', 'core' + ); + } + } + ~~~ + +- Run this command i.e. `php artisan optimize`. + +- Now, check the configuration, + + ![Admin ACL Output](../../assets/1.x/images/package-development/admin-custom-config-output.png) + +## Supported Field Types + +There are several field types supported by the Bagisto. Let us know all of them, + +- Text Type +- Number Type +- Boolean Type +- Select Type +- Textarea Type +- Image Type + +Let's get started with the first one. + +### Text Type + +This field type will give you the input field of type text. + +#### Example + +~~~php +return [ + ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'text_type', + 'title' => 'admin::app.admin.system.text-type', + 'type' => 'text', + 'default_value' => '', + ], + ], + ], + ... +]; +~~~ + +### Number Type + +This field type will give you the input field of type number. + +#### Example + +~~~php +return [ + ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'number_type', + 'title' => 'admin::app.admin.system.number-type', + 'type' => 'number', + ], + ], + ], + ... +]; +~~~ + +### Boolean Type + +This field type will give you the enable/disable switch. + +#### Example + +~~~php +return [ + ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'boolean_type', + 'title' => 'admin::app.admin.system.boolean-type', + 'type' => 'boolean', + ], + ], + ], + ... +]; +~~~ + +### Select Type + +This field type will give you the select field with mentioned options. + +#### Example + +~~~php +return [ + ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'select_type', + 'title' => 'admin::app.admin.system.select-type', + 'type' => 'select', + 'options' => [ + [ + 'title' => 'option_1', + 'value' => 'value_1', + ], [ + 'title' => 'option_2', + 'value' => 'vallue_2', + ], + ], + ], + ], + ], + ... +]; +~~~ + +### Textarea Type + +This field type will give you the textarea field mostly used for long text. + +#### Example + +~~~php +return [ + ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'textarea_type', + 'title' => 'admin::app.admin.system.textarea-type', + 'type' => 'textarea' + ], + ], + ], + ... +]; +~~~ + +### Image Type + +This field type will give you the file upload option for uploading the images. + +#### Example + +~~~php +return [ + ... + [ + 'key' => 'general.general.custom-types', + 'name' => 'admin::app.admin.system.custom-types', + 'sort' => 1, + 'fields' => [ + [ + 'name' => 'image_type', + 'title' => 'admin::app.admin.system.image-type', + 'type' => 'image', + 'validation' => 'mimes:bmp,jpeg,jpg,png,webp', + ], + ], + ], + ... +]; +~~~ diff --git a/docs/1.x/packages/create-migrations.md b/docs/1.x/packages/create-migrations.md new file mode 100644 index 00000000..a688ee39 --- /dev/null +++ b/docs/1.x/packages/create-migrations.md @@ -0,0 +1,26 @@ +# Create migrations + +You can create migration in two ways, + +1. By using Bagisto Package Generator. +2. By normal laravel command and then manually copy to the respective folder. + +## By using Bagisto Package Generator + +This command will create a new migration class in `packages/ACME/HelloWorld/src/Database/Migrations` directory. + +`php artisan package:make-migration CreateUsersTable ACME/HelloWorld` + +## By normal laravel command and then manually copy to the respective folder + +To create a migration, use the `make:migration` artisan command: + +`php artisan make:migration create_users_table` + +The new migration will be placed in your `database/migrations` directory. Each migration file name contains a timestamp which allows Laravel to determine the order of the migrations. + +The --table and --create options may also be used to indicate the name of the table and whether the migration will be creating a new table. + +You may also specify a --path option when creating the migration. The path should be relative to the root directory of your installation: + +`php artisan make:migration create_demo_table --path=packages/ACME/HelloWorld/src/Database/Migrations` \ No newline at end of file diff --git a/docs/1.x/packages/create-models.md b/docs/1.x/packages/create-models.md new file mode 100644 index 00000000..eeccb32e --- /dev/null +++ b/docs/1.x/packages/create-models.md @@ -0,0 +1,23 @@ +# Create models + +## Create model by using Bagisto Package Generator + +- This command will create a following files, + - New model class in `packages/ACME/HelloWorld/src/Models` directory. + - New model proxy class in `packages/ACME/HelloWorld/src/Models` directory. + - New model contract in `packages/ACME/HelloWorld/src/Contracts` directory. + + `php artisan package:make-model User ACME/HelloWorld` + +## Create model by normal laravel commands + +- Models typically live in the `app` directory, but you are free to place them anywhere that can be auto-loaded according to your `composer.json` file. All Eloquent models extend `Illuminate\Database\Eloquent\Model` class. + +- The simple way to create a model is executing the command `make:model` artisan command, + + `php artisan make:model User` + +- After creating model, to generate database migration, you may append `--migration or -m option` artisan command as stated below, + + `php artisan make:model User --migration` + `php artisan make:model User -m` \ No newline at end of file diff --git a/docs/1.x/packages/create-package.md b/docs/1.x/packages/create-package.md new file mode 100644 index 00000000..42d3ca36 --- /dev/null +++ b/docs/1.x/packages/create-package.md @@ -0,0 +1,832 @@ +# Create a new package + +There are two ways to create a package. + +1. By using Bagisto Package Generator (**Recommended**) +2. By manually setting up all files (**Expert Level**) + +## 1. By using Bagisto Package Generator + +- You need to install [Bagisto Package Generator](https://github.com/bagisto/bagisto-package-generator). + +- If you have not installed this package then you need to go to the root folder of **Bagisto** and run the following command + + ```php + composer require bagisto/bagisto-package-generator + ``` + +- Now, to generate your package you need to use the following command, + + - If the package directory does not exist, + + ```php + php artisan package:make ACME/HelloWorld + ``` + + - If somehow the package directory is already present then you can use the force command as well. For that you just need to pass the '**--force**' command. + + ```php + php artisan package:make ACME/HelloWorld --force + ``` + +- Now check your `packages` directory, everything is setup for you. + +- After that, you need to register your service provider in `config/app.php`. + + ```php + [ + ... + ACME\HelloWorld\Providers\HelloWorldServiceProvider::class, + ... + ] + ... + ]; + ``` + +- Add you package namespace in `psr-4` key in `composer.json` file for auto loading which is located in Bagisto root directory. + + ```json + "autoload": { + ... + "psr-4": { + ... + "ACME\\HelloWorld\\": "packages/ACME/HelloWorld/src" + ... + } + ... + } + ``` + +- Run the below listed command: + + ```php + composer dump-autoload + php artisan optimize + ``` + + ```php + php artisan vendor:publish --force + + -> Press the number before "ACME\HelloWorld\Providers\HelloWorldServiceProvider" and then press enter to publish all assets and configurations. + ``` + +::: details Check output in the browser + +![helloworld-admin-browser-output](../../assets/1.x/images/package-development/hello-world-package-output.png) + +::: + +- Now start creating something cool. + +## 2. By manually setting up all files + +By manually setting up package, we assume that you are familiar with packages directory structures and flow. If not then you can find a basic tree structure of package below, + +::: details Basic tree structure of the package + +``` +- ACME/HelloWorld/ + - publishable/assets + - css/ + - images/ + - js/ + - src/ + - Config/ + - acl.php + - admin-menu.php + - Console/ + - Commands/ + - Contracts/ + - Database/ + - Migrations/ + - Seeders/ + - Events/ + - Http/ + - Controllers/ + - Admin/ + - HelloWorldController.php + - Shop/ + - HelloWorldController.php + - Middleware/ + - Requests/ + - admin-routes.php + - shop-routes.php + - Listeners/ + - Mail/ + - Models/ + - Providers/ + - HelloWorldServiceProvider.php + - ModuleServiceProvider.php + - Repositories/ + - Resources/ + - assets/ + - images/ + - js/ + - app.js + - sass/ + - admin.scss + - default.scss + - velocity.scss + - lang/ + - views/ + - admin/ + - layouts/ + - style.blade.php + - index.blade.php + - shop/ + - default/ + - index.blade.php + - velocity/ + - index.blade.php + - package.json + - webpack.mix.js +``` + +::: + +Let's start with first step by creating the packages folder. + +### Step-1 + +- In `packages` folder, create a folder with your company name and inside that create a folder with your package name. Let's say `ACME/HelloWorld`. So, your basic structure will look like this, + + ``` + - packages/ + - ACME/HelloWorld/ + ``` + +### Step-2 + +- In your package folder, create a folder named as `src`. This is the place where you need to put all your files related to your package. Now, your updated structure will look like this, + + ``` + - packages/ + - ACME/HelloWorld/ + - src/ + ``` + +### Step-3 + +- In `src` folder, create a folder named as `Providers` and inside that folder, create a file named as `PackagenameServiceProvider.php`. Let's say `HelloWorldServiceProvider.php`. + + ::: tip + If you want to do this with the **Bagisto Package Generator** then you need to type the following command, it will generate the service provider for you. + + ```php + php artisan package:make-provider HelloWorldServiceProvider ACME/HelloWorld + ``` + + If somehow the file already exists then you can use `--force` to overwrite the file. + ::: + +- Copy the below code and paste it in `HelloWorldServiceProvider.php`, + + ```php + [ + ... + ACME\HelloWorld\Providers\HelloWorldServiceProvider::class, + ... + ] + ... + ]; + ``` + +### Step-5 + +- Add your package namespace in `psr-4` key in `composer.json` file for auto loading which is located in Bagisto root directory. + + ```json + "autoload": { + ... + "psr-4": { + ... + "ACME\\HelloWorld\\": "packages/ACME/HelloWorld/src" + ... + } + ... + } + ``` + +- Run `composer dump-autoload`. + +### Step-6 + +- Now, you need to add routing & views in your package. + + - **For routes**: Create a `Http` folder in `packages/ACME/HelloWorld/src` and create two files named as `admin-routes.php` and `shop-routes.php`. So the updated structure will look like below, + + ::: details Updated directory structure + + ``` + - packages/ + - ACME/HelloWorld/ + - src/ + ... + - Http/ + - admin-routes.php + - shop-routes.php + ``` + + ::: + + - `admin-routes.php`: This file is for the admin routes. Add below codes to this file, + + ```php + ['web', 'admin']], function () { + Route::prefix(config('app.admin_url'))->group(function () { + + // all admin routes will place here + }); + }); + ``` + + - `shop-routes.php`: This file is for the shop routes. Add below codes to this file, + + ```php + ['web', 'theme', 'locale', 'currency']], function () { + + // all shop routes will be place here + + }); + ``` + + ::: tip + + - If you don't want to do it manually, then you can use our **Bagisto Package Generator**. For that you need to use this command, + + - For **admin-routes.php**, + + ```php + php artisan package:make-admin-route ACME/HelloWorld + ``` + + - For **shop-routes.php**, + + ```php + php artisan package:make-shop-route ACME/HelloWorld + ``` + + ::: + + - **For views**: Create `Resources` folder in `packages/ACME/HelloWorld/src` path. In `Resources` folder, create another folder named as `views`. Now, in the `views` folder, we need to create a two more folder i.e. `admin` and `shop`. So updated structure will look like this, + + ::: details Updated directory structure + + ``` + - packages/ + - ACME/HelloWorld/ + - src/ + ... + - Resources/ + ... + - views/ + - admin/ + - shop/ + ``` + + ::: + + - Inside each folder i.e. `admin` and `shop` create a file named as `index.blade.php`. Add some data to `index.blade.php`, + + - `admin/index.blade.php` + + ```html +

Hello World Admin

+ ``` + + - `shop/index.blade.php` + + ```html +

Hello World Shop

+ ``` + +- Now, we need to register our routes and views to service provider’s boot method i.e. `packages/ACME/HelloWorld/src/Providers/HelloWorldServiceProvider.php` + + ```php + loadRoutesFrom(__DIR__ . '/../Http/admin-routes.php'); + + $this->loadRoutesFrom(__DIR__ . '/../Http/shop-routes.php'); + + $this->loadViewsFrom(__DIR__ . '/../Resources/views', 'helloworld'); + } + + /** + * Register services. + * + * @return void + */ + public function register() + { + + } + } + ``` + +### Step-7 + +- Now, we need to create a route and render a view on that route. + +- Go to `packages/ACME/HelloWorld/src/Http/shop-routes.php` file and create a route to render view. + + ```php + ['web', 'theme', 'locale', 'currency']], function () { + + // all shop routes will be place here + Route::view('/hello-world', 'helloworld::shop.index'); + + }); + ``` + +- Same for admin routes in file `packages/ACME/HelloWorld/src/Http/admin-routes.php`. + + ```php + ['web', 'admin']], function () { + + // all admin routes will place here + Route::view('/admin/hello-world', 'helloworld::admin.index'); + + }); + ``` + +- Now, check your route in your browser, + + ::: details Admin Output + + ![Admin Browser Output](../../assets/1.x/images/package-development/helloworld-admin-browser-output.png) + + ::: + + ::: details Shop Output + + ![Shop Browser Output](../../assets/1.x/images/package-development/helloworld-shop-browser-output.png) + + ::: + +### Step-8 + +- Now, we are going to create a language file for our package. For this create a `lang` folder in the `packages/ACME/HelloWorld/src/Resources` path. + +- In `lang` folder, you can create a different folder for language translations like for English 'en', Hindi ‘hn’ etc. Moving forward, we will create a folder name `en` (say language code) and in that folder, create a file name as `app.php` to perform language translation. + + ::: details Updated directory structure + + ``` + - packages/ + - ACME/HelloWorld/ + - src/ + ... + - Resources/ + ... + - lang/ + - en/ + - app.php + ``` + + ::: + +- Now, we need to register the language file to the service provider. + + ```php + loadRoutesFrom(__DIR__ . '/../Http/admin-routes.php'); + + $this->loadRoutesFrom(__DIR__ . '/../Http/shop-routes.php'); + + $this->loadViewsFrom(__DIR__ . '/../Resources/views', 'helloworld'); + + $this->loadTranslationsFrom(__DIR__ . '/../Resources/lang', 'helloworld'); + } + + /** + * Register services. + * + * @return void + */ + public function register() + { + + } + } + ``` + +- Now we can write a translation in `app.php` like below, + + ```php + [ + 'name' => 'Prateek Srivastava' + ] + ]; + ``` + +- Add below code to your blade file. + + ```html + {{ __('helloworld::app.hello-world.name') }} + ``` + + ::: details Admin Output + + ![Translation Output](../../assets/1.x/images/package-development/hello-world-admin-translation-output.png) + + ::: + + ::: details Shop Output + + ![Translation Output](../../assets/1.x/images/package-development/hello-world-shop-translation-output.png) + + ::: + +### Step-9 + +- Now we will add CSS, JS and images to our package. + +- In `Resources` folder creates a folder name `assets` & create `sass`, `js` and `images` folder. + + - In **sass** folder, add file **_app.scss_** + + - In **js** folder, add file **app.js** + +::: details Updated directory structure + +```php +- packages/ + - ACME/HelloWorld/ + - src/ + ... + - Resources/ + - assets/ + - sass/ + - app.scss + - js/ + - app.js + - images/ +``` + +::: + +- To add assets, create `package.json` and `webpack.mix.js` file inside the root of your package i.e. `packages/ACME/HelloWorld`. + +- Copy below code to `package.json`, + + ```json + { + "scripts": { + "dev": "npm run development", + "development": "cross-env NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js", + "watch": "cross-env NODE_ENV=development node_modules/webpack/bin/webpack.js --watch --progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js", + "watch-poll": "npm run watch -- --watch-poll", + "hot": "cross-env NODE_ENV=development node_modules/webpack-dev-server/bin/webpack-dev-server.js --inline --hot --config=node_modules/laravel-mix/setup/webpack.config.js", + "prod": "npm run production", + "production": "cross-env NODE_ENV=production node_modules/webpack/bin/webpack.js --no-progress --hide-modules --config=node_modules/laravel-mix/setup/webpack.config.js" + }, + + "devDependencies": { + "cross-env": "^7.0.2", + "laravel-mix": "^5.0.1", + "laravel-mix-merge-manifest": "^0.1.2" + } + } + ``` + +- Copy below code to `webpack.mix.js`, + + ```javascript + const mix = require("laravel-mix"); + + if (mix == "undefined") { + const { mix } = require("laravel-mix"); + } + + require("laravel-mix-merge-manifest"); + + if (mix.inProduction()) { + var publicPath = "publishable/assets"; + } else { + var publicPath = "../../../public/vendor/webkul/helloworld/assets"; + } + + mix.setPublicPath(publicPath).mergeManifest(); + + mix.disableNotifications(); + + mix + .js([__dirname + "/src/Resources/assets/js/app.js"], "js/helloworld.js") + .copyDirectory( + __dirname + "/src/Resources/assets/images", + publicPath + "/images" + ) + .sass( + __dirname + "/src/Resources/assets/sass/app.scss", + "css/helloworld.css" + ) + .options({ + processCssUrls: false, + }); + + if (mix.inProduction()) { + mix.version(); + } + ``` + +- After doing this go to the root of your package i.e. `packages/ACME/HelloWorld` and run `npm install` which will install all dependencies. + +- Now, `app.js` and `app.scss` is ready. Write all your css and js here. + +- When you done with your changes, then run `npm run prod` which will compiled all your css, js and images to the publishable folder. Then register your publishable in `HelloWorldServiceProvider`, + + ::: tip + + You can use `npm run watch` also, this will watch all your changes and put all your changes to the public path. When you done with all your changes then run `npm run prod` to compile all your changes and move to publishable folder. + + ::: + + ```php + loadRoutesFrom(__DIR__ . '/../Http/admin-routes.php'); + + $this->loadRoutesFrom(__DIR__ . '/../Http/shop-routes.php'); + + $this->loadViewsFrom(__DIR__ . '/../Resources/views', 'helloworld'); + + $this->loadTranslationsFrom(__DIR__ . '/../Resources/lang', 'helloworld'); + + $this->publishes([ + __DIR__ . '/../../publishable/assets' => public_path('vendor/webkul/helloworld/assets'), + ], 'public'); + } + + /** + * Register services. + * + * @return void + */ + public function register() + { + + } + } + ``` + +- After doing this we need to add an event listener so that admin layouts include our CSS. For this we need to add an Event Listener in service provider. But before adding event, let's create a `layouts` folder in `packages/ACME/Test/src/Resources/views/admin` and inside that create a file called `style.blade.php` & mention compiled CSS path inside this file. + + ```html + + ``` + +- **For Event Listener:** Add facade 'Event' into your `HelloWorldServiceProvider.php` file, + + ```php + loadRoutesFrom(__DIR__ . '/../Http/admin-routes.php'); + + $this->loadRoutesFrom(__DIR__ . '/../Http/shop-routes.php'); + + $this->loadViewsFrom(__DIR__ . '/../Resources/views', 'helloworld'); + + $this->loadTranslationsFrom(__DIR__ . '/../Resources/lang', 'helloworld'); + + $this->publishes([ + __DIR__ . '/../../publishable/assets' => public_path('vendor/webkul/helloworld/assets'), + ], 'public'); + + Event::listen('bagisto.admin.layout.head', function($viewRenderEventManager) { + $viewRenderEventManager->addTemplate('helloworld::admin.layouts.style'); + }); + } + + /** + * Register services. + * + * @return void + */ + public function register() + { + + } + } + ``` + +- Till now, we configured our package HelloWorld and now we need to extend the default layout of our admin panel by using `@extends('admin::layouts.master')` in file `packages/ACME/HelloWorld/src/Resources/views/admin/index.blade.php`. Below is the simple template which you can copy to your `index.blade.php` file, + + ```html + @extends('admin::layouts.master') @section('page_title') Package HelloWorld + @stop @section('content-wrapper') + +
+ + +
+
+ + @stop + ``` + +- If you don’t want to include this one then you can create your own master file which includes your packages CSS & JS. + +- Run `php artisan vendor:publish --all --force`. This will move all your publishable assets to their respective directory which you mentioned in the service provider. + +### Step-10 + +- Now we will add Database to our package. Create a `Database` folder in `packages/ACME/HelloWorld/src` path and inside `Database` folder create `Migrations` and `Seeders` folder. + +- Now, we need to add migrations to our service provider to load them. + + ```php + loadRoutesFrom(__DIR__ . '/../Http/admin-routes.php'); + + $this->loadRoutesFrom(__DIR__ . '/../Http/shop-routes.php'); + + $this->loadViewsFrom(__DIR__ . '/../Resources/views', 'helloworld'); + + $this->loadTranslationsFrom(__DIR__ . '/../Resources/lang', 'helloworld'); + + $this->publishes([ + __DIR__ . '/../../publishable/assets' => public_path('vendor/webkul/helloworld/assets'), + ], 'public'); + + Event::listen('bagisto.admin.layout.head', function($viewRenderEventManager) { + $viewRenderEventManager->addTemplate('helloworld::helloworld.layouts.style'); + }); + + $this->loadMigrationsFrom(__DIR__ .'/../Database/Migrations'); + } + + /** + * Register services. + * + * @return void + */ + public function register() + { + + } + } + ``` + +- Now start adding your migration files. diff --git a/docs/1.x/packages/store-data-through-repositories.md b/docs/1.x/packages/store-data-through-repositories.md new file mode 100644 index 00000000..d06e89ef --- /dev/null +++ b/docs/1.x/packages/store-data-through-repositories.md @@ -0,0 +1,130 @@ +# Store data through Repository + +## Contracts, Repositories and Proxies + +### Contracts + +Laravel's Contracts are a set of interfaces that define the core services provided by the framework. For example, an `Illuminate\Contracts\Queue\Queue` contract defines the methods needed for queueing jobs, while the `Illuminate\Contracts\Mail\Mailer` contract defines the methods needed for sending an e-mail. + +Each contract has a corresponding implementation provided by the framework. For example, Laravel provides a queue implementation with a variety of drivers, and a mailer implementation that is powered by SwiftMailer. + +All of the Laravel contracts live in their own GitHub repository. This provides a quick reference point for all available contracts, as well as a single, decoupled package that may be utilized by package developers. + +### Repositories + +Generally, we wrote all of our application logic in the controller. There’s an alternative approach of development that abstracts some calls into PHP classes called Repositories. The idea is that we can decouple models from controllers and assign a readable name's to complicated queries. + +This file defines our Repository class. Instances of this class have a model property that we tie to an Eloquent model. Once this is bound in the constructor we can call Eloquent methods like findOrFail, update or all from the class methods. + +### Proxies + +Proxies as their name state will drive you to the actual model class. The concept of model proxies has been introduced to override the functionality of the existing Model. It is a type of model inheritance without creating a new table in the database. + +## Steps to store data through repository + +- For creating models, create a file named as `HelloWorld.php` in `packages/ACME/HelloWorld/src/Models`, and copy the below code in file, + + ~~~php + Note: If you have created model by using **Bagisto Package Generator**, then you can skip the model proxy and contract creation step. + +- Now, at the same location create a model proxy file as `HelloWorldProxy.php`. This Proxy class will extends `Konekt\Concord\Proxies\ModelProxy`. Copy the below code in file, + + ~~~php + [ + ACME\HelloWorld\Providers\ModuleServiceProvider::class + ] + ]; + ~~~ + +- Now, you are all set to go. diff --git a/docs/1.x/themes/README.md b/docs/1.x/themes/README.md new file mode 100644 index 00000000..f2cb0a16 --- /dev/null +++ b/docs/1.x/themes/README.md @@ -0,0 +1,7 @@ +# Themes + +We hope that now you know how to create a package, if not then you may refer to [Package Development](../packages) section. + +Creating a custom theme for Bagisto had been a hot topic lately. More and more users are actively trying our framework and we’re genuinely overwhelmed by it. + +Creating a custom theme for Bagisto is super easy with just a few lines of configuration code. Similarly following the traditional way of creating view files in Laravel would be enough. diff --git a/docs/1.x/themes/change-email-template.md b/docs/1.x/themes/change-email-template.md new file mode 100644 index 00000000..a8536864 --- /dev/null +++ b/docs/1.x/themes/change-email-template.md @@ -0,0 +1,98 @@ +# Change email template + +In this section, we are explaining how to change the email templates in Bagisto. As we all know, everyone wants some customization according to their own taste that's why knowing about changing the email template is also quite helpful for some users. + +## Email template flow + +Before diving into template change first we should know how the email template works in the Bagisto. + +There are several mail notification classes like `CancelOrderAdminNotification`, `NewCustomerNotification`, and many more present in the `Webkul\Admin\Mail` namespace. Let's check one of these files, we are taking `CancelOrderAdminNotification` class as an example. + +~~~php +order = $order; + } + + public function build() + { + return $this->from(core()->getSenderEmailDetails()['email'], core()->getSenderEmailDetails()['name']) + ->to(core()->getAdminEmailDetails()['email']) + ->subject(trans('shop::app.mail.order.cancel.subject')) + ->view('shop::emails.sales.order-cancel-admin'); + } +} +~~~ + +If you check the `build()` method in the above class. You will come to know that the main view file i.e. `view('shop::emails.sales.order-cancel-admin')` is loaded from the shop package. + +Now check the view file mentioned in the `view('shop::emails.sales.order-cancel-admin')` method. If you check at this path `packages/Webkul/Shop/src/Resources/views/emails/sales/order-cancel-admin.blade.php`, you will get this file. Let's explore this one, if you check this file you will come to know that the main layout component i.e. `shop::emails.layouts.master` is used. + +~~~php +@component('shop::emails.layouts.master') + ... +@endcomponent +~~~ + +And this is responsible for your layouts. You can also explore that file if you want. Now we will move on to how to change these layouts. + +## Changing email template + +Now, we are changing the template. The recommended way to change the template is by overriding the package's view. If you check the above flow you will come to know that all views for emails are defined in the shop package. So we need to override the view for the shop package. + +Let's override the view of the same file which we explained above i.e. `view('shop::emails.sales.order-cancel-admin')`. + +As this is a Laravel stuff, Bagisto also registers two locations for your views i.e. the application's `resources/themes` directory mentioned in the `config/themes.php` and the directory you specify. So, if you are using the `default` theme i.e. `shop` package, then Bagisto will first check if a custom version of the view has been placed in the `resources/themes/default` directory. Then, if the view has not been customized, Bagisto will search the package view directory. + +Now, for overriding we are creating the same structure in the application's `resources/themes/default` directory. + +~~~directory-structure +- resources/ + - themes/ + - default/ + - views/ + - emails/ + - sales/ + - order-cancel-admin.blade.php +~~~ + +Let's say this file i.e. `order-cancel-admin.blade.php` is having some random paragraphs like below, + +~~~order-cancel-admin.blade.php +... + +Lorem ipsum dolor sit amet consectetur adipisicing elit. Laborum porro cumque numquam neque dicta quo, accusantium, perferendis sed beatae nesciunt eum impedit vel doloribus dolor excepturi vero tenetur perspiciatis saepe? + +... +~~~ + +Now, test the mail. + +## Mail Sample + +![Mail Sample](../../assets/1.x/images/themes/mail-sample.png) diff --git a/docs/1.x/themes/create-admin-theme.md b/docs/1.x/themes/create-admin-theme.md new file mode 100644 index 00000000..4d17b089 --- /dev/null +++ b/docs/1.x/themes/create-admin-theme.md @@ -0,0 +1,101 @@ +--- +title: Create a admin theme +--- + +# Create an new admin theme + +In the Bagisto root directory go to the **config** folder and open `themes.php`. +Now search for the keys `admin-default` and `admin-themes`. It will look like this, + +```php + 'default', + + 'admin-themes' => [ + 'default' => [ + 'views_path' => 'resources/admin-themes/default/views', + 'assets_path' => 'public/admin-themes/default/assets', + 'name' => 'Default' + ] + ] + ]; +``` + +| Key | Description| +| --- | ---------- | +| admin-default | is used to set the current theme. | +| admin-themes | is used to store a list of themes | + +Now add one more theme into `admin-themes`. + +```php + 'default', + + 'admin-themes' => [ + 'default' => [ + 'views_path' => 'resources/admin-themes/default/views', + 'assets_path' => 'public/admin-themes/default/assets', + 'name' => 'Default' + ], + + 'theme1' => [ + 'views_path' => 'resources/admin-themes/theme1/views', + 'assets_path' => 'public/admin-themes/theme1/assets', + 'name' => 'Theme 1' + ] + ] + ]; +``` + +As you see we have added the view and assets path in the `theme1` array. +Now set your views and assets folder according to your mentioned path. + +The resources structure will look like this, + +~~~php + - resources + - admin-themes + - theme1 + - views +~~~ + +Assets structure will look like this, + +~~~php + - public + - admin-themes + - theme1 + - assets +~~~ + +Now lets replace the dashboard page. +Just create the exact dashboard's directory structure for `theme1` as present in `default`. +So it will look like this, + +~~~php + - resources + - admin-themes + - theme1 + - views + - dashboard + - index.blade.php +~~~ + +Add some lines to the `index.blade.php`, + +~~~php + Theme 1 Sample +~~~ + +Now everything is setup. Just one thing is pending i.e. we need to activate the theme. So, for that we need to change the `admin-default` key in file `config/themes.php`. + +~~~php + ... + 'admin-default' => 'theme1', + ... +~~~ + +Now check the dashboard page. \ No newline at end of file diff --git a/docs/1.x/themes/create-theme.md b/docs/1.x/themes/create-theme.md new file mode 100644 index 00000000..5e98ae56 --- /dev/null +++ b/docs/1.x/themes/create-theme.md @@ -0,0 +1,87 @@ +--- +title: Create a store theme +--- + +# Create a store theme + +Please follow the steps mentioned below that how to create a custom theme in Bagisto. + +Go to your project’s root directory and check for **config** folder. +Inside **config** folder, you will find a file called **_themes.php_** like directory below: + + - app/ + - bin/ + - bootstrap/ + - config/ + - themes.php + - database/ + - packages/Webkul + + + +Check contents of **_themes.php_** file, it holds all necessary information of creating a custom theme. + +```php + 'default', + + 'themes' => [ + 'default' => [ + 'views_path' => 'resources/themes/default/views', + 'assets_path' => 'public/themes/default/assets', + 'name' => 'Default' + ], + + // 'bliss' => [ + // 'views_path' => 'resources/themes/bliss/views', + // 'assets_path' => 'public/themes/bliss/assets', + // 'name' => 'Bliss', + // 'parent' => 'default' + // ] + ] +]; +``` + + + +Let’s go through the parameters of **_themes.php_** file. Because understanding those parameters will help you in creating a custom theme. + +##### An Explanation For These Parameters: + +- default: Declared at the top signifies the currently active or default theme in Bagisto. It is assigned with the value 'default’. The default(string) indicates the name of the currently active theme. + +- themes: This parameter is where you’ve to define all essentials for your own custom theme. Multiple themes can also be created and used at the same time in Bagisto. + + - Inside 'themes’ there is another array by name 'default' which is your currently active theme containing some key-value pairs. + + - default: Inside array 'default', it holds few more key-value pairs. such as 'views_path', 'assets_path', 'name’ all those are explained below: + + - views_path: It’ll take the path of your views or blade files that you want to put up in your custom theme. + + - assets_path: Responsible for your assets i.e. images, CSS and javascript files, etc. + + - name: Defines a global name for your theme inside Bagisto. + + - parent: This is a magic parameter that you can find in the commented code below the sub-array 'default'. Using this parameter you can make use of existing themes inside Bagisto and just customize them even further. This parameter will take the value of the 'name’ parameter listed in the 3rd point above. + + + +Finally, define your own paths and name of your custom theme inside **_themes.php_** file, and start creating view files. Do not forget to cover all get routes of shop package having a parameter called 'view’. You can get route file of shop package located at `packages/Webkul/Shop/src/Http/routes.php` + + + +Make sure the name of the blade file should be the same one as passed in this GET route file like this: + +```php +//Store front header nav-menu fetch + Route::get('/categories/{slug}', 'Webkul\Shop\Http\Controllers\CategoryController@index') + ->defaults('_config', [ + 'view' => 'shop::products.index' + ])->name('shop.categories.index'); +``` + + + +For all views check all GET routes as they hold a view parameter with the value of view to be used. diff --git a/docs/1.x/themes/customize-hompepage-menu.md b/docs/1.x/themes/customize-hompepage-menu.md new file mode 100644 index 00000000..d7288347 --- /dev/null +++ b/docs/1.x/themes/customize-hompepage-menu.md @@ -0,0 +1,27 @@ +# Customize homepage menu + +In this section, we will give you an overview of the menu items. How you can access the menu items and how it can be used for customization. In both themes i.e. default and velocity, we are displaying the categories in the menu items. + +## Accessing categories + +If you check the shop package, you will come to know that we have used the `CategoryRepository` class in the namespace `Webkul\Category\Repositories\CategoryRepository`. + +In this class, there is a method named `getVisibleCategoryTree`. This method will give you the listing of all the categories. You just need to pass the main root category id. + +## Sample from default theme + +If you check the blade file in the default theme, here is the below code, + +~~~php +foreach (app('Webkul\Category\Repositories\CategoryRepository')->getVisibleCategoryTree(core()->getCurrentChannel()->root_category_id) as $category) { + ... +} +~~~ + +Now loop through these and customize your menu according to your needs. + +::: tip + +There are several more categories methods present in the repository. Just go ahead explore those also. + +::: diff --git a/docs/1.x/themes/integrate-image-search-in-theme.md b/docs/1.x/themes/integrate-image-search-in-theme.md new file mode 100644 index 00000000..a06599da --- /dev/null +++ b/docs/1.x/themes/integrate-image-search-in-theme.md @@ -0,0 +1,72 @@ +# Integrate image search in theme + +In this section, we will show you how you can integrate image search with your new theme. If you check our **default theme** and **velocity theme**, you will come to know that we are using the [Tensorflow](https://www.tensorflow.org/js) JS and loading the model named **Tensorflow** MobileNet. + +The **Tensorflow** JS model does not need any knowledge for machine learning. You just need to pass any browser-based image elements `` and it will return an array that is best suited according to their predictions and their confidences. + +## Usage + +Make sure all your scripts are loaded in the footer, if you check the **default theme** and **velocity theme** we are using the yielding. So you can also use the same yielding. So we are assuming that you have added `scripts` yield in your main layouts. + +- Let's start with the loading of the library and model, + + ~~~php + @push('scripts') + + + @endpush + ~~~ + +- As **Tensorflow** model only need the image element. So, we are just taking the sample image element. + + ~~~php + @push('scripts') + + + + + @endpush + ~~~ + + ::: tip + + This is the sample image element, you can add file input to get the image from the user. + + ::: + +- Now, the main part just pass your image element to the model, + + ~~~php + @push('scripts') + + + + + + + @endpush + ~~~ + +- Now you have all the predictions. Just pass all your predictions to your search input. + + ::: tip + + Make query string from the predictions and redirect to the search route. + + ::: + +## Conclusion + +If you check the whole flow, you will come to know that we are passing an image element to **Tensorflow**'s model in return we are getting the array of predictions and from that predictions, we are making the query strings and redirecting to the search route. diff --git a/docs/1.x/themes/tracer.md b/docs/1.x/themes/tracer.md new file mode 100644 index 00000000..68cbc6f4 --- /dev/null +++ b/docs/1.x/themes/tracer.md @@ -0,0 +1,32 @@ +# Blade file tracer + +[[toc]] + +## Introduction +When you want to change or create a theme it can become difficult to find out which part contains the code that you need to work on. +This is why we added the blade file tracer as it will help developers, contributors & partners who deal with Bagisto to find the blade file of the templates/views and understand the structure of the project. + +## Configuration +Let’s start to make this easier with just a simple config change. +Go to your Bagisto root directory and open the file **config/view.php**, inside this file change the `tracer` value to `true`. + +```php + /* + |-------------------------------------------------------------------------- + | Blade File Tracer + |-------------------------------------------------------------------------- + | + | Shows blade file path in front + | + */ + + 'tracer' => true, +``` + +Now return to your Bagisto root directory and run the following commands +```bash +php artisan view:clear +php artisan config:cache +``` + +Now you are ready to visit your Storefront & Admin, you will see the blade file hint path in each block of your template. diff --git a/docs/1.x/translations/README.md b/docs/1.x/translations/README.md new file mode 100644 index 00000000..e69de29b diff --git a/docs/1.x/translations/change-the-language-of-error-validations-on-your-store.md b/docs/1.x/translations/change-the-language-of-error-validations-on-your-store.md new file mode 100644 index 00000000..4880528d --- /dev/null +++ b/docs/1.x/translations/change-the-language-of-error-validations-on-your-store.md @@ -0,0 +1,27 @@ +# Change the language of error validations on your store + +If you want to make your website easily accessible to customers in multiple languages and expand your business to a global level, then language translation is imperative for your website. + +This will help you get more traffic and further generate sales. + +By using language translation in Bagisto, you can easily localize your website for many global or regional languages. + +Your customer can easily translate your whole website just by a single click which also plays a major role in website SEO in the respective region and to show validation messages as per your locale, you need to follow these below steps: + +## Steps to change the language of error validation + +1. Within Shop package, go to src/Resources/assets/js/lang/locales.js + +2. define your error translation for your locale code as shown below in the screenshot + + ![error-translation](../../assets/1.x/images/user-guide/locale-trans.png) + +3. Now, within **app.js**, add `ar: { messages: locales.messages.ar }` for your locale code in dictionary property such as ar for arabic + + ~~~javascript + Vue.use(VeeValidate, { + dictionary: { + ar: { messages: locales.messages.ar } + } + }); + ~~~ \ No newline at end of file diff --git a/docs/1.x/translations/translation-based-on-locale.md b/docs/1.x/translations/translation-based-on-locale.md new file mode 100644 index 00000000..61cfd3c2 --- /dev/null +++ b/docs/1.x/translations/translation-based-on-locale.md @@ -0,0 +1,68 @@ +# Translation based on locale + +If you want to make your website easily accessible to customers in multiple languages and expand your business to a global platform then language translation is crucial for your website. It will help you generate more traffic and increase sales. + +By using language translation in Bagisto, you can easily localize your website for many global or regional languages. Your customer can easily translate your whole website just by a single click which also plays a major role in website SEO in the respective region and to show translation as per your locale, you need to follow these below steps: + +## Steps to apply Translation Based on Locale + +You can easily perform language translation for both Admin dashboard and the front-end view + +**Translation For Front-End View** + +Kindly follow the steps as needed on the admin dashboard. + +**Step 1:-** On Admin Sidebar, click on Setting>>Locales>>Add Locale + +![locale](../../assets/1.x/images/user-guide/locale.png) + +**Step 2:-** Enter the code and Name of locale (here I am taking an example of Arabic language or you can select as per your choice) and click on Save Locale. + +![add-locale-bagisto](../../assets/1.x/images/user-guide/add-locale-bagisto.png) + +**Step 3:-** Next, you need to set the Channels.Click on Setting>> Channels. Open the selected Channel in Edit Mode. Under Currencies and Locales + +Locale:- You can select either one or multi-select locales as per your choice. + +Default Locale:- You have to set your default Locale so that if the Customer will not select any locale then it will be showing in the Default Locale set by you + +Once the settings have been done, click on Save Channels. + +![channel-setting-in-bagisto](../../assets/1.x/images/user-guide/channel-setting-in-bagisto.png) + +**Step 4:-** Next, you need to change locale in the below main section: Products, Categories, and Attributes + +![language-changes](../../assets/1.x/images/user-guide/language-changes.png) + +**Step 5:-** Under Attributes Section, click on Attributes which you want to change. Next, open selected attribute in Edit Mode. Enter the attribute name in Arabic after which click on Save Attribute. Here I am giving an example of Attribute “Pattern“. + +![arrabic-attribute](../../assets/1.x/images/user-guide/arrabic-attribute.png) + +**Step 6:-** Under Categories Section, click on Categories. Enter the category name in Arabic and enter the description in Arabic after which click Save Category. + +![catageory-in-arabic](../../assets/1.x/images/user-guide/catageory-in-arabic.png) + +**Step 7:-** Under Product Section, click on Product. Open the selected product in Edit Mode and enter the product name in Arabic and Short Description in Arabic + +![product-in-arabic](../../assets/1.x/images/user-guide/product-in-arabic.png) + + +**_Steps To Perform On The Front End_** + +**Step 1:-** At the bottom of the front end there is an option of Locale so you can select your Locale + +![translation](../../assets/1.x/images/user-guide/translation.png) + +When you will select Locale in English then the front end will be visible like this: + +![front-end](../../assets/1.x/images/user-guide/front-end.png) + +When you will select the locale in Arabic from the front end then it will be visible like this: + +![front-end-in-arabic](../../assets/1.x/images/user-guide/front-end-in-arabic.png) + +**Translation For Admin View** + +You need to specify the locale in config/app.php file of the root as shown in the screenshot, replace 'en' with your locale code. + +![locale-setup](../../assets/1.x/images/user-guide/locale-setup.png) diff --git a/docs/1.x/user-guides/README.md b/docs/1.x/user-guides/README.md new file mode 100644 index 00000000..e69de29b diff --git a/docs/1.x/user-guides/cart-catalog-rule.md b/docs/1.x/user-guides/cart-catalog-rule.md new file mode 100644 index 00000000..7b4bd51b --- /dev/null +++ b/docs/1.x/user-guides/cart-catalog-rule.md @@ -0,0 +1,16 @@ +--- +title: Revampment of cart & catalog rule | Bagisto Web APIs Documentation +layout: default +--- + +## Revamping the Catalog & Cart Rule + +There is a revamping of cart & catalog rule at the code level. The user needs to upgrade their bagisto version to v0.1.9 for the usage of our cart & catalog rule. To upgrade the module, the points below must be followed: + +1. Initially, the user needs to take a backup of their project database. + +2. Take a pull from [Bagisto v0.1.9](https://github.com/bagisto/bagisto/tree/v0.1.9){: target="\_blank" .link-color}. There may be some conflicts, you need to resolve it by own. + +3. Run `php artisan migrate` and `php artisan db:seed` command. + +**Note** : The changes in core packages will be removed, if done. \ No newline at end of file diff --git a/docs/1.x/user-guides/cart-rule.md b/docs/1.x/user-guides/cart-rule.md new file mode 100644 index 00000000..b96114ba --- /dev/null +++ b/docs/1.x/user-guides/cart-rule.md @@ -0,0 +1,52 @@ +--- +title: Cart Rules | Bagisto +--- + +# Cart Rules + +To Add cart-rules, you need to explore promotions menu -> Cart Rules. Here, we have a option to Add Cart Rule +. Options you will find in creating cart rules as below: + +- **General Information** + + 1. Rule Name: the name of cart rule is given + 2. Description: the description of cart rule is given + 3. Start: From the date & time, the cart rule will be applicable + 4. End: upto the date & time, the cart rule will be applicable + 5. Customer Groups: Bydefault, we have provided three option of customer group as 'guest', 'general', 'wholesale'. But, if needed, we can create customer groups from **customers -> groups menu**. + 6. Channels: this multi-select box shows the available channels + 7. Is active: this accepts the boolean value of enable/disable cart rule + 8. Use Coupon: this accepts the boolean value for enable/disable coupons + 9. Priority: this sets the priority of one cart rule over another + +- **Conditions** + + Within this, two dropdown options are available + + 1. All Conditions are true: We have an option to add condition based on which cart rule will implement if all the conditions are true. + 2. Any condition is true: We have an option to add condition based on which cart rule will implement if in all listed condition any condition is true. + +- **Actions** + +The section provides actions on cart rules on multiple criteria. For this, we have an multiple form-fields i.e., + +1. **_Apply_**: + + - Percentage of product + - Apply as fixed amount + +2. **_Discount Amount_**: This field based on above _apply_ field i.e., + + - If percentage of product is selected then this field accepts the percent value which will be the amount of percentage apply as a discount on product. + + - If apply as fixed amount is selected then the specified amount in this field will be deducted/reduced from the product price + +3. **_Buy Atleast_**: It accepts numeric value that determine how many product quantity need to be purchase to apply cart rule/discount + +4. **_Max. Quantity Allowed To Be Discounted_**: In this, we specifies on how many product quantity discount will be applied. + +5. **_Free Shipping_**: Accepts boolean value for enable/disable free shipping means **_no delivery charges_** + +6. **_Apply to shipping_**: Accepts boolean value and determines whether discount applies to shipping cost or not. + +7. **_End other rules_**: Accepts boolean value to enable/disbale other discount i.e., If non-couponables rules are applied such as offer, sale etc. Then, there is no need to apply coupons. diff --git a/docs/1.x/user-guides/social-auth.md b/docs/1.x/user-guides/social-auth.md new file mode 100644 index 00000000..43d727c3 --- /dev/null +++ b/docs/1.x/user-guides/social-auth.md @@ -0,0 +1,76 @@ +# Social Authentication + +[[toc]] + +## Introduction +In addition to the default authentication, Bagisto also provide a convenient way to authenticate with multiple OAuth providers. +The following social networks are provided out of the box: [Facebook](https://facebook.com) [GitHub](https://github.com) [Google](https://google.com) [LinkedIn](https://linkedin.com) and [Twitter](https://twitter.com) + +Once you configured one of the social networks, your customers can authenticate by one of these social networks by just a single buttons, there is no need to fill various fields. + +## Configuration +To get started, you need to enable this feature first in the admin interface, navigate to configure>>Customer>>Social login. +Here you can enable / disable social authentication providers as shown in the below image. + +![admin_social_auth](../../assets/1.x/images/user-guide/social/admin_social_auth.png) + +## Configuring Github + +### Register a new OAuth application +Before you can allow you customers to authenticate with Github, you first need to create a [GitHub application](https://github.com/settings/applications/new). +::: tip Authorization callback URL +You can find the **Authorization callback URL** inside the .env file and change yourhost.com with your domain name. +::: + +![github_oauth_step1](../../assets/1.x/images/user-guide/social/github-OAuth-step1.png) + +Once your new OAuth Application is registered, click on the name of your new application to get the **Client ID** and **Client Secret**. +![github_oauth_step2](../../assets/1.x/images/user-guide/social/github-OAuth-step3.png) + +### Configure credentials for the OAuth application +Now that you have the **Github Client ID**, **Client Secret** and **Authorization callback URL**, you just need to add these to your **.env** file. +Remember to change the GITHUB_CALLBACK_URL yourhost.com with your domain name. + +``` +GITHUB_CLIENT_ID= +GITHUB_CLIENT_SECRET= +GITHUB_CALLBACK_URL=https://yourhost.com/customer/social-login/github/callback +``` + +## Configuring Google + +### Register a new OAuth application +Before you can allow you customers to authenticate with Google, you first need to create a [Google application](https://console.developers.google.com/project). +1. Go to your API & Services ->Library +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step1.png) +2. Now click on Google+API under the section Social. +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step2.png) +3. Now, click the **Enable button** to enable the Google+ API. +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step3.png) +4. Now, click My Project to create a new project. +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step4.png) +5. On clicking My Project, a pop-up will appear. Click “New Project” link. +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step5.png) +6. Enter the name for your store so that you can identify your project. Please note that you should not include any Google word for your project name. +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step6.png) +7. Meanwhile, go to the Credentials menu option and then click on Create credentials. +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step7.png) +8. After that, click on **OAuth client ID**. +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step8.png) +9. Select the Application type and enter the Authorized JavaScript origins and the Authorized redirect URLs, once that is done click the **Create** button. +::: tip OAuth Redirect URL +Set the OAuth Redirect URL like this: www.example.com/socialsignup/google/callback/ +::: +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step9.png) +10. After clicking the **Create** button in the above step you will get the Client Id and Client Secret. +![github_oauth_step1](../../assets/1.x/images/user-guide/social/google-OAuth-step10.png) + +### Configure credentials for the OAuth application +Now that you have the **Google Client ID**, **Client Secret** and **Authorization callback URL**, you just need to add these to your **.env** file. +Remember to change the GOOGLE_CALLBACK_UR yourhost.com with your domain name. + +``` +GOOGLE_CLIENT_ID= +GOOGLE_CLIENT_SECRET= +GOOGLE_CALLBACK_URL=https://yourhost.com/customer/social-login/google/callback +``` \ No newline at end of file diff --git a/docs/1.x/user-guides/tax-rates.md b/docs/1.x/user-guides/tax-rates.md new file mode 100644 index 00000000..c1454bf0 --- /dev/null +++ b/docs/1.x/user-guides/tax-rates.md @@ -0,0 +1,23 @@ +# Tax Rates + +In e-commerce, there are various taxes involved while purchasing the product. These taxes and the rate of taxes differ from country to country. + +In this section, we will focus only on the tax configuration. If you want to know more details about tax categories, tax rates, then feel free to check out out this [blog](https://bagisto.com/en/taxes-in-bagisto/). + +## Pricing + +If you check the configuration in the backend i.e. **Configuration > Taxes > Catalog**, you will see the '**Tax Inclusive**' button in the pricing section, + + ![Pricing Config](../../assets/1.x/images/user-guide/tax-rates/pricing-config.png) + +If this button is enabled then all the products in the shop will show tax-inclusive rates. + +## Default Location Calculation + +Now, in the same configuration, you will also see the '**Default Location Calculation**' with some fields, let us discuss all of them, + + ![Default Location Calculation Config](../../assets/1.x/images/user-guide/tax-rates/default-location-calculation-config.png) + +These are the default fields that can be handled by the admin. Let's say if the address of the customer or guest is not found, then in last, it will select the value from these configs. + +Even if these configs are not set then in last it will check in the `config/app.php` file. If still it's not found then tax will not be applied. diff --git a/docs/2.x/products/README.md b/docs/2.x/products/README.md new file mode 100644 index 00000000..8d80db10 --- /dev/null +++ b/docs/2.x/products/README.md @@ -0,0 +1,25 @@ +# Product types + +**TOPICS:** Inventory, Products + +**CREATED FOR:** +- Beginner +- Intermediate +- Admin +- Leader +- User + +Inventory Management supports inventory and order management for all product types in Bagisto: simple, configurable, virtual, downloadable, bundle, and grouped. Options and requirements may differ per product type for sources, stocks, and shipping. + +Single-source merchants create and update product settings and quantities without requiring additional updates. All created and newly imported products automatically assign to the Default Source and Default Stock, immediately available to customers if enabled and In-Stock. + +Multi-source merchants assign sources, quantities per source, and settings during or after product creation. Commerce assigns all newly imported products to the Default Source, requiring additional edits to assign sources and quantities. + +| Product Type | Shipping and Source Selection Algorithm | +|-----------------|------------------------------------------------------------------------------------------------------------------------------------| +| Simple | Supports SSA recommendations and overrides at shipping. | +| Configurable | Supports SSA recommendations and overrides at shipping. | +| Virtual | Always uses the SSA recommendation. The system runs the algorithm implicitly when it creates invoices, and always uses the suggested results. You cannot adjust these results. | +| Downloadable | Always uses the SSA recommendation. The system runs the algorithm implicitly when it creates invoices, and always uses the suggested results. You cannot adjust these results. | +| Bundle | Supports SSA recommendations and overrides at shipping. | +| Grouped | Supports SSA recommendations and overrides at shipping. | diff --git a/docs/2.x/products/bundle.md b/docs/2.x/products/bundle.md new file mode 100644 index 00000000..11f97540 --- /dev/null +++ b/docs/2.x/products/bundle.md @@ -0,0 +1,96 @@ +# Bundle Product + +Today's document will guide you on how to create bundle products in Bagisto. Bundle products and Grouped products are similar, where a bundle product includes customizable items that the store owner can configure to create a unique product in [Bagisto](https://bagisto.com/en/) + +Each item in a bundle product can be based on one of the following product types: + +- Simple Product +- Variants of Configurable Products + +### Steps To Create A Bundle Product In Bagisto 2.0 + +1. On the Bagisto admin dashboard, go to Catalog Section >> Products >> select Bundle under the Product Type. +2. Select Attribute Family. +3. Enter the SKU (Stock Keeping Unit) for the product (unique to every product). +4. Click the Save Button. + + ![Bundle](../../assets/2.x/images/bundle-product/bundle.png) + +After clicking on the Save Product button, you will be redirected to the next page with several new settings. + +### General Settings + +- **Name:** Enter the name of the product. +- **URL Key:** This will be the end of the URL, e.g., http://bagisto.test.com/products/assembled-core-i3-4-gb-ddr3500-gbwindows-10-pro151-inch-screen-black. +- **Tax Category:** Select the Tax Category from the dropdown list. + + ![editProduct](../../assets/2.x/images/bundle-product/editProduct.png) + +#### New + +- Enable the toggle button to feature the product as a new product, shown under the New Products section. + +#### Featured + +- Enable the toggle button to show the product under the Featured Products section. + +#### Visible Individually + +- Enable the toggle button to make the product visible on the frontend. + +#### Status + +- Enable the toggle button to enable the product on your eCommerce store. + +#### Guest Checkout + +- Enable the toggle button to allow guest customers to order the product. + + ![toggleButtons](../../assets/2.x/images/bundle-product/toggleButtons.png) + +### Description + +Fill in the following fields under description: + +- **Short Description:** Enter a short description of the product feature. +- **Description:** Mention your product in detail. + + ![description](../../assets/2.x/images/bundle-product/description.png) + +### Meta Description + +Fill in the following fields under meta description for improved searchability on search engines: + +- **Meta Title:** Provide the main title of the product. +- **Meta Keyword:** Provide meta keywords for specific search engine optimization. +- **Meta Description:** Enter a description for better search engine listings. + + ![metaDescription](../../assets/2.x/images/bundle-product/metaDescription.png) + +### Images + +To add product images, click on Add Images. You can add multiple images for your product. + +![image](../../assets/2.x/images/bundle-product/image.png) + +### Bundle Item + +Click on Add Option and: + +- Enter the Option Title. +- Set the Input Type (Select, Radio buttons, Checkbox, Multi-Select). +- Mark the Required checkbox if the field is mandatory. + +![options](../../assets/2.x/images/bundle-product/options.png) + +In the Search Product section, search for the product to add to the bundle. Once found, add the product to the bundle, specifying the quantity for each item. + +At the front end, customers can increase the quantity of the product to add to the cart, but the default quantity included in a bundle item cannot be changed. + +![bundleOptions](../../assets/2.x/images/bundle-product/bundleOptions.png) + +### Product At Front End + +The bundle product will be visible at the front end. + +![output](../../assets/2.x/images/bundle-product/output.png) diff --git a/docs/2.x/products/configurable.md b/docs/2.x/products/configurable.md new file mode 100644 index 00000000..d8b7b480 --- /dev/null +++ b/docs/2.x/products/configurable.md @@ -0,0 +1,66 @@ +# Configurable Product + +Configurable products are items or services that offer customers the flexibility to personalize certain attributes according to their preferences. Whether in manufacturing, e-commerce, or software, these products enable users to choose from predefined options, such as features, specifications, colors, or sizes. + +This customization allows for a diverse range of variations without the need for creating unique products. Configurable products are designed to meet individual needs, enhancing customer satisfaction and providing a tailored experience in [Bagisto](https://bagisto.com/en/). + +### How to Create a Configurable Product in Bagisto 2.0 +1. **Add Product:** Click on **Catalog >>** select **Configurable** as Product Type >> select **Family** >> enter SKU and then save the product as shown in the below image. + + ![Configurable](../../assets/2.x/images/configurable-product/configurable.png) + + After you Save the Product, you get an option to select the Color & Size. In case you want some other attribute in your configurable product, you need to create an attribute first and then save the product as shown in the below image. + + ![Configurable](../../assets/2.x/images/configurable-product/configurableAttributes.png) + +### General Attributes +Below is the list of fields you need to fill under General Attributes. + +- **SKU:** Provide SKU (Stock Keeping Unit) of the product which is unique to every product. +- **URL Key:** This will be the end of the URL, for example, http://bagisto.test.com/products/philips-speaker (Speaker is a URL key) +- **Tax Category:** You can select the Tax Category from the drop-down list that you want to be applied to the product. + + ![Configurable](../../assets/2.x/images/configurable-product/editProducts.png) + +Also, make sure to enable the Settings. + +- **New:** Enable the toggle button if you want to feature the product as a new product. The resulting product will be shown under the New Products section. +- **Visible Individually:** Enable the toggle button so that the product will be visible on the front end. +- **Featured:** Enable the toggle button if you want to show the product under the Featured Products section. +- **Status:** Enable the toggle button to make the product enabled on your eCommerce store. +- **Guest Checkout:** Enable the toggle button to allow the product to be ordered by the guest customer. + + ![Configurable](../../assets/2.x/images/configurable-product/toggleButtons.png) + +### Description +Below is the list of the fields you need to fill regarding the product under the description. + +- **Short Description:** Enter a short description of the feature of the product. +- **Description:** Here you can mention your product in detail. + + ![Configurable](../../assets/2.x/images/configurable-product/descriptions.png) + +### Meta Description +Below is the list of fields that you need to provide under the meta description to make your product easily searchable on search engines. + +- **Meta Title:** Provide the main title of the product by which your product will be known. +- **Meta Keyword:** The meta keyword for the product needs to be provided to improve its searchability on the search engine for specific keywords. +- **Meta Description:** Enter the description so that the product can easily appear in search engine listing. + + ![Configurable](../../assets/2.x/images/configurable-product/metaDescriptions.png) + +### Images +Add the product images, click on **Add Images**. You can add multiple images for your product. + + ![Configurable](../../assets/2.x/images/configurable-product/image.png) + +Now you will be able to see the Variations right below the video section as shown below. You can simply Edit each product as we have created according to the Color and Size. + + ![Configurable](../../assets/2.x/images/configurable-product/variations.png) + +After all Variations are created, finally, Save the Product. + +### Front End +The product will be visible as given below on the front end. + + ![Configurable](../../assets/2.x/images/configurable-product/output.png) diff --git a/docs/2.x/products/downloadable.md b/docs/2.x/products/downloadable.md new file mode 100644 index 00000000..76b28834 --- /dev/null +++ b/docs/2.x/products/downloadable.md @@ -0,0 +1,77 @@ +# Downloadable Product + +Today, in this document, we will explore "How to Create Downloadable Product in Bagisto 2.0". Downloadable products refer to items that can be downloaded, such as eBooks, software applications, music, updates, games, etc. These products are digital and do not involve a shipping method at checkout. + +### Steps to Create a Downloadable Product in Bagisto 2.0 + +1. On the Bagisto admin dashboard, go to Catalog Section >> Products >> select Downloadable under the Product Type. +2. Select Attribute Family. +3. Enter SKU (Stock Keeping Unit) of the product, unique to every product. +4. Save the Product, and you will be redirected to the next page with general settings. + +### General Settings + +- **Name:** Enter the name of the product. +- **URL Key:** This will be the end of the URL, e.g., http://bagisto.test.com/products/bagisto-e-book (bagisto-e-book is the URL key). +- **Tax Category:** Select the Tax Category from the drop-down list. + +#### New + +- Enable the toggle button to feature the product as a new product, shown under the New Products section. + +#### Featured + +- Enable the toggle button to show the product under the Featured Products section. + +#### Visible Individually + +- Enable the toggle button to make the product visible on the frontend. + +#### Status + +- Enable the toggle button to enable the product on your eCommerce store. + +### Description + +Fill in the following fields under the description: + +- **Short Description:** Enter a brief description of the product feature. +- **Description:** Mention your product in detail. + +### Meta Description + +Fill in the following fields under meta description for improved searchability on search engines: + +- **Meta Title:** Provide the main title of the product. +- **Meta Keyword:** Provide meta keywords for specific search engine optimization. +- **Meta Description:** Enter a description for better search engine listings. + +### Price + +Insert the price, cost, and special price. Set the special price date for which the special price will be shown on the website. + +### Images + +To add product images, click on Add Images. You can add multiple images for your product. + +### Downloadable Information + +Here, enter the downloadable information about your product: + +- **Name:** Enter the name of your downloadable product. +- **Price:** Enter the price of the downloadable product. +- **File:** Attach the file. + - **Upload File:** Upload the file. + - **Insert URL:** Insert the URL. +- **Sample:** Insert URL/upload file to give a free sample. +- **Download Allow:** Specify the maximum number of downloads. Enter "0" for unlimited downloads. + +### Samples + +If you want to provide a free sample of your product, add a new link from the Samples section below the Links section. Enter the title and attach the sample file. + +### Product At Front End + +The downloadable product will be visible at the front end. + +Thanks for reading this blog. Please comment below if you have any questions. Also, you can hire Laravel Developers for your custom Laravel projects. If you encounter any issues, feel free to raise a ticket at our Support Portal. diff --git a/docs/2.x/products/grouped.md b/docs/2.x/products/grouped.md new file mode 100644 index 00000000..59e2db7f --- /dev/null +++ b/docs/2.x/products/grouped.md @@ -0,0 +1,74 @@ +# Grouped Product + +This document guides you on creating a Grouped Product in Bagisto 2.0. A grouped product is a collection of simple products that can be combined in Bagisto. This versatile product type allows you to offer variations of a single product or a group of products as a coordinated set. Each product in a grouped product can be purchased separately or all together as part of the group. + +### Steps to Create a Grouped Product in Bagisto 2.0 + +1. On the Bagisto admin dashboard, go to Catalog Section >> Products >> select Grouped under the Product Type. +2. Select Attribute Family >> enter SKU >> Click to Save Product. +3. Enter the SKU (Stock Keeping Unit) of the product, unique to every product. + +After clicking on the Save Product button, you will be redirected to the next page with several new settings as shown in the below image. + +### General Settings + +- **Name:** Enter the name of the product. +- **URL Key:** This will be the end of the URL, e.g., http://bagisto.test.com/products/set-of-men-casual-wear (set-of-men-casual-wear is a URL key). +- **Tax Category:** Select the Tax Category from the dropdown list. + +#### New + +- Enable the toggle button to feature the product as a new product, shown under the New Products section. + +#### Featured + +- Enable the toggle button to show the product under the Featured Products section. + +#### Visible Individually + +- Enable the toggle button to make the product visible on the frontend. + +#### Status + +- Enable the toggle button to enable the product on your eCommerce store. + +#### Guest Checkout + +- Enable the toggle button to allow the product to be ordered by guest customers. + +### Price + +- Insert the price, cost, and special price. Set the special price date for which the special price will be shown on the website. + +### Description + +Fill in the following fields under the description: + +- **Short Description:** Enter a short description of the product feature. +- **Description:** Mention your product in detail. + +### Meta Description + +Fill in the following fields under meta description for improved searchability on search engines: + +- **Meta Title:** Provide the main title of the product. +- **Meta Keyword:** Provide meta keywords for specific search engine optimization. +- **Meta Description:** Enter a description for better search engine listings. + +### Images + +To add product images, click on Add Images. You can add multiple images for your product. + +### Grouped Products + +#### Search Products + +Under this section, you can search for the Simple Products to include in the Grouped Product. Once you've added all the required products to the grouped product, they will be listed. + +Here, enter the default quantity (automatically added to the customer's cart), and sort orders to determine the product's appearance on the frontend, as shown in the image below. + +### Product at Front End + +The grouped product will be visible at the front end, as shown in the image below: + +Thanks for reading this blog. Please comment below if you have any questions. Also, you can hire Laravel Developers for your custom Laravel projects. If you encounter any issues, feel free to raise a ticket at our Support Portal. diff --git a/docs/2.x/products/simple.md b/docs/2.x/products/simple.md new file mode 100644 index 00000000..6455f3aa --- /dev/null +++ b/docs/2.x/products/simple.md @@ -0,0 +1,87 @@ +# Simple Product + +A **simple product** is a product type in e-commerce that does not require customers to choose additional attributes (such as size or color) to add to the cart. It should be a physical item and can be shipped to customers. + +Therefore, any service, such as downloadable items, does not count as a simple product. This is the step-by-step tutorial on how to add a simple product in [Bagisto](https://bagisto.com/en/). + +### Create Simple Product in Bagisto 2.0 +1. Click on **Catalog >> Products >>** select **Simple** under Product Type. + + ![Simple](../../assets/2.x/images/simple-product/simple.png) + +Now Save the Product, and you will get redirected to the Edit product page as shown below. + +### General Attributes +Below is the list of fields you need to fill under General Attributes. + + ![editProduct](../../assets/2.x/images/simple-product/editProduct.png) + +### Description +Below is the list of the fields you need to fill in regarding the product under description. + +#### Short Description +Enter a short description of the feature of the product. + +#### Description +Mention your product in detail. + + ![description](../../assets/2.x/images/simple-product/description.png) + +### Meta Description +Below is the list of fields that you need to provide under the meta description to make your product easily searchable on search engines. + +#### Meta Title +Provide the main title of the product by which your product will be known. + +#### Meta Keyword +The meta keyword for the product needs to be provided to improve its searchability on the search engine for specific keywords. + +#### Meta Description +Enter the description so that products can easily appear in search engine listings. + +![metaDescription](../../assets/2.x/images/simple-product/metaDescription.png) + +### Images +To add the product images, click on **Add Images**. You can add multiple images for your product. + +![image](../../assets/2.x/images/simple-product/image.png) + +### New +Enable the toggle button if you want to feature the product as a new product. The resulting product will be shown under the New Products section. + +### Featured +Enable the toggle button if you want to show the product under the Featured Products section. + +### Visible Individually +Enable the toggle button so that the product will be visible on the front end. + +### Status +Enable the toggle button to enable the product on your eCommerce store. + +### Guest Checkout +Enable the toggle button to allow the product to be ordered by guest customers. + +![toggleButtons](../../assets/2.x/images/simple-product/toggleButtons.png) + +### Price +Insert the price, cost, and special price, and set the special price date for which the special price will be shown on the website. + +![price](../../assets/2.x/images/simple-product/price.png) + +### Shipping +Set the Width, Height, Depth, and Weight of the product. + +![shipping](../../assets/2.x/images/simple-product/shipping.png) + +### Inventories +Insert the quantity of the product that is there in your inventory. By default, it is set to 0 so it shows on the front end as out of stock. + +![inventories](../../assets/2.x/images/simple-product/inventories.png) + +At last, Save the Product. + +### Front End +The product will be visible as given below on the front end. + +![product](../../assets/2.x/images/simple-product/product.png) + diff --git a/docs/2.x/products/virtual.md b/docs/2.x/products/virtual.md new file mode 100644 index 00000000..2f762060 --- /dev/null +++ b/docs/2.x/products/virtual.md @@ -0,0 +1,86 @@ +# Virtual Product + +This document provides a guide on creating virtual products in Bagisto 2.0. In an eCommerce store, products can generally be categorized into two types: physical and intangible. Virtual products fall under the category of intangible products, including memberships, services, warranties, or subscriptions in [Bagisto](https://bagisto.com/en/). + +A virtual product, unlike a downloadable product, is not something that can be downloaded but rather a service offered to customers. + +### Steps To Create Virtual Product In Bagisto 2.0 + +1. Go to Catalog >> Products >> Select Virtual under Product Type select Family. +2. Enter SKU and save the product, as shown in the image below. + + ![Virtual](../../assets/2.x/images/virtual-product/virtual.png) + +After clicking on the Save Product button, you'll be redirected to the next page with various new settings. + +### General Settings + +- **Name:** Enter the name of the product. +- **URL Key:** This will be the end of the URL, e.g., http://bagisto.test.com/products/fitness-membership (fitness-membership is a URL key). +- **Tax Category:** Select the tax category from the dropdown list. + + ![editProduct](../../assets/2.x/images/virtual-product/editProduct.png) + +#### New + +- Enable the toggle button to feature the product as a new product, which will be shown under the New Products section. + +#### Featured + +- Enable the toggle button to show the product under the Featured Products section. + +#### Visible Individually + +- Enable the toggle button to make the product visible on the frontend. + +#### Status + +- Enable the toggle button to enable the product on your eCommerce store. + +#### Guest Checkout + +- Enable the toggle button to allow guest customers to order the product. + + ![toggleButtons](../../assets/2.x/images/virtual-product/toggleButtons.png) + +### Description + +Fill in the following fields under the description: + +- **Short Description:** Enter a brief description of the product feature. +- **Description:** Provide a detailed description of the product. + + ![description](../../assets/2.x/images/virtual-product/description.png) + +### Meta Description + +Fill in the following fields under meta description for improved searchability on search engines: + +- **Meta Title:** Provide the main title of the product. +- **Meta Keyword:** Provide meta keywords for specific search engine optimization. +- **Meta Description:** Enter a description for better search engine listings. + + ![metaDescription](../../assets/2.x/images/virtual-product/metaDescription.png) + +### Images + +Add product images by clicking on Add Images. Multiple images can be added. + + ![image](../../assets/2.x/images/virtual-product/image.png) + +### Inventory + +Insert the quantity of the product available in your inventory. The default is set to 0, indicating out of stock on the frontend. + +![inventories](../../assets/2.x/images/virtual-product/inventories.png) + +### Price + +Insert the price, cost, and special price. Set the special price date for displaying the special price on the website. + +![price](../../assets/2.x/images/virtual-product/price.png) + +### Product At Front End + +![output](../../assets/2.x/images/virtual-product/output.png) + diff --git a/docs/CNAME b/docs/CNAME new file mode 100644 index 00000000..58946797 --- /dev/null +++ b/docs/CNAME @@ -0,0 +1 @@ +devdocs.bagisto.com diff --git a/docs/README.md b/docs/README.md new file mode 100644 index 00000000..b45496b3 --- /dev/null +++ b/docs/README.md @@ -0,0 +1,15 @@ +--- +home: true +heroText: Bagisto Developer Portal +tagline: Find detailed documentation and code examples. +actionText: Get Started → +actionLink: /2.x/prologue/ +features: +- title: Package creation + details: Learn how to create a new package for Bagisto. +- title: Digging Deeper + details: Learn advanced topics like payment methods, shipping methods. +- title: Custom theme + details: Learn how to create or customize a theme for Bagisto. +footer: Copyright © 2023 Bagisto +--- \ No newline at end of file diff --git a/docs/assets/1.5.x/images/advanced-topics/limiting-error-messages.png b/docs/assets/1.5.x/images/advanced-topics/limiting-error-messages.png new file mode 100644 index 00000000..c2b9485e Binary files /dev/null and b/docs/assets/1.5.x/images/advanced-topics/limiting-error-messages.png differ diff --git a/docs/assets/1.5.x/images/advanced-topics/mail-sample.png b/docs/assets/1.5.x/images/advanced-topics/mail-sample.png new file mode 100644 index 00000000..5bc4a05e Binary files /dev/null and b/docs/assets/1.5.x/images/advanced-topics/mail-sample.png differ diff --git a/docs/assets/1.5.x/images/advanced-topics/product-index.png b/docs/assets/1.5.x/images/advanced-topics/product-index.png new file mode 100644 index 00000000..7b889997 Binary files /dev/null and b/docs/assets/1.5.x/images/advanced-topics/product-index.png differ diff --git a/docs/assets/1.5.x/images/package-development/admin-acl-output.png b/docs/assets/1.5.x/images/package-development/admin-acl-output.png new file mode 100644 index 00000000..9530ff9b Binary files /dev/null and b/docs/assets/1.5.x/images/package-development/admin-acl-output.png differ diff --git a/docs/assets/1.5.x/images/package-development/admin-menu-output.png b/docs/assets/1.5.x/images/package-development/admin-menu-output.png new file mode 100644 index 00000000..055dd51c Binary files /dev/null and b/docs/assets/1.5.x/images/package-development/admin-menu-output.png differ diff --git a/docs/assets/1.5.x/images/package-development/blog-admin-lang-output.png b/docs/assets/1.5.x/images/package-development/blog-admin-lang-output.png new file mode 100644 index 00000000..5547ac84 Binary files /dev/null and b/docs/assets/1.5.x/images/package-development/blog-admin-lang-output.png differ diff --git a/docs/assets/1.5.x/images/package-development/blog-admin-output.png b/docs/assets/1.5.x/images/package-development/blog-admin-output.png new file mode 100644 index 00000000..8b1cec70 Binary files /dev/null and b/docs/assets/1.5.x/images/package-development/blog-admin-output.png differ diff --git a/docs/assets/1.5.x/images/package-development/blog-package-output.png b/docs/assets/1.5.x/images/package-development/blog-package-output.png new file mode 100644 index 00000000..d586cfd3 Binary files /dev/null and b/docs/assets/1.5.x/images/package-development/blog-package-output.png differ diff --git a/docs/assets/1.5.x/images/package-development/blog-shop-lang-output.png b/docs/assets/1.5.x/images/package-development/blog-shop-lang-output.png new file mode 100644 index 00000000..848d3dc7 Binary files /dev/null and b/docs/assets/1.5.x/images/package-development/blog-shop-lang-output.png differ diff --git a/docs/assets/1.5.x/images/package-development/blog-shop-output.png b/docs/assets/1.5.x/images/package-development/blog-shop-output.png new file mode 100644 index 00000000..cef8f7ab Binary files /dev/null and b/docs/assets/1.5.x/images/package-development/blog-shop-output.png differ diff --git a/docs/assets/1.5.x/images/package-development/custom-config-output.png b/docs/assets/1.5.x/images/package-development/custom-config-output.png new file mode 100644 index 00000000..ac3fc89c Binary files /dev/null and b/docs/assets/1.5.x/images/package-development/custom-config-output.png differ diff --git a/docs/assets/1.x/images/advanced-topics/best-security-practices/limiting-error-messages.png b/docs/assets/1.x/images/advanced-topics/best-security-practices/limiting-error-messages.png new file mode 100644 index 00000000..c2b9485e Binary files /dev/null and b/docs/assets/1.x/images/advanced-topics/best-security-practices/limiting-error-messages.png differ diff --git a/docs/assets/1.x/images/advanced-topics/elastic-search/installed-elastic-info.png b/docs/assets/1.x/images/advanced-topics/elastic-search/installed-elastic-info.png new file mode 100644 index 00000000..638feca2 Binary files /dev/null and b/docs/assets/1.x/images/advanced-topics/elastic-search/installed-elastic-info.png differ diff --git a/docs/assets/1.x/images/advanced-topics/elastic-search/product-index.png b/docs/assets/1.x/images/advanced-topics/elastic-search/product-index.png new file mode 100644 index 00000000..e5e3669a Binary files /dev/null and b/docs/assets/1.x/images/advanced-topics/elastic-search/product-index.png differ diff --git a/docs/assets/1.x/images/api/bagisto_add_create.jpg b/docs/assets/1.x/images/api/bagisto_add_create.jpg new file mode 100644 index 00000000..20030893 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_add_create.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_add_getId.jpg b/docs/assets/1.x/images/api/bagisto_add_getId.jpg new file mode 100644 index 00000000..0dbb9ee3 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_add_getId.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_add_info.jpg b/docs/assets/1.x/images/api/bagisto_add_info.jpg new file mode 100644 index 00000000..f6e8d193 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_add_info.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_add_no_pag.jpg b/docs/assets/1.x/images/api/bagisto_add_no_pag.jpg new file mode 100644 index 00000000..b48d2795 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_add_no_pag.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_add_save.jpg b/docs/assets/1.x/images/api/bagisto_add_save.jpg new file mode 100644 index 00000000..cef49653 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_add_save.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_addresses.jpg b/docs/assets/1.x/images/api/bagisto_addresses.jpg new file mode 100644 index 00000000..cabe4631 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_addresses.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_addresses_pag.jpg b/docs/assets/1.x/images/api/bagisto_addresses_pag.jpg new file mode 100644 index 00000000..c487f1d3 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_addresses_pag.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_attribute.jpg b/docs/assets/1.x/images/api/bagisto_attribute.jpg new file mode 100644 index 00000000..3f1ef7a1 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_attribute.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cart.jpg b/docs/assets/1.x/images/api/bagisto_cart.jpg new file mode 100644 index 00000000..4b498419 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cart.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cart_add.jpg b/docs/assets/1.x/images/api/bagisto_cart_add.jpg new file mode 100644 index 00000000..62931661 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cart_add.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cart_empty.jpg b/docs/assets/1.x/images/api/bagisto_cart_empty.jpg new file mode 100644 index 00000000..9f528b93 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cart_empty.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cart_guest.jpg b/docs/assets/1.x/images/api/bagisto_cart_guest.jpg new file mode 100644 index 00000000..6983ccea Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cart_guest.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cart_remove_item.jpg b/docs/assets/1.x/images/api/bagisto_cart_remove_item.jpg new file mode 100644 index 00000000..c50e63ea Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cart_remove_item.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cart_update.jpg b/docs/assets/1.x/images/api/bagisto_cart_update.jpg new file mode 100644 index 00000000..ec3a6fe4 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cart_update.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cat_descendant.jpg b/docs/assets/1.x/images/api/bagisto_cat_descendant.jpg new file mode 100644 index 00000000..e4980e46 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cat_descendant.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cat_link.jpg b/docs/assets/1.x/images/api/bagisto_cat_link.jpg new file mode 100644 index 00000000..48d9cf62 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cat_link.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cat_meta.jpg b/docs/assets/1.x/images/api/bagisto_cat_meta.jpg new file mode 100644 index 00000000..21f158ef Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cat_meta.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cat_no_pagination.jpg b/docs/assets/1.x/images/api/bagisto_cat_no_pagination.jpg new file mode 100644 index 00000000..dbc5dc88 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cat_no_pagination.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cat_pagination.jpg b/docs/assets/1.x/images/api/bagisto_cat_pagination.jpg new file mode 100644 index 00000000..83ab43d8 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cat_pagination.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cat_path.jpg b/docs/assets/1.x/images/api/bagisto_cat_path.jpg new file mode 100644 index 00000000..9905f0de Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cat_path.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cat_single.jpg b/docs/assets/1.x/images/api/bagisto_cat_single.jpg new file mode 100644 index 00000000..e9c79a2d Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cat_single.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_config.jpg b/docs/assets/1.x/images/api/bagisto_config.jpg new file mode 100644 index 00000000..7c47ca26 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_config.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_config_attr.jpg b/docs/assets/1.x/images/api/bagisto_config_attr.jpg new file mode 100644 index 00000000..a24e5542 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_config_attr.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_details.jpg b/docs/assets/1.x/images/api/bagisto_cust_details.jpg new file mode 100644 index 00000000..dc833c00 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_details.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_forgot.jpg b/docs/assets/1.x/images/api/bagisto_cust_forgot.jpg new file mode 100644 index 00000000..893f9431 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_forgot.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_id.jpg b/docs/assets/1.x/images/api/bagisto_cust_id.jpg new file mode 100644 index 00000000..4bc452cc Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_login.jpg b/docs/assets/1.x/images/api/bagisto_cust_login.jpg new file mode 100644 index 00000000..487a609d Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_login.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_logout.jpg b/docs/assets/1.x/images/api/bagisto_cust_logout.jpg new file mode 100644 index 00000000..c1629d34 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_logout.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_profile.jpg b/docs/assets/1.x/images/api/bagisto_cust_profile.jpg new file mode 100644 index 00000000..357011e0 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_profile.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_reg_error.jpg b/docs/assets/1.x/images/api/bagisto_cust_reg_error.jpg new file mode 100644 index 00000000..ea7c1c26 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_reg_error.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_register.jpg b/docs/assets/1.x/images/api/bagisto_cust_register.jpg new file mode 100644 index 00000000..9550e77e Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_register.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_wishlists.jpg b/docs/assets/1.x/images/api/bagisto_cust_wishlists.jpg new file mode 100644 index 00000000..1c2d5d17 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_wishlists.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_cust_wrong.jpg b/docs/assets/1.x/images/api/bagisto_cust_wrong.jpg new file mode 100644 index 00000000..e6d77d5e Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_cust_wrong.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_invoices.jpg b/docs/assets/1.x/images/api/bagisto_invoices.jpg new file mode 100644 index 00000000..fab7cf1f Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_invoices.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_invoices_id.jpg b/docs/assets/1.x/images/api/bagisto_invoices_id.jpg new file mode 100644 index 00000000..d7d94bc8 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_invoices_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_invoices_order_id.jpg b/docs/assets/1.x/images/api/bagisto_invoices_order_id.jpg new file mode 100644 index 00000000..0afca3c4 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_invoices_order_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_move_to_wishlist.jpg b/docs/assets/1.x/images/api/bagisto_move_to_wishlist.jpg new file mode 100644 index 00000000..0070037f Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_move_to_wishlist.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_orders.jpg b/docs/assets/1.x/images/api/bagisto_orders.jpg new file mode 100644 index 00000000..426fa756 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_orders.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_orders_custId.jpg b/docs/assets/1.x/images/api/bagisto_orders_custId.jpg new file mode 100644 index 00000000..986d90cc Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_orders_custId.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_orders_cust_no_pag.jpg b/docs/assets/1.x/images/api/bagisto_orders_cust_no_pag.jpg new file mode 100644 index 00000000..8eacf765 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_orders_cust_no_pag.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_orders_cust_pag.jpg b/docs/assets/1.x/images/api/bagisto_orders_cust_pag.jpg new file mode 100644 index 00000000..df263e7f Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_orders_cust_pag.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_orders_id.jpg b/docs/assets/1.x/images/api/bagisto_orders_id.jpg new file mode 100644 index 00000000..2b24b306 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_orders_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_orders_no_pag.jpg b/docs/assets/1.x/images/api/bagisto_orders_no_pag.jpg new file mode 100644 index 00000000..d17cf7e8 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_orders_no_pag.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_orders_page.jpg b/docs/assets/1.x/images/api/bagisto_orders_page.jpg new file mode 100644 index 00000000..76e03ea8 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_orders_page.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_all.jpg b/docs/assets/1.x/images/api/bagisto_prod_all.jpg new file mode 100644 index 00000000..28dd9b90 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_all.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_category.jpg b/docs/assets/1.x/images/api/bagisto_prod_category.jpg new file mode 100644 index 00000000..8ff27690 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_category.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_color.jpg b/docs/assets/1.x/images/api/bagisto_prod_color.jpg new file mode 100644 index 00000000..e7e5bade Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_color.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_id.jpg b/docs/assets/1.x/images/api/bagisto_prod_id.jpg new file mode 100644 index 00000000..3f052fc2 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_name.jpg b/docs/assets/1.x/images/api/bagisto_prod_name.jpg new file mode 100644 index 00000000..aaf27f53 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_name.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_new.jpg b/docs/assets/1.x/images/api/bagisto_prod_new.jpg new file mode 100644 index 00000000..56c72f34 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_new.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_price_config.jpg b/docs/assets/1.x/images/api/bagisto_prod_price_config.jpg new file mode 100644 index 00000000..5f2a4a87 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_price_config.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_price_simple.jpg b/docs/assets/1.x/images/api/bagisto_prod_price_simple.jpg new file mode 100644 index 00000000..69ca8dfa Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_price_simple.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_size.jpg b/docs/assets/1.x/images/api/bagisto_prod_size.jpg new file mode 100644 index 00000000..9e790c19 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_size.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_sku.jpg b/docs/assets/1.x/images/api/bagisto_prod_sku.jpg new file mode 100644 index 00000000..90d7eec8 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_sku.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_prod_url_key.jpg b/docs/assets/1.x/images/api/bagisto_prod_url_key.jpg new file mode 100644 index 00000000..2d978b02 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_prod_url_key.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_reviews.jpg b/docs/assets/1.x/images/api/bagisto_reviews.jpg new file mode 100644 index 00000000..b72f32cc Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_reviews.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_reviews_cust_id.jpg b/docs/assets/1.x/images/api/bagisto_reviews_cust_id.jpg new file mode 100644 index 00000000..603ccb07 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_reviews_cust_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_reviews_cust_no_page.jpg b/docs/assets/1.x/images/api/bagisto_reviews_cust_no_page.jpg new file mode 100644 index 00000000..66af604b Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_reviews_cust_no_page.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_reviews_cust_page.jpg b/docs/assets/1.x/images/api/bagisto_reviews_cust_page.jpg new file mode 100644 index 00000000..808d3e48 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_reviews_cust_page.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_reviews_id.jpg b/docs/assets/1.x/images/api/bagisto_reviews_id.jpg new file mode 100644 index 00000000..7c38ccbc Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_reviews_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_reviews_no_page.jpg b/docs/assets/1.x/images/api/bagisto_reviews_no_page.jpg new file mode 100644 index 00000000..15be166d Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_reviews_no_page.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_reviews_page.jpg b/docs/assets/1.x/images/api/bagisto_reviews_page.jpg new file mode 100644 index 00000000..abbbfcb2 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_reviews_page.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_reviews_prod_id.jpg b/docs/assets/1.x/images/api/bagisto_reviews_prod_id.jpg new file mode 100644 index 00000000..c68614da Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_reviews_prod_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_save_address.jpg b/docs/assets/1.x/images/api/bagisto_save_address.jpg new file mode 100644 index 00000000..f6842d04 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_save_address.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_save_order.jpg b/docs/assets/1.x/images/api/bagisto_save_order.jpg new file mode 100644 index 00000000..62e2099b Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_save_order.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_save_payment.jpg b/docs/assets/1.x/images/api/bagisto_save_payment.jpg new file mode 100644 index 00000000..a296fc10 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_save_payment.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_save_shipping.jpg b/docs/assets/1.x/images/api/bagisto_save_shipping.jpg new file mode 100644 index 00000000..c4fc5aa1 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_save_shipping.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_ship_order_id.jpg b/docs/assets/1.x/images/api/bagisto_ship_order_id.jpg new file mode 100644 index 00000000..028e675e Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_ship_order_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_shipment_id.jpg b/docs/assets/1.x/images/api/bagisto_shipment_id.jpg new file mode 100644 index 00000000..691089a7 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_shipment_id.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_shipments.jpg b/docs/assets/1.x/images/api/bagisto_shipments.jpg new file mode 100644 index 00000000..93c0b789 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_shipments.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_wishlist_add.jpg b/docs/assets/1.x/images/api/bagisto_wishlist_add.jpg new file mode 100644 index 00000000..f516bb81 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_wishlist_add.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_wishlist_cust.jpg b/docs/assets/1.x/images/api/bagisto_wishlist_cust.jpg new file mode 100644 index 00000000..fbd47ae3 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_wishlist_cust.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_wishlist_no_page.jpg b/docs/assets/1.x/images/api/bagisto_wishlist_no_page.jpg new file mode 100644 index 00000000..fd75cec5 Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_wishlist_no_page.jpg differ diff --git a/docs/assets/1.x/images/api/bagisto_wishlist_page.jpg b/docs/assets/1.x/images/api/bagisto_wishlist_page.jpg new file mode 100644 index 00000000..4c10d2af Binary files /dev/null and b/docs/assets/1.x/images/api/bagisto_wishlist_page.jpg differ diff --git a/docs/assets/1.x/images/api/demo_products.jpg b/docs/assets/1.x/images/api/demo_products.jpg new file mode 100644 index 00000000..b976b2cb Binary files /dev/null and b/docs/assets/1.x/images/api/demo_products.jpg differ diff --git a/docs/assets/1.x/images/package-development/admin-acl-output.png b/docs/assets/1.x/images/package-development/admin-acl-output.png new file mode 100644 index 00000000..ef254c2a Binary files /dev/null and b/docs/assets/1.x/images/package-development/admin-acl-output.png differ diff --git a/docs/assets/1.x/images/package-development/admin-custom-config-output.png b/docs/assets/1.x/images/package-development/admin-custom-config-output.png new file mode 100644 index 00000000..2dc5275a Binary files /dev/null and b/docs/assets/1.x/images/package-development/admin-custom-config-output.png differ diff --git a/docs/assets/1.x/images/package-development/admin-menu-output.png b/docs/assets/1.x/images/package-development/admin-menu-output.png new file mode 100644 index 00000000..4009c0f1 Binary files /dev/null and b/docs/assets/1.x/images/package-development/admin-menu-output.png differ diff --git a/docs/assets/1.x/images/package-development/hello-world-admin-translation-output.png b/docs/assets/1.x/images/package-development/hello-world-admin-translation-output.png new file mode 100644 index 00000000..fe02296b Binary files /dev/null and b/docs/assets/1.x/images/package-development/hello-world-admin-translation-output.png differ diff --git a/docs/assets/1.x/images/package-development/hello-world-package-output.png b/docs/assets/1.x/images/package-development/hello-world-package-output.png new file mode 100644 index 00000000..dd4a556e Binary files /dev/null and b/docs/assets/1.x/images/package-development/hello-world-package-output.png differ diff --git a/docs/assets/1.x/images/package-development/hello-world-shop-translation-output.png b/docs/assets/1.x/images/package-development/hello-world-shop-translation-output.png new file mode 100644 index 00000000..7f21be68 Binary files /dev/null and b/docs/assets/1.x/images/package-development/hello-world-shop-translation-output.png differ diff --git a/docs/assets/1.x/images/package-development/helloworld-admin-browser-output.png b/docs/assets/1.x/images/package-development/helloworld-admin-browser-output.png new file mode 100644 index 00000000..8d218fb7 Binary files /dev/null and b/docs/assets/1.x/images/package-development/helloworld-admin-browser-output.png differ diff --git a/docs/assets/1.x/images/package-development/helloworld-shop-browser-output.png b/docs/assets/1.x/images/package-development/helloworld-shop-browser-output.png new file mode 100644 index 00000000..65622e78 Binary files /dev/null and b/docs/assets/1.x/images/package-development/helloworld-shop-browser-output.png differ diff --git a/docs/assets/1.x/images/themes/mail-sample.png b/docs/assets/1.x/images/themes/mail-sample.png new file mode 100644 index 00000000..5bc4a05e Binary files /dev/null and b/docs/assets/1.x/images/themes/mail-sample.png differ diff --git a/docs/assets/1.x/images/user-guide/add-locale-bagisto.png b/docs/assets/1.x/images/user-guide/add-locale-bagisto.png new file mode 100644 index 00000000..2b2591d6 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/add-locale-bagisto.png differ diff --git a/docs/assets/1.x/images/user-guide/arrabic-attribute.png b/docs/assets/1.x/images/user-guide/arrabic-attribute.png new file mode 100644 index 00000000..b77cafb3 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/arrabic-attribute.png differ diff --git a/docs/assets/1.x/images/user-guide/catageory-in-arabic.png b/docs/assets/1.x/images/user-guide/catageory-in-arabic.png new file mode 100644 index 00000000..27b07a6a Binary files /dev/null and b/docs/assets/1.x/images/user-guide/catageory-in-arabic.png differ diff --git a/docs/assets/1.x/images/user-guide/channel-setting-in-bagisto.png b/docs/assets/1.x/images/user-guide/channel-setting-in-bagisto.png new file mode 100644 index 00000000..2c523770 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/channel-setting-in-bagisto.png differ diff --git a/docs/assets/1.x/images/user-guide/front-end-in-arabic.png b/docs/assets/1.x/images/user-guide/front-end-in-arabic.png new file mode 100644 index 00000000..407f7c77 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/front-end-in-arabic.png differ diff --git a/docs/assets/1.x/images/user-guide/front-end.png b/docs/assets/1.x/images/user-guide/front-end.png new file mode 100644 index 00000000..dde4d7e6 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/front-end.png differ diff --git a/docs/assets/1.x/images/user-guide/language-changes.png b/docs/assets/1.x/images/user-guide/language-changes.png new file mode 100644 index 00000000..f2958b8f Binary files /dev/null and b/docs/assets/1.x/images/user-guide/language-changes.png differ diff --git a/docs/assets/1.x/images/user-guide/locale-setup.png b/docs/assets/1.x/images/user-guide/locale-setup.png new file mode 100644 index 00000000..e5e75cb1 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/locale-setup.png differ diff --git a/docs/assets/1.x/images/user-guide/locale-trans.png b/docs/assets/1.x/images/user-guide/locale-trans.png new file mode 100644 index 00000000..9129fe8a Binary files /dev/null and b/docs/assets/1.x/images/user-guide/locale-trans.png differ diff --git a/docs/assets/1.x/images/user-guide/locale.png b/docs/assets/1.x/images/user-guide/locale.png new file mode 100644 index 00000000..0e4ecb10 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/locale.png differ diff --git a/docs/assets/1.x/images/user-guide/product-in-arabic (1).png b/docs/assets/1.x/images/user-guide/product-in-arabic (1).png new file mode 100644 index 00000000..4eb2c723 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/product-in-arabic (1).png differ diff --git a/docs/assets/1.x/images/user-guide/product-in-arabic.png b/docs/assets/1.x/images/user-guide/product-in-arabic.png new file mode 100644 index 00000000..4eb2c723 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/product-in-arabic.png differ diff --git a/docs/assets/1.x/images/user-guide/social/admin_social_auth.png b/docs/assets/1.x/images/user-guide/social/admin_social_auth.png new file mode 100644 index 00000000..56b5f81d Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/admin_social_auth.png differ diff --git a/docs/assets/1.x/images/user-guide/social/github-OAuth-step1.png b/docs/assets/1.x/images/user-guide/social/github-OAuth-step1.png new file mode 100644 index 00000000..c0798ae6 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/github-OAuth-step1.png differ diff --git a/docs/assets/1.x/images/user-guide/social/github-OAuth-step2.png b/docs/assets/1.x/images/user-guide/social/github-OAuth-step2.png new file mode 100644 index 00000000..5aab231f Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/github-OAuth-step2.png differ diff --git a/docs/assets/1.x/images/user-guide/social/github-OAuth-step3.png b/docs/assets/1.x/images/user-guide/social/github-OAuth-step3.png new file mode 100644 index 00000000..a6739e3c Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/github-OAuth-step3.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step1.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step1.png new file mode 100644 index 00000000..892d998e Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step1.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step10.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step10.png new file mode 100644 index 00000000..b2a85a27 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step10.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step2.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step2.png new file mode 100644 index 00000000..d54d81e7 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step2.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step3.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step3.png new file mode 100644 index 00000000..8b3c46ec Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step3.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step4.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step4.png new file mode 100644 index 00000000..0c5ad562 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step4.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step5.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step5.png new file mode 100644 index 00000000..3252e17a Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step5.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step6.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step6.png new file mode 100644 index 00000000..96db7464 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step6.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step7.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step7.png new file mode 100644 index 00000000..0fa1b04d Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step7.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step8.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step8.png new file mode 100644 index 00000000..13cb025d Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step8.png differ diff --git a/docs/assets/1.x/images/user-guide/social/google-OAuth-step9.png b/docs/assets/1.x/images/user-guide/social/google-OAuth-step9.png new file mode 100644 index 00000000..3f7dff8b Binary files /dev/null and b/docs/assets/1.x/images/user-guide/social/google-OAuth-step9.png differ diff --git a/docs/assets/1.x/images/user-guide/tax-rates/default-location-calculation-config.png b/docs/assets/1.x/images/user-guide/tax-rates/default-location-calculation-config.png new file mode 100644 index 00000000..accf9f27 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/tax-rates/default-location-calculation-config.png differ diff --git a/docs/assets/1.x/images/user-guide/tax-rates/pricing-config.png b/docs/assets/1.x/images/user-guide/tax-rates/pricing-config.png new file mode 100644 index 00000000..b5a9d304 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/tax-rates/pricing-config.png differ diff --git a/docs/assets/1.x/images/user-guide/translation.png b/docs/assets/1.x/images/user-guide/translation.png new file mode 100644 index 00000000..41ac6365 Binary files /dev/null and b/docs/assets/1.x/images/user-guide/translation.png differ diff --git a/docs/assets/2.x/images/advanced-topics/limiting-error-messages.png b/docs/assets/2.x/images/advanced-topics/limiting-error-messages.png new file mode 100644 index 00000000..c2b9485e Binary files /dev/null and b/docs/assets/2.x/images/advanced-topics/limiting-error-messages.png differ diff --git a/docs/assets/2.x/images/advanced-topics/mail-sample.png b/docs/assets/2.x/images/advanced-topics/mail-sample.png new file mode 100644 index 00000000..5bc4a05e Binary files /dev/null and b/docs/assets/2.x/images/advanced-topics/mail-sample.png differ diff --git a/docs/assets/2.x/images/advanced-topics/product-index.png b/docs/assets/2.x/images/advanced-topics/product-index.png new file mode 100644 index 00000000..7b889997 Binary files /dev/null and b/docs/assets/2.x/images/advanced-topics/product-index.png differ diff --git a/docs/assets/2.x/images/bundle-product/bundle.png b/docs/assets/2.x/images/bundle-product/bundle.png new file mode 100644 index 00000000..a2a5cb22 Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/bundle.png differ diff --git a/docs/assets/2.x/images/bundle-product/bundleOptions.png b/docs/assets/2.x/images/bundle-product/bundleOptions.png new file mode 100644 index 00000000..a54b09ea Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/bundleOptions.png differ diff --git a/docs/assets/2.x/images/bundle-product/description.png b/docs/assets/2.x/images/bundle-product/description.png new file mode 100644 index 00000000..5a6922f1 Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/description.png differ diff --git a/docs/assets/2.x/images/bundle-product/editProduct.png b/docs/assets/2.x/images/bundle-product/editProduct.png new file mode 100644 index 00000000..cf973cc3 Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/editProduct.png differ diff --git a/docs/assets/2.x/images/bundle-product/image.png b/docs/assets/2.x/images/bundle-product/image.png new file mode 100644 index 00000000..3b42f767 Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/image.png differ diff --git a/docs/assets/2.x/images/bundle-product/metaDescription.png b/docs/assets/2.x/images/bundle-product/metaDescription.png new file mode 100644 index 00000000..29c337a6 Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/metaDescription.png differ diff --git a/docs/assets/2.x/images/bundle-product/options.png b/docs/assets/2.x/images/bundle-product/options.png new file mode 100644 index 00000000..b07f7c02 Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/options.png differ diff --git a/docs/assets/2.x/images/bundle-product/output.png b/docs/assets/2.x/images/bundle-product/output.png new file mode 100644 index 00000000..aaf64178 Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/output.png differ diff --git a/docs/assets/2.x/images/bundle-product/toggleButtons.png b/docs/assets/2.x/images/bundle-product/toggleButtons.png new file mode 100644 index 00000000..7740ea31 Binary files /dev/null and b/docs/assets/2.x/images/bundle-product/toggleButtons.png differ diff --git a/docs/assets/2.x/images/configurable-product/configurable.png b/docs/assets/2.x/images/configurable-product/configurable.png new file mode 100644 index 00000000..8f69f0e1 Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/configurable.png differ diff --git a/docs/assets/2.x/images/configurable-product/configurableAttributes.png b/docs/assets/2.x/images/configurable-product/configurableAttributes.png new file mode 100644 index 00000000..1e1b7fb9 Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/configurableAttributes.png differ diff --git a/docs/assets/2.x/images/configurable-product/descriptions.png b/docs/assets/2.x/images/configurable-product/descriptions.png new file mode 100644 index 00000000..75d85a1b Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/descriptions.png differ diff --git a/docs/assets/2.x/images/configurable-product/editProducts.png b/docs/assets/2.x/images/configurable-product/editProducts.png new file mode 100644 index 00000000..41bf02cd Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/editProducts.png differ diff --git a/docs/assets/2.x/images/configurable-product/image.png b/docs/assets/2.x/images/configurable-product/image.png new file mode 100644 index 00000000..30a69ee1 Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/image.png differ diff --git a/docs/assets/2.x/images/configurable-product/metaDescriptions.png b/docs/assets/2.x/images/configurable-product/metaDescriptions.png new file mode 100644 index 00000000..3951ed81 Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/metaDescriptions.png differ diff --git a/docs/assets/2.x/images/configurable-product/output.png b/docs/assets/2.x/images/configurable-product/output.png new file mode 100644 index 00000000..2038b8a5 Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/output.png differ diff --git a/docs/assets/2.x/images/configurable-product/toggleButtons.png b/docs/assets/2.x/images/configurable-product/toggleButtons.png new file mode 100644 index 00000000..7740ea31 Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/toggleButtons.png differ diff --git a/docs/assets/2.x/images/configurable-product/variations.png b/docs/assets/2.x/images/configurable-product/variations.png new file mode 100644 index 00000000..d2ad9c44 Binary files /dev/null and b/docs/assets/2.x/images/configurable-product/variations.png differ diff --git a/docs/assets/2.x/images/grouped-product/editProduct.png b/docs/assets/2.x/images/grouped-product/editProduct.png new file mode 100644 index 00000000..e4f3a205 Binary files /dev/null and b/docs/assets/2.x/images/grouped-product/editProduct.png differ diff --git a/docs/assets/2.x/images/grouped-product/grouped.png b/docs/assets/2.x/images/grouped-product/grouped.png new file mode 100644 index 00000000..5c85f76c Binary files /dev/null and b/docs/assets/2.x/images/grouped-product/grouped.png differ diff --git a/docs/assets/2.x/images/package-development/admin-acl-output.png b/docs/assets/2.x/images/package-development/admin-acl-output.png new file mode 100644 index 00000000..bbe45727 Binary files /dev/null and b/docs/assets/2.x/images/package-development/admin-acl-output.png differ diff --git a/docs/assets/2.x/images/package-development/admin-menu-output.png b/docs/assets/2.x/images/package-development/admin-menu-output.png new file mode 100644 index 00000000..1583f2ac Binary files /dev/null and b/docs/assets/2.x/images/package-development/admin-menu-output.png differ diff --git a/docs/assets/2.x/images/package-development/blog-admin-lang-output.png b/docs/assets/2.x/images/package-development/blog-admin-lang-output.png new file mode 100644 index 00000000..5547ac84 Binary files /dev/null and b/docs/assets/2.x/images/package-development/blog-admin-lang-output.png differ diff --git a/docs/assets/2.x/images/package-development/blog-admin-output.png b/docs/assets/2.x/images/package-development/blog-admin-output.png new file mode 100644 index 00000000..8b1cec70 Binary files /dev/null and b/docs/assets/2.x/images/package-development/blog-admin-output.png differ diff --git a/docs/assets/2.x/images/package-development/blog-package-output.png b/docs/assets/2.x/images/package-development/blog-package-output.png new file mode 100644 index 00000000..1583f2ac Binary files /dev/null and b/docs/assets/2.x/images/package-development/blog-package-output.png differ diff --git a/docs/assets/2.x/images/package-development/blog-shop-lang-output.png b/docs/assets/2.x/images/package-development/blog-shop-lang-output.png new file mode 100644 index 00000000..848d3dc7 Binary files /dev/null and b/docs/assets/2.x/images/package-development/blog-shop-lang-output.png differ diff --git a/docs/assets/2.x/images/package-development/blog-shop-output.png b/docs/assets/2.x/images/package-development/blog-shop-output.png new file mode 100644 index 00000000..cef8f7ab Binary files /dev/null and b/docs/assets/2.x/images/package-development/blog-shop-output.png differ diff --git a/docs/assets/2.x/images/package-development/custom-config-output-1.png b/docs/assets/2.x/images/package-development/custom-config-output-1.png new file mode 100644 index 00000000..27013ede Binary files /dev/null and b/docs/assets/2.x/images/package-development/custom-config-output-1.png differ diff --git a/docs/assets/2.x/images/package-development/custom-config-output-2.png b/docs/assets/2.x/images/package-development/custom-config-output-2.png new file mode 100644 index 00000000..32be0654 Binary files /dev/null and b/docs/assets/2.x/images/package-development/custom-config-output-2.png differ diff --git a/docs/assets/2.x/images/simple-product/description.png b/docs/assets/2.x/images/simple-product/description.png new file mode 100644 index 00000000..856ff9bc Binary files /dev/null and b/docs/assets/2.x/images/simple-product/description.png differ diff --git a/docs/assets/2.x/images/simple-product/editProduct.png b/docs/assets/2.x/images/simple-product/editProduct.png new file mode 100644 index 00000000..8e9c6e01 Binary files /dev/null and b/docs/assets/2.x/images/simple-product/editProduct.png differ diff --git a/docs/assets/2.x/images/simple-product/image.png b/docs/assets/2.x/images/simple-product/image.png new file mode 100644 index 00000000..e9500c54 Binary files /dev/null and b/docs/assets/2.x/images/simple-product/image.png differ diff --git a/docs/assets/2.x/images/simple-product/inventories.png b/docs/assets/2.x/images/simple-product/inventories.png new file mode 100644 index 00000000..284886d4 Binary files /dev/null and b/docs/assets/2.x/images/simple-product/inventories.png differ diff --git a/docs/assets/2.x/images/simple-product/metaDescription.png b/docs/assets/2.x/images/simple-product/metaDescription.png new file mode 100644 index 00000000..370beedd Binary files /dev/null and b/docs/assets/2.x/images/simple-product/metaDescription.png differ diff --git a/docs/assets/2.x/images/simple-product/price.png b/docs/assets/2.x/images/simple-product/price.png new file mode 100644 index 00000000..7fb241ee Binary files /dev/null and b/docs/assets/2.x/images/simple-product/price.png differ diff --git a/docs/assets/2.x/images/simple-product/product.png b/docs/assets/2.x/images/simple-product/product.png new file mode 100644 index 00000000..c9ffc720 Binary files /dev/null and b/docs/assets/2.x/images/simple-product/product.png differ diff --git a/docs/assets/2.x/images/simple-product/shipping.png b/docs/assets/2.x/images/simple-product/shipping.png new file mode 100644 index 00000000..45458036 Binary files /dev/null and b/docs/assets/2.x/images/simple-product/shipping.png differ diff --git a/docs/assets/2.x/images/simple-product/simple.png b/docs/assets/2.x/images/simple-product/simple.png new file mode 100644 index 00000000..91ef39df Binary files /dev/null and b/docs/assets/2.x/images/simple-product/simple.png differ diff --git a/docs/assets/2.x/images/simple-product/toggleButtons.png b/docs/assets/2.x/images/simple-product/toggleButtons.png new file mode 100644 index 00000000..7740ea31 Binary files /dev/null and b/docs/assets/2.x/images/simple-product/toggleButtons.png differ diff --git a/docs/assets/2.x/images/virtual-product/description.png b/docs/assets/2.x/images/virtual-product/description.png new file mode 100644 index 00000000..59227aa7 Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/description.png differ diff --git a/docs/assets/2.x/images/virtual-product/editProduct.png b/docs/assets/2.x/images/virtual-product/editProduct.png new file mode 100644 index 00000000..39fc2d71 Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/editProduct.png differ diff --git a/docs/assets/2.x/images/virtual-product/image.png b/docs/assets/2.x/images/virtual-product/image.png new file mode 100644 index 00000000..edca5e01 Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/image.png differ diff --git a/docs/assets/2.x/images/virtual-product/inventories.png b/docs/assets/2.x/images/virtual-product/inventories.png new file mode 100644 index 00000000..284886d4 Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/inventories.png differ diff --git a/docs/assets/2.x/images/virtual-product/metaDescription.png b/docs/assets/2.x/images/virtual-product/metaDescription.png new file mode 100644 index 00000000..bbaedc50 Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/metaDescription.png differ diff --git a/docs/assets/2.x/images/virtual-product/output.png b/docs/assets/2.x/images/virtual-product/output.png new file mode 100644 index 00000000..91c0ea3e Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/output.png differ diff --git a/docs/assets/2.x/images/virtual-product/price.png b/docs/assets/2.x/images/virtual-product/price.png new file mode 100644 index 00000000..9eb133a0 Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/price.png differ diff --git a/docs/assets/2.x/images/virtual-product/toggleButtons.png b/docs/assets/2.x/images/virtual-product/toggleButtons.png new file mode 100644 index 00000000..7740ea31 Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/toggleButtons.png differ diff --git a/docs/assets/2.x/images/virtual-product/virtual.png b/docs/assets/2.x/images/virtual-product/virtual.png new file mode 100644 index 00000000..1d3e63ba Binary files /dev/null and b/docs/assets/2.x/images/virtual-product/virtual.png differ diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 00000000..6dbdd50b --- /dev/null +++ b/package-lock.json @@ -0,0 +1,16026 @@ +{ + "name": "bagisto-docs", + "version": "1.0.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "bagisto-docs", + "version": "1.0.0", + "license": "MIT", + "dependencies": { + "vuepress-bar": "^0.4.4" + }, + "devDependencies": { + "@vuepress/plugin-back-to-top": "^1.9.9", + "@vuepress/plugin-pwa": "^1.9.9", + "vuepress": "^1.9.9", + "vuepress-plugin-auto-sidebar": "^2.3.2", + "vuepress-plugin-copy-code": "0.0.1" + } + }, + "node_modules/@ampproject/remapping": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", + "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", + "dev": true, + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.0", + "@jridgewell/trace-mapping": "^0.3.9" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.23.5", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", + "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==", + "dev": true, + "dependencies": { + "@babel/highlight": "^7.23.4", + "chalk": "^2.4.2" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/compat-data": { + "version": "7.23.5", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz", + "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/core": { + "version": "7.23.7", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.23.7.tgz", + "integrity": "sha512-+UpDgowcmqe36d4NwqvKsyPMlOLNGMsfMmQ5WGCu+siCe3t3dfe9njrzGfdN4qq+bcNUt0+Vw6haRxBOycs4dw==", + "dev": true, + "dependencies": { + "@ampproject/remapping": "^2.2.0", + "@babel/code-frame": "^7.23.5", + "@babel/generator": "^7.23.6", + "@babel/helper-compilation-targets": "^7.23.6", + "@babel/helper-module-transforms": "^7.23.3", + "@babel/helpers": "^7.23.7", + "@babel/parser": "^7.23.6", + "@babel/template": "^7.22.15", + "@babel/traverse": "^7.23.7", + "@babel/types": "^7.23.6", + "convert-source-map": "^2.0.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.2", + "json5": "^2.2.3", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/babel" + } + }, + "node_modules/@babel/core/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@babel/core/node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/@babel/generator": { + "version": "7.23.6", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.6.tgz", + "integrity": "sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.23.6", + "@jridgewell/gen-mapping": "^0.3.2", + "@jridgewell/trace-mapping": "^0.3.17", + "jsesc": "^2.5.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-annotate-as-pure": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.22.5.tgz", + "integrity": "sha512-LvBTxu8bQSQkcyKOU+a1btnNFQ1dMAd0R6PyW3arXes06F6QLWLIrd681bxRPIXlrMGR3XYnW9JyML7dP3qgxg==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.22.15", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.22.15.tgz", + "integrity": "sha512-QkBXwGgaoC2GtGZRoma6kv7Szfv06khvhFav67ZExau2RaXzy8MpHSMO2PNoP2XtmQphJQRHFfg77Bq731Yizw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.15" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-compilation-targets": { + "version": "7.23.6", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.23.6.tgz", + "integrity": "sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.23.5", + "@babel/helper-validator-option": "^7.23.5", + "browserslist": "^4.22.2", + "lru-cache": "^5.1.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-create-class-features-plugin": { + "version": "7.23.7", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.23.7.tgz", + "integrity": "sha512-xCoqR/8+BoNnXOY7RVSgv6X+o7pmT5q1d+gGcRlXYkI+9B31glE4jeejhKVpA04O1AtzOt7OSQ6VYKP5FcRl9g==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.22.5", + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-function-name": "^7.23.0", + "@babel/helper-member-expression-to-functions": "^7.23.0", + "@babel/helper-optimise-call-expression": "^7.22.5", + "@babel/helper-replace-supers": "^7.22.20", + "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5", + "@babel/helper-split-export-declaration": "^7.22.6", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-create-regexp-features-plugin": { + "version": "7.22.15", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.22.15.tgz", + "integrity": "sha512-29FkPLFjn4TPEa3RE7GpW+qbE8tlsu3jntNYNfcGsc49LphF1PQIiD+vMZ1z1xVOKt+93khA9tc2JBs3kBjA7w==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.22.5", + "regexpu-core": "^5.3.1", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-define-polyfill-provider": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.4.4.tgz", + "integrity": "sha512-QcJMILQCu2jm5TFPGA3lCpJJTeEP+mqeXooG/NZbg/h5FTFi6V0+99ahlRsW8/kRLyb24LZVCCiclDedhLKcBA==", + "dev": true, + "dependencies": { + "@babel/helper-compilation-targets": "^7.22.6", + "@babel/helper-plugin-utils": "^7.22.5", + "debug": "^4.1.1", + "lodash.debounce": "^4.0.8", + "resolve": "^1.14.2" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/@babel/helper-define-polyfill-provider/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@babel/helper-define-polyfill-provider/node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/@babel/helper-environment-visitor": { + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.20.tgz", + "integrity": "sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-function-name": { + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.23.0.tgz", + "integrity": "sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==", + "dev": true, + "dependencies": { + "@babel/template": "^7.22.15", + "@babel/types": "^7.23.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-hoist-variables": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", + "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-member-expression-to-functions": { + "version": "7.23.0", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.23.0.tgz", + "integrity": "sha512-6gfrPwh7OuT6gZyJZvd6WbTfrqAo7vm4xCzAXOusKqq/vWdKXphTpj5klHKNmRUU6/QRGlBsyU9mAIPaWHlqJA==", + "dev": true, + "dependencies": { + "@babel/types": "^7.23.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-imports": { + "version": "7.22.15", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz", + "integrity": "sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.15" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-module-transforms": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.23.3.tgz", + "integrity": "sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-module-imports": "^7.22.15", + "@babel/helper-simple-access": "^7.22.5", + "@babel/helper-split-export-declaration": "^7.22.6", + "@babel/helper-validator-identifier": "^7.22.20" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-optimise-call-expression": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.22.5.tgz", + "integrity": "sha512-HBwaojN0xFRx4yIvpwGqxiV2tUfl7401jlok564NgB9EHS1y6QT17FmKWm4ztqjeVdXLuC4fSvHc5ePpQjoTbw==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-plugin-utils": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", + "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-remap-async-to-generator": { + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.22.20.tgz", + "integrity": "sha512-pBGyV4uBqOns+0UvhsTO8qgl8hO89PmiDYv+/COyp1aeMcmfrfruz+/nCMFiYyFF/Knn0yfrC85ZzNFjembFTw==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.22.5", + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-wrap-function": "^7.22.20" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-replace-supers": { + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.22.20.tgz", + "integrity": "sha512-qsW0In3dbwQUbK8kejJ4R7IHVGwHJlV6lpG6UA7a9hSa2YEiAib+N1T2kr6PEeUT+Fl7najmSOS6SmAwCHK6Tw==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-member-expression-to-functions": "^7.22.15", + "@babel/helper-optimise-call-expression": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/helper-simple-access": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", + "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-skip-transparent-expression-wrappers": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.22.5.tgz", + "integrity": "sha512-tK14r66JZKiC43p8Ki33yLBVJKlQDFoA8GYN67lWCDCqoL6EMMSuM9b+Iff2jHaM/RRFYl7K+iiru7hbRqNx8Q==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-split-export-declaration": { + "version": "7.22.6", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", + "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", + "dev": true, + "dependencies": { + "@babel/types": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-string-parser": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz", + "integrity": "sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.20.tgz", + "integrity": "sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-option": { + "version": "7.23.5", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.23.5.tgz", + "integrity": "sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-wrap-function": { + "version": "7.22.20", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.22.20.tgz", + "integrity": "sha512-pms/UwkOpnQe/PDAEdV/d7dVCoBbB+R4FvYoHGZz+4VPcg7RtYy2KP7S2lbuWM6FCSgob5wshfGESbC/hzNXZw==", + "dev": true, + "dependencies": { + "@babel/helper-function-name": "^7.22.5", + "@babel/template": "^7.22.15", + "@babel/types": "^7.22.19" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helpers": { + "version": "7.23.8", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.23.8.tgz", + "integrity": "sha512-KDqYz4PiOWvDFrdHLPhKtCThtIcKVy6avWD2oG4GEvyQ+XDZwHD4YQd+H2vNMnq2rkdxsDkU82T+Vk8U/WXHRQ==", + "dev": true, + "dependencies": { + "@babel/template": "^7.22.15", + "@babel/traverse": "^7.23.7", + "@babel/types": "^7.23.6" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", + "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", + "dev": true, + "dependencies": { + "@babel/helper-validator-identifier": "^7.22.20", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/parser": { + "version": "7.23.6", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.6.tgz", + "integrity": "sha512-Z2uID7YJ7oNvAI20O9X0bblw7Qqs8Q2hFy0R9tAfnfLkp5MW0UH9eUvnDSnFwKZ0AvgS1ucqR4KzvVHgnke1VQ==", + "dev": true, + "bin": { + "parser": "bin/babel-parser.js" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.23.3.tgz", + "integrity": "sha512-iRkKcCqb7iGnq9+3G6rZ+Ciz5VywC4XNRHe57lKM+jOeYAoR0lVqdeeDRfh0tQcTfw/+vBhHn926FmQhLtlFLQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.23.3.tgz", + "integrity": "sha512-WwlxbfMNdVEpQjZmK5mhm7oSwD3dS6eU+Iwsi4Knl9wAletWem7kaRsGOG+8UEbRyqxY4SS5zvtfXwX+jMxUwQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5", + "@babel/plugin-transform-optional-chaining": "^7.23.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.13.0" + } + }, + "node_modules/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": { + "version": "7.23.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly/-/plugin-bugfix-v8-static-class-fields-redefine-readonly-7.23.7.tgz", + "integrity": "sha512-LlRT7HgaifEpQA1ZgLVOIJZZFVPWN5iReq/7/JixwBtwcoeVGDBD53ZV28rrsLYOZs1Y/EHhA8N/Z6aazHR8cw==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-proposal-class-properties": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz", + "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==", + "deprecated": "This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-class-properties instead.", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-decorators": { + "version": "7.23.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-decorators/-/plugin-proposal-decorators-7.23.7.tgz", + "integrity": "sha512-b1s5JyeMvqj7d9m9KhJNHKc18gEJiSyVzVX3bwbiPalQBQpuvfPh6lA9F7Kk/dWH0TIiXRpB9yicwijY6buPng==", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.23.7", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-decorators": "^7.23.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-proposal-private-property-in-object": { + "version": "7.21.0-placeholder-for-preset-env.2", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.21.0-placeholder-for-preset-env.2.tgz", + "integrity": "sha512-SOSkfJDddaM7mak6cPEpswyTRnuRltl429hMraQEglW+OkovnCzsiszTmsrlY//qLFjCpQDFRvjdm2wA5pPm9w==", + "dev": true, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-class-properties": { + "version": "7.12.13", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", + "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.12.13" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-class-static-block": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", + "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-decorators": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-decorators/-/plugin-syntax-decorators-7.23.3.tgz", + "integrity": "sha512-cf7Niq4/+/juY67E0PbgH0TDhLQ5J7zS8C/Q5FFx+DWyrRa9sUQdTXkjqKu8zGvuqr7vw1muKiukseihU+PJDA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-dynamic-import": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", + "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-export-namespace-from": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", + "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.3" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-assertions": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.23.3.tgz", + "integrity": "sha512-lPgDSU+SJLK3xmFDTV2ZRQAiM7UuUjGidwBywFavObCiZc1BeAAcMtHJKUya92hPHO+at63JJPLygilZard8jw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-attributes": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.23.3.tgz", + "integrity": "sha512-pawnE0P9g10xgoP7yKr6CK63K2FMsTE+FZidZO/1PwRdzmAPVs+HS1mAURUsgaoxammTJvULUdIkEK0gOcU2tA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-import-meta": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", + "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-jsx": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.23.3.tgz", + "integrity": "sha512-EB2MELswq55OHUoRZLGg/zC7QWUKfNLpE57m/S2yr1uEneIgsTgrSzXP3NXEsMkVn76OlaVVnzN+ugObuYGwhg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-logical-assignment-operators": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", + "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-numeric-separator": { + "version": "7.10.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", + "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.10.4" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.8.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-private-property-in-object": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", + "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-top-level-await": { + "version": "7.14.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", + "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-syntax-unicode-sets-regex": { + "version": "7.18.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-unicode-sets-regex/-/plugin-syntax-unicode-sets-regex-7.18.6.tgz", + "integrity": "sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.18.6", + "@babel/helper-plugin-utils": "^7.18.6" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-transform-arrow-functions": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.23.3.tgz", + "integrity": "sha512-NzQcQrzaQPkaEwoTm4Mhyl8jI1huEL/WWIEvudjTCMJ9aBZNpsJbMASx7EQECtQQPS/DcnFpo0FIh3LvEO9cxQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-async-generator-functions": { + "version": "7.23.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.23.7.tgz", + "integrity": "sha512-PdxEpL71bJp1byMG0va5gwQcXHxuEYC/BgI/e88mGTtohbZN28O5Yit0Plkkm/dBzCF/BxmbNcses1RH1T+urA==", + "dev": true, + "dependencies": { + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-remap-async-to-generator": "^7.22.20", + "@babel/plugin-syntax-async-generators": "^7.8.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-async-to-generator": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.23.3.tgz", + "integrity": "sha512-A7LFsKi4U4fomjqXJlZg/u0ft/n8/7n7lpffUP/ZULx/DtV9SGlNKZolHH6PE8Xl1ngCc0M11OaeZptXVkfKSw==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-remap-async-to-generator": "^7.22.20" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-block-scoped-functions": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.23.3.tgz", + "integrity": "sha512-vI+0sIaPIO6CNuM9Kk5VmXcMVRiOpDh7w2zZt9GXzmE/9KD70CUEVhvPR/etAeNK/FAEkhxQtXOzVF3EuRL41A==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-block-scoping": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.23.4.tgz", + "integrity": "sha512-0QqbP6B6HOh7/8iNR4CQU2Th/bbRtBp4KS9vcaZd1fZ0wSh5Fyssg0UCIHwxh+ka+pNDREbVLQnHCMHKZfPwfw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-class-properties": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-properties/-/plugin-transform-class-properties-7.23.3.tgz", + "integrity": "sha512-uM+AN8yCIjDPccsKGlw271xjJtGii+xQIF/uMPS8H15L12jZTsLfF4o5vNO7d/oUguOyfdikHGc/yi9ge4SGIg==", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-class-static-block": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.23.4.tgz", + "integrity": "sha512-nsWu/1M+ggti1SOALj3hfx5FXzAY06fwPJsUZD4/A5e1bWi46VUIWtD+kOX6/IdhXGsXBWllLFDSnqSCdUNydQ==", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-class-static-block": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.12.0" + } + }, + "node_modules/@babel/plugin-transform-classes": { + "version": "7.23.8", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.23.8.tgz", + "integrity": "sha512-yAYslGsY1bX6Knmg46RjiCiNSwJKv2IUC8qOdYKqMMr0491SXFhcHqOdRDeCRohOOIzwN/90C6mQ9qAKgrP7dg==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.22.5", + "@babel/helper-compilation-targets": "^7.23.6", + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-function-name": "^7.23.0", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-replace-supers": "^7.22.20", + "@babel/helper-split-export-declaration": "^7.22.6", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-computed-properties": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.23.3.tgz", + "integrity": "sha512-dTj83UVTLw/+nbiHqQSFdwO9CbTtwq1DsDqm3CUEtDrZNET5rT5E6bIdTlOftDTDLMYxvxHNEYO4B9SLl8SLZw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/template": "^7.22.15" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-destructuring": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.23.3.tgz", + "integrity": "sha512-n225npDqjDIr967cMScVKHXJs7rout1q+tt50inyBCPkyZ8KxeI6d+GIbSBTT/w/9WdlWDOej3V9HE5Lgk57gw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-dotall-regex": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.23.3.tgz", + "integrity": "sha512-vgnFYDHAKzFaTVp+mneDsIEbnJ2Np/9ng9iviHw3P/KVcgONxpNULEW/51Z/BaFojG2GI2GwwXck5uV1+1NOYQ==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-duplicate-keys": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.23.3.tgz", + "integrity": "sha512-RrqQ+BQmU3Oyav3J+7/myfvRCq7Tbz+kKLLshUmMwNlDHExbGL7ARhajvoBJEvc+fCguPPu887N+3RRXBVKZUA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-dynamic-import": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.23.4.tgz", + "integrity": "sha512-V6jIbLhdJK86MaLh4Jpghi8ho5fGzt3imHOBu/x0jlBaPYqDoWz4RDXjmMOfnh+JWNaQleEAByZLV0QzBT4YQQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-exponentiation-operator": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.23.3.tgz", + "integrity": "sha512-5fhCsl1odX96u7ILKHBj4/Y8vipoqwsJMh4csSA8qFfxrZDEA4Ssku2DyNvMJSmZNOEBT750LfFPbtrnTP90BQ==", + "dev": true, + "dependencies": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-export-namespace-from": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.23.4.tgz", + "integrity": "sha512-GzuSBcKkx62dGzZI1WVgTWvkkz84FZO5TC5T8dl/Tht/rAla6Dg/Mz9Yhypg+ezVACf/rgDuQt3kbWEv7LdUDQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-for-of": { + "version": "7.23.6", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.23.6.tgz", + "integrity": "sha512-aYH4ytZ0qSuBbpfhuofbg/e96oQ7U2w1Aw/UQmKT+1l39uEhUPoFS3fHevDc1G0OvewyDudfMKY1OulczHzWIw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-function-name": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.23.3.tgz", + "integrity": "sha512-I1QXp1LxIvt8yLaib49dRW5Okt7Q4oaxao6tFVKS/anCdEOMtYwWVKoiOA1p34GOWIZjUK0E+zCp7+l1pfQyiw==", + "dev": true, + "dependencies": { + "@babel/helper-compilation-targets": "^7.22.15", + "@babel/helper-function-name": "^7.23.0", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-json-strings": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.23.4.tgz", + "integrity": "sha512-81nTOqM1dMwZ/aRXQ59zVubN9wHGqk6UtqRK+/q+ciXmRy8fSolhGVvG09HHRGo4l6fr/c4ZhXUQH0uFW7PZbg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-json-strings": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-literals": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.23.3.tgz", + "integrity": "sha512-wZ0PIXRxnwZvl9AYpqNUxpZ5BiTGrYt7kueGQ+N5FiQ7RCOD4cm8iShd6S6ggfVIWaJf2EMk8eRzAh52RfP4rQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-logical-assignment-operators": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.23.4.tgz", + "integrity": "sha512-Mc/ALf1rmZTP4JKKEhUwiORU+vcfarFVLfcFiolKUo6sewoxSEgl36ak5t+4WamRsNr6nzjZXQjM35WsU+9vbg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-member-expression-literals": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.23.3.tgz", + "integrity": "sha512-sC3LdDBDi5x96LA+Ytekz2ZPk8i/Ck+DEuDbRAll5rknJ5XRTSaPKEYwomLcs1AA8wg9b3KjIQRsnApj+q51Ag==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-amd": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.23.3.tgz", + "integrity": "sha512-vJYQGxeKM4t8hYCKVBlZX/gtIY2I7mRGFNcm85sgXGMTBcoV3QdVtdpbcWEbzbfUIUZKwvgFT82mRvaQIebZzw==", + "dev": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.23.3", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-commonjs": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.23.3.tgz", + "integrity": "sha512-aVS0F65LKsdNOtcz6FRCpE4OgsP2OFnW46qNxNIX9h3wuzaNcSQsJysuMwqSibC98HPrf2vCgtxKNwS0DAlgcA==", + "dev": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.23.3", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-simple-access": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-systemjs": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.23.3.tgz", + "integrity": "sha512-ZxyKGTkF9xT9YJuKQRo19ewf3pXpopuYQd8cDXqNzc3mUNbOME0RKMoZxviQk74hwzfQsEe66dE92MaZbdHKNQ==", + "dev": true, + "dependencies": { + "@babel/helper-hoist-variables": "^7.22.5", + "@babel/helper-module-transforms": "^7.23.3", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-validator-identifier": "^7.22.20" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-modules-umd": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.23.3.tgz", + "integrity": "sha512-zHsy9iXX2nIsCBFPud3jKn1IRPWg3Ing1qOZgeKV39m1ZgIdpJqvlWVeiHBZC6ITRG0MfskhYe9cLgntfSFPIg==", + "dev": true, + "dependencies": { + "@babel/helper-module-transforms": "^7.23.3", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.22.5", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.22.5.tgz", + "integrity": "sha512-YgLLKmS3aUBhHaxp5hi1WJTgOUb/NCuDHzGT9z9WTt3YG+CPRhJs6nprbStx6DnWM4dh6gt7SU3sZodbZ08adQ==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.22.5", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/plugin-transform-new-target": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.23.3.tgz", + "integrity": "sha512-YJ3xKqtJMAT5/TIZnpAR3I+K+WaDowYbN3xyxI8zxx/Gsypwf9B9h0VB+1Nh6ACAAPRS5NSRje0uVv5i79HYGQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-nullish-coalescing-operator": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.23.4.tgz", + "integrity": "sha512-jHE9EVVqHKAQx+VePv5LLGHjmHSJR76vawFPTdlxR/LVJPfOEGxREQwQfjuZEOPTwG92X3LINSh3M40Rv4zpVA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-numeric-separator": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.23.4.tgz", + "integrity": "sha512-mps6auzgwjRrwKEZA05cOwuDc9FAzoyFS4ZsG/8F43bTLf/TgkJg7QXOrPO1JO599iA3qgK9MXdMGOEC8O1h6Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-numeric-separator": "^7.10.4" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-object-rest-spread": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.23.4.tgz", + "integrity": "sha512-9x9K1YyeQVw0iOXJlIzwm8ltobIIv7j2iLyP2jIhEbqPRQ7ScNgwQufU2I0Gq11VjyG4gI4yMXt2VFags+1N3g==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.23.3", + "@babel/helper-compilation-targets": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-transform-parameters": "^7.23.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-object-super": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.23.3.tgz", + "integrity": "sha512-BwQ8q0x2JG+3lxCVFohg+KbQM7plfpBwThdW9A6TMtWwLsbDA01Ek2Zb/AgDN39BiZsExm4qrXxjk+P1/fzGrA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-replace-supers": "^7.22.20" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-optional-catch-binding": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.23.4.tgz", + "integrity": "sha512-XIq8t0rJPHf6Wvmbn9nFxU6ao4c7WhghTR5WyV8SrJfUFzyxhCm4nhC+iAp3HFhbAKLfYpgzhJ6t4XCtVwqO5A==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-optional-chaining": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.23.4.tgz", + "integrity": "sha512-ZU8y5zWOfjM5vZ+asjgAPwDaBjJzgufjES89Rs4Lpq63O300R/kOz30WCLo6BxxX6QVEilwSlpClnG5cZaikTA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5", + "@babel/plugin-syntax-optional-chaining": "^7.8.3" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-parameters": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.23.3.tgz", + "integrity": "sha512-09lMt6UsUb3/34BbECKVbVwrT9bO6lILWln237z7sLaWnMsTi7Yc9fhX5DLpkJzAGfaReXI22wP41SZmnAA3Vw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-private-methods": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-methods/-/plugin-transform-private-methods-7.23.3.tgz", + "integrity": "sha512-UzqRcRtWsDMTLrRWFvUBDwmw06tCQH9Rl1uAjfh6ijMSmGYQ+fpdB+cnqRC8EMh5tuuxSv0/TejGL+7vyj+50g==", + "dev": true, + "dependencies": { + "@babel/helper-create-class-features-plugin": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-private-property-in-object": { + "version": "7.23.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.23.4.tgz", + "integrity": "sha512-9G3K1YqTq3F4Vt88Djx1UZ79PDyj+yKRnUy7cZGSMe+a7jkwD259uKKuUzQlPkGam7R+8RJwh5z4xO27fA1o2A==", + "dev": true, + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.22.5", + "@babel/helper-create-class-features-plugin": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-property-literals": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.23.3.tgz", + "integrity": "sha512-jR3Jn3y7cZp4oEWPFAlRsSWjxKe4PZILGBSd4nis1TsC5qeSpb+nrtihJuDhNI7QHiVbUaiXa0X2RZY3/TI6Nw==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-regenerator": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.23.3.tgz", + "integrity": "sha512-KP+75h0KghBMcVpuKisx3XTu9Ncut8Q8TuvGO4IhY+9D5DFEckQefOuIsB/gQ2tG71lCke4NMrtIPS8pOj18BQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "regenerator-transform": "^0.15.2" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-reserved-words": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.23.3.tgz", + "integrity": "sha512-QnNTazY54YqgGxwIexMZva9gqbPa15t/x9VS+0fsEFWplwVpXYZivtgl43Z1vMpc1bdPP2PP8siFeVcnFvA3Cg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-runtime": { + "version": "7.23.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.23.7.tgz", + "integrity": "sha512-fa0hnfmiXc9fq/weK34MUV0drz2pOL/vfKWvN7Qw127hiUPabFCUMgAbYWcchRzMJit4o5ARsK/s+5h0249pLw==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5", + "babel-plugin-polyfill-corejs2": "^0.4.7", + "babel-plugin-polyfill-corejs3": "^0.8.7", + "babel-plugin-polyfill-regenerator": "^0.5.4", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-shorthand-properties": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.23.3.tgz", + "integrity": "sha512-ED2fgqZLmexWiN+YNFX26fx4gh5qHDhn1O2gvEhreLW2iI63Sqm4llRLCXALKrCnbN4Jy0VcMQZl/SAzqug/jg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-spread": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.23.3.tgz", + "integrity": "sha512-VvfVYlrlBVu+77xVTOAoxQ6mZbnIq5FM0aGBSFEcIh03qHf+zNqA4DC/3XMUozTg7bZV3e3mZQ0i13VB6v5yUg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-skip-transparent-expression-wrappers": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-sticky-regex": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.23.3.tgz", + "integrity": "sha512-HZOyN9g+rtvnOU3Yh7kSxXrKbzgrm5X4GncPY1QOquu7epga5MxKHVpYu2hvQnry/H+JjckSYRb93iNfsioAGg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-template-literals": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.23.3.tgz", + "integrity": "sha512-Flok06AYNp7GV2oJPZZcP9vZdszev6vPBkHLwxwSpaIqx75wn6mUd3UFWsSsA0l8nXAKkyCmL/sR02m8RYGeHg==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-typeof-symbol": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.23.3.tgz", + "integrity": "sha512-4t15ViVnaFdrPC74be1gXBSMzXk3B4Us9lP7uLRQHTFpV5Dvt33pn+2MyyNxmN3VTTm3oTrZVMUmuw3oBnQ2oQ==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-escapes": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.23.3.tgz", + "integrity": "sha512-OMCUx/bU6ChE3r4+ZdylEqAjaQgHAgipgW8nsCfu5pGqDcFytVd91AwRvUJSBZDz0exPGgnjoqhgRYLRjFZc9Q==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-property-regex": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-property-regex/-/plugin-transform-unicode-property-regex-7.23.3.tgz", + "integrity": "sha512-KcLIm+pDZkWZQAFJ9pdfmh89EwVfmNovFBcXko8szpBeF8z68kWIPeKlmSOkT9BXJxs2C0uk+5LxoxIv62MROA==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-regex": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.23.3.tgz", + "integrity": "sha512-wMHpNA4x2cIA32b/ci3AfwNgheiva2W0WUKWTK7vBHBhDKfPsc5cFGNWm69WBqpwd86u1qwZ9PWevKqm1A3yAw==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/plugin-transform-unicode-sets-regex": { + "version": "7.23.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-sets-regex/-/plugin-transform-unicode-sets-regex-7.23.3.tgz", + "integrity": "sha512-W7lliA/v9bNR83Qc3q1ip9CQMZ09CcHDbHfbLRDNuAhn1Mvkr1ZNF7hPmztMQvtTGVLJ9m8IZqWsTkXOml8dbw==", + "dev": true, + "dependencies": { + "@babel/helper-create-regexp-features-plugin": "^7.22.15", + "@babel/helper-plugin-utils": "^7.22.5" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0" + } + }, + "node_modules/@babel/preset-env": { + "version": "7.23.8", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.23.8.tgz", + "integrity": "sha512-lFlpmkApLkEP6woIKprO6DO60RImpatTQKtz4sUcDjVcK8M8mQ4sZsuxaTMNOZf0sqAq/ReYW1ZBHnOQwKpLWA==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.23.5", + "@babel/helper-compilation-targets": "^7.23.6", + "@babel/helper-plugin-utils": "^7.22.5", + "@babel/helper-validator-option": "^7.23.5", + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.23.3", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.23.3", + "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": "^7.23.7", + "@babel/plugin-proposal-private-property-in-object": "7.21.0-placeholder-for-preset-env.2", + "@babel/plugin-syntax-async-generators": "^7.8.4", + "@babel/plugin-syntax-class-properties": "^7.12.13", + "@babel/plugin-syntax-class-static-block": "^7.14.5", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-export-namespace-from": "^7.8.3", + "@babel/plugin-syntax-import-assertions": "^7.23.3", + "@babel/plugin-syntax-import-attributes": "^7.23.3", + "@babel/plugin-syntax-import-meta": "^7.10.4", + "@babel/plugin-syntax-json-strings": "^7.8.3", + "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.10.4", + "@babel/plugin-syntax-object-rest-spread": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.3", + "@babel/plugin-syntax-private-property-in-object": "^7.14.5", + "@babel/plugin-syntax-top-level-await": "^7.14.5", + "@babel/plugin-syntax-unicode-sets-regex": "^7.18.6", + "@babel/plugin-transform-arrow-functions": "^7.23.3", + "@babel/plugin-transform-async-generator-functions": "^7.23.7", + "@babel/plugin-transform-async-to-generator": "^7.23.3", + "@babel/plugin-transform-block-scoped-functions": "^7.23.3", + "@babel/plugin-transform-block-scoping": "^7.23.4", + "@babel/plugin-transform-class-properties": "^7.23.3", + "@babel/plugin-transform-class-static-block": "^7.23.4", + "@babel/plugin-transform-classes": "^7.23.8", + "@babel/plugin-transform-computed-properties": "^7.23.3", + "@babel/plugin-transform-destructuring": "^7.23.3", + "@babel/plugin-transform-dotall-regex": "^7.23.3", + "@babel/plugin-transform-duplicate-keys": "^7.23.3", + "@babel/plugin-transform-dynamic-import": "^7.23.4", + "@babel/plugin-transform-exponentiation-operator": "^7.23.3", + "@babel/plugin-transform-export-namespace-from": "^7.23.4", + "@babel/plugin-transform-for-of": "^7.23.6", + "@babel/plugin-transform-function-name": "^7.23.3", + "@babel/plugin-transform-json-strings": "^7.23.4", + "@babel/plugin-transform-literals": "^7.23.3", + "@babel/plugin-transform-logical-assignment-operators": "^7.23.4", + "@babel/plugin-transform-member-expression-literals": "^7.23.3", + "@babel/plugin-transform-modules-amd": "^7.23.3", + "@babel/plugin-transform-modules-commonjs": "^7.23.3", + "@babel/plugin-transform-modules-systemjs": "^7.23.3", + "@babel/plugin-transform-modules-umd": "^7.23.3", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.22.5", + "@babel/plugin-transform-new-target": "^7.23.3", + "@babel/plugin-transform-nullish-coalescing-operator": "^7.23.4", + "@babel/plugin-transform-numeric-separator": "^7.23.4", + "@babel/plugin-transform-object-rest-spread": "^7.23.4", + "@babel/plugin-transform-object-super": "^7.23.3", + "@babel/plugin-transform-optional-catch-binding": "^7.23.4", + "@babel/plugin-transform-optional-chaining": "^7.23.4", + "@babel/plugin-transform-parameters": "^7.23.3", + "@babel/plugin-transform-private-methods": "^7.23.3", + "@babel/plugin-transform-private-property-in-object": "^7.23.4", + "@babel/plugin-transform-property-literals": "^7.23.3", + "@babel/plugin-transform-regenerator": "^7.23.3", + "@babel/plugin-transform-reserved-words": "^7.23.3", + "@babel/plugin-transform-shorthand-properties": "^7.23.3", + "@babel/plugin-transform-spread": "^7.23.3", + "@babel/plugin-transform-sticky-regex": "^7.23.3", + "@babel/plugin-transform-template-literals": "^7.23.3", + "@babel/plugin-transform-typeof-symbol": "^7.23.3", + "@babel/plugin-transform-unicode-escapes": "^7.23.3", + "@babel/plugin-transform-unicode-property-regex": "^7.23.3", + "@babel/plugin-transform-unicode-regex": "^7.23.3", + "@babel/plugin-transform-unicode-sets-regex": "^7.23.3", + "@babel/preset-modules": "0.1.6-no-external-plugins", + "babel-plugin-polyfill-corejs2": "^0.4.7", + "babel-plugin-polyfill-corejs3": "^0.8.7", + "babel-plugin-polyfill-regenerator": "^0.5.4", + "core-js-compat": "^3.31.0", + "semver": "^6.3.1" + }, + "engines": { + "node": ">=6.9.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@babel/preset-modules": { + "version": "0.1.6-no-external-plugins", + "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.6-no-external-plugins.tgz", + "integrity": "sha512-HrcgcIESLm9aIR842yhJ5RWan/gebQUJ6E/E5+rf0y9o6oj7w0Br+sWuL6kEQ/o/AdfvR1Je9jG18/gnpwjEyA==", + "dev": true, + "dependencies": { + "@babel/helper-plugin-utils": "^7.0.0", + "@babel/types": "^7.4.4", + "esutils": "^2.0.2" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/@babel/regjsgen": { + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/@babel/regjsgen/-/regjsgen-0.8.0.tgz", + "integrity": "sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA==", + "dev": true + }, + "node_modules/@babel/runtime": { + "version": "7.23.8", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.8.tgz", + "integrity": "sha512-Y7KbAP984rn1VGMbGqKmBLio9V7y5Je9GvU4rQPCPinCyNfUcToxIXl06d59URp/F3LwinvODxab5N/G6qggkw==", + "dev": true, + "dependencies": { + "regenerator-runtime": "^0.14.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/template": { + "version": "7.22.15", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", + "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.22.13", + "@babel/parser": "^7.22.15", + "@babel/types": "^7.22.15" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse": { + "version": "7.23.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.7.tgz", + "integrity": "sha512-tY3mM8rH9jM0YHFGyfC0/xf+SB5eKUu7HPj7/k3fpi9dAlsMc5YbQvDi0Sh2QTPXqMhyaAtzAr807TIyfQrmyg==", + "dev": true, + "dependencies": { + "@babel/code-frame": "^7.23.5", + "@babel/generator": "^7.23.6", + "@babel/helper-environment-visitor": "^7.22.20", + "@babel/helper-function-name": "^7.23.0", + "@babel/helper-hoist-variables": "^7.22.5", + "@babel/helper-split-export-declaration": "^7.22.6", + "@babel/parser": "^7.23.6", + "@babel/types": "^7.23.6", + "debug": "^4.3.1", + "globals": "^11.1.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/traverse/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@babel/traverse/node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/@babel/types": { + "version": "7.23.6", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.6.tgz", + "integrity": "sha512-+uarb83brBzPKN38NX1MkB6vb6+mwvR6amUulqAE7ccQw1pEl+bCia9TbdG1lsnFP7lZySvUn37CHyXQdfTwzg==", + "dev": true, + "dependencies": { + "@babel/helper-string-parser": "^7.23.4", + "@babel/helper-validator-identifier": "^7.22.20", + "to-fast-properties": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@hapi/address": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@hapi/address/-/address-2.1.4.tgz", + "integrity": "sha512-QD1PhQk+s31P1ixsX0H0Suoupp3VMXzIVMSwobR3F3MSUO2YCV0B7xqLcUw/Bh8yuvd3LhpyqLQWTNcRmp6IdQ==", + "deprecated": "Moved to 'npm install @sideway/address'", + "dev": true + }, + "node_modules/@hapi/bourne": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/@hapi/bourne/-/bourne-1.3.2.tgz", + "integrity": "sha512-1dVNHT76Uu5N3eJNTYcvxee+jzX4Z9lfciqRRHCU27ihbUcYi+iSc2iml5Ke1LXe1SyJCLA0+14Jh4tXJgOppA==", + "deprecated": "This version has been deprecated and is no longer supported or maintained", + "dev": true + }, + "node_modules/@hapi/hoek": { + "version": "8.5.1", + "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-8.5.1.tgz", + "integrity": "sha512-yN7kbciD87WzLGc5539Tn0sApjyiGHAJgKvG9W8C7O+6c7qmoQMfVs0W4bX17eqz6C78QJqqFrtgdK5EWf6Qow==", + "deprecated": "This version has been deprecated and is no longer supported or maintained", + "dev": true + }, + "node_modules/@hapi/joi": { + "version": "15.1.1", + "resolved": "https://registry.npmjs.org/@hapi/joi/-/joi-15.1.1.tgz", + "integrity": "sha512-entf8ZMOK8sc+8YfeOlM8pCfg3b5+WZIKBfUaaJT8UsjAAPjartzxIYm3TIbjvA4u+u++KbcXD38k682nVHDAQ==", + "deprecated": "Switch to 'npm install joi'", + "dev": true, + "dependencies": { + "@hapi/address": "2.x.x", + "@hapi/bourne": "1.x.x", + "@hapi/hoek": "8.x.x", + "@hapi/topo": "3.x.x" + } + }, + "node_modules/@hapi/topo": { + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-3.1.6.tgz", + "integrity": "sha512-tAag0jEcjwH+P2quUfipd7liWCNX2F8NvYjQp2wtInsZxnMlypdw0FtAOLxtvvkO+GSRRbmNi8m/5y42PQJYCQ==", + "deprecated": "This version has been deprecated and is no longer supported or maintained", + "dev": true, + "dependencies": { + "@hapi/hoek": "^8.3.0" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", + "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", + "dev": true, + "dependencies": { + "@jridgewell/set-array": "^1.0.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.9" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", + "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "dev": true, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.4.15", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", + "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", + "dev": true + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.21", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.21.tgz", + "integrity": "sha512-SRfKmRe1KvYnxjEMtxEr+J4HIeMX5YBg/qhRHpxEIGjhX1rshcHlnFUE9K0GazhVKWM7B+nARSkV8LuvJdJ5/g==", + "dev": true, + "dependencies": { + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" + } + }, + "node_modules/@mrmlnc/readdir-enhanced": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz", + "integrity": "sha512-bPHp6Ji8b41szTOcaP63VlnbbO5Ny6dwAATtY6JTjh5N2OLrb5Qk/Th5cRkRQhkWCt+EJsYrNB0MiL+Gpn6e3g==", + "dev": true, + "dependencies": { + "call-me-maybe": "^1.0.1", + "glob-to-regexp": "^0.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@nodelib/fs.stat": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-1.1.3.tgz", + "integrity": "sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw==", + "dev": true, + "engines": { + "node": ">= 6" + } + }, + "node_modules/@sindresorhus/is": { + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@sindresorhus/is/-/is-0.14.0.tgz", + "integrity": "sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/@szmarczak/http-timer": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/@szmarczak/http-timer/-/http-timer-1.1.2.tgz", + "integrity": "sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA==", + "dev": true, + "dependencies": { + "defer-to-connect": "^1.0.1" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/@types/body-parser": { + "version": "1.19.5", + "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.5.tgz", + "integrity": "sha512-fB3Zu92ucau0iQ0JMCFQE7b/dv8Ot07NI3KaZIkIUNXq82k4eBAqUaneXfleGY9JWskeS9y+u0nXMyspcuQrCg==", + "dev": true, + "dependencies": { + "@types/connect": "*", + "@types/node": "*" + } + }, + "node_modules/@types/connect": { + "version": "3.4.38", + "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.38.tgz", + "integrity": "sha512-K6uROf1LD88uDQqJCktA4yzL1YYAK6NgfsI0v/mTgyPKWsX1CnJ0XPSDhViejru1GcRkLWb8RlzFYJRqGUbaug==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/connect-history-api-fallback": { + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/@types/connect-history-api-fallback/-/connect-history-api-fallback-1.5.4.tgz", + "integrity": "sha512-n6Cr2xS1h4uAulPRdlw6Jl6s1oG8KrVilPN2yUITEs+K48EzMJJ3W1xy8K5eWuFvjp3R74AOIGSmp2UfBJ8HFw==", + "dev": true, + "dependencies": { + "@types/express-serve-static-core": "*", + "@types/node": "*" + } + }, + "node_modules/@types/express": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.21.tgz", + "integrity": "sha512-ejlPM315qwLpaQlQDTjPdsUFSc6ZsP4AN6AlWnogPjQ7CVi7PYF3YVz+CY3jE2pwYf7E/7HlDAN0rV2GxTG0HQ==", + "dev": true, + "dependencies": { + "@types/body-parser": "*", + "@types/express-serve-static-core": "^4.17.33", + "@types/qs": "*", + "@types/serve-static": "*" + } + }, + "node_modules/@types/express-serve-static-core": { + "version": "4.17.41", + "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.41.tgz", + "integrity": "sha512-OaJ7XLaelTgrvlZD8/aa0vvvxZdUmlCn6MtWeB7TkiKW70BQLc9XEPpDLPdbo52ZhXUCrznlWdCHWxJWtdyajA==", + "dev": true, + "dependencies": { + "@types/node": "*", + "@types/qs": "*", + "@types/range-parser": "*", + "@types/send": "*" + } + }, + "node_modules/@types/glob": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", + "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", + "dev": true, + "dependencies": { + "@types/minimatch": "*", + "@types/node": "*" + } + }, + "node_modules/@types/highlight.js": { + "version": "9.12.4", + "resolved": "https://registry.npmjs.org/@types/highlight.js/-/highlight.js-9.12.4.tgz", + "integrity": "sha512-t2szdkwmg2JJyuCM20e8kR2X59WCE5Zkl4bzm1u1Oukjm79zpbiAv+QjnwLnuuV0WHEcX2NgUItu0pAMKuOPww==", + "dev": true + }, + "node_modules/@types/http-errors": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/@types/http-errors/-/http-errors-2.0.4.tgz", + "integrity": "sha512-D0CFMMtydbJAegzOyHjtiKPLlvnm3iTZyZRSZoLq2mRhDdmLfIWOCYPfQJ4cu2erKghU++QvjcUjp/5h7hESpA==", + "dev": true + }, + "node_modules/@types/http-proxy": { + "version": "1.17.14", + "resolved": "https://registry.npmjs.org/@types/http-proxy/-/http-proxy-1.17.14.tgz", + "integrity": "sha512-SSrD0c1OQzlFX7pGu1eXxSEjemej64aaNPRhhVYUGqXh0BtldAAx37MG8btcumvpgKyZp1F5Gn3JkktdxiFv6w==", + "dev": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@types/json-schema": { + "version": "7.0.15", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz", + "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==", + "dev": true + }, + "node_modules/@types/linkify-it": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/@types/linkify-it/-/linkify-it-3.0.5.tgz", + "integrity": "sha512-yg6E+u0/+Zjva+buc3EIb+29XEg4wltq7cSmd4Uc2EE/1nUVmxyzpX6gUXD0V8jIrG0r7YeOGVIbYRkxeooCtw==", + "dev": true + }, + "node_modules/@types/markdown-it": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/@types/markdown-it/-/markdown-it-10.0.3.tgz", + "integrity": "sha512-daHJk22isOUvNssVGF2zDnnSyxHhFYhtjeX4oQaKD6QzL3ZR1QSgiD1g+Q6/WSWYVogNXYDXODtbgW/WiFCtyw==", + "dev": true, + "dependencies": { + "@types/highlight.js": "^9.7.0", + "@types/linkify-it": "*", + "@types/mdurl": "*", + "highlight.js": "^9.7.0" + } + }, + "node_modules/@types/mdurl": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/@types/mdurl/-/mdurl-1.0.5.tgz", + "integrity": "sha512-6L6VymKTzYSrEf4Nev4Xa1LCHKrlTlYCBMTlQKFuddo1CvQcE52I0mwfOJayueUC7MJuXOeHTcIU683lzd0cUA==", + "dev": true + }, + "node_modules/@types/mime": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/@types/mime/-/mime-1.3.5.tgz", + "integrity": "sha512-/pyBZWSLD2n0dcHE3hq8s8ZvcETHtEuF+3E7XVt0Ig2nvsVQXdghHVcEkIWjy9A0wKfTn97a/PSDYohKIlnP/w==", + "dev": true + }, + "node_modules/@types/minimatch": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", + "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", + "dev": true + }, + "node_modules/@types/node": { + "version": "20.11.2", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.11.2.tgz", + "integrity": "sha512-cZShBaVa+UO1LjWWBPmWRR4+/eY/JR/UIEcDlVsw3okjWEu+rB7/mH6X3B/L+qJVHDLjk9QW/y2upp9wp1yDXA==", + "dev": true, + "dependencies": { + "undici-types": "~5.26.4" + } + }, + "node_modules/@types/q": { + "version": "1.5.8", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.5.8.tgz", + "integrity": "sha512-hroOstUScF6zhIi+5+x0dzqrHA1EJi+Irri6b1fxolMTqqHIV/Cg77EtnQcZqZCu8hR3mX2BzIxN4/GzI68Kfw==", + "dev": true + }, + "node_modules/@types/qs": { + "version": "6.9.11", + "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.11.tgz", + "integrity": "sha512-oGk0gmhnEJK4Yyk+oI7EfXsLayXatCWPHary1MtcmbAifkobT9cM9yutG/hZKIseOU0MqbIwQ/u2nn/Gb+ltuQ==", + "dev": true + }, + "node_modules/@types/range-parser": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.7.tgz", + "integrity": "sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ==", + "dev": true + }, + "node_modules/@types/send": { + "version": "0.17.4", + "resolved": "https://registry.npmjs.org/@types/send/-/send-0.17.4.tgz", + "integrity": "sha512-x2EM6TJOybec7c52BX0ZspPodMsQUd5L6PRwOunVyVUhXiBSKf3AezDL8Dgvgt5o0UfKNfuA0eMLr2wLT4AiBA==", + "dev": true, + "dependencies": { + "@types/mime": "^1", + "@types/node": "*" + } + }, + "node_modules/@types/serve-static": { + "version": "1.15.5", + "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.5.tgz", + "integrity": "sha512-PDRk21MnK70hja/YF8AHfC7yIsiQHn1rcXx7ijCFBX/k+XQJhQT/gw3xekXKJvx+5SXaMMS8oqQy09Mzvz2TuQ==", + "dev": true, + "dependencies": { + "@types/http-errors": "*", + "@types/mime": "*", + "@types/node": "*" + } + }, + "node_modules/@types/source-list-map": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/@types/source-list-map/-/source-list-map-0.1.6.tgz", + "integrity": "sha512-5JcVt1u5HDmlXkwOD2nslZVllBBc7HDuOICfiZah2Z0is8M8g+ddAEawbmd3VjedfDHBzxCaXLs07QEmb7y54g==", + "dev": true + }, + "node_modules/@types/tapable": { + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/@types/tapable/-/tapable-1.0.12.tgz", + "integrity": "sha512-bTHG8fcxEqv1M9+TD14P8ok8hjxoOCkfKc8XXLaaD05kI7ohpeI956jtDOD3XHKBQrlyPughUtzm1jtVhHpA5Q==", + "dev": true + }, + "node_modules/@types/uglify-js": { + "version": "3.17.4", + "resolved": "https://registry.npmjs.org/@types/uglify-js/-/uglify-js-3.17.4.tgz", + "integrity": "sha512-Hm/T0kV3ywpJyMGNbsItdivRhYNCQQf1IIsYsXnoVPES4t+FMLyDe0/K+Ea7ahWtMtSNb22ZdY7MIyoD9rqARg==", + "dev": true, + "dependencies": { + "source-map": "^0.6.1" + } + }, + "node_modules/@types/webpack": { + "version": "4.41.38", + "resolved": "https://registry.npmjs.org/@types/webpack/-/webpack-4.41.38.tgz", + "integrity": "sha512-oOW7E931XJU1mVfCnxCVgv8GLFL768pDO5u2Gzk82i8yTIgX6i7cntyZOkZYb/JtYM8252SN9bQp9tgkVDSsRw==", + "dev": true, + "dependencies": { + "@types/node": "*", + "@types/tapable": "^1", + "@types/uglify-js": "*", + "@types/webpack-sources": "*", + "anymatch": "^3.0.0", + "source-map": "^0.6.0" + } + }, + "node_modules/@types/webpack-dev-server": { + "version": "3.11.6", + "resolved": "https://registry.npmjs.org/@types/webpack-dev-server/-/webpack-dev-server-3.11.6.tgz", + "integrity": "sha512-XCph0RiiqFGetukCTC3KVnY1jwLcZ84illFRMbyFzCcWl90B/76ew0tSqF46oBhnLC4obNDG7dMO0JfTN0MgMQ==", + "dev": true, + "dependencies": { + "@types/connect-history-api-fallback": "*", + "@types/express": "*", + "@types/serve-static": "*", + "@types/webpack": "^4", + "http-proxy-middleware": "^1.0.0" + } + }, + "node_modules/@types/webpack-sources": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/@types/webpack-sources/-/webpack-sources-3.2.3.tgz", + "integrity": "sha512-4nZOdMwSPHZ4pTEZzSp0AsTM4K7Qmu40UKW4tJDiOVs20UzYF9l+qUe4s0ftfN0pin06n+5cWWDJXH+sbhAiDw==", + "dev": true, + "dependencies": { + "@types/node": "*", + "@types/source-list-map": "*", + "source-map": "^0.7.3" + } + }, + "node_modules/@types/webpack-sources/node_modules/source-map": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", + "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@vue/babel-helper-vue-jsx-merge-props": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-helper-vue-jsx-merge-props/-/babel-helper-vue-jsx-merge-props-1.4.0.tgz", + "integrity": "sha512-JkqXfCkUDp4PIlFdDQ0TdXoIejMtTHP67/pvxlgeY+u5k3LEdKuWZ3LK6xkxo52uDoABIVyRwqVkfLQJhk7VBA==", + "dev": true + }, + "node_modules/@vue/babel-helper-vue-transform-on": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/@vue/babel-helper-vue-transform-on/-/babel-helper-vue-transform-on-1.1.6.tgz", + "integrity": "sha512-XxM2tZHjYHTd9yiKHHt7fKCN0e2BK2z78UxU5rpjH3YCstEV/tcrW29CaOdrxIdeD0c/9mHHebvXWwDxlphjKA==", + "dev": true + }, + "node_modules/@vue/babel-plugin-jsx": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/@vue/babel-plugin-jsx/-/babel-plugin-jsx-1.1.6.tgz", + "integrity": "sha512-s2pK8Wwg0LiR25lyCKWGJePt8aXF0DsXOmTHYJnlKNdT3yTKfdvkKmsWjaHBctFvwWmetedObrAoINc9BeYZlA==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.22.15", + "@babel/plugin-syntax-jsx": "^7.23.3", + "@babel/template": "^7.22.15", + "@babel/traverse": "^7.23.7", + "@babel/types": "^7.23.6", + "@vue/babel-helper-vue-transform-on": "^1.1.6", + "camelcase": "^6.3.0", + "html-tags": "^3.3.1", + "svg-tags": "^1.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + }, + "peerDependenciesMeta": { + "@babel/core": { + "optional": true + } + } + }, + "node_modules/@vue/babel-plugin-transform-vue-jsx": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-plugin-transform-vue-jsx/-/babel-plugin-transform-vue-jsx-1.4.0.tgz", + "integrity": "sha512-Fmastxw4MMx0vlgLS4XBX0XiBbUFzoMGeVXuMV08wyOfXdikAFqBTuYPR0tlk+XskL19EzHc39SgjrPGY23JnA==", + "dev": true, + "dependencies": { + "@babel/helper-module-imports": "^7.0.0", + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-helper-vue-jsx-merge-props": "^1.4.0", + "html-tags": "^2.0.0", + "lodash.kebabcase": "^4.1.1", + "svg-tags": "^1.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@vue/babel-plugin-transform-vue-jsx/node_modules/html-tags": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/html-tags/-/html-tags-2.0.0.tgz", + "integrity": "sha512-+Il6N8cCo2wB/Vd3gqy/8TZhTD3QvcVeQLCnZiGkGCH3JP28IgGAY41giccp2W4R3jfyJPAP318FQTa1yU7K7g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/@vue/babel-preset-app": { + "version": "4.5.19", + "resolved": "https://registry.npmjs.org/@vue/babel-preset-app/-/babel-preset-app-4.5.19.tgz", + "integrity": "sha512-VCNRiAt2P/bLo09rYt3DLe6xXUMlhJwrvU18Ddd/lYJgC7s8+wvhgYs+MTx4OiAXdu58drGwSBO9SPx7C6J82Q==", + "dev": true, + "dependencies": { + "@babel/core": "^7.11.0", + "@babel/helper-compilation-targets": "^7.9.6", + "@babel/helper-module-imports": "^7.8.3", + "@babel/plugin-proposal-class-properties": "^7.8.3", + "@babel/plugin-proposal-decorators": "^7.8.3", + "@babel/plugin-syntax-dynamic-import": "^7.8.3", + "@babel/plugin-syntax-jsx": "^7.8.3", + "@babel/plugin-transform-runtime": "^7.11.0", + "@babel/preset-env": "^7.11.0", + "@babel/runtime": "^7.11.0", + "@vue/babel-plugin-jsx": "^1.0.3", + "@vue/babel-preset-jsx": "^1.2.4", + "babel-plugin-dynamic-import-node": "^2.3.3", + "core-js": "^3.6.5", + "core-js-compat": "^3.6.5", + "semver": "^6.1.0" + }, + "peerDependencies": { + "@babel/core": "*", + "core-js": "^3", + "vue": "^2 || ^3.0.0-0" + }, + "peerDependenciesMeta": { + "core-js": { + "optional": true + }, + "vue": { + "optional": true + } + } + }, + "node_modules/@vue/babel-preset-jsx": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-preset-jsx/-/babel-preset-jsx-1.4.0.tgz", + "integrity": "sha512-QmfRpssBOPZWL5xw7fOuHNifCQcNQC1PrOo/4fu6xlhlKJJKSA3HqX92Nvgyx8fqHZTUGMPHmFA+IDqwXlqkSA==", + "dev": true, + "dependencies": { + "@vue/babel-helper-vue-jsx-merge-props": "^1.4.0", + "@vue/babel-plugin-transform-vue-jsx": "^1.4.0", + "@vue/babel-sugar-composition-api-inject-h": "^1.4.0", + "@vue/babel-sugar-composition-api-render-instance": "^1.4.0", + "@vue/babel-sugar-functional-vue": "^1.4.0", + "@vue/babel-sugar-inject-h": "^1.4.0", + "@vue/babel-sugar-v-model": "^1.4.0", + "@vue/babel-sugar-v-on": "^1.4.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0", + "vue": "*" + }, + "peerDependenciesMeta": { + "vue": { + "optional": true + } + } + }, + "node_modules/@vue/babel-sugar-composition-api-inject-h": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-composition-api-inject-h/-/babel-sugar-composition-api-inject-h-1.4.0.tgz", + "integrity": "sha512-VQq6zEddJHctnG4w3TfmlVp5FzDavUSut/DwR0xVoe/mJKXyMcsIibL42wPntozITEoY90aBV0/1d2KjxHU52g==", + "dev": true, + "dependencies": { + "@babel/plugin-syntax-jsx": "^7.2.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@vue/babel-sugar-composition-api-render-instance": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-composition-api-render-instance/-/babel-sugar-composition-api-render-instance-1.4.0.tgz", + "integrity": "sha512-6ZDAzcxvy7VcnCjNdHJ59mwK02ZFuP5CnucloidqlZwVQv5CQLijc3lGpR7MD3TWFi78J7+a8J56YxbCtHgT9Q==", + "dev": true, + "dependencies": { + "@babel/plugin-syntax-jsx": "^7.2.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@vue/babel-sugar-functional-vue": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-functional-vue/-/babel-sugar-functional-vue-1.4.0.tgz", + "integrity": "sha512-lTEB4WUFNzYt2In6JsoF9sAYVTo84wC4e+PoZWSgM6FUtqRJz7wMylaEhSRgG71YF+wfLD6cc9nqVeXN2rwBvw==", + "dev": true, + "dependencies": { + "@babel/plugin-syntax-jsx": "^7.2.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@vue/babel-sugar-inject-h": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-inject-h/-/babel-sugar-inject-h-1.4.0.tgz", + "integrity": "sha512-muwWrPKli77uO2fFM7eA3G1lAGnERuSz2NgAxuOLzrsTlQl8W4G+wwbM4nB6iewlKbwKRae3nL03UaF5ffAPMA==", + "dev": true, + "dependencies": { + "@babel/plugin-syntax-jsx": "^7.2.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@vue/babel-sugar-v-model": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-v-model/-/babel-sugar-v-model-1.4.0.tgz", + "integrity": "sha512-0t4HGgXb7WHYLBciZzN5s0Hzqan4Ue+p/3FdQdcaHAb7s5D9WZFGoSxEZHrR1TFVZlAPu1bejTKGeAzaaG3NCQ==", + "dev": true, + "dependencies": { + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-helper-vue-jsx-merge-props": "^1.4.0", + "@vue/babel-plugin-transform-vue-jsx": "^1.4.0", + "camelcase": "^5.0.0", + "html-tags": "^2.0.0", + "svg-tags": "^1.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@vue/babel-sugar-v-model/node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/@vue/babel-sugar-v-model/node_modules/html-tags": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/html-tags/-/html-tags-2.0.0.tgz", + "integrity": "sha512-+Il6N8cCo2wB/Vd3gqy/8TZhTD3QvcVeQLCnZiGkGCH3JP28IgGAY41giccp2W4R3jfyJPAP318FQTa1yU7K7g==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/@vue/babel-sugar-v-on": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@vue/babel-sugar-v-on/-/babel-sugar-v-on-1.4.0.tgz", + "integrity": "sha512-m+zud4wKLzSKgQrWwhqRObWzmTuyzl6vOP7024lrpeJM4x2UhQtRDLgYjXAw9xBXjCwS0pP9kXjg91F9ZNo9JA==", + "dev": true, + "dependencies": { + "@babel/plugin-syntax-jsx": "^7.2.0", + "@vue/babel-plugin-transform-vue-jsx": "^1.4.0", + "camelcase": "^5.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.0.0-0" + } + }, + "node_modules/@vue/babel-sugar-v-on/node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/@vue/compiler-sfc": { + "version": "2.7.16", + "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-2.7.16.tgz", + "integrity": "sha512-KWhJ9k5nXuNtygPU7+t1rX6baZeqOYLEforUPjgNDBnLicfHCoi48H87Q8XyLZOrNNsmhuwKqtpDQWjEFe6Ekg==", + "dev": true, + "dependencies": { + "@babel/parser": "^7.23.5", + "postcss": "^8.4.14", + "source-map": "^0.6.1" + }, + "optionalDependencies": { + "prettier": "^1.18.2 || ^2.0.0" + } + }, + "node_modules/@vue/compiler-sfc/node_modules/picocolors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", + "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", + "dev": true + }, + "node_modules/@vue/compiler-sfc/node_modules/postcss": { + "version": "8.4.33", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.33.tgz", + "integrity": "sha512-Kkpbhhdjw2qQs2O2DGX+8m5OVqEcbB9HRBvuYM9pgrjEFUg30A9LmXNlTAUj4S9kgtGyrMbTzVjH7E+s5Re2yg==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.0.0", + "source-map-js": "^1.0.2" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/@vue/component-compiler-utils": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/@vue/component-compiler-utils/-/component-compiler-utils-3.3.0.tgz", + "integrity": "sha512-97sfH2mYNU+2PzGrmK2haqffDpVASuib9/w2/noxiFi31Z54hW+q3izKQXXQZSNhtiUpAI36uSuYepeBe4wpHQ==", + "dev": true, + "dependencies": { + "consolidate": "^0.15.1", + "hash-sum": "^1.0.2", + "lru-cache": "^4.1.2", + "merge-source-map": "^1.1.0", + "postcss": "^7.0.36", + "postcss-selector-parser": "^6.0.2", + "source-map": "~0.6.1", + "vue-template-es2015-compiler": "^1.9.0" + }, + "optionalDependencies": { + "prettier": "^1.18.2 || ^2.0.0" + } + }, + "node_modules/@vue/component-compiler-utils/node_modules/lru-cache": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", + "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", + "dev": true, + "dependencies": { + "pseudomap": "^1.0.2", + "yallist": "^2.1.2" + } + }, + "node_modules/@vue/component-compiler-utils/node_modules/yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A==", + "dev": true + }, + "node_modules/@vuepress/core": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/core/-/core-1.9.10.tgz", + "integrity": "sha512-H9ddo5fSinPb8QYl8OJFbZikMpOW84bm/U3Drzz8CnCXNtpda7CU2wX/XzOhe98G8jp45xhtZRkxOrqzBBAShA==", + "dev": true, + "dependencies": { + "@babel/core": "^7.8.4", + "@vue/babel-preset-app": "^4.1.2", + "@vuepress/markdown": "1.9.10", + "@vuepress/markdown-loader": "1.9.10", + "@vuepress/plugin-last-updated": "1.9.10", + "@vuepress/plugin-register-components": "1.9.10", + "@vuepress/shared-utils": "1.9.10", + "@vuepress/types": "1.9.10", + "autoprefixer": "^9.5.1", + "babel-loader": "^8.0.4", + "bundle-require": "2.1.8", + "cache-loader": "^3.0.0", + "chokidar": "^2.0.3", + "connect-history-api-fallback": "^1.5.0", + "copy-webpack-plugin": "^5.0.2", + "core-js": "^3.6.4", + "cross-spawn": "^6.0.5", + "css-loader": "^2.1.1", + "esbuild": "0.14.7", + "file-loader": "^3.0.1", + "js-yaml": "^3.13.1", + "lru-cache": "^5.1.1", + "mini-css-extract-plugin": "0.6.0", + "optimize-css-assets-webpack-plugin": "^5.0.1", + "portfinder": "^1.0.13", + "postcss-loader": "^3.0.0", + "postcss-safe-parser": "^4.0.1", + "toml": "^3.0.0", + "url-loader": "^1.0.1", + "vue": "^2.6.10", + "vue-loader": "^15.7.1", + "vue-router": "^3.4.5", + "vue-server-renderer": "^2.6.10", + "vue-template-compiler": "^2.6.10", + "vuepress-html-webpack-plugin": "^3.2.0", + "vuepress-plugin-container": "^2.0.2", + "webpack": "^4.8.1", + "webpack-chain": "^6.0.0", + "webpack-dev-server": "^3.5.1", + "webpack-merge": "^4.1.2", + "webpackbar": "3.2.0" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/@vuepress/markdown": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/markdown/-/markdown-1.9.10.tgz", + "integrity": "sha512-sXTLjeZzH8SQuAL5AEH0hhsMljjNJbzWbBvzaj5yQCCdf+3sp/dJ0kwnBSnQjFPPnzPg5t3tLKGUYHyW0KiKzA==", + "dev": true, + "dependencies": { + "@vuepress/shared-utils": "1.9.10", + "markdown-it": "^8.4.1", + "markdown-it-anchor": "^5.0.2", + "markdown-it-chain": "^1.3.0", + "markdown-it-emoji": "^1.4.0", + "markdown-it-table-of-contents": "^0.4.0", + "prismjs": "^1.13.0" + } + }, + "node_modules/@vuepress/markdown-loader": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/markdown-loader/-/markdown-loader-1.9.10.tgz", + "integrity": "sha512-94BlwKc+lOaN/A5DkyA9KWHvMlMC1sWunAXE3Tv0WYzgYLDs9QqCsx7L5kLkpcOOVVm/8kBJumnXvVBwhqJddw==", + "dev": true, + "dependencies": { + "@vuepress/markdown": "1.9.10", + "loader-utils": "^1.1.0", + "lru-cache": "^5.1.1" + } + }, + "node_modules/@vuepress/plugin-active-header-links": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/plugin-active-header-links/-/plugin-active-header-links-1.9.10.tgz", + "integrity": "sha512-2dRr3DE2UBFXhyMtLR3sGTdRyDM8YStuY6AOoQmoSgwy1IHt7PO7ypOuf1akF+1Nv8Q2aISU06q6TExZouu3Mw==", + "dev": true, + "dependencies": { + "@vuepress/types": "1.9.10", + "lodash.debounce": "^4.0.8" + } + }, + "node_modules/@vuepress/plugin-back-to-top": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/plugin-back-to-top/-/plugin-back-to-top-1.9.10.tgz", + "integrity": "sha512-iInIp66wu717CAnT2pyd9Bs/vAgrUBOBIQ7WMnfJo07cW/ZIothpyrSHnpCRSsfJ/jLivMPqW0pviqppt64BzQ==", + "dev": true, + "dependencies": { + "@vuepress/types": "1.9.10", + "lodash.debounce": "^4.0.8" + } + }, + "node_modules/@vuepress/plugin-last-updated": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/plugin-last-updated/-/plugin-last-updated-1.9.10.tgz", + "integrity": "sha512-YxzWGF/OfU6WsHSynZFn74NGGp7dY27Bjy9JyyFo8wF5+2V1gpyDjveHKHGKugS/pMXlxfjzhv9E2Wmy9R7Iog==", + "dev": true, + "dependencies": { + "@vuepress/types": "1.9.10", + "cross-spawn": "^6.0.5" + } + }, + "node_modules/@vuepress/plugin-nprogress": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/plugin-nprogress/-/plugin-nprogress-1.9.10.tgz", + "integrity": "sha512-I1kkm6yWUQd7vwiV3lEDVpVP0Lr04K0zlczU502lDUa1RufSZ7vt+mlF5fOM28GqT+pKTEToWmm+VNT/R3qvMQ==", + "dev": true, + "dependencies": { + "@vuepress/types": "1.9.10", + "nprogress": "^0.2.0" + } + }, + "node_modules/@vuepress/plugin-pwa": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/plugin-pwa/-/plugin-pwa-1.9.10.tgz", + "integrity": "sha512-pP3CUYKyIpnePswZGj9sBHJUzOczSmWSkmdoJftEnsBQT10YycJ81khS9WKEGPbTurbCOCCXsOzaEqCLysyYaA==", + "dev": true, + "dependencies": { + "@vuepress/shared-utils": "1.9.10", + "@vuepress/types": "1.9.10", + "register-service-worker": "^1.7.0", + "workbox-build": "^4.3.1" + } + }, + "node_modules/@vuepress/plugin-register-components": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/plugin-register-components/-/plugin-register-components-1.9.10.tgz", + "integrity": "sha512-sgdJ5OydTPZAoTkselpvVP3Xsd6bfZ0FpaxOTinal0gJ99h49lvLu9bvzMx13rdGRFO/kRXn0qQQpwKTAfTPqA==", + "dev": true, + "dependencies": { + "@vuepress/shared-utils": "1.9.10", + "@vuepress/types": "1.9.10" + } + }, + "node_modules/@vuepress/plugin-search": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/plugin-search/-/plugin-search-1.9.10.tgz", + "integrity": "sha512-bn2XJikaRgQZXvu8upCjOWrxbLHIRTqnJ3w7G0mo6jCYWGVsHNo6XhVpqylpLR2PWnHT/ImO2bGo38/5Bag/tQ==", + "dev": true, + "dependencies": { + "@vuepress/types": "1.9.10" + } + }, + "node_modules/@vuepress/shared-utils": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/shared-utils/-/shared-utils-1.9.10.tgz", + "integrity": "sha512-M9A3DocPih+V8dKK2Zg9FJQ/f3JZrYsdaM/vQ9F48l8bPlzxw5NvqXIYMK4kKcGEyerQNTWCudoCpLL5uiU0hg==", + "dev": true, + "dependencies": { + "chalk": "^2.3.2", + "escape-html": "^1.0.3", + "fs-extra": "^7.0.1", + "globby": "^9.2.0", + "gray-matter": "^4.0.1", + "hash-sum": "^1.0.2", + "semver": "^6.0.0", + "toml": "^3.0.0", + "upath": "^1.1.0" + } + }, + "node_modules/@vuepress/theme-default": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/theme-default/-/theme-default-1.9.10.tgz", + "integrity": "sha512-XnXn9t+pYCIhWi3cZXJlighuy93FFm5yXdISAAlFlcNkshuGtqamkjacHV8q/QZMfOhSIs6wX7Hj88u2IsT5mw==", + "dev": true, + "dependencies": { + "@vuepress/plugin-active-header-links": "1.9.10", + "@vuepress/plugin-nprogress": "1.9.10", + "@vuepress/plugin-search": "1.9.10", + "@vuepress/types": "1.9.10", + "docsearch.js": "^2.5.2", + "lodash": "^4.17.15", + "stylus": "^0.54.8", + "stylus-loader": "^3.0.2", + "vuepress-plugin-container": "^2.0.2", + "vuepress-plugin-smooth-scroll": "^0.0.3" + } + }, + "node_modules/@vuepress/types": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/@vuepress/types/-/types-1.9.10.tgz", + "integrity": "sha512-TDNQn4og85onmBpLTTXXmncW3rUnYGr2MkuI8OIFJZetDNM49t1WbjNVlrT+kx7C6qXi6okDQgrHGYXajHZWfg==", + "dev": true, + "dependencies": { + "@types/markdown-it": "^10.0.0", + "@types/webpack-dev-server": "^3", + "webpack-chain": "^6.0.0" + } + }, + "node_modules/@webassemblyjs/ast": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.9.0.tgz", + "integrity": "sha512-C6wW5L+b7ogSDVqymbkkvuW9kruN//YisMED04xzeBBqjHa2FYnmvOlS6Xj68xWQRgWvI9cIglsjFowH/RJyEA==", + "dev": true, + "dependencies": { + "@webassemblyjs/helper-module-context": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/wast-parser": "1.9.0" + } + }, + "node_modules/@webassemblyjs/floating-point-hex-parser": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.9.0.tgz", + "integrity": "sha512-TG5qcFsS8QB4g4MhrxK5TqfdNe7Ey/7YL/xN+36rRjl/BlGE/NcBvJcqsRgCP6Z92mRE+7N50pRIi8SmKUbcQA==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-api-error": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.9.0.tgz", + "integrity": "sha512-NcMLjoFMXpsASZFxJ5h2HZRcEhDkvnNFOAKneP5RbKRzaWJN36NC4jqQHKwStIhGXu5mUWlUUk7ygdtrO8lbmw==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-buffer": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.9.0.tgz", + "integrity": "sha512-qZol43oqhq6yBPx7YM3m9Bv7WMV9Eevj6kMi6InKOuZxhw+q9hOkvq5e/PpKSiLfyetpaBnogSbNCfBwyB00CA==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-code-frame": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.9.0.tgz", + "integrity": "sha512-ERCYdJBkD9Vu4vtjUYe8LZruWuNIToYq/ME22igL+2vj2dQ2OOujIZr3MEFvfEaqKoVqpsFKAGsRdBSBjrIvZA==", + "dev": true, + "dependencies": { + "@webassemblyjs/wast-printer": "1.9.0" + } + }, + "node_modules/@webassemblyjs/helper-fsm": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-fsm/-/helper-fsm-1.9.0.tgz", + "integrity": "sha512-OPRowhGbshCb5PxJ8LocpdX9Kl0uB4XsAjl6jH/dWKlk/mzsANvhwbiULsaiqT5GZGT9qinTICdj6PLuM5gslw==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-module-context": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-module-context/-/helper-module-context-1.9.0.tgz", + "integrity": "sha512-MJCW8iGC08tMk2enck1aPW+BE5Cw8/7ph/VGZxwyvGbJwjktKkDK7vy7gAmMDx88D7mhDTCNKAW5tED+gZ0W8g==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0" + } + }, + "node_modules/@webassemblyjs/helper-wasm-bytecode": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.9.0.tgz", + "integrity": "sha512-R7FStIzyNcd7xKxCZH5lE0Bqy+hGTwS3LJjuv1ZVxd9O7eHCedSdrId/hMOd20I+v8wDXEn+bjfKDLzTepoaUw==", + "dev": true + }, + "node_modules/@webassemblyjs/helper-wasm-section": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.9.0.tgz", + "integrity": "sha512-XnMB8l3ek4tvrKUUku+IVaXNHz2YsJyOOmz+MMkZvh8h1uSJpSen6vYnw3IoQ7WwEuAhL8Efjms1ZWjqh2agvw==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0" + } + }, + "node_modules/@webassemblyjs/ieee754": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.9.0.tgz", + "integrity": "sha512-dcX8JuYU/gvymzIHc9DgxTzUUTLexWwt8uCTWP3otys596io0L5aW02Gb1RjYpx2+0Jus1h4ZFqjla7umFniTg==", + "dev": true, + "dependencies": { + "@xtuc/ieee754": "^1.2.0" + } + }, + "node_modules/@webassemblyjs/leb128": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.9.0.tgz", + "integrity": "sha512-ENVzM5VwV1ojs9jam6vPys97B/S65YQtv/aanqnU7D8aSoHFX8GyhGg0CMfyKNIHBuAVjy3tlzd5QMMINa7wpw==", + "dev": true, + "dependencies": { + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@webassemblyjs/utf8": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.9.0.tgz", + "integrity": "sha512-GZbQlWtopBTP0u7cHrEx+73yZKrQoBMpwkGEIqlacljhXCkVM1kMQge/Mf+csMJAjEdSwhOyLAS0AoR3AG5P8w==", + "dev": true + }, + "node_modules/@webassemblyjs/wasm-edit": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.9.0.tgz", + "integrity": "sha512-FgHzBm80uwz5M8WKnMTn6j/sVbqilPdQXTWraSjBwFXSYGirpkSWE2R9Qvz9tNiTKQvoKILpCuTjBKzOIm0nxw==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/helper-wasm-section": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0", + "@webassemblyjs/wasm-opt": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0", + "@webassemblyjs/wast-printer": "1.9.0" + } + }, + "node_modules/@webassemblyjs/wasm-gen": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.9.0.tgz", + "integrity": "sha512-cPE3o44YzOOHvlsb4+E9qSqjc9Qf9Na1OO/BHFy4OI91XDE14MjFN4lTMezzaIWdPqHnsTodGGNP+iRSYfGkjA==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/ieee754": "1.9.0", + "@webassemblyjs/leb128": "1.9.0", + "@webassemblyjs/utf8": "1.9.0" + } + }, + "node_modules/@webassemblyjs/wasm-opt": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.9.0.tgz", + "integrity": "sha512-Qkjgm6Anhm+OMbIL0iokO7meajkzQD71ioelnfPEj6r4eOFuqm4YC3VBPqXjFyyNwowzbMD+hizmprP/Fwkl2A==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-buffer": "1.9.0", + "@webassemblyjs/wasm-gen": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0" + } + }, + "node_modules/@webassemblyjs/wasm-parser": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.9.0.tgz", + "integrity": "sha512-9+wkMowR2AmdSWQzsPEjFU7njh8HTO5MqO8vjwEHuM+AMHioNqSBONRdr0NQQ3dVQrzp0s8lTcYqzUdb7YgELA==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-api-error": "1.9.0", + "@webassemblyjs/helper-wasm-bytecode": "1.9.0", + "@webassemblyjs/ieee754": "1.9.0", + "@webassemblyjs/leb128": "1.9.0", + "@webassemblyjs/utf8": "1.9.0" + } + }, + "node_modules/@webassemblyjs/wast-parser": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-parser/-/wast-parser-1.9.0.tgz", + "integrity": "sha512-qsqSAP3QQ3LyZjNC/0jBJ/ToSxfYJ8kYyuiGvtn/8MK89VrNEfwj7BPQzJVHi0jGTRK2dGdJ5PRqhtjzoww+bw==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/floating-point-hex-parser": "1.9.0", + "@webassemblyjs/helper-api-error": "1.9.0", + "@webassemblyjs/helper-code-frame": "1.9.0", + "@webassemblyjs/helper-fsm": "1.9.0", + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@webassemblyjs/wast-printer": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.9.0.tgz", + "integrity": "sha512-2J0nE95rHXHyQ24cWjMKJ1tqB/ds8z/cyeOZxJhcb+rW+SQASVjuznUSmdz5GpVJTzU8JkhYut0D3siFDD6wsA==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/wast-parser": "1.9.0", + "@xtuc/long": "4.2.2" + } + }, + "node_modules/@xtuc/ieee754": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", + "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==", + "dev": true + }, + "node_modules/@xtuc/long": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", + "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", + "dev": true + }, + "node_modules/abbrev": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", + "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", + "dev": true + }, + "node_modules/accepts": { + "version": "1.3.8", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", + "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", + "dev": true, + "dependencies": { + "mime-types": "~2.1.34", + "negotiator": "0.6.3" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/acorn": { + "version": "6.4.2", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.2.tgz", + "integrity": "sha512-XtGIhXwF8YM8bJhGxG5kXgjkEuNGLTkoYqVE+KMR+aspr4KGYmKYg7yUe3KghyQ9yheNwLnjmzh/7+gfDBmHCQ==", + "dev": true, + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/agentkeepalive": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/agentkeepalive/-/agentkeepalive-2.2.0.tgz", + "integrity": "sha512-TnB6ziK363p7lR8QpeLC8aMr8EGYBKZTpgzQLfqTs3bR0Oo5VbKdwKf8h0dSzsYrB7lSCgfJnMZKqShvlq5Oyg==", + "dev": true, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ajv-errors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/ajv-errors/-/ajv-errors-1.0.1.tgz", + "integrity": "sha512-DCRfO/4nQ+89p/RK43i8Ezd41EqdGIU4ld7nGF8OQ14oc/we5rEntLCUa7+jrn3nn83BosfwZA0wb4pon2o8iQ==", + "dev": true, + "peerDependencies": { + "ajv": ">=5.0.0" + } + }, + "node_modules/ajv-keywords": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz", + "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", + "dev": true, + "peerDependencies": { + "ajv": "^6.9.1" + } + }, + "node_modules/algoliasearch": { + "version": "3.35.1", + "resolved": "https://registry.npmjs.org/algoliasearch/-/algoliasearch-3.35.1.tgz", + "integrity": "sha512-K4yKVhaHkXfJ/xcUnil04xiSrB8B8yHZoFEhWNpXg23eiCnqvTZw1tn/SqvdsANlYHLJlKl0qi3I/Q2Sqo7LwQ==", + "dev": true, + "dependencies": { + "agentkeepalive": "^2.2.0", + "debug": "^2.6.9", + "envify": "^4.0.0", + "es6-promise": "^4.1.0", + "events": "^1.1.0", + "foreach": "^2.0.5", + "global": "^4.3.2", + "inherits": "^2.0.1", + "isarray": "^2.0.1", + "load-script": "^1.0.0", + "object-keys": "^1.0.11", + "querystring-es3": "^0.2.1", + "reduce": "^1.0.1", + "semver": "^5.1.0", + "tunnel-agent": "^0.6.0" + }, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/algoliasearch/node_modules/semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true, + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/alphanum-sort": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/alphanum-sort/-/alphanum-sort-1.0.2.tgz", + "integrity": "sha512-0FcBfdcmaumGPQ0qPn7Q5qTgz/ooXgIyp1rf8ik5bGX8mpE2YHjC0P/eyQvxu1GURYQgq9ozf2mteQ5ZD9YiyQ==", + "dev": true + }, + "node_modules/ansi-align": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz", + "integrity": "sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==", + "dev": true, + "dependencies": { + "string-width": "^4.1.0" + } + }, + "node_modules/ansi-colors": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.4.tgz", + "integrity": "sha512-hHUXGagefjN2iRrID63xckIvotOXOojhQKWIPUZ4mNUZ9nLZW+7FMNoE1lOkEhNWYsx/7ysGIuJYCiMAA9FnrA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", + "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", + "dev": true, + "dependencies": { + "type-fest": "^0.21.3" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ansi-escapes/node_modules/type-fest": { + "version": "0.21.3", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", + "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ansi-html-community": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/ansi-html-community/-/ansi-html-community-0.0.8.tgz", + "integrity": "sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw==", + "dev": true, + "engines": [ + "node >= 0.8.0" + ], + "bin": { + "ansi-html": "bin/ansi-html" + } + }, + "node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "dev": true, + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/aproba": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", + "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==", + "dev": true + }, + "node_modules/argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "dependencies": { + "sprintf-js": "~1.0.2" + } + }, + "node_modules/arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha512-YVIQ82gZPGBebQV/a8dar4AitzCQs0jjXwMPZllpXMaGjXPYVUawSxQrRsjhjupyVxEvbHgUmIhKVlND+j02kA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/arr-flatten": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", + "integrity": "sha512-sKpyeERZ02v1FeCZT8lrfJq5u6goHCtpTAzPwJYe7c8SPFOboNjNg1vz2L4VTn9T4PQxEx13TbXLmYUcS6Ug7Q==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/array-buffer-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", + "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "is-array-buffer": "^3.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array-flatten": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-2.1.2.tgz", + "integrity": "sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ==", + "dev": true + }, + "node_modules/array-union": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", + "integrity": "sha512-Dxr6QJj/RdU/hCaBjOfxW+q6lyuVE6JFWIrAUpuOOhoJJoQ99cUn3igRaHVB5P9WrgFVN0FfArM3x0cueOU8ng==", + "dev": true, + "dependencies": { + "array-uniq": "^1.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/array-uniq": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", + "integrity": "sha512-MNha4BWQ6JbwhFhj03YK552f7cb3AzoE8SzeljgChvL1dl3IcvggXVz1DilzySZkCja+CXuZbdW7yATchWn8/Q==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha512-SleRWjh9JUud2wH1hPs9rZBZ33H6T9HOiL0uwGnGx9FpE6wKGyfWugmbkEOIs6qWrZhg0LWeLziLrEwQJhs5mQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/array.prototype.reduce": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/array.prototype.reduce/-/array.prototype.reduce-1.0.6.tgz", + "integrity": "sha512-UW+Mz8LG/sPSU8jRDCjVr6J/ZKAGpHfwrZ6kWTG5qCxIEiXdVshqGnu5vEZA8S1y6X4aCSbQZ0/EEsfvEvBiSg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-array-method-boxes-properly": "^1.0.0", + "is-string": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/arraybuffer.prototype.slice": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz", + "integrity": "sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.0", + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "get-intrinsic": "^1.2.1", + "is-array-buffer": "^3.0.2", + "is-shared-array-buffer": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/asn1": { + "version": "0.2.6", + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.6.tgz", + "integrity": "sha512-ix/FxPn0MDjeyJ7i/yoHGFt/EX6LyNbxSEhPPXODPL+KB0VPk86UYfL0lMdy+KCnv+fmvIzySwaK5COwqVbWTQ==", + "dev": true, + "dependencies": { + "safer-buffer": "~2.1.0" + } + }, + "node_modules/asn1.js": { + "version": "5.4.1", + "resolved": "https://registry.npmjs.org/asn1.js/-/asn1.js-5.4.1.tgz", + "integrity": "sha512-+I//4cYPccV8LdmBLiX8CYvf9Sp3vQsrqu2QNXRcrbiWvcx/UdlFiqUJJzxRQxgsZmvhXhn4cSKeSmoFjVdupA==", + "dev": true, + "dependencies": { + "bn.js": "^4.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0", + "safer-buffer": "^2.1.0" + } + }, + "node_modules/asn1.js/node_modules/bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", + "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", + "dev": true + }, + "node_modules/assert": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/assert/-/assert-1.5.1.tgz", + "integrity": "sha512-zzw1uCAgLbsKwBfFc8CX78DDg+xZeBksSO3vwVIDDN5i94eOrPsSSyiVhmsSABFDM/OcpE2aagCat9dnWQLG1A==", + "dev": true, + "dependencies": { + "object.assign": "^4.1.4", + "util": "^0.10.4" + } + }, + "node_modules/assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha512-NfJ4UzBCcQGLDlQq7nHxH+tv3kyZ0hHQqF5BO6J7tNJeP5do1llPr8dZ8zHonfhAu0PHAdMkSo+8o0wxg9lZWw==", + "dev": true, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/assert/node_modules/inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==", + "dev": true + }, + "node_modules/assert/node_modules/util": { + "version": "0.10.4", + "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz", + "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", + "dev": true, + "dependencies": { + "inherits": "2.0.3" + } + }, + "node_modules/assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", + "integrity": "sha512-Q+JC7Whu8HhmTdBph/Tq59IoRtoy6KAm5zzPv00WdujX82lbAL8K7WVjne7vdCsAmbF4AYaDOPyO3k0kl8qIrw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/async": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.4.tgz", + "integrity": "sha512-mzo5dfJYwAn29PeiJ0zvwTo04zj8HDJj0Mn8TD7sno7q12prdbnasKJHhkm2c1LgrhlJ0teaea8860oxi51mGA==", + "dev": true, + "dependencies": { + "lodash": "^4.17.14" + } + }, + "node_modules/async-each": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.6.tgz", + "integrity": "sha512-c646jH1avxr+aVpndVMeAfYw7wAa6idufrlN3LPA4PmKS0QEGp6PIC9nwz0WQkkvBGAMEki3pFdtxaF39J9vvg==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + ] + }, + "node_modules/async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", + "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==", + "dev": true + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", + "dev": true + }, + "node_modules/atob": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", + "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", + "dev": true, + "bin": { + "atob": "bin/atob.js" + }, + "engines": { + "node": ">= 4.5.0" + } + }, + "node_modules/autocomplete.js": { + "version": "0.36.0", + "resolved": "https://registry.npmjs.org/autocomplete.js/-/autocomplete.js-0.36.0.tgz", + "integrity": "sha512-jEwUXnVMeCHHutUt10i/8ZiRaCb0Wo+ZyKxeGsYwBDtw6EJHqEeDrq4UwZRD8YBSvp3g6klP678il2eeiVXN2Q==", + "dev": true, + "dependencies": { + "immediate": "^3.2.3" + } + }, + "node_modules/autoprefixer": { + "version": "9.8.8", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-9.8.8.tgz", + "integrity": "sha512-eM9d/swFopRt5gdJ7jrpCwgvEMIayITpojhkkSMRsFHYuH5bkSQ4p/9qTEHtmNudUZh22Tehu7I6CxAW0IXTKA==", + "dev": true, + "dependencies": { + "browserslist": "^4.12.0", + "caniuse-lite": "^1.0.30001109", + "normalize-range": "^0.1.2", + "num2fraction": "^1.2.2", + "picocolors": "^0.2.1", + "postcss": "^7.0.32", + "postcss-value-parser": "^4.1.0" + }, + "bin": { + "autoprefixer": "bin/autoprefixer" + }, + "funding": { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/autoprefixer" + } + }, + "node_modules/available-typed-arrays": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", + "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/aws-sign2": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", + "integrity": "sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/aws4": { + "version": "1.12.0", + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.12.0.tgz", + "integrity": "sha512-NmWvPnx0F1SfrQbYwOi7OeaNGokp9XhzNioJ/CSBs8Qa4vxug81mhJEAVZwxXuBmYB5KDRfMq/F3RR0BIU7sWg==", + "dev": true + }, + "node_modules/babel-extract-comments": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/babel-extract-comments/-/babel-extract-comments-1.0.0.tgz", + "integrity": "sha512-qWWzi4TlddohA91bFwgt6zO/J0X+io7Qp184Fw0m2JYRSTZnJbFR8+07KmzudHCZgOiKRCrjhylwv9Xd8gfhVQ==", + "dev": true, + "dependencies": { + "babylon": "^6.18.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/babel-loader": { + "version": "8.3.0", + "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-8.3.0.tgz", + "integrity": "sha512-H8SvsMF+m9t15HNLMipppzkC+Y2Yq+v3SonZyU70RBL/h1gxPkH08Ot8pEE9Z4Kd+czyWJClmFS8qzIP9OZ04Q==", + "dev": true, + "dependencies": { + "find-cache-dir": "^3.3.1", + "loader-utils": "^2.0.0", + "make-dir": "^3.1.0", + "schema-utils": "^2.6.5" + }, + "engines": { + "node": ">= 8.9" + }, + "peerDependencies": { + "@babel/core": "^7.0.0", + "webpack": ">=2" + } + }, + "node_modules/babel-loader/node_modules/loader-utils": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz", + "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==", + "dev": true, + "dependencies": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^2.1.2" + }, + "engines": { + "node": ">=8.9.0" + } + }, + "node_modules/babel-plugin-dynamic-import-node": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.3.tgz", + "integrity": "sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ==", + "dev": true, + "dependencies": { + "object.assign": "^4.1.0" + } + }, + "node_modules/babel-plugin-polyfill-corejs2": { + "version": "0.4.7", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.4.7.tgz", + "integrity": "sha512-LidDk/tEGDfuHW2DWh/Hgo4rmnw3cduK6ZkOI1NPFceSK3n/yAGeOsNT7FLnSGHkXj3RHGSEVkN3FsCTY6w2CQ==", + "dev": true, + "dependencies": { + "@babel/compat-data": "^7.22.6", + "@babel/helper-define-polyfill-provider": "^0.4.4", + "semver": "^6.3.1" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/babel-plugin-polyfill-corejs3": { + "version": "0.8.7", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.8.7.tgz", + "integrity": "sha512-KyDvZYxAzkC0Aj2dAPyDzi2Ym15e5JKZSK+maI7NAwSqofvuFglbSsxE7wUOvTg9oFVnHMzVzBKcqEb4PJgtOA==", + "dev": true, + "dependencies": { + "@babel/helper-define-polyfill-provider": "^0.4.4", + "core-js-compat": "^3.33.1" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/babel-plugin-polyfill-regenerator": { + "version": "0.5.4", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.5.4.tgz", + "integrity": "sha512-S/x2iOCvDaCASLYsOOgWOq4bCfKYVqvO/uxjkaYyZ3rVsVE3CeAI/c84NpyuBBymEgNvHgjEot3a9/Z/kXvqsg==", + "dev": true, + "dependencies": { + "@babel/helper-define-polyfill-provider": "^0.4.4" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, + "node_modules/babel-plugin-syntax-object-rest-spread": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", + "integrity": "sha512-C4Aq+GaAj83pRQ0EFgTvw5YO6T3Qz2KGrNRwIj9mSoNHVvdZY4KO2uA6HNtNXCw993iSZnckY1aLW8nOi8i4+w==", + "dev": true + }, + "node_modules/babel-plugin-transform-object-rest-spread": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-object-rest-spread/-/babel-plugin-transform-object-rest-spread-6.26.0.tgz", + "integrity": "sha512-ocgA9VJvyxwt+qJB0ncxV8kb/CjfTcECUY4tQ5VT7nP6Aohzobm8CDFaQ5FHdvZQzLmf0sgDxB8iRXZXxwZcyA==", + "dev": true, + "dependencies": { + "babel-plugin-syntax-object-rest-spread": "^6.8.0", + "babel-runtime": "^6.26.0" + } + }, + "node_modules/babel-runtime": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", + "integrity": "sha512-ITKNuq2wKlW1fJg9sSW52eepoYgZBggvOAHC0u/CYu/qxQ9EVzThCgR69BnSXLHjy2f7SY5zaQ4yt7H9ZVxY2g==", + "dev": true, + "dependencies": { + "core-js": "^2.4.0", + "regenerator-runtime": "^0.11.0" + } + }, + "node_modules/babel-runtime/node_modules/core-js": { + "version": "2.6.12", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.12.tgz", + "integrity": "sha512-Kb2wC0fvsWfQrgk8HU5lW6U/Lcs8+9aaYcy4ZFc6DDlo4nZ7n70dEgE5rtR0oG6ufKDUnrwfWL1mXR5ljDatrQ==", + "deprecated": "core-js@<3.23.3 is no longer maintained and not recommended for usage due to the number of issues. Because of the V8 engine whims, feature detection in old core-js versions could cause a slowdown up to 100x even if nothing is polyfilled. Some versions have web compatibility issues. Please, upgrade your dependencies to the actual version of core-js.", + "dev": true, + "hasInstallScript": true + }, + "node_modules/babel-runtime/node_modules/regenerator-runtime": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", + "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==", + "dev": true + }, + "node_modules/babylon": { + "version": "6.18.0", + "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", + "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==", + "dev": true, + "bin": { + "babylon": "bin/babylon.js" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" + }, + "node_modules/base": { + "version": "0.11.2", + "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "dev": true, + "dependencies": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/base/node_modules/define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha512-cZTYKFWspt9jZsMscWo8sc/5lbPC9Q0N5nBLgb+Yd915iL3udB1uFgS3B8YCx66UVHq018DAVFoee7x+gxggeA==", + "dev": true, + "dependencies": { + "is-descriptor": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/base64-js": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", + "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/batch": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz", + "integrity": "sha512-x+VAiMRL6UPkx+kudNvxTl6hB2XNNCG2r+7wixVfIYwu/2HKRXimwQyaumLjMveWvT2Hkd/cAJw+QBMfJ/EKVw==", + "dev": true + }, + "node_modules/bcrypt-pbkdf": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", + "integrity": "sha512-qeFIXtP4MSoi6NLqO12WfqARWWuCKi2Rn/9hJLEmtB5yTNr9DqFWkJRCf2qShWzPeAMRnOgCrq0sg/KLv5ES9w==", + "dev": true, + "dependencies": { + "tweetnacl": "^0.14.3" + } + }, + "node_modules/big.js": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", + "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/binary-extensions": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", + "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/bindings": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", + "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", + "dev": true, + "optional": true, + "dependencies": { + "file-uri-to-path": "1.0.0" + } + }, + "node_modules/bluebird": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", + "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==", + "dev": true + }, + "node_modules/bn.js": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-5.2.1.tgz", + "integrity": "sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ==", + "dev": true + }, + "node_modules/body-parser": { + "version": "1.20.1", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", + "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", + "dev": true, + "dependencies": { + "bytes": "3.1.2", + "content-type": "~1.0.4", + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "on-finished": "2.4.1", + "qs": "6.11.0", + "raw-body": "2.5.1", + "type-is": "~1.6.18", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/body-parser/node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/body-parser/node_modules/qs": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", + "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", + "dev": true, + "dependencies": { + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/bonjour": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/bonjour/-/bonjour-3.5.0.tgz", + "integrity": "sha512-RaVTblr+OnEli0r/ud8InrU7D+G0y6aJhlxaLa6Pwty4+xoxboF1BsUI45tujvRpbj9dQVoglChqonGAsjEBYg==", + "dev": true, + "dependencies": { + "array-flatten": "^2.1.0", + "deep-equal": "^1.0.1", + "dns-equal": "^1.0.0", + "dns-txt": "^2.0.2", + "multicast-dns": "^6.0.1", + "multicast-dns-service-types": "^1.1.0" + } + }, + "node_modules/boolbase": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", + "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", + "dev": true + }, + "node_modules/boxen": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/boxen/-/boxen-4.2.0.tgz", + "integrity": "sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ==", + "dev": true, + "dependencies": { + "ansi-align": "^3.0.0", + "camelcase": "^5.3.1", + "chalk": "^3.0.0", + "cli-boxes": "^2.2.0", + "string-width": "^4.1.0", + "term-size": "^2.1.0", + "type-fest": "^0.8.1", + "widest-line": "^3.1.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/boxen/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/boxen/node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/boxen/node_modules/chalk": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", + "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/boxen/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/boxen/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/boxen/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/boxen/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/braces": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", + "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", + "dev": true, + "dependencies": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/braces/node_modules/extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==", + "dev": true, + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/braces/node_modules/is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/brorand": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", + "integrity": "sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w==", + "dev": true + }, + "node_modules/browserify-aes": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", + "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", + "dev": true, + "dependencies": { + "buffer-xor": "^1.0.3", + "cipher-base": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.3", + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/browserify-cipher": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/browserify-cipher/-/browserify-cipher-1.0.1.tgz", + "integrity": "sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w==", + "dev": true, + "dependencies": { + "browserify-aes": "^1.0.4", + "browserify-des": "^1.0.0", + "evp_bytestokey": "^1.0.0" + } + }, + "node_modules/browserify-des": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/browserify-des/-/browserify-des-1.0.2.tgz", + "integrity": "sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A==", + "dev": true, + "dependencies": { + "cipher-base": "^1.0.1", + "des.js": "^1.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "node_modules/browserify-rsa": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.1.0.tgz", + "integrity": "sha512-AdEER0Hkspgno2aR97SAf6vi0y0k8NuOpGnVH3O99rcA5Q6sh8QxcngtHuJ6uXwnfAXNM4Gn1Gb7/MV1+Ymbog==", + "dev": true, + "dependencies": { + "bn.js": "^5.0.0", + "randombytes": "^2.0.1" + } + }, + "node_modules/browserify-sign": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/browserify-sign/-/browserify-sign-4.2.2.tgz", + "integrity": "sha512-1rudGyeYY42Dk6texmv7c4VcQ0EsvVbLwZkA+AQB7SxvXxmcD93jcHie8bzecJ+ChDlmAm2Qyu0+Ccg5uhZXCg==", + "dev": true, + "dependencies": { + "bn.js": "^5.2.1", + "browserify-rsa": "^4.1.0", + "create-hash": "^1.2.0", + "create-hmac": "^1.1.7", + "elliptic": "^6.5.4", + "inherits": "^2.0.4", + "parse-asn1": "^5.1.6", + "readable-stream": "^3.6.2", + "safe-buffer": "^5.2.1" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/browserify-sign/node_modules/readable-stream": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/browserify-sign/node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/browserify-zlib": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz", + "integrity": "sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA==", + "dev": true, + "dependencies": { + "pako": "~1.0.5" + } + }, + "node_modules/browserslist": { + "version": "4.22.2", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.2.tgz", + "integrity": "sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "caniuse-lite": "^1.0.30001565", + "electron-to-chromium": "^1.4.601", + "node-releases": "^2.0.14", + "update-browserslist-db": "^1.0.13" + }, + "bin": { + "browserslist": "cli.js" + }, + "engines": { + "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" + } + }, + "node_modules/buffer": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz", + "integrity": "sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg==", + "dev": true, + "dependencies": { + "base64-js": "^1.0.2", + "ieee754": "^1.1.4", + "isarray": "^1.0.0" + } + }, + "node_modules/buffer-from": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", + "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", + "dev": true + }, + "node_modules/buffer-indexof": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-indexof/-/buffer-indexof-1.1.1.tgz", + "integrity": "sha512-4/rOEg86jivtPTeOUUT61jJO1Ya1TrR/OkqCSZDyq84WJh3LuuiphBYJN+fm5xufIk4XAFcEwte/8WzC8If/1g==", + "dev": true + }, + "node_modules/buffer-json": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/buffer-json/-/buffer-json-2.0.0.tgz", + "integrity": "sha512-+jjPFVqyfF1esi9fvfUs3NqM0pH1ziZ36VP4hmA/y/Ssfo/5w5xHKfTw9BwQjoJ1w/oVtpLomqwUHKdefGyuHw==", + "dev": true + }, + "node_modules/buffer-xor": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", + "integrity": "sha512-571s0T7nZWK6vB67HI5dyUF7wXiNcfaPPPTl6zYCNApANjIvYJTg7hlud/+cJpdAhS7dVzqMLmfhfHR3rAcOjQ==", + "dev": true + }, + "node_modules/buffer/node_modules/isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", + "dev": true + }, + "node_modules/builtin-status-codes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", + "integrity": "sha512-HpGFw18DgFWlncDfjTa2rcQ4W88O1mC8e8yZ2AvQY5KDaktSTwo+KRf6nHK6FRI5FyRyb/5T6+TSxfP7QyGsmQ==", + "dev": true + }, + "node_modules/bundle-require": { + "version": "2.1.8", + "resolved": "https://registry.npmjs.org/bundle-require/-/bundle-require-2.1.8.tgz", + "integrity": "sha512-oOEg3A0hy/YzvNWNowtKD0pmhZKseOFweCbgyMqTIih4gRY1nJWsvrOCT27L9NbIyL5jMjTFrAUpGxxpW68Puw==", + "dev": true, + "peerDependencies": { + "esbuild": ">=0.13" + } + }, + "node_modules/bytes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", + "integrity": "sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/cac": { + "version": "6.7.14", + "resolved": "https://registry.npmjs.org/cac/-/cac-6.7.14.tgz", + "integrity": "sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/cacache": { + "version": "12.0.4", + "resolved": "https://registry.npmjs.org/cacache/-/cacache-12.0.4.tgz", + "integrity": "sha512-a0tMB40oefvuInr4Cwb3GerbL9xTj1D5yg0T5xrjGCGyfvbxseIXX7BAO/u/hIXdafzOI5JC3wDwHyf24buOAQ==", + "dev": true, + "dependencies": { + "bluebird": "^3.5.5", + "chownr": "^1.1.1", + "figgy-pudding": "^3.5.1", + "glob": "^7.1.4", + "graceful-fs": "^4.1.15", + "infer-owner": "^1.0.3", + "lru-cache": "^5.1.1", + "mississippi": "^3.0.0", + "mkdirp": "^0.5.1", + "move-concurrently": "^1.0.1", + "promise-inflight": "^1.0.1", + "rimraf": "^2.6.3", + "ssri": "^6.0.1", + "unique-filename": "^1.1.1", + "y18n": "^4.0.0" + } + }, + "node_modules/cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "dev": true, + "dependencies": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/cache-loader": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/cache-loader/-/cache-loader-3.0.1.tgz", + "integrity": "sha512-HzJIvGiGqYsFUrMjAJNDbVZoG7qQA+vy9AIoKs7s9DscNfki0I589mf2w6/tW+kkFH3zyiknoWV5Jdynu6b/zw==", + "dev": true, + "dependencies": { + "buffer-json": "^2.0.0", + "find-cache-dir": "^2.1.0", + "loader-utils": "^1.2.3", + "mkdirp": "^0.5.1", + "neo-async": "^2.6.1", + "schema-utils": "^1.0.0" + }, + "engines": { + "node": ">= 6.9.0" + }, + "peerDependencies": { + "webpack": "^4.0.0" + } + }, + "node_modules/cache-loader/node_modules/find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "dev": true, + "dependencies": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/cache-loader/node_modules/find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "dependencies": { + "locate-path": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/cache-loader/node_modules/locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "dependencies": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/cache-loader/node_modules/make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "dependencies": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/cache-loader/node_modules/p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "dependencies": { + "p-limit": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/cache-loader/node_modules/path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/cache-loader/node_modules/pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "dependencies": { + "find-up": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/cache-loader/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/cache-loader/node_modules/semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true, + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/cacheable-request": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/cacheable-request/-/cacheable-request-6.1.0.tgz", + "integrity": "sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg==", + "dev": true, + "dependencies": { + "clone-response": "^1.0.2", + "get-stream": "^5.1.0", + "http-cache-semantics": "^4.0.0", + "keyv": "^3.0.0", + "lowercase-keys": "^2.0.0", + "normalize-url": "^4.1.0", + "responselike": "^1.0.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cacheable-request/node_modules/get-stream": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", + "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", + "dev": true, + "dependencies": { + "pump": "^3.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cacheable-request/node_modules/lowercase-keys": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz", + "integrity": "sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/cacheable-request/node_modules/normalize-url": { + "version": "4.5.1", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-4.5.1.tgz", + "integrity": "sha512-9UZCFRHQdNrfTpGg8+1INIg93B6zE0aXMVFkw1WFwvO4SlZywU6aLg5Of0Ap/PgcbSw4LNxvMWXMeugwMCX0AA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/call-bind": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz", + "integrity": "sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.1", + "set-function-length": "^1.1.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/call-me-maybe": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/call-me-maybe/-/call-me-maybe-1.0.2.tgz", + "integrity": "sha512-HpX65o1Hnr9HH25ojC1YGs7HCQLq0GCOibSaWER0eNpgJ/Z1MZv2mTc7+xh6WOPxbRVcmgbv4hGU+uSQ/2xFZQ==", + "dev": true + }, + "node_modules/caller-callsite": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-callsite/-/caller-callsite-2.0.0.tgz", + "integrity": "sha512-JuG3qI4QOftFsZyOn1qq87fq5grLIyk1JYd5lJmdA+fG7aQ9pA/i3JIJGcO3q0MrRcHlOt1U+ZeHW8Dq9axALQ==", + "dev": true, + "dependencies": { + "callsites": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/caller-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-2.0.0.tgz", + "integrity": "sha512-MCL3sf6nCSXOwCTzvPKhN18TU7AHTvdtam8DAogxcrJ8Rjfbbg7Lgng64H9Iy+vUV6VGFClN/TyxBkAebLRR4A==", + "dev": true, + "dependencies": { + "caller-callsite": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/callsites": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", + "integrity": "sha512-ksWePWBloaWPxJYQ8TL0JHvtci6G5QTKwQ95RcWAa/lzoAKuAOflGdAK92hpHXjkwb8zLxoLNUoNYZgVsaJzvQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/camel-case": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-3.0.0.tgz", + "integrity": "sha512-+MbKztAYHXPr1jNTSKQF52VpcFjwY5RkR7fxksV8Doo4KAYc5Fl4UJRgthBbTmEx8C54DqahhbLJkDwjI3PI/w==", + "dev": true, + "dependencies": { + "no-case": "^2.2.0", + "upper-case": "^1.1.1" + } + }, + "node_modules/camelcase": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", + "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/caniuse-api": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz", + "integrity": "sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw==", + "dev": true, + "dependencies": { + "browserslist": "^4.0.0", + "caniuse-lite": "^1.0.0", + "lodash.memoize": "^4.1.2", + "lodash.uniq": "^4.5.0" + } + }, + "node_modules/caniuse-lite": { + "version": "1.0.30001576", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001576.tgz", + "integrity": "sha512-ff5BdakGe2P3SQsMsiqmt1Lc8221NR1VzHj5jXN5vBny9A6fpze94HiVV/n7XRosOlsShJcvMv5mdnpjOGCEgg==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ] + }, + "node_modules/caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==", + "dev": true + }, + "node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/chokidar": { + "version": "2.1.8", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz", + "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==", + "deprecated": "Chokidar 2 does not receive security updates since 2019. Upgrade to chokidar 3 with 15x fewer dependencies", + "dev": true, + "dependencies": { + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" + }, + "optionalDependencies": { + "fsevents": "^1.2.7" + } + }, + "node_modules/chokidar/node_modules/anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", + "dev": true, + "dependencies": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + } + }, + "node_modules/chokidar/node_modules/anymatch/node_modules/normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha512-3pKJwH184Xo/lnH6oyP1q2pMd7HcypqqmRs91/6/i2CGtWwIKGCkOOMTm/zXbgTEWHw1uNpNi/igc3ePOYHb6w==", + "dev": true, + "dependencies": { + "remove-trailing-separator": "^1.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/chownr": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", + "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", + "dev": true + }, + "node_modules/chrome-trace-event": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz", + "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==", + "dev": true, + "engines": { + "node": ">=6.0" + } + }, + "node_modules/ci-info": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", + "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==", + "dev": true + }, + "node_modules/cipher-base": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", + "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", + "dev": true, + "dependencies": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/class-utils": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", + "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", + "dev": true, + "dependencies": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/class-utils/node_modules/define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha512-Rr7ADjQZenceVOAKop6ALkkRAmH1A4Gx9hV/7ZujPUN2rkATqFO0JZLZInbAjpZYoJ1gUx8MRMQVkYemcbMSTA==", + "dev": true, + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/class-utils/node_modules/is-descriptor": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.7.tgz", + "integrity": "sha512-C3grZTvObeN1xud4cRWl366OMXZTj0+HGyk4hvfpx4ZHt1Pb60ANSXqCK7pdOTeUQpRzECBSTphqvD7U+l22Eg==", + "dev": true, + "dependencies": { + "is-accessor-descriptor": "^1.0.1", + "is-data-descriptor": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/clean-css": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.2.4.tgz", + "integrity": "sha512-EJUDT7nDVFDvaQgAo2G/PJvxmp1o/c6iXLbswsBbUFXi1Nr+AjA2cKmfbKDMjMvzEe75g3P6JkaDDAKk96A85A==", + "dev": true, + "dependencies": { + "source-map": "~0.6.0" + }, + "engines": { + "node": ">= 4.0" + } + }, + "node_modules/cli-boxes": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/cli-boxes/-/cli-boxes-2.2.1.tgz", + "integrity": "sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==", + "dev": true, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cliui": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", + "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/cliui/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/cliui/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/cliui/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" + }, + "node_modules/cliui/node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/clone-response": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/clone-response/-/clone-response-1.0.3.tgz", + "integrity": "sha512-ROoL94jJH2dUVML2Y/5PEDNaSHgeOdSDicUyS7izcF63G6sTc/FTjLub4b8Il9S8S0beOfYt0TaA5qvFK+w0wA==", + "dev": true, + "dependencies": { + "mimic-response": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/coa": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/coa/-/coa-2.0.2.tgz", + "integrity": "sha512-q5/jG+YQnSy4nRTV4F7lPepBJZ8qBNJJDBuJdoejDyLXgmL7IEo+Le2JDZudFTFt7mrCqIRaSjws4ygRCTCAXA==", + "dev": true, + "dependencies": { + "@types/q": "^1.5.1", + "chalk": "^2.4.1", + "q": "^1.1.2" + }, + "engines": { + "node": ">= 4.0" + } + }, + "node_modules/collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", + "integrity": "sha512-lNkKvzEeMBBjUGHZ+q6z9pSJla0KWAQPvtzhEV9+iGyQYG+pBpl7xKDhxoNSOZH2hhv0v5k0y2yAM4o4SjoSkw==", + "dev": true, + "dependencies": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/color": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/color/-/color-3.2.1.tgz", + "integrity": "sha512-aBl7dZI9ENN6fUGC7mWpMTPNHmWUSNan9tuWN6ahh5ZLNk9baLJOnSMlrQkHcrfFgz2/RigjUVAjdx36VcemKA==", + "dev": true, + "dependencies": { + "color-convert": "^1.9.3", + "color-string": "^1.6.0" + } + }, + "node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true + }, + "node_modules/color-string": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.9.1.tgz", + "integrity": "sha512-shrVawQFojnZv6xM40anx4CkoDP+fZsw/ZerEMsW/pyzsRbElpsL/DBVW7q3ExxwusdNXI3lXpuhEZkzs8p5Eg==", + "dev": true, + "dependencies": { + "color-name": "^1.0.0", + "simple-swizzle": "^0.2.2" + } + }, + "node_modules/colors": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/colors/-/colors-1.4.0.tgz", + "integrity": "sha512-a+UqTh4kgZg/SlGvfbzDHpgRu7AAQOmmqRHJnxhRZICKFUT91brVhNNt58CMWU9PsBbv3PDCZUHbVxuDiH2mtA==", + "dev": true, + "engines": { + "node": ">=0.1.90" + } + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "dev": true, + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commander": { + "version": "2.17.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz", + "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==", + "dev": true + }, + "node_modules/common-tags": { + "version": "1.8.2", + "resolved": "https://registry.npmjs.org/common-tags/-/common-tags-1.8.2.tgz", + "integrity": "sha512-gk/Z852D2Wtb//0I+kRFNKKE9dIIVirjoqPoA1wJU+XePVXZfGeBpk45+A1rKO4Q43prqWBNY/MiIeRLbPWUaA==", + "dev": true, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", + "dev": true + }, + "node_modules/component-emitter": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.1.tgz", + "integrity": "sha512-T0+barUSQRTUQASh8bx02dl+DhF54GtIDY13Y3m9oWTklKbb3Wv974meRpeZ3lp1JpLVECWWNHC4vaG2XHXouQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/compressible": { + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", + "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", + "dev": true, + "dependencies": { + "mime-db": ">= 1.43.0 < 2" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/compression": { + "version": "1.7.4", + "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz", + "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==", + "dev": true, + "dependencies": { + "accepts": "~1.3.5", + "bytes": "3.0.0", + "compressible": "~2.0.16", + "debug": "2.6.9", + "on-headers": "~1.0.2", + "safe-buffer": "5.1.2", + "vary": "~1.1.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" + }, + "node_modules/concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "dev": true, + "engines": [ + "node >= 0.8" + ], + "dependencies": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + } + }, + "node_modules/configstore": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/configstore/-/configstore-5.0.1.tgz", + "integrity": "sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA==", + "dev": true, + "dependencies": { + "dot-prop": "^5.2.0", + "graceful-fs": "^4.1.2", + "make-dir": "^3.0.0", + "unique-string": "^2.0.0", + "write-file-atomic": "^3.0.0", + "xdg-basedir": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/connect-history-api-fallback": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-1.6.0.tgz", + "integrity": "sha512-e54B99q/OUoH64zYYRf3HBP5z24G38h5D3qXu23JGRoigpX5Ss4r9ZnDk3g0Z8uQC2x2lPaJ+UlWBc1ZWBWdLg==", + "dev": true, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/consola": { + "version": "2.15.3", + "resolved": "https://registry.npmjs.org/consola/-/consola-2.15.3.tgz", + "integrity": "sha512-9vAdYbHj6x2fLKC4+oPH0kFzY/orMZyG2Aj+kNylHxKGJ/Ed4dpNyAQYwJOdqO4zdM7XpVHmyejQDcQHrnuXbw==", + "dev": true + }, + "node_modules/console-browserify": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.2.0.tgz", + "integrity": "sha512-ZMkYO/LkF17QvCPqM0gxw8yUzigAOZOSWSHg91FH6orS7vcEj5dVZTidN2fQ14yBSdg97RqhSNwLUXInd52OTA==", + "dev": true + }, + "node_modules/consolidate": { + "version": "0.15.1", + "resolved": "https://registry.npmjs.org/consolidate/-/consolidate-0.15.1.tgz", + "integrity": "sha512-DW46nrsMJgy9kqAbPt5rKaCr7uFtpo4mSUvLHIUbJEjm0vo+aY5QLwBUq3FK4tRnJr/X0Psc0C4jf/h+HtXSMw==", + "deprecated": "Please upgrade to consolidate v1.0.0+ as it has been modernized with several long-awaited fixes implemented. Maintenance is supported by Forward Email at https://forwardemail.net ; follow/watch https://github.com/ladjs/consolidate for updates and release changelog", + "dev": true, + "dependencies": { + "bluebird": "^3.1.1" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/constants-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", + "integrity": "sha512-xFxOwqIzR/e1k1gLiWEophSCMqXcwVHIH7akf7b/vxcUeGunlj3hvZaaqxwHsTgn+IndtkQJgSztIDWeumWJDQ==", + "dev": true + }, + "node_modules/content-disposition": { + "version": "0.5.4", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", + "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", + "dev": true, + "dependencies": { + "safe-buffer": "5.2.1" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/content-disposition/node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/content-type": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", + "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/convert-source-map": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==", + "dev": true + }, + "node_modules/cookie": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", + "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==", + "dev": true + }, + "node_modules/copy-concurrently": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/copy-concurrently/-/copy-concurrently-1.0.5.tgz", + "integrity": "sha512-f2domd9fsVDFtaFcbaRZuYXwtdmnzqbADSwhSWYxYB/Q8zsdUUFMXVRwXGDMWmbEzAn1kdRrtI1T/KTFOL4X2A==", + "dev": true, + "dependencies": { + "aproba": "^1.1.1", + "fs-write-stream-atomic": "^1.0.8", + "iferr": "^0.1.5", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.0" + } + }, + "node_modules/copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", + "integrity": "sha512-XgZ0pFcakEUlbwQEVNg3+QAis1FyTL3Qel9FYy8pSkQqoG3PNoT0bOCQtOXcOkur21r2Eq2kI+IE+gsmAEVlYw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/copy-webpack-plugin": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/copy-webpack-plugin/-/copy-webpack-plugin-5.1.2.tgz", + "integrity": "sha512-Uh7crJAco3AjBvgAy9Z75CjK8IG+gxaErro71THQ+vv/bl4HaQcpkexAY8KVW/T6D2W2IRr+couF/knIRkZMIQ==", + "dev": true, + "dependencies": { + "cacache": "^12.0.3", + "find-cache-dir": "^2.1.0", + "glob-parent": "^3.1.0", + "globby": "^7.1.1", + "is-glob": "^4.0.1", + "loader-utils": "^1.2.3", + "minimatch": "^3.0.4", + "normalize-path": "^3.0.0", + "p-limit": "^2.2.1", + "schema-utils": "^1.0.0", + "serialize-javascript": "^4.0.0", + "webpack-log": "^2.0.0" + }, + "engines": { + "node": ">= 6.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependencies": { + "webpack": "^4.0.0 || ^5.0.0" + } + }, + "node_modules/copy-webpack-plugin/node_modules/find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "dev": true, + "dependencies": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/copy-webpack-plugin/node_modules/find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "dependencies": { + "locate-path": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/copy-webpack-plugin/node_modules/globby": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/globby/-/globby-7.1.1.tgz", + "integrity": "sha512-yANWAN2DUcBtuus5Cpd+SKROzXHs2iVXFZt/Ykrfz6SAXqacLX25NZpltE+39ceMexYF4TtEadjuSTw8+3wX4g==", + "dev": true, + "dependencies": { + "array-union": "^1.0.1", + "dir-glob": "^2.0.0", + "glob": "^7.1.2", + "ignore": "^3.3.5", + "pify": "^3.0.0", + "slash": "^1.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/copy-webpack-plugin/node_modules/globby/node_modules/pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/copy-webpack-plugin/node_modules/ignore": { + "version": "3.3.10", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.10.tgz", + "integrity": "sha512-Pgs951kaMm5GXP7MOvxERINe3gsaVjUWFm+UZPSq9xYriQAksyhg0csnS0KXSNRD5NmNdapXEpjxG49+AKh/ug==", + "dev": true + }, + "node_modules/copy-webpack-plugin/node_modules/locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "dependencies": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/copy-webpack-plugin/node_modules/make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "dependencies": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/copy-webpack-plugin/node_modules/p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "dependencies": { + "p-limit": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/copy-webpack-plugin/node_modules/path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/copy-webpack-plugin/node_modules/pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "dependencies": { + "find-up": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/copy-webpack-plugin/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/copy-webpack-plugin/node_modules/semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true, + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/copy-webpack-plugin/node_modules/slash": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", + "integrity": "sha512-3TYDR7xWt4dIqV2JauJr+EJeW356RXijHeUlO+8djJ+uBXPn8/2dpzBc8yQhh583sVvc9CvFAeQVgijsH+PNNg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/core-js": { + "version": "3.35.0", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.35.0.tgz", + "integrity": "sha512-ntakECeqg81KqMueeGJ79Q5ZgQNR+6eaE8sxGCx62zMbAIj65q+uYvatToew3m6eAGdU4gNZwpZ34NMe4GYswg==", + "dev": true, + "hasInstallScript": true, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/core-js" + } + }, + "node_modules/core-js-compat": { + "version": "3.35.0", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.35.0.tgz", + "integrity": "sha512-5blwFAddknKeNgsjBzilkdQ0+YK8L1PfqPYq40NOYMYFSS38qj+hpTcLLWwpIwA2A5bje/x5jmVn2tzUMg9IVw==", + "dev": true, + "dependencies": { + "browserslist": "^4.22.2" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/core-js" + } + }, + "node_modules/core-util-is": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", + "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", + "dev": true + }, + "node_modules/cosmiconfig": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-5.2.1.tgz", + "integrity": "sha512-H65gsXo1SKjf8zmrJ67eJk8aIRKV5ff2D4uKZIBZShbhGSpEmsQOPW/SKMKYhSTrqR7ufy6RP69rPogdaPh/kA==", + "dev": true, + "dependencies": { + "import-fresh": "^2.0.0", + "is-directory": "^0.3.1", + "js-yaml": "^3.13.1", + "parse-json": "^4.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/create-ecdh": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.4.tgz", + "integrity": "sha512-mf+TCx8wWc9VpuxfP2ht0iSISLZnt0JgWlrOKZiNqyUZWnjIaCIVNQArMHnCZKfEYRg6IM7A+NeJoN8gf/Ws0A==", + "dev": true, + "dependencies": { + "bn.js": "^4.1.0", + "elliptic": "^6.5.3" + } + }, + "node_modules/create-ecdh/node_modules/bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", + "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", + "dev": true + }, + "node_modules/create-hash": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", + "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", + "dev": true, + "dependencies": { + "cipher-base": "^1.0.1", + "inherits": "^2.0.1", + "md5.js": "^1.3.4", + "ripemd160": "^2.0.1", + "sha.js": "^2.4.0" + } + }, + "node_modules/create-hmac": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", + "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", + "dev": true, + "dependencies": { + "cipher-base": "^1.0.3", + "create-hash": "^1.1.0", + "inherits": "^2.0.1", + "ripemd160": "^2.0.0", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "node_modules/cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "dev": true, + "dependencies": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + }, + "engines": { + "node": ">=4.8" + } + }, + "node_modules/cross-spawn/node_modules/semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true, + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/crypto-browserify": { + "version": "3.12.0", + "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.12.0.tgz", + "integrity": "sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg==", + "dev": true, + "dependencies": { + "browserify-cipher": "^1.0.0", + "browserify-sign": "^4.0.0", + "create-ecdh": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.0", + "diffie-hellman": "^5.0.0", + "inherits": "^2.0.1", + "pbkdf2": "^3.0.3", + "public-encrypt": "^4.0.0", + "randombytes": "^2.0.0", + "randomfill": "^1.0.3" + }, + "engines": { + "node": "*" + } + }, + "node_modules/crypto-random-string": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/crypto-random-string/-/crypto-random-string-2.0.0.tgz", + "integrity": "sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/css": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/css/-/css-2.2.4.tgz", + "integrity": "sha512-oUnjmWpy0niI3x/mPL8dVEI1l7MnG3+HHyRPHf+YFSbK+svOhXpmSOcDURUh2aOCgl2grzrOPt1nHLuCVFULLw==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "source-map": "^0.6.1", + "source-map-resolve": "^0.5.2", + "urix": "^0.1.0" + } + }, + "node_modules/css-color-names": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/css-color-names/-/css-color-names-0.0.4.tgz", + "integrity": "sha512-zj5D7X1U2h2zsXOAM8EyUREBnnts6H+Jm+d1M2DbiQQcUtnqgQsMrdo8JW9R80YFUmIdBZeMu5wvYM7hcgWP/Q==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/css-declaration-sorter": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/css-declaration-sorter/-/css-declaration-sorter-4.0.1.tgz", + "integrity": "sha512-BcxQSKTSEEQUftYpBVnsH4SF05NTuBokb19/sBt6asXGKZ/6VP7PLG1CBCkFDYOnhXhPh0jMhO6xZ71oYHXHBA==", + "dev": true, + "dependencies": { + "postcss": "^7.0.1", + "timsort": "^0.3.0" + }, + "engines": { + "node": ">4" + } + }, + "node_modules/css-loader": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-2.1.1.tgz", + "integrity": "sha512-OcKJU/lt232vl1P9EEDamhoO9iKY3tIjY5GU+XDLblAykTdgs6Ux9P1hTHve8nFKy5KPpOXOsVI/hIwi3841+w==", + "dev": true, + "dependencies": { + "camelcase": "^5.2.0", + "icss-utils": "^4.1.0", + "loader-utils": "^1.2.3", + "normalize-path": "^3.0.0", + "postcss": "^7.0.14", + "postcss-modules-extract-imports": "^2.0.0", + "postcss-modules-local-by-default": "^2.0.6", + "postcss-modules-scope": "^2.1.0", + "postcss-modules-values": "^2.0.0", + "postcss-value-parser": "^3.3.0", + "schema-utils": "^1.0.0" + }, + "engines": { + "node": ">= 6.9.0" + }, + "peerDependencies": { + "webpack": "^4.0.0" + } + }, + "node_modules/css-loader/node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/css-loader/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/css-loader/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/css-parse": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/css-parse/-/css-parse-2.0.0.tgz", + "integrity": "sha512-UNIFik2RgSbiTwIW1IsFwXWn6vs+bYdq83LKTSOsx7NJR7WII9dxewkHLltfTLVppoUApHV0118a4RZRI9FLwA==", + "dev": true, + "dependencies": { + "css": "^2.0.0" + } + }, + "node_modules/css-select": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-2.1.0.tgz", + "integrity": "sha512-Dqk7LQKpwLoH3VovzZnkzegqNSuAziQyNZUcrdDM401iY+R5NkGBXGmtO05/yaXQziALuPogeG0b7UAgjnTJTQ==", + "dev": true, + "dependencies": { + "boolbase": "^1.0.0", + "css-what": "^3.2.1", + "domutils": "^1.7.0", + "nth-check": "^1.0.2" + } + }, + "node_modules/css-select-base-adapter": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/css-select-base-adapter/-/css-select-base-adapter-0.1.1.tgz", + "integrity": "sha512-jQVeeRG70QI08vSTwf1jHxp74JoZsr2XSgETae8/xC8ovSnL2WF87GTLO86Sbwdt2lK4Umg4HnnwMO4YF3Ce7w==", + "dev": true + }, + "node_modules/css-tree": { + "version": "1.0.0-alpha.37", + "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.0.0-alpha.37.tgz", + "integrity": "sha512-DMxWJg0rnz7UgxKT0Q1HU/L9BeJI0M6ksor0OgqOnF+aRCDWg/N2641HmVyU9KVIu0OVVWOb2IpC9A+BJRnejg==", + "dev": true, + "dependencies": { + "mdn-data": "2.0.4", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/css-what": { + "version": "3.4.2", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-3.4.2.tgz", + "integrity": "sha512-ACUm3L0/jiZTqfzRM3Hi9Q8eZqd6IK37mMWPLz9PJxkLWllYeRf+EHUSHYEtFop2Eqytaq1FizFVh7XfBnXCDQ==", + "dev": true, + "engines": { + "node": ">= 6" + }, + "funding": { + "url": "https://github.com/sponsors/fb55" + } + }, + "node_modules/cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", + "dev": true, + "bin": { + "cssesc": "bin/cssesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/cssnano": { + "version": "4.1.11", + "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-4.1.11.tgz", + "integrity": "sha512-6gZm2htn7xIPJOHY824ERgj8cNPgPxyCSnkXc4v7YvNW+TdVfzgngHcEhy/8D11kUWRUMbke+tC+AUcUsnMz2g==", + "dev": true, + "dependencies": { + "cosmiconfig": "^5.0.0", + "cssnano-preset-default": "^4.0.8", + "is-resolvable": "^1.0.0", + "postcss": "^7.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/cssnano-preset-default": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/cssnano-preset-default/-/cssnano-preset-default-4.0.8.tgz", + "integrity": "sha512-LdAyHuq+VRyeVREFmuxUZR1TXjQm8QQU/ktoo/x7bz+SdOge1YKc5eMN6pRW7YWBmyq59CqYba1dJ5cUukEjLQ==", + "dev": true, + "dependencies": { + "css-declaration-sorter": "^4.0.1", + "cssnano-util-raw-cache": "^4.0.1", + "postcss": "^7.0.0", + "postcss-calc": "^7.0.1", + "postcss-colormin": "^4.0.3", + "postcss-convert-values": "^4.0.1", + "postcss-discard-comments": "^4.0.2", + "postcss-discard-duplicates": "^4.0.2", + "postcss-discard-empty": "^4.0.1", + "postcss-discard-overridden": "^4.0.1", + "postcss-merge-longhand": "^4.0.11", + "postcss-merge-rules": "^4.0.3", + "postcss-minify-font-values": "^4.0.2", + "postcss-minify-gradients": "^4.0.2", + "postcss-minify-params": "^4.0.2", + "postcss-minify-selectors": "^4.0.2", + "postcss-normalize-charset": "^4.0.1", + "postcss-normalize-display-values": "^4.0.2", + "postcss-normalize-positions": "^4.0.2", + "postcss-normalize-repeat-style": "^4.0.2", + "postcss-normalize-string": "^4.0.2", + "postcss-normalize-timing-functions": "^4.0.2", + "postcss-normalize-unicode": "^4.0.1", + "postcss-normalize-url": "^4.0.1", + "postcss-normalize-whitespace": "^4.0.2", + "postcss-ordered-values": "^4.1.2", + "postcss-reduce-initial": "^4.0.3", + "postcss-reduce-transforms": "^4.0.2", + "postcss-svgo": "^4.0.3", + "postcss-unique-selectors": "^4.0.1" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/cssnano-util-get-arguments": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cssnano-util-get-arguments/-/cssnano-util-get-arguments-4.0.0.tgz", + "integrity": "sha512-6RIcwmV3/cBMG8Aj5gucQRsJb4vv4I4rn6YjPbVWd5+Pn/fuG+YseGvXGk00XLkoZkaj31QOD7vMUpNPC4FIuw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/cssnano-util-get-match": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cssnano-util-get-match/-/cssnano-util-get-match-4.0.0.tgz", + "integrity": "sha512-JPMZ1TSMRUPVIqEalIBNoBtAYbi8okvcFns4O0YIhcdGebeYZK7dMyHJiQ6GqNBA9kE0Hym4Aqym5rPdsV/4Cw==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/cssnano-util-raw-cache": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/cssnano-util-raw-cache/-/cssnano-util-raw-cache-4.0.1.tgz", + "integrity": "sha512-qLuYtWK2b2Dy55I8ZX3ky1Z16WYsx544Q0UWViebptpwn/xDBmog2TLg4f+DBMg1rJ6JDWtn96WHbOKDWt1WQA==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/cssnano-util-same-parent": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/cssnano-util-same-parent/-/cssnano-util-same-parent-4.0.1.tgz", + "integrity": "sha512-WcKx5OY+KoSIAxBW6UBBRay1U6vkYheCdjyVNDm85zt5K9mHoGOfsOsqIszfAqrQQFIIKgjh2+FDgIj/zsl21Q==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/csso": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/csso/-/csso-4.2.0.tgz", + "integrity": "sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA==", + "dev": true, + "dependencies": { + "css-tree": "^1.1.2" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/csso/node_modules/css-tree": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.1.3.tgz", + "integrity": "sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==", + "dev": true, + "dependencies": { + "mdn-data": "2.0.14", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/csso/node_modules/mdn-data": { + "version": "2.0.14", + "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.14.tgz", + "integrity": "sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow==", + "dev": true + }, + "node_modules/csstype": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", + "dev": true + }, + "node_modules/cyclist": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/cyclist/-/cyclist-1.0.2.tgz", + "integrity": "sha512-0sVXIohTfLqVIW3kb/0n6IiWF3Ifj5nm2XaSrLq2DI6fKIGa2fYAZdk917rUneaeLVpYfFcyXE2ft0fe3remsA==", + "dev": true + }, + "node_modules/dashdash": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", + "integrity": "sha512-jRFi8UDGo6j+odZiEpjazZaWqEal3w/basFjQHQEwVtZJGDpxbH1MeYluwCS8Xq5wmLJooDlMgvVarmWfGM44g==", + "dev": true, + "dependencies": { + "assert-plus": "^1.0.0" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/de-indent": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/de-indent/-/de-indent-1.0.2.tgz", + "integrity": "sha512-e/1zu3xH5MQryN2zdVaF0OrdNLUbvWxzMbi+iNA6Bky7l1RoP8a2fIbRocyHclXt/arDrrR6lL3TqFD9pMQTsg==", + "dev": true + }, + "node_modules/debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/decode-uri-component": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.2.tgz", + "integrity": "sha512-FqUYQ+8o158GyGTrMFJms9qh3CqTKvAqgqsTnkLI8sKu0028orqBhxNMFkFen0zGyg6epACD32pjVk58ngIErQ==", + "dev": true, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/decompress-response": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-3.3.0.tgz", + "integrity": "sha512-BzRPQuY1ip+qDonAOz42gRm/pg9F768C+npV/4JOsxRC2sq+Rlk+Q4ZCAsOhnIaMrgarILY+RMUIvMmmX1qAEA==", + "dev": true, + "dependencies": { + "mimic-response": "^1.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/deep-equal": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.1.2.tgz", + "integrity": "sha512-5tdhKF6DbU7iIzrIOa1AOUt39ZRm13cmL1cGEh//aqR8x9+tNfbywRf0n5FD/18OKMdo7DNEtrX2t22ZAkI+eg==", + "dev": true, + "dependencies": { + "is-arguments": "^1.1.1", + "is-date-object": "^1.0.5", + "is-regex": "^1.1.4", + "object-is": "^1.1.5", + "object-keys": "^1.1.1", + "regexp.prototype.flags": "^1.5.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/deep-extend": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", + "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", + "dev": true, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/deepmerge": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-1.5.2.tgz", + "integrity": "sha512-95k0GDqvBjZavkuvzx/YqVLv/6YYa17fz6ILMSf7neqQITCPbnfEnQvEgMPNjH4kgobe7+WIL0yJEHku+H3qtQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/default-gateway": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-4.2.0.tgz", + "integrity": "sha512-h6sMrVB1VMWVrW13mSc6ia/DwYYw5MN6+exNu1OaJeFac5aSAvwM7lZ0NVfTABuSkQelr4h5oebg3KB1XPdjgA==", + "dev": true, + "dependencies": { + "execa": "^1.0.0", + "ip-regex": "^2.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/default-gateway/node_modules/execa": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", + "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", + "dev": true, + "dependencies": { + "cross-spawn": "^6.0.0", + "get-stream": "^4.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/default-gateway/node_modules/is-stream": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", + "integrity": "sha512-uQPm8kcs47jx38atAcWTVxyltQYoPT68y9aWYdV6yWXSyW8mzSat0TL6CiWdZeCdF3KrAvpVtnHbTv4RN+rqdQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/default-gateway/node_modules/npm-run-path": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", + "integrity": "sha512-lJxZYlT4DW/bRUtFh1MQIWqmLwQfAxnqWG4HhEdjMlkrJYnJn0Jrr2u3mgxqaWsdiBc76TYkTG/mhrnYTuzfHw==", + "dev": true, + "dependencies": { + "path-key": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/defer-to-connect": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz", + "integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==", + "dev": true + }, + "node_modules/define-data-property": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.1.tgz", + "integrity": "sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.1", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/define-properties": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "dev": true, + "dependencies": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/define-property": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", + "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "dev": true, + "dependencies": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/del": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/del/-/del-4.1.1.tgz", + "integrity": "sha512-QwGuEUouP2kVwQenAsOof5Fv8K9t3D8Ca8NxcXKrIpEHjTXK5J2nXLdP+ALI1cgv8wj7KuwBhTwBkOZSJKM5XQ==", + "dev": true, + "dependencies": { + "@types/glob": "^7.1.1", + "globby": "^6.1.0", + "is-path-cwd": "^2.0.0", + "is-path-in-cwd": "^2.0.0", + "p-map": "^2.0.0", + "pify": "^4.0.1", + "rimraf": "^2.6.3" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/del/node_modules/globby": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", + "integrity": "sha512-KVbFv2TQtbzCoxAnfD6JcHZTYCzyliEaaeM/gH8qQdkKr5s0OP9scEgvdcngyk7AVdY6YVW/TJHd+lQ/Df3Daw==", + "dev": true, + "dependencies": { + "array-union": "^1.0.1", + "glob": "^7.0.3", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/del/node_modules/globby/node_modules/pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "dev": true, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/des.js": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/des.js/-/des.js-1.1.0.tgz", + "integrity": "sha512-r17GxjhUCjSRy8aiJpr8/UadFIzMzJGexI3Nmz4ADi9LYSFx4gTBp80+NaX/YsXWWLhpZ7v/v/ubEc/bCNfKwg==", + "dev": true, + "dependencies": { + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "node_modules/destroy": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", + "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", + "dev": true, + "engines": { + "node": ">= 0.8", + "npm": "1.2.8000 || >= 1.4.16" + } + }, + "node_modules/detect-node": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.1.0.tgz", + "integrity": "sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==", + "dev": true + }, + "node_modules/diffie-hellman": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.3.tgz", + "integrity": "sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg==", + "dev": true, + "dependencies": { + "bn.js": "^4.1.0", + "miller-rabin": "^4.0.0", + "randombytes": "^2.0.0" + } + }, + "node_modules/diffie-hellman/node_modules/bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", + "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", + "dev": true + }, + "node_modules/dir-glob": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-2.2.2.tgz", + "integrity": "sha512-f9LBi5QWzIW3I6e//uxZoLBlUt9kcp66qo0sSCxL6YZKc75R1c4MFCoe/LaZiBGmgujvQdxc5Bn3QhfyvK5Hsw==", + "dev": true, + "dependencies": { + "path-type": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/dns-equal": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/dns-equal/-/dns-equal-1.0.0.tgz", + "integrity": "sha512-z+paD6YUQsk+AbGCEM4PrOXSss5gd66QfcVBFTKR/HpFL9jCqikS94HYwKww6fQyO7IxrIIyUu+g0Ka9tUS2Cg==", + "dev": true + }, + "node_modules/dns-packet": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-1.3.4.tgz", + "integrity": "sha512-BQ6F4vycLXBvdrJZ6S3gZewt6rcrks9KBgM9vrhW+knGRqc8uEdT7fuCwloc7nny5xNoMJ17HGH0R/6fpo8ECA==", + "dev": true, + "dependencies": { + "ip": "^1.1.0", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/dns-txt": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/dns-txt/-/dns-txt-2.0.2.tgz", + "integrity": "sha512-Ix5PrWjphuSoUXV/Zv5gaFHjnaJtb02F2+Si3Ht9dyJ87+Z/lMmy+dpNHtTGraNK958ndXq2i+GLkWsWHcKaBQ==", + "dev": true, + "dependencies": { + "buffer-indexof": "^1.0.0" + } + }, + "node_modules/docsearch.js": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/docsearch.js/-/docsearch.js-2.6.3.tgz", + "integrity": "sha512-GN+MBozuyz664ycpZY0ecdQE0ND/LSgJKhTLA0/v3arIS3S1Rpf2OJz6A35ReMsm91V5apcmzr5/kM84cvUg+A==", + "deprecated": "This package has been deprecated and is no longer maintained. Please use @docsearch/js.", + "dev": true, + "dependencies": { + "algoliasearch": "^3.24.5", + "autocomplete.js": "0.36.0", + "hogan.js": "^3.0.2", + "request": "^2.87.0", + "stack-utils": "^1.0.1", + "to-factory": "^1.0.0", + "zepto": "^1.2.0" + } + }, + "node_modules/dom-converter": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/dom-converter/-/dom-converter-0.2.0.tgz", + "integrity": "sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA==", + "dev": true, + "dependencies": { + "utila": "~0.4" + } + }, + "node_modules/dom-serializer": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", + "integrity": "sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g==", + "dev": true, + "dependencies": { + "domelementtype": "^2.0.1", + "entities": "^2.0.0" + } + }, + "node_modules/dom-serializer/node_modules/domelementtype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", + "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/fb55" + } + ] + }, + "node_modules/dom-serializer/node_modules/entities": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", + "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", + "dev": true, + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" + } + }, + "node_modules/dom-walk": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/dom-walk/-/dom-walk-0.1.2.tgz", + "integrity": "sha512-6QvTW9mrGeIegrFXdtQi9pk7O/nSK6lSdXW2eqUspN5LWD7UTji2Fqw5V2YLjBpHEoU9Xl/eUWNpDeZvoyOv2w==", + "dev": true + }, + "node_modules/domain-browser": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.2.0.tgz", + "integrity": "sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA==", + "dev": true, + "engines": { + "node": ">=0.4", + "npm": ">=1.2" + } + }, + "node_modules/domelementtype": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", + "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==", + "dev": true + }, + "node_modules/domhandler": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz", + "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==", + "dev": true, + "dependencies": { + "domelementtype": "^2.2.0" + }, + "engines": { + "node": ">= 4" + }, + "funding": { + "url": "https://github.com/fb55/domhandler?sponsor=1" + } + }, + "node_modules/domhandler/node_modules/domelementtype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", + "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/fb55" + } + ] + }, + "node_modules/domutils": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz", + "integrity": "sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==", + "dev": true, + "dependencies": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "node_modules/dot-prop": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.3.0.tgz", + "integrity": "sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q==", + "dev": true, + "dependencies": { + "is-obj": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/duplexer3": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/duplexer3/-/duplexer3-0.1.5.tgz", + "integrity": "sha512-1A8za6ws41LQgv9HrE/66jyC5yuSjQ3L/KOpFtoBilsAK2iA2wuS5rTt1OCzIvtS2V7nVmedsUU+DGRcjBmOYA==", + "dev": true + }, + "node_modules/duplexify": { + "version": "3.7.1", + "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.7.1.tgz", + "integrity": "sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g==", + "dev": true, + "dependencies": { + "end-of-stream": "^1.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.0.0", + "stream-shift": "^1.0.0" + } + }, + "node_modules/ecc-jsbn": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", + "integrity": "sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw==", + "dev": true, + "dependencies": { + "jsbn": "~0.1.0", + "safer-buffer": "^2.1.0" + } + }, + "node_modules/ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==", + "dev": true + }, + "node_modules/electron-to-chromium": { + "version": "1.4.630", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.630.tgz", + "integrity": "sha512-osHqhtjojpCsACVnuD11xO5g9xaCyw7Qqn/C2KParkMv42i8jrJJgx3g7mkHfpxwhy9MnOJr8+pKOdZ7qzgizg==", + "dev": true + }, + "node_modules/elliptic": { + "version": "6.5.4", + "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.4.tgz", + "integrity": "sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ==", + "dev": true, + "dependencies": { + "bn.js": "^4.11.9", + "brorand": "^1.1.0", + "hash.js": "^1.0.0", + "hmac-drbg": "^1.0.1", + "inherits": "^2.0.4", + "minimalistic-assert": "^1.0.1", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "node_modules/elliptic/node_modules/bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", + "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", + "dev": true + }, + "node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" + }, + "node_modules/emojis-list": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz", + "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/encodeurl": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", + "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/end-of-stream": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", + "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", + "dev": true, + "dependencies": { + "once": "^1.4.0" + } + }, + "node_modules/enhanced-resolve": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-4.5.0.tgz", + "integrity": "sha512-Nv9m36S/vxpsI+Hc4/ZGRs0n9mXqSWGGq49zxb/cJfPAQMbUtttJAlNPS4AQzaBdw/pKskw5bMbekT/Y7W/Wlg==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.1.2", + "memory-fs": "^0.5.0", + "tapable": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/enhanced-resolve/node_modules/memory-fs": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.5.0.tgz", + "integrity": "sha512-jA0rdU5KoQMC0e6ppoNRtpp6vjFq6+NY7r8hywnC7V+1Xj/MtHwGIbB1QaK/dunyjWteJzmkpd7ooeWg10T7GA==", + "dev": true, + "dependencies": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + }, + "engines": { + "node": ">=4.3.0 <5.0.0 || >=5.10" + } + }, + "node_modules/entities": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz", + "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==", + "dev": true + }, + "node_modules/envify": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/envify/-/envify-4.1.0.tgz", + "integrity": "sha512-IKRVVoAYr4pIx4yIWNsz9mOsboxlNXiu7TNBnem/K/uTHdkyzXWDzHCK7UTolqBbgaBz0tQHsD3YNls0uIIjiw==", + "dev": true, + "dependencies": { + "esprima": "^4.0.0", + "through": "~2.3.4" + }, + "bin": { + "envify": "bin/envify" + } + }, + "node_modules/envinfo": { + "version": "7.11.0", + "resolved": "https://registry.npmjs.org/envinfo/-/envinfo-7.11.0.tgz", + "integrity": "sha512-G9/6xF1FPbIw0TtalAMaVPpiq2aDEuKLXM314jPVAO9r2fo2a4BLqMNkmRS7O/xPPZ+COAhGIz3ETvHEV3eUcg==", + "dev": true, + "bin": { + "envinfo": "dist/cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/errno": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.8.tgz", + "integrity": "sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==", + "dev": true, + "dependencies": { + "prr": "~1.0.1" + }, + "bin": { + "errno": "cli.js" + } + }, + "node_modules/error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "dependencies": { + "is-arrayish": "^0.2.1" + } + }, + "node_modules/es-abstract": { + "version": "1.22.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.3.tgz", + "integrity": "sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.0", + "arraybuffer.prototype.slice": "^1.0.2", + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.5", + "es-set-tostringtag": "^2.0.1", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.2", + "get-symbol-description": "^1.0.0", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0", + "internal-slot": "^1.0.5", + "is-array-buffer": "^3.0.2", + "is-callable": "^1.2.7", + "is-negative-zero": "^2.0.2", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.2", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.12", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.4", + "regexp.prototype.flags": "^1.5.1", + "safe-array-concat": "^1.0.1", + "safe-regex-test": "^1.0.0", + "string.prototype.trim": "^1.2.8", + "string.prototype.trimend": "^1.0.7", + "string.prototype.trimstart": "^1.0.7", + "typed-array-buffer": "^1.0.0", + "typed-array-byte-length": "^1.0.0", + "typed-array-byte-offset": "^1.0.0", + "typed-array-length": "^1.0.4", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es-array-method-boxes-properly": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-array-method-boxes-properly/-/es-array-method-boxes-properly-1.0.0.tgz", + "integrity": "sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA==", + "dev": true + }, + "node_modules/es-set-tostringtag": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz", + "integrity": "sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.2", + "has-tostringtag": "^1.0.0", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es6-promise": { + "version": "4.2.8", + "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz", + "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", + "dev": true + }, + "node_modules/esbuild": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.7.tgz", + "integrity": "sha512-+u/msd6iu+HvfysUPkZ9VHm83LImmSNnecYPfFI01pQ7TTcsFR+V0BkybZX7mPtIaI7LCrse6YRj+v3eraJSgw==", + "dev": true, + "hasInstallScript": true, + "bin": { + "esbuild": "bin/esbuild" + }, + "optionalDependencies": { + "esbuild-android-arm64": "0.14.7", + "esbuild-darwin-64": "0.14.7", + "esbuild-darwin-arm64": "0.14.7", + "esbuild-freebsd-64": "0.14.7", + "esbuild-freebsd-arm64": "0.14.7", + "esbuild-linux-32": "0.14.7", + "esbuild-linux-64": "0.14.7", + "esbuild-linux-arm": "0.14.7", + "esbuild-linux-arm64": "0.14.7", + "esbuild-linux-mips64le": "0.14.7", + "esbuild-linux-ppc64le": "0.14.7", + "esbuild-netbsd-64": "0.14.7", + "esbuild-openbsd-64": "0.14.7", + "esbuild-sunos-64": "0.14.7", + "esbuild-windows-32": "0.14.7", + "esbuild-windows-64": "0.14.7", + "esbuild-windows-arm64": "0.14.7" + } + }, + "node_modules/esbuild-android-arm64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.7.tgz", + "integrity": "sha512-9/Q1NC4JErvsXzJKti0NHt+vzKjZOgPIjX/e6kkuCzgfT/GcO3FVBcGIv4HeJG7oMznE6KyKhvLrFgt7CdU2/w==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/esbuild-darwin-64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.7.tgz", + "integrity": "sha512-Z9X+3TT/Xj+JiZTVlwHj2P+8GoiSmUnGVz0YZTSt8WTbW3UKw5Pw2ucuJ8VzbD2FPy0jbIKJkko/6CMTQchShQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/esbuild-darwin-arm64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.7.tgz", + "integrity": "sha512-68e7COhmwIiLXBEyxUxZSSU0akgv8t3e50e2QOtKdBUE0F6KIRISzFntLe2rYlNqSsjGWsIO6CCc9tQxijjSkw==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/esbuild-freebsd-64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.7.tgz", + "integrity": "sha512-76zy5jAjPiXX/S3UvRgG85Bb0wy0zv/J2lel3KtHi4V7GUTBfhNUPt0E5bpSXJ6yMT7iThhnA5rOn+IJiUcslQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ] + }, + "node_modules/esbuild-freebsd-arm64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.7.tgz", + "integrity": "sha512-lSlYNLiqyzd7qCN5CEOmLxn7MhnGHPcu5KuUYOG1i+t5A6q7LgBmfYC9ZHJBoYyow3u4CNu79AWHbvVLpE/VQQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "freebsd" + ] + }, + "node_modules/esbuild-linux-32": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.7.tgz", + "integrity": "sha512-Vk28u409wVOXqTaT6ek0TnfQG4Ty1aWWfiysIaIRERkNLhzLhUf4i+qJBN8mMuGTYOkE40F0Wkbp6m+IidOp2A==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/esbuild-linux-64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.7.tgz", + "integrity": "sha512-+Lvz6x+8OkRk3K2RtZwO+0a92jy9si9cUea5Zoru4yJ/6EQm9ENX5seZE0X9DTwk1dxJbjmLsJsd3IoowyzgVg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/esbuild-linux-arm": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.7.tgz", + "integrity": "sha512-OzpXEBogbYdcBqE4uKynuSn5YSetCvK03Qv1HcOY1VN6HmReuatjJ21dCH+YPHSpMEF0afVCnNfffvsGEkxGJQ==", + "cpu": [ + "arm" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/esbuild-linux-arm64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.7.tgz", + "integrity": "sha512-kJd5beWSqteSAW086qzCEsH6uwpi7QRIpzYWHzEYwKKu9DiG1TwIBegQJmLpPsLp4v5RAFjea0JAmAtpGtRpqg==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/esbuild-linux-mips64le": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.7.tgz", + "integrity": "sha512-mFWpnDhZJmj/h7pxqn1GGDsKwRfqtV7fx6kTF5pr4PfXe8pIaTERpwcKkoCwZUkWAOmUEjMIUAvFM72A6hMZnA==", + "cpu": [ + "mips64el" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/esbuild-linux-ppc64le": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.7.tgz", + "integrity": "sha512-wM7f4M0bsQXfDL4JbbYD0wsr8cC8KaQ3RPWc/fV27KdErPW7YsqshZZSjDV0kbhzwpNNdhLItfbaRT8OE8OaKA==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/esbuild-netbsd-64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.7.tgz", + "integrity": "sha512-J/afS7woKyzGgAL5FlgvMyqgt5wQ597lgsT+xc2yJ9/7BIyezeXutXqfh05vszy2k3kSvhLesugsxIA71WsqBw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "netbsd" + ] + }, + "node_modules/esbuild-openbsd-64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.7.tgz", + "integrity": "sha512-7CcxgdlCD+zAPyveKoznbgr3i0Wnh0L8BDGRCjE/5UGkm5P/NQko51tuIDaYof8zbmXjjl0OIt9lSo4W7I8mrw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "openbsd" + ] + }, + "node_modules/esbuild-sunos-64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.7.tgz", + "integrity": "sha512-GKCafP2j/KUljVC3nesw1wLFSZktb2FGCmoT1+730zIF5O6hNroo0bSEofm6ZK5mNPnLiSaiLyRB9YFgtkd5Xg==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "sunos" + ] + }, + "node_modules/esbuild-windows-32": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.7.tgz", + "integrity": "sha512-5I1GeL/gZoUUdTPA0ws54bpYdtyeA2t6MNISalsHpY269zK8Jia/AXB3ta/KcDHv2SvNwabpImeIPXC/k0YW6A==", + "cpu": [ + "ia32" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/esbuild-windows-64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.7.tgz", + "integrity": "sha512-CIGKCFpQOSlYsLMbxt8JjxxvVw9MlF1Rz2ABLVfFyHUF5OeqHD5fPhGrCVNaVrhO8Xrm+yFmtjcZudUGr5/WYQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/esbuild-windows-arm64": { + "version": "0.14.7", + "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.7.tgz", + "integrity": "sha512-eOs1eSivOqN7cFiRIukEruWhaCf75V0N8P0zP7dh44LIhLl8y6/z++vv9qQVbkBm5/D7M7LfCfCTmt1f1wHOCw==", + "cpu": [ + "arm64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/escalade": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", + "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-goat": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/escape-goat/-/escape-goat-2.1.1.tgz", + "integrity": "sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==", + "dev": true + }, + "node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/eslint-scope": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", + "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", + "dev": true, + "dependencies": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "dependencies": { + "estraverse": "^5.2.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esrecurse/node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", + "dev": true, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/eventemitter3": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", + "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==", + "dev": true + }, + "node_modules/events": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", + "integrity": "sha512-kEcvvCBByWXGnZy6JUlgAp2gBIUjfCAV6P6TgT1/aaQKcmuAEC4OZTV1I4EWQLz2gxZw76atuVyvHhTxvi0Flw==", + "dev": true, + "engines": { + "node": ">=0.4.x" + } + }, + "node_modules/eventsource": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/eventsource/-/eventsource-2.0.2.tgz", + "integrity": "sha512-IzUmBGPR3+oUG9dUeXynyNmf91/3zUSJg1lCktzKw47OXuhco54U3r9B7O4XX+Rb1Itm9OZ2b0RkTs10bICOxA==", + "dev": true, + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/evp_bytestokey": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", + "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", + "dev": true, + "dependencies": { + "md5.js": "^1.3.4", + "safe-buffer": "^5.1.1" + } + }, + "node_modules/execa": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", + "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", + "dev": true, + "dependencies": { + "cross-spawn": "^7.0.3", + "get-stream": "^6.0.0", + "human-signals": "^2.1.0", + "is-stream": "^2.0.0", + "merge-stream": "^2.0.0", + "npm-run-path": "^4.0.1", + "onetime": "^5.1.2", + "signal-exit": "^3.0.3", + "strip-final-newline": "^2.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sindresorhus/execa?sponsor=1" + } + }, + "node_modules/execa/node_modules/cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "dev": true, + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/execa/node_modules/get-stream": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", + "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/execa/node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/execa/node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "dev": true, + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/execa/node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/execa/node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha512-w/ozOKR9Obk3qoWeY/WDi6MFta9AoMR+zud60mdnbniMcBxRuFJyDt2LdX/14A1UABeqk+Uk+LDfUpvoGKppZA==", + "dev": true, + "dependencies": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/expand-brackets/node_modules/define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha512-Rr7ADjQZenceVOAKop6ALkkRAmH1A4Gx9hV/7ZujPUN2rkATqFO0JZLZInbAjpZYoJ1gUx8MRMQVkYemcbMSTA==", + "dev": true, + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/expand-brackets/node_modules/extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==", + "dev": true, + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/expand-brackets/node_modules/is-descriptor": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.7.tgz", + "integrity": "sha512-C3grZTvObeN1xud4cRWl366OMXZTj0+HGyk4hvfpx4ZHt1Pb60ANSXqCK7pdOTeUQpRzECBSTphqvD7U+l22Eg==", + "dev": true, + "dependencies": { + "is-accessor-descriptor": "^1.0.1", + "is-data-descriptor": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/expand-brackets/node_modules/is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/express": { + "version": "4.18.2", + "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", + "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", + "dev": true, + "dependencies": { + "accepts": "~1.3.8", + "array-flatten": "1.1.1", + "body-parser": "1.20.1", + "content-disposition": "0.5.4", + "content-type": "~1.0.4", + "cookie": "0.5.0", + "cookie-signature": "1.0.6", + "debug": "2.6.9", + "depd": "2.0.0", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "finalhandler": "1.2.0", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "merge-descriptors": "1.0.1", + "methods": "~1.1.2", + "on-finished": "2.4.1", + "parseurl": "~1.3.3", + "path-to-regexp": "0.1.7", + "proxy-addr": "~2.0.7", + "qs": "6.11.0", + "range-parser": "~1.2.1", + "safe-buffer": "5.2.1", + "send": "0.18.0", + "serve-static": "1.15.0", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "type-is": "~1.6.18", + "utils-merge": "1.0.1", + "vary": "~1.1.2" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/express/node_modules/array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==", + "dev": true + }, + "node_modules/express/node_modules/qs": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", + "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", + "dev": true, + "dependencies": { + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/express/node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", + "dev": true + }, + "node_modules/extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", + "integrity": "sha512-BwY5b5Ql4+qZoefgMj2NUmx+tehVTH/Kf4k1ZEtOHNFcm2wSxMRo992l6X3TIgni2eZVTZ85xMOjF31fwZAj6Q==", + "dev": true, + "dependencies": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "dev": true, + "dependencies": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob/node_modules/define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha512-cZTYKFWspt9jZsMscWo8sc/5lbPC9Q0N5nBLgb+Yd915iL3udB1uFgS3B8YCx66UVHq018DAVFoee7x+gxggeA==", + "dev": true, + "dependencies": { + "is-descriptor": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob/node_modules/extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==", + "dev": true, + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extglob/node_modules/is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/extsprintf": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", + "integrity": "sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g==", + "dev": true, + "engines": [ + "node >=0.6.0" + ] + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true + }, + "node_modules/fast-glob": { + "version": "2.2.7", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-2.2.7.tgz", + "integrity": "sha512-g1KuQwHOZAmOZMuBtHdxDtju+T2RT8jgCC9aANsbpdiDDTSnjgfuVsIBNKbUeJI3oKMRExcfNDtJl4OhbffMsw==", + "dev": true, + "dependencies": { + "@mrmlnc/readdir-enhanced": "^2.2.1", + "@nodelib/fs.stat": "^1.1.2", + "glob-parent": "^3.1.0", + "is-glob": "^4.0.0", + "merge2": "^1.2.3", + "micromatch": "^3.1.10" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true + }, + "node_modules/faye-websocket": { + "version": "0.11.4", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz", + "integrity": "sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==", + "dev": true, + "dependencies": { + "websocket-driver": ">=0.5.1" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/figgy-pudding": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/figgy-pudding/-/figgy-pudding-3.5.2.tgz", + "integrity": "sha512-0btnI/H8f2pavGMN8w40mlSKOfTK2SVJmBfBeVIj3kNw0swwgzyRq0d5TJVOwodFmtvpPeWPN/MCcfuWF0Ezbw==", + "deprecated": "This module is no longer supported.", + "dev": true + }, + "node_modules/figures": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", + "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", + "dev": true, + "dependencies": { + "escape-string-regexp": "^1.0.5" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/file-loader": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/file-loader/-/file-loader-3.0.1.tgz", + "integrity": "sha512-4sNIOXgtH/9WZq4NvlfU3Opn5ynUsqBwSLyM+I7UOwdGigTBYfVVQEwe/msZNX/j4pCJTIM14Fsw66Svo1oVrw==", + "dev": true, + "dependencies": { + "loader-utils": "^1.0.2", + "schema-utils": "^1.0.0" + }, + "engines": { + "node": ">= 6.9.0" + }, + "peerDependencies": { + "webpack": "^4.0.0" + } + }, + "node_modules/file-loader/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/file-uri-to-path": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", + "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", + "dev": true, + "optional": true + }, + "node_modules/fill-range": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha512-VcpLTWqWDiTerugjj8e3+esbg+skS3M9e54UuR3iCeIDMXCLTsAH8hTSzDQU/X6/6t3eYkOKoZSef2PlU6U1XQ==", + "dev": true, + "dependencies": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/fill-range/node_modules/extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==", + "dev": true, + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/fill-range/node_modules/is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/finalhandler": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", + "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", + "dev": true, + "dependencies": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "2.4.1", + "parseurl": "~1.3.3", + "statuses": "2.0.1", + "unpipe": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/find-cache-dir": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz", + "integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==", + "dev": true, + "dependencies": { + "commondir": "^1.0.1", + "make-dir": "^3.0.2", + "pkg-dir": "^4.1.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/avajs/find-cache-dir?sponsor=1" + } + }, + "node_modules/find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "dev": true, + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/flush-write-stream": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.1.1.tgz", + "integrity": "sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "readable-stream": "^2.3.6" + } + }, + "node_modules/follow-redirects": { + "version": "1.15.5", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz", + "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "dependencies": { + "is-callable": "^1.1.3" + } + }, + "node_modules/for-in": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", + "integrity": "sha512-7EwmXrOjyL+ChxMhmG5lnW9MPt1aIeZEwKhQzoBUdTV0N3zuwWDZYVJatDvZ2OyzPUvdIAZDsCetk3coyMfcnQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/foreach": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.6.tgz", + "integrity": "sha512-k6GAGDyqLe9JaebCsFCoudPPWfihKu8pylYXRlqP1J7ms39iPoTtk2fviNglIeQEwdh0bQeKJ01ZPyuyQvKzwg==", + "dev": true + }, + "node_modules/forever-agent": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", + "integrity": "sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/form-data": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", + "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", + "dev": true, + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 0.12" + } + }, + "node_modules/forwarded": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", + "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", + "integrity": "sha512-GMBAbW9antB8iZRHLoGw0b3HANt57diZYFO/HL1JGIC1MjKrdmhxvrJbupnVvpys0zsz7yBApXdQyfepKly2kA==", + "dev": true, + "dependencies": { + "map-cache": "^0.2.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/fresh": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", + "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/from2": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/from2/-/from2-2.3.0.tgz", + "integrity": "sha512-OMcX/4IC/uqEPVgGeyfN22LJk6AZrMkRZHxcHBMBvHScDGgwTm2GT2Wkgtocyd3JfZffjj2kYUDXXII0Fk9W0g==", + "dev": true, + "dependencies": { + "inherits": "^2.0.1", + "readable-stream": "^2.0.0" + } + }, + "node_modules/fs-extra": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", + "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + }, + "engines": { + "node": ">=6 <7 || >=8" + } + }, + "node_modules/fs-write-stream-atomic": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz", + "integrity": "sha512-gehEzmPn2nAwr39eay+x3X34Ra+M2QlVUTLhkXPjWdeO8RF9kszk116avgBJM3ZyNHgHXBNx+VmPaFC36k0PzA==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.1.2", + "iferr": "^0.1.5", + "imurmurhash": "^0.1.4", + "readable-stream": "1 || 2" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==" + }, + "node_modules/fsevents": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.13.tgz", + "integrity": "sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==", + "deprecated": "The v1 package contains DANGEROUS / INSECURE binaries. Upgrade to safe fsevents v2", + "dev": true, + "hasInstallScript": true, + "optional": true, + "os": [ + "darwin" + ], + "dependencies": { + "bindings": "^1.5.0", + "nan": "^2.12.1" + }, + "engines": { + "node": ">= 4.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/function.prototype.name": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/gensync": { + "version": "1.0.0-beta.2", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-intrinsic": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.2.tgz", + "integrity": "sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-own-enumerable-property-symbols": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz", + "integrity": "sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g==", + "dev": true + }, + "node_modules/get-stream": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", + "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", + "dev": true, + "dependencies": { + "pump": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/get-symbol-description": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", + "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-value": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", + "integrity": "sha512-Ln0UQDlxH1BapMu3GPtf7CuYNwRZf2gwCuPqbyG6pB8WfmFpzqcy4xtAaAMUhnNqjMKTiCPZG2oMT3YSx8U2NA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/getpass": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng==", + "dev": true, + "dependencies": { + "assert-plus": "^1.0.0" + } + }, + "node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha512-E8Ak/2+dZY6fnzlR7+ueWvhsH1SjHr4jjss4YS/h4py44jY9MhK/VFdaZJAWDz6BbL21KeteKxFSFpq8OS5gVA==", + "dev": true, + "dependencies": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + } + }, + "node_modules/glob-parent/node_modules/is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha512-UFpDDrPgM6qpnFNI+rh/p3bUaq9hKLZN8bMUWzxmcnZVS3omf4IPK+BrewlnWjO1WmUsMYuSjKh4UJuV4+Lqmw==", + "dev": true, + "dependencies": { + "is-extglob": "^2.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/glob-to-regexp": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.3.0.tgz", + "integrity": "sha512-Iozmtbqv0noj0uDDqoL0zNq0VBEfK2YFoMAZoxJe4cwphvLR+JskfF30QhXHOR4m3KrE6NLRYw+U9MRXvifyig==", + "dev": true + }, + "node_modules/global": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/global/-/global-4.4.0.tgz", + "integrity": "sha512-wv/LAoHdRE3BeTGz53FAamhGlPLhlssK45usmGFThIi4XqnBmjKQ16u+RNbP7WvigRZDxUsM0J3gcQ5yicaL0w==", + "dev": true, + "dependencies": { + "min-document": "^2.19.0", + "process": "^0.11.10" + } + }, + "node_modules/global-dirs": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-2.1.0.tgz", + "integrity": "sha512-MG6kdOUh/xBnyo9cJFeIKkLEc1AyFq42QTU4XiX51i2NEdxLxLWXIjEjmqKeSuKR7pAZjTqUVoT2b2huxVLgYQ==", + "dev": true, + "dependencies": { + "ini": "1.3.7" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/globalthis": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.3.tgz", + "integrity": "sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==", + "dev": true, + "dependencies": { + "define-properties": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/globby": { + "version": "9.2.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-9.2.0.tgz", + "integrity": "sha512-ollPHROa5mcxDEkwg6bPt3QbEf4pDQSNtd6JPL1YvOvAo/7/0VAm9TccUeoTmarjPw4pfUthSCqcyfNB1I3ZSg==", + "dev": true, + "dependencies": { + "@types/glob": "^7.1.1", + "array-union": "^1.0.2", + "dir-glob": "^2.2.2", + "fast-glob": "^2.2.6", + "glob": "^7.1.3", + "ignore": "^4.0.3", + "pify": "^4.0.1", + "slash": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/got": { + "version": "9.6.0", + "resolved": "https://registry.npmjs.org/got/-/got-9.6.0.tgz", + "integrity": "sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q==", + "dev": true, + "dependencies": { + "@sindresorhus/is": "^0.14.0", + "@szmarczak/http-timer": "^1.1.2", + "cacheable-request": "^6.0.0", + "decompress-response": "^3.3.0", + "duplexer3": "^0.1.4", + "get-stream": "^4.1.0", + "lowercase-keys": "^1.0.1", + "mimic-response": "^1.0.1", + "p-cancelable": "^1.0.0", + "to-readable-stream": "^1.0.0", + "url-parse-lax": "^3.0.0" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true + }, + "node_modules/gray-matter": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/gray-matter/-/gray-matter-4.0.3.tgz", + "integrity": "sha512-5v6yZd4JK3eMI3FqqCouswVqwugaA9r4dNZB1wwcmrD02QkV5H0y7XBQW8QwQqEaZY1pM9aqORSORhJRdNK44Q==", + "dev": true, + "dependencies": { + "js-yaml": "^3.13.1", + "kind-of": "^6.0.2", + "section-matter": "^1.0.0", + "strip-bom-string": "^1.0.0" + }, + "engines": { + "node": ">=6.0" + } + }, + "node_modules/handle-thing": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/handle-thing/-/handle-thing-2.0.1.tgz", + "integrity": "sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==", + "dev": true + }, + "node_modules/har-schema": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", + "integrity": "sha512-Oqluz6zhGX8cyRaTQlFMPw80bSJVG2x/cFb8ZPhUILGgHka9SsokCCOQgpveePerqidZOrT14ipqfJb7ILcW5Q==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/har-validator": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.5.tgz", + "integrity": "sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==", + "deprecated": "this library is no longer supported", + "dev": true, + "dependencies": { + "ajv": "^6.12.3", + "har-schema": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/has": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.4.tgz", + "integrity": "sha512-qdSAmqLF6209RFj4VVItywPMbm3vWylknmB3nvNiUIs72xAimcM8nVYxYr7ncvZq5qzk9MKIZR8ijqD/1QuYjQ==", + "dev": true, + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/has-property-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz", + "integrity": "sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", + "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-tostringtag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", + "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", + "dev": true, + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", + "integrity": "sha512-IBXk4GTsLYdQ7Rvt+GRBrFSVEkmuOUy4re0Xjd9kJSUQpnTrWR4/y9RpfexN9vkAPMFuQoeWKwqzPozRTlasGw==", + "dev": true, + "dependencies": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/has-values": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", + "integrity": "sha512-ODYZC64uqzmtfGMEAX/FvZiRyWLpAC3vYnNunURUnkGVTS+mI0smVsWaPydRBsE3g+ok7h960jChO8mFcWlHaQ==", + "dev": true, + "dependencies": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/has-values/node_modules/kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha512-24XsCxmEbRwEDbz/qz3stgin8TTzZ1ESR56OMCN0ujYg+vRutNSiOj9bHH9u85DKgXguraugV5sFuvbD4FW/hw==", + "dev": true, + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/has-yarn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/has-yarn/-/has-yarn-2.1.0.tgz", + "integrity": "sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/hash-base": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.1.0.tgz", + "integrity": "sha512-1nmYp/rhMDiE7AYkDw+lLwlAzz0AntGIe51F3RfFfEqyQ3feY2eI/NcwC6umIQVOASPMsWJLJScWKSSvzL9IVA==", + "dev": true, + "dependencies": { + "inherits": "^2.0.4", + "readable-stream": "^3.6.0", + "safe-buffer": "^5.2.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/hash-base/node_modules/readable-stream": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/hash-base/node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/hash-sum": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/hash-sum/-/hash-sum-1.0.2.tgz", + "integrity": "sha512-fUs4B4L+mlt8/XAtSOGMUO1TXmAelItBPtJG7CyHJfYTdDjwisntGO2JQz7oUsatOY9o68+57eziUVNw/mRHmA==", + "dev": true + }, + "node_modules/hash.js": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", + "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "minimalistic-assert": "^1.0.1" + } + }, + "node_modules/hasown": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz", + "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==", + "dev": true, + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/he": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", + "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", + "dev": true, + "bin": { + "he": "bin/he" + } + }, + "node_modules/hex-color-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/hex-color-regex/-/hex-color-regex-1.1.0.tgz", + "integrity": "sha512-l9sfDFsuqtOqKDsQdqrMRk0U85RZc0RtOR9yPI7mRVOa4FsR/BVnZ0shmQRM96Ji99kYZP/7hn1cedc1+ApsTQ==", + "dev": true + }, + "node_modules/highlight.js": { + "version": "9.18.5", + "resolved": "https://registry.npmjs.org/highlight.js/-/highlight.js-9.18.5.tgz", + "integrity": "sha512-a5bFyofd/BHCX52/8i8uJkjr9DYwXIPnM/plwI6W7ezItLGqzt7X2G2nXuYSfsIJdkwwj/g9DG1LkcGJI/dDoA==", + "deprecated": "Support has ended for 9.x series. Upgrade to @latest", + "dev": true, + "hasInstallScript": true, + "engines": { + "node": "*" + } + }, + "node_modules/hmac-drbg": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", + "integrity": "sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg==", + "dev": true, + "dependencies": { + "hash.js": "^1.0.3", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "node_modules/hogan.js": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/hogan.js/-/hogan.js-3.0.2.tgz", + "integrity": "sha512-RqGs4wavGYJWE07t35JQccByczmNUXQT0E12ZYV1VKYu5UiAU9lsos/yBAcf840+zrUQQxgVduCR5/B8nNtibg==", + "dev": true, + "dependencies": { + "mkdirp": "0.3.0", + "nopt": "1.0.10" + }, + "bin": { + "hulk": "bin/hulk" + } + }, + "node_modules/hogan.js/node_modules/mkdirp": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.3.0.tgz", + "integrity": "sha512-OHsdUcVAQ6pOtg5JYWpCBo9W/GySVuwvP9hueRMW7UqshC0tbfzLv8wjySTPm3tfUZ/21CE9E1pJagOA91Pxew==", + "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/hpack.js": { + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/hpack.js/-/hpack.js-2.1.6.tgz", + "integrity": "sha512-zJxVehUdMGIKsRaNt7apO2Gqp0BdqW5yaiGHXXmbpvxgBYVZnAql+BJb4RO5ad2MgpbZKn5G6nMnegrH1FcNYQ==", + "dev": true, + "dependencies": { + "inherits": "^2.0.1", + "obuf": "^1.0.0", + "readable-stream": "^2.0.1", + "wbuf": "^1.1.0" + } + }, + "node_modules/hsl-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/hsl-regex/-/hsl-regex-1.0.0.tgz", + "integrity": "sha512-M5ezZw4LzXbBKMruP+BNANf0k+19hDQMgpzBIYnya//Al+fjNct9Wf3b1WedLqdEs2hKBvxq/jh+DsHJLj0F9A==", + "dev": true + }, + "node_modules/hsla-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/hsla-regex/-/hsla-regex-1.0.0.tgz", + "integrity": "sha512-7Wn5GMLuHBjZCb2bTmnDOycho0p/7UVaAeqXZGbHrBCl6Yd/xDhQJAXe6Ga9AXJH2I5zY1dEdYw2u1UptnSBJA==", + "dev": true + }, + "node_modules/html-entities": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-1.4.0.tgz", + "integrity": "sha512-8nxjcBcd8wovbeKx7h3wTji4e6+rhaVuPNpMqwWgnHh+N9ToqsCs6XztWRBPQ+UtzsoMAdKZtUENoVzU/EMtZA==", + "dev": true + }, + "node_modules/html-minifier": { + "version": "3.5.21", + "resolved": "https://registry.npmjs.org/html-minifier/-/html-minifier-3.5.21.tgz", + "integrity": "sha512-LKUKwuJDhxNa3uf/LPR/KVjm/l3rBqtYeCOAekvG8F1vItxMUpueGd94i/asDDr8/1u7InxzFA5EeGjhhG5mMA==", + "dev": true, + "dependencies": { + "camel-case": "3.0.x", + "clean-css": "4.2.x", + "commander": "2.17.x", + "he": "1.2.x", + "param-case": "2.1.x", + "relateurl": "0.2.x", + "uglify-js": "3.4.x" + }, + "bin": { + "html-minifier": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/html-tags": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/html-tags/-/html-tags-3.3.1.tgz", + "integrity": "sha512-ztqyC3kLto0e9WbNp0aeP+M3kTt+nbaIveGmUxAtZa+8iFgKLUOD4YKM5j+f3QD89bra7UeumolZHKuOXnTmeQ==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/htmlparser2": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-6.1.0.tgz", + "integrity": "sha512-gyyPk6rgonLFEDGoeRgQNaEUvdJ4ktTmmUh/h2t7s+M8oPpIPxgNACWa+6ESR57kXstwqPiCut0V8NRpcwgU7A==", + "dev": true, + "funding": [ + "https://github.com/fb55/htmlparser2?sponsor=1", + { + "type": "github", + "url": "https://github.com/sponsors/fb55" + } + ], + "dependencies": { + "domelementtype": "^2.0.1", + "domhandler": "^4.0.0", + "domutils": "^2.5.2", + "entities": "^2.0.0" + } + }, + "node_modules/htmlparser2/node_modules/dom-serializer": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.4.1.tgz", + "integrity": "sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==", + "dev": true, + "dependencies": { + "domelementtype": "^2.0.1", + "domhandler": "^4.2.0", + "entities": "^2.0.0" + }, + "funding": { + "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1" + } + }, + "node_modules/htmlparser2/node_modules/domelementtype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", + "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/fb55" + } + ] + }, + "node_modules/htmlparser2/node_modules/domutils": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz", + "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==", + "dev": true, + "dependencies": { + "dom-serializer": "^1.0.1", + "domelementtype": "^2.2.0", + "domhandler": "^4.2.0" + }, + "funding": { + "url": "https://github.com/fb55/domutils?sponsor=1" + } + }, + "node_modules/htmlparser2/node_modules/entities": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", + "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", + "dev": true, + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" + } + }, + "node_modules/http-cache-semantics": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", + "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==", + "dev": true + }, + "node_modules/http-deceiver": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz", + "integrity": "sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw==", + "dev": true + }, + "node_modules/http-errors": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", + "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", + "dev": true, + "dependencies": { + "depd": "2.0.0", + "inherits": "2.0.4", + "setprototypeof": "1.2.0", + "statuses": "2.0.1", + "toidentifier": "1.0.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/http-parser-js": { + "version": "0.5.8", + "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.8.tgz", + "integrity": "sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q==", + "dev": true + }, + "node_modules/http-proxy": { + "version": "1.18.1", + "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.18.1.tgz", + "integrity": "sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ==", + "dev": true, + "dependencies": { + "eventemitter3": "^4.0.0", + "follow-redirects": "^1.0.0", + "requires-port": "^1.0.0" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/http-proxy-middleware": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-1.3.1.tgz", + "integrity": "sha512-13eVVDYS4z79w7f1+NPllJtOQFx/FdUW4btIvVRMaRlUY9VGstAbo5MOhLEuUgZFRHn3x50ufn25zkj/boZnEg==", + "dev": true, + "dependencies": { + "@types/http-proxy": "^1.17.5", + "http-proxy": "^1.18.1", + "is-glob": "^4.0.1", + "is-plain-obj": "^3.0.0", + "micromatch": "^4.0.2" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/http-proxy-middleware/node_modules/braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "dependencies": { + "fill-range": "^7.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/http-proxy-middleware/node_modules/fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/http-proxy-middleware/node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true, + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/http-proxy-middleware/node_modules/micromatch": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", + "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", + "dev": true, + "dependencies": { + "braces": "^3.0.2", + "picomatch": "^2.3.1" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/http-proxy-middleware/node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/http-signature": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", + "integrity": "sha512-CAbnr6Rz4CYQkLYUtSNXxQPUH2gK8f3iWexVlsnMeD+GjlsQ0Xsy1cOX+mN3dtxYomRy21CiOzU8Uhw6OwncEQ==", + "dev": true, + "dependencies": { + "assert-plus": "^1.0.0", + "jsprim": "^1.2.2", + "sshpk": "^1.7.0" + }, + "engines": { + "node": ">=0.8", + "npm": ">=1.3.7" + } + }, + "node_modules/https-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-1.0.0.tgz", + "integrity": "sha512-J+FkSdyD+0mA0N+81tMotaRMfSL9SGi+xpD3T6YApKsc3bGSXJlfXri3VyFOeYkfLRQisDk1W+jIFFKBeUBbBg==", + "dev": true + }, + "node_modules/human-signals": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", + "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", + "dev": true, + "engines": { + "node": ">=10.17.0" + } + }, + "node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/icss-replace-symbols": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/icss-replace-symbols/-/icss-replace-symbols-1.1.0.tgz", + "integrity": "sha512-chIaY3Vh2mh2Q3RGXttaDIzeiPvaVXJ+C4DAh/w3c37SKZ/U6PGMmuicR2EQQp9bKG8zLMCl7I+PtIoOOPp8Gg==", + "dev": true + }, + "node_modules/icss-utils": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-4.1.1.tgz", + "integrity": "sha512-4aFq7wvWyMHKgxsH8QQtGpvbASCf+eM3wPRLI6R+MgAnTCZ6STYsRvttLvRWK0Nfif5piF394St3HeJDaljGPA==", + "dev": true, + "dependencies": { + "postcss": "^7.0.14" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/ieee754": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", + "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ] + }, + "node_modules/iferr": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/iferr/-/iferr-0.1.5.tgz", + "integrity": "sha512-DUNFN5j7Tln0D+TxzloUjKB+CtVu6myn0JEFak6dG18mNt9YkQ6lzGCdafwofISZ1lLF3xRHJ98VKy9ynkcFaA==", + "dev": true + }, + "node_modules/ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/immediate": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/immediate/-/immediate-3.3.0.tgz", + "integrity": "sha512-HR7EVodfFUdQCTIeySw+WDRFJlPcLOJbXfwwZ7Oom6tjsvZ3bOkCDJHehQC3nxJrv7+f9XecwazynjU8e4Vw3Q==", + "dev": true + }, + "node_modules/import-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-cwd/-/import-cwd-2.1.0.tgz", + "integrity": "sha512-Ew5AZzJQFqrOV5BTW3EIoHAnoie1LojZLXKcCQ/yTRyVZosBhK1x1ViYjHGf5pAFOq8ZyChZp6m/fSN7pJyZtg==", + "dev": true, + "dependencies": { + "import-from": "^2.1.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/import-fresh": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-2.0.0.tgz", + "integrity": "sha512-eZ5H8rcgYazHbKC3PG4ClHNykCSxtAhxSSEM+2mb+7evD2CKF5V7c0dNum7AdpDh0ZdICwZY9sRSn8f+KH96sg==", + "dev": true, + "dependencies": { + "caller-path": "^2.0.0", + "resolve-from": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/import-from": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-from/-/import-from-2.1.0.tgz", + "integrity": "sha512-0vdnLL2wSGnhlRmzHJAg5JHjt1l2vYhzJ7tNLGbeVg0fse56tpGaH0uzH+r9Slej+BSXXEHvBKDEnVSLLE9/+w==", + "dev": true, + "dependencies": { + "resolve-from": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/import-lazy": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-2.1.0.tgz", + "integrity": "sha512-m7ZEHgtw69qOGw+jwxXkHlrlIPdTGkyh66zXZ1ajZbxkDBNjSY/LGbmjc7h0s2ELsUDTAhFr55TrPSSqJGPG0A==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/import-local": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-2.0.0.tgz", + "integrity": "sha512-b6s04m3O+s3CGSbqDIyP4R6aAwAeYlVq9+WUWep6iHa8ETRf9yei1U48C5MmfJmV9AiLYYBKPMq/W+/WRpQmCQ==", + "dev": true, + "dependencies": { + "pkg-dir": "^3.0.0", + "resolve-cwd": "^2.0.0" + }, + "bin": { + "import-local-fixture": "fixtures/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/import-local/node_modules/find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "dependencies": { + "locate-path": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/import-local/node_modules/locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "dependencies": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/import-local/node_modules/p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "dependencies": { + "p-limit": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/import-local/node_modules/path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/import-local/node_modules/pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "dependencies": { + "find-up": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true, + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/indexes-of": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/indexes-of/-/indexes-of-1.0.1.tgz", + "integrity": "sha512-bup+4tap3Hympa+JBJUG7XuOsdNQ6fxt0MHyXMKuLBKn0OqsTfvUxkUrroEX1+B2VsSHvCjiIcZVxRtYa4nllA==", + "dev": true + }, + "node_modules/infer-owner": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/infer-owner/-/infer-owner-1.0.4.tgz", + "integrity": "sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A==", + "dev": true + }, + "node_modules/inflection": { + "version": "1.13.4", + "resolved": "https://registry.npmjs.org/inflection/-/inflection-1.13.4.tgz", + "integrity": "sha512-6I/HUDeYFfuNCVS3td055BaXBwKYuzw7K3ExVMStBowKo9oOAMJIXIHvdyR3iboTCp1b+1i5DSkIZTcwIktuDw==", + "engines": [ + "node >= 0.4.0" + ] + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "node_modules/ini": { + "version": "1.3.7", + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.7.tgz", + "integrity": "sha512-iKpRpXP+CrP2jyrxvg1kMUpXDyRUFDWurxbnVT1vQPx+Wz9uCYsMIqYuSBLV+PAaZG/d7kRLKRFc9oDMsH+mFQ==", + "dev": true + }, + "node_modules/internal-ip": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/internal-ip/-/internal-ip-4.3.0.tgz", + "integrity": "sha512-S1zBo1D6zcsyuC6PMmY5+55YMILQ9av8lotMx447Bq6SAgo/sDK6y6uUKmuYhW7eacnIhFfsPmCNYdDzsnnDCg==", + "dev": true, + "dependencies": { + "default-gateway": "^4.2.0", + "ipaddr.js": "^1.9.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/internal-slot": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.6.tgz", + "integrity": "sha512-Xj6dv+PsbtwyPpEflsejS+oIZxmMlV44zAhG479uYu89MsjcYOhCFnNyKrkJrihbsiasQyY0afoCl/9BLR65bg==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.2", + "hasown": "^2.0.0", + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/ip": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.8.tgz", + "integrity": "sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg==", + "dev": true + }, + "node_modules/ip-regex": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/ip-regex/-/ip-regex-2.1.0.tgz", + "integrity": "sha512-58yWmlHpp7VYfcdTwMTvwMmqx/Elfxjd9RXTDyMsbL7lLWmhMylLEqiYVLKuLzOZqVgiWXD9MfR62Vv89VRxkw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "dev": true, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/is-absolute-url": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-2.1.0.tgz", + "integrity": "sha512-vOx7VprsKyllwjSkLV79NIhpyLfr3jAp7VaTCMXOJHu4m0Ew1CZ2fcjASwmV1jI3BWuWHB013M48eyeldk9gYg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-accessor-descriptor": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.1.tgz", + "integrity": "sha512-YBUanLI8Yoihw923YeFUS5fs0fF2f5TSFTNiYAAzhhDscDa3lEqYuz1pDOEP5KvX94I9ey3vsqjJcLVFVU+3QA==", + "dev": true, + "dependencies": { + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/is-arguments": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.1.1.tgz", + "integrity": "sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-array-buffer": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", + "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.0", + "is-typed-array": "^1.1.10" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", + "dev": true + }, + "node_modules/is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "dependencies": { + "has-bigints": "^1.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", + "integrity": "sha512-9fRVlXc0uCxEDj1nQzaWONSpbTfx0FmJfzHF7pwlI8DkWGoHBBea4Pg5Ky0ojwwxQmnSifgbKkI06Qv0Ljgj+Q==", + "dev": true, + "dependencies": { + "binary-extensions": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true + }, + "node_modules/is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-ci": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", + "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", + "dev": true, + "dependencies": { + "ci-info": "^2.0.0" + }, + "bin": { + "is-ci": "bin.js" + } + }, + "node_modules/is-color-stop": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-color-stop/-/is-color-stop-1.1.0.tgz", + "integrity": "sha512-H1U8Vz0cfXNujrJzEcvvwMDW9Ra+biSYA3ThdQvAnMLJkEHQXn6bWzLkxHtVYJ+Sdbx0b6finn3jZiaVe7MAHA==", + "dev": true, + "dependencies": { + "css-color-names": "^0.0.4", + "hex-color-regex": "^1.1.0", + "hsl-regex": "^1.0.0", + "hsla-regex": "^1.0.0", + "rgb-regex": "^1.0.1", + "rgba-regex": "^1.0.0" + } + }, + "node_modules/is-core-module": { + "version": "2.13.1", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", + "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", + "dev": true, + "dependencies": { + "hasown": "^2.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-data-descriptor": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.1.tgz", + "integrity": "sha512-bc4NlCDiCr28U4aEsQ3Qs2491gVq4V8G7MQyws968ImqjKuYtTJXrl7Vq7jsN7Ly/C3xj5KWFrY7sHNeDkAzXw==", + "dev": true, + "dependencies": { + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-descriptor": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.3.tgz", + "integrity": "sha512-JCNNGbwWZEVaSPtS45mdtrneRWJFp07LLmykxeFV5F6oBvNF8vHSfJuJgoT472pSfk+Mf8VnlrspaFBHWM8JAw==", + "dev": true, + "dependencies": { + "is-accessor-descriptor": "^1.0.1", + "is-data-descriptor": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/is-directory": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", + "integrity": "sha512-yVChGzahRFvbkscn2MlwGismPO12i9+znNruC5gVEntG3qu0xQMzsGg/JFbrsqDOHtHFPci+V5aP5T9I+yeKqw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "dev": true, + "dependencies": { + "is-plain-object": "^2.0.4" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "engines": { + "node": ">=8" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-installed-globally": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.3.2.tgz", + "integrity": "sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g==", + "dev": true, + "dependencies": { + "global-dirs": "^2.0.1", + "is-path-inside": "^3.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-negative-zero": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", + "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-npm": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/is-npm/-/is-npm-4.0.0.tgz", + "integrity": "sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha512-4cboCqIpliH+mAvFNegjZQ4kgKc3ZUhQVr3HvWbSh5q3WH2v82ct+T2Y1hdU5Gdtorx/cLifQjqCbL7bpznLTg==", + "dev": true, + "dependencies": { + "kind-of": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-number/node_modules/kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ==", + "dev": true, + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-obj": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", + "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-path-cwd": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-2.2.0.tgz", + "integrity": "sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/is-path-in-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-2.1.0.tgz", + "integrity": "sha512-rNocXHgipO+rvnP6dk3zI20RpOtrAM/kzbB258Uw5BWr3TpXi861yzjo16Dn4hUox07iw5AyeMLHWsujkjzvRQ==", + "dev": true, + "dependencies": { + "is-path-inside": "^2.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/is-path-in-cwd/node_modules/is-path-inside": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-2.1.0.tgz", + "integrity": "sha512-wiyhTzfDWsvwAW53OBWF5zuvaOGlZ6PwYxAbPVDhpm+gM09xKQGjBq/8uYN12aDvMxnAnq3dxTyoSoRNmg5YFg==", + "dev": true, + "dependencies": { + "path-is-inside": "^1.0.2" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/is-path-inside": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", + "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-plain-obj": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-3.0.0.tgz", + "integrity": "sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA==", + "dev": true, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "dev": true, + "dependencies": { + "isobject": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-regexp": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-regexp/-/is-regexp-1.0.0.tgz", + "integrity": "sha512-7zjFAPO4/gwyQAAgRRmqeEeyIICSdmCqa3tsVHMdBzaXXRiqopZL4Cyghg/XulGWrtABTpbnYYzzIRffLkP4oA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-resolvable": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", + "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", + "dev": true + }, + "node_modules/is-shared-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", + "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-stream": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", + "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typed-array": { + "version": "1.1.12", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz", + "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==", + "dev": true, + "dependencies": { + "which-typed-array": "^1.1.11" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==", + "dev": true + }, + "node_modules/is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-wsl": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-1.1.0.tgz", + "integrity": "sha512-gfygJYZ2gLTDlmbWMI0CE2MwnFzSN/2SZfkMlItC4K/JBlsWVDB0bO6XhqcY13YXE7iMcAJnzTCJjPiTeJJ0Mw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/is-yarn-global": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/is-yarn-global/-/is-yarn-global-0.3.0.tgz", + "integrity": "sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw==", + "dev": true + }, + "node_modules/isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "dev": true + }, + "node_modules/isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/isstream": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", + "integrity": "sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==", + "dev": true + }, + "node_modules/javascript-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/javascript-stringify/-/javascript-stringify-2.1.0.tgz", + "integrity": "sha512-JVAfqNPTvNq3sB/VHQJAFxN/sPgKnsKrCwyRt15zwNCdrMMJDdcEOdubuy+DuJYYdm0ox1J4uzEuYKkN+9yhVg==", + "dev": true + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "dev": true + }, + "node_modules/js-yaml": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", + "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", + "dependencies": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg==", + "dev": true + }, + "node_modules/jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true, + "bin": { + "jsesc": "bin/jsesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/json-buffer": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.0.tgz", + "integrity": "sha512-CuUqjv0FUZIdXkHPI8MezCnFCdaTAacej1TZYulLoAg1h/PhwkdXFN4V/gzY4g+fMBCOV2xF+rp7t2XD2ns/NQ==", + "dev": true + }, + "node_modules/json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", + "dev": true + }, + "node_modules/json-schema": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.4.0.tgz", + "integrity": "sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA==", + "dev": true + }, + "node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true + }, + "node_modules/json-stringify-safe": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", + "integrity": "sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==", + "dev": true + }, + "node_modules/json5": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", + "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==", + "dev": true, + "bin": { + "json5": "lib/cli.js" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==", + "dev": true, + "optionalDependencies": { + "graceful-fs": "^4.1.6" + } + }, + "node_modules/jsprim": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.2.tgz", + "integrity": "sha512-P2bSOMAc/ciLz6DzgjVlGJP9+BrJWu5UDGK70C2iweC5QBIeFf0ZXRvGjEj2uYgrY2MkAAhsSWHDWlFtEroZWw==", + "dev": true, + "dependencies": { + "assert-plus": "1.0.0", + "extsprintf": "1.3.0", + "json-schema": "0.4.0", + "verror": "1.10.0" + }, + "engines": { + "node": ">=0.6.0" + } + }, + "node_modules/keyv": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-3.1.0.tgz", + "integrity": "sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA==", + "dev": true, + "dependencies": { + "json-buffer": "3.0.0" + } + }, + "node_modules/killable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/killable/-/killable-1.0.1.tgz", + "integrity": "sha512-LzqtLKlUwirEUyl/nicirVmNiPvYs7l5n8wOPP7fyJVpUPkvCnW/vuiXGpylGUlnPDnB7311rARzAt3Mhswpjg==", + "dev": true + }, + "node_modules/kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/last-call-webpack-plugin": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/last-call-webpack-plugin/-/last-call-webpack-plugin-3.0.0.tgz", + "integrity": "sha512-7KI2l2GIZa9p2spzPIVZBYyNKkN+e/SQPpnjlTiPhdbDW3F86tdKKELxKpzJ5sgU19wQWsACULZmpTPYHeWO5w==", + "dev": true, + "dependencies": { + "lodash": "^4.17.5", + "webpack-sources": "^1.1.0" + } + }, + "node_modules/latest-version": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/latest-version/-/latest-version-5.1.0.tgz", + "integrity": "sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA==", + "dev": true, + "dependencies": { + "package-json": "^6.3.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/linkify-it": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-2.2.0.tgz", + "integrity": "sha512-GnAl/knGn+i1U/wjBz3akz2stz+HrHLsxMwHQGofCDfPvlf+gDKN58UtfmUquTY4/MXeE2x7k19KQmeoZi94Iw==", + "dev": true, + "dependencies": { + "uc.micro": "^1.0.1" + } + }, + "node_modules/load-script": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/load-script/-/load-script-1.0.0.tgz", + "integrity": "sha512-kPEjMFtZvwL9TaZo0uZ2ml+Ye9HUMmPwbYRJ324qF9tqMejwykJ5ggTyvzmrbBeapCAbk98BSbTeovHEEP1uCA==", + "dev": true + }, + "node_modules/loader-runner": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-2.4.0.tgz", + "integrity": "sha512-Jsmr89RcXGIwivFY21FcRrisYZfvLMTWx5kOLc+JTxtpBOG6xML0vzbc6SEQG2FO9/4Fc3wW4LVcB5DmGflaRw==", + "dev": true, + "engines": { + "node": ">=4.3.0 <5.0.0 || >=5.10" + } + }, + "node_modules/loader-utils": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.4.2.tgz", + "integrity": "sha512-I5d00Pd/jwMD2QCduo657+YM/6L3KZu++pmX9VFncxaxvHcru9jx1lBaFft+r4Mt2jK0Yhp41XlRAihzPxHNCg==", + "dev": true, + "dependencies": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^1.0.1" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/loader-utils/node_modules/json5": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", + "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", + "dev": true, + "dependencies": { + "minimist": "^1.2.0" + }, + "bin": { + "json5": "lib/cli.js" + } + }, + "node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "dev": true, + "dependencies": { + "p-locate": "^4.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "dev": true + }, + "node_modules/lodash._reinterpolate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", + "integrity": "sha512-xYHt68QRoYGjeeM/XOE1uJtvXQAgvszfBhjV4yvsQH0u2i9I6cI6c6/eG4Hh3UAOVn0y/xAXwmTzEay49Q//HA==", + "dev": true + }, + "node_modules/lodash.clonedeep": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", + "integrity": "sha512-H5ZhCF25riFd9uB5UCkVKo61m3S/xZk1x4wA6yp/L3RFP6Z/eHH1ymQcGLo7J3GMPfm0V/7m1tryHuGVxpqEBQ==", + "dev": true + }, + "node_modules/lodash.debounce": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", + "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", + "dev": true + }, + "node_modules/lodash.escaperegexp": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.escaperegexp/-/lodash.escaperegexp-4.1.2.tgz", + "integrity": "sha512-TM9YBvyC84ZxE3rgfefxUWiQKLilstD6k7PTGt6wfbtXF8ixIJLOL3VYyV/z+ZiPLsVxAsKAFVwWlWeb2Y8Yyw==" + }, + "node_modules/lodash.kebabcase": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/lodash.kebabcase/-/lodash.kebabcase-4.1.1.tgz", + "integrity": "sha512-N8XRTIMMqqDgSy4VLKPnJ/+hpGZN+PHQiJnSenYqPaVV/NCqEogTnAdZLQiGKhxX+JCs8waWq2t1XHWKOmlY8g==", + "dev": true + }, + "node_modules/lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", + "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag==", + "dev": true + }, + "node_modules/lodash.sortby": { + "version": "4.7.0", + "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz", + "integrity": "sha512-HDWXG8isMntAyRF5vZ7xKuEvOhT4AhlRt/3czTSjvGUxjYCBVRQY48ViDHyfYz9VIoBkW4TMGQNapx+l3RUwdA==" + }, + "node_modules/lodash.template": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.template/-/lodash.template-4.5.0.tgz", + "integrity": "sha512-84vYFxIkmidUiFxidA/KjjH9pAycqW+h980j7Fuz5qxRtO9pgB7MDFTdys1N7A5mcucRiDyEq4fusljItR1T/A==", + "dev": true, + "dependencies": { + "lodash._reinterpolate": "^3.0.0", + "lodash.templatesettings": "^4.0.0" + } + }, + "node_modules/lodash.templatesettings": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/lodash.templatesettings/-/lodash.templatesettings-4.2.0.tgz", + "integrity": "sha512-stgLz+i3Aa9mZgnjr/O+v9ruKZsPsndy7qPZOchbqk2cnTU1ZaldKK+v7m54WoKIyxiuMZTKT2H81F8BeAc3ZQ==", + "dev": true, + "dependencies": { + "lodash._reinterpolate": "^3.0.0" + } + }, + "node_modules/lodash.uniq": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz", + "integrity": "sha512-xfBaXQd9ryd9dlSDvnvI0lvxfLJlYAZzXomUYzLKtUeOQvOP5piqAWuGtrhWeqaXK9hhoM/iyJc5AV+XfsX3HQ==", + "dev": true + }, + "node_modules/loglevel": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.8.1.tgz", + "integrity": "sha512-tCRIJM51SHjAayKwC+QAg8hT8vg6z7GSgLJKGvzuPb1Wc+hLzqtuVLxp6/HzSPOozuK+8ErAhy7U/sVzw8Dgfg==", + "dev": true, + "engines": { + "node": ">= 0.6.0" + }, + "funding": { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/loglevel" + } + }, + "node_modules/lower-case": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-1.1.4.tgz", + "integrity": "sha512-2Fgx1Ycm599x+WGpIYwJOvsjmXFzTSc34IwDWALRA/8AopUKAVPwfJ+h5+f85BCp0PWmmJcWzEpxOpoXycMpdA==", + "dev": true + }, + "node_modules/lowercase-keys": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz", + "integrity": "sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "dev": true, + "dependencies": { + "yallist": "^3.0.2" + } + }, + "node_modules/make-dir": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", + "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", + "dev": true, + "dependencies": { + "semver": "^6.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", + "integrity": "sha512-8y/eV9QQZCiyn1SprXSrCmqJN0yNRATe+PO8ztwqrvrbdRLA3eYJF0yaR0YayLWkMbsQSKWS9N2gPcGEc4UsZg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/map-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", + "integrity": "sha512-4y7uGv8bd2WdM9vpQsiQNo41Ln1NvhvDRuVt0k2JZQ+ezN2uaQes7lZeZ+QQUHOLQAtDaBJ+7wCbi+ab/KFs+w==", + "dev": true, + "dependencies": { + "object-visit": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/markdown-it": { + "version": "8.4.2", + "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-8.4.2.tgz", + "integrity": "sha512-GcRz3AWTqSUphY3vsUqQSFMbgR38a4Lh3GWlHRh/7MRwz8mcu9n2IO7HOh+bXHrR9kOPDl5RNCaEsrneb+xhHQ==", + "dev": true, + "dependencies": { + "argparse": "^1.0.7", + "entities": "~1.1.1", + "linkify-it": "^2.0.0", + "mdurl": "^1.0.1", + "uc.micro": "^1.0.5" + }, + "bin": { + "markdown-it": "bin/markdown-it.js" + } + }, + "node_modules/markdown-it-anchor": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/markdown-it-anchor/-/markdown-it-anchor-5.3.0.tgz", + "integrity": "sha512-/V1MnLL/rgJ3jkMWo84UR+K+jF1cxNG1a+KwqeXqTIJ+jtA8aWSHuigx8lTzauiIjBDbwF3NcWQMotd0Dm39jA==", + "dev": true, + "peerDependencies": { + "markdown-it": "*" + } + }, + "node_modules/markdown-it-chain": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/markdown-it-chain/-/markdown-it-chain-1.3.0.tgz", + "integrity": "sha512-XClV8I1TKy8L2qsT9iX3qiV+50ZtcInGXI80CA+DP62sMs7hXlyV/RM3hfwy5O3Ad0sJm9xIwQELgANfESo8mQ==", + "dev": true, + "dependencies": { + "webpack-chain": "^4.9.0" + }, + "engines": { + "node": ">=6.9" + }, + "peerDependencies": { + "markdown-it": ">=5.0.0" + } + }, + "node_modules/markdown-it-chain/node_modules/javascript-stringify": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/javascript-stringify/-/javascript-stringify-1.6.0.tgz", + "integrity": "sha512-fnjC0up+0SjEJtgmmG+teeel68kutkvzfctO/KxE3qJlbunkJYAshgH3boU++gSBHP8z5/r0ts0qRIrHf0RTQQ==", + "dev": true + }, + "node_modules/markdown-it-chain/node_modules/webpack-chain": { + "version": "4.12.1", + "resolved": "https://registry.npmjs.org/webpack-chain/-/webpack-chain-4.12.1.tgz", + "integrity": "sha512-BCfKo2YkDe2ByqkEWe1Rw+zko4LsyS75LVr29C6xIrxAg9JHJ4pl8kaIZ396SUSNp6b4815dRZPSTAS8LlURRQ==", + "deprecated": "Package no longer supported. Contact Support at https://www.npmjs.com/support for more info.", + "dev": true, + "dependencies": { + "deepmerge": "^1.5.2", + "javascript-stringify": "^1.6.0" + } + }, + "node_modules/markdown-it-container": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/markdown-it-container/-/markdown-it-container-2.0.0.tgz", + "integrity": "sha512-IxPOaq2LzrGuFGyYq80zaorXReh2ZHGFOB1/Hen429EJL1XkPI3FJTpx9TsJeua+j2qTru4h3W1TiCRdeivMmA==", + "dev": true + }, + "node_modules/markdown-it-emoji": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/markdown-it-emoji/-/markdown-it-emoji-1.4.0.tgz", + "integrity": "sha512-QCz3Hkd+r5gDYtS2xsFXmBYrgw6KuWcJZLCEkdfAuwzZbShCmCfta+hwAMq4NX/4xPzkSHduMKgMkkPUJxSXNg==", + "dev": true + }, + "node_modules/markdown-it-meta": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/markdown-it-meta/-/markdown-it-meta-0.0.1.tgz", + "integrity": "sha512-sCQG7mHJM3i4l6MztgzxE8t3aTQB5CSCO0wq8k6CEaqud40eryWXqPesq5AyztbYgwnxJcNIsmFsKDRkrl6Zuw==", + "dependencies": { + "js-yaml": "^3.8.1" + } + }, + "node_modules/markdown-it-table-of-contents": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/markdown-it-table-of-contents/-/markdown-it-table-of-contents-0.4.4.tgz", + "integrity": "sha512-TAIHTHPwa9+ltKvKPWulm/beozQU41Ab+FIefRaQV1NRnpzwcV9QOe6wXQS5WLivm5Q/nlo0rl6laGkMDZE7Gw==", + "dev": true, + "engines": { + "node": ">6.4.0" + } + }, + "node_modules/md5.js": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", + "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", + "dev": true, + "dependencies": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "node_modules/mdn-data": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.4.tgz", + "integrity": "sha512-iV3XNKw06j5Q7mi6h+9vbx23Tv7JkjEVgKHW4pimwyDGWm0OIQntJJ+u1C6mg6mK1EaTv42XQ7w76yuzH7M2cA==", + "dev": true + }, + "node_modules/mdurl": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-1.0.1.tgz", + "integrity": "sha512-/sKlQJCBYVY9Ers9hqzKou4H6V5UWc/M59TH2dvkt+84itfnq7uFOMLpOiOS4ujvHP4etln18fmIxA5R5fll0g==" + }, + "node_modules/media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/memory-fs": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.4.1.tgz", + "integrity": "sha512-cda4JKCxReDXFXRqOHPQscuIYg1PvxbE2S2GP45rnwfEK+vZaXC8C1OFvdHIbgw0DLzowXGVoxLaAmlgRy14GQ==", + "dev": true, + "dependencies": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + } + }, + "node_modules/merge": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/merge/-/merge-2.1.1.tgz", + "integrity": "sha512-jz+Cfrg9GWOZbQAnDQ4hlVnQky+341Yk5ru8bZSe6sIDTCIg8n9i/u7hSQGSVOF3C7lH6mGtqjkiT9G4wFLL0w==", + "dev": true + }, + "node_modules/merge-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", + "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==", + "dev": true + }, + "node_modules/merge-source-map": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/merge-source-map/-/merge-source-map-1.1.0.tgz", + "integrity": "sha512-Qkcp7P2ygktpMPh2mCQZaf3jhN6D3Z/qVZHSdWvQ+2Ef5HgRAPBO57A77+ENm0CPx2+1Ce/MYKi3ymqdfuqibw==", + "dev": true, + "dependencies": { + "source-map": "^0.6.1" + } + }, + "node_modules/merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", + "dev": true + }, + "node_modules/merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/methods": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/micromatch": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", + "dev": true, + "dependencies": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/miller-rabin": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", + "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", + "dev": true, + "dependencies": { + "bn.js": "^4.0.0", + "brorand": "^1.0.1" + }, + "bin": { + "miller-rabin": "bin/miller-rabin" + } + }, + "node_modules/miller-rabin/node_modules/bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", + "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", + "dev": true + }, + "node_modules/mime": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-2.6.0.tgz", + "integrity": "sha512-USPkMeET31rOMiarsBNIHZKLGgvKc/LrjofAnBlOttf5ajRvqiRA8QsenbcooctK6d6Ts6aqZXBA+XbkKthiQg==", + "dev": true, + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "dev": true, + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/mimic-response": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-1.0.1.tgz", + "integrity": "sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/min-document": { + "version": "2.19.0", + "resolved": "https://registry.npmjs.org/min-document/-/min-document-2.19.0.tgz", + "integrity": "sha512-9Wy1B3m3f66bPPmU5hdA4DR4PB2OfDU/+GS3yAB7IQozE3tqXaVv2zOjgla7MEGSRv95+ILmOuvhLkOK6wJtCQ==", + "dev": true, + "dependencies": { + "dom-walk": "^0.1.0" + } + }, + "node_modules/mini-css-extract-plugin": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-0.6.0.tgz", + "integrity": "sha512-79q5P7YGI6rdnVyIAV4NXpBQJFWdkzJxCim3Kog4078fM0piAaFlwocqbejdWtLW1cEzCexPrh6EdyFsPgVdAw==", + "dev": true, + "dependencies": { + "loader-utils": "^1.1.0", + "normalize-url": "^2.0.1", + "schema-utils": "^1.0.0", + "webpack-sources": "^1.1.0" + }, + "engines": { + "node": ">= 6.9.0" + }, + "peerDependencies": { + "webpack": "^4.4.0" + } + }, + "node_modules/mini-css-extract-plugin/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/minimalistic-assert": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", + "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", + "dev": true + }, + "node_modules/minimalistic-crypto-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", + "integrity": "sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg==", + "dev": true + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/minimist": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", + "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/mississippi": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/mississippi/-/mississippi-3.0.0.tgz", + "integrity": "sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA==", + "dev": true, + "dependencies": { + "concat-stream": "^1.5.0", + "duplexify": "^3.4.2", + "end-of-stream": "^1.1.0", + "flush-write-stream": "^1.0.0", + "from2": "^2.1.0", + "parallel-transform": "^1.1.0", + "pump": "^3.0.0", + "pumpify": "^1.3.3", + "stream-each": "^1.1.0", + "through2": "^2.0.0" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/mixin-deep": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz", + "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==", + "dev": true, + "dependencies": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/mkdirp": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", + "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", + "dev": true, + "dependencies": { + "minimist": "^1.2.6" + }, + "bin": { + "mkdirp": "bin/cmd.js" + } + }, + "node_modules/move-concurrently": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/move-concurrently/-/move-concurrently-1.0.1.tgz", + "integrity": "sha512-hdrFxZOycD/g6A6SoI2bB5NA/5NEqD0569+S47WZhPvm46sD50ZHdYaFmnua5lndde9rCHGjmfK7Z8BuCt/PcQ==", + "dev": true, + "dependencies": { + "aproba": "^1.1.1", + "copy-concurrently": "^1.0.0", + "fs-write-stream-atomic": "^1.0.8", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.3" + } + }, + "node_modules/ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", + "dev": true + }, + "node_modules/multicast-dns": { + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/multicast-dns/-/multicast-dns-6.2.3.tgz", + "integrity": "sha512-ji6J5enbMyGRHIAkAOu3WdV8nggqviKCEKtXcOqfphZZtQrmHKycfynJ2V7eVPUA4NhJ6V7Wf4TmGbTwKE9B6g==", + "dev": true, + "dependencies": { + "dns-packet": "^1.3.1", + "thunky": "^1.0.2" + }, + "bin": { + "multicast-dns": "cli.js" + } + }, + "node_modules/multicast-dns-service-types": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/multicast-dns-service-types/-/multicast-dns-service-types-1.1.0.tgz", + "integrity": "sha512-cnAsSVxIDsYt0v7HmC0hWZFwwXSh+E6PgCrREDuN/EsjgLwA5XRmlMHhSiDPrt6HxY1gTivEa/Zh7GtODoLevQ==", + "dev": true + }, + "node_modules/nan": { + "version": "2.18.0", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.18.0.tgz", + "integrity": "sha512-W7tfG7vMOGtD30sHoZSSc/JVYiyDPEyQVso/Zz+/uQd0B0L46gtC+pHha5FFMRpil6fm/AoEcRWyOVi4+E/f8w==", + "dev": true, + "optional": true + }, + "node_modules/nanoid": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "bin": { + "nanoid": "bin/nanoid.cjs" + }, + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + } + }, + "node_modules/nanomatch": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", + "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", + "dev": true, + "dependencies": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/negotiator": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", + "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/neo-async": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", + "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==", + "dev": true + }, + "node_modules/nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", + "dev": true + }, + "node_modules/no-case": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-2.3.2.tgz", + "integrity": "sha512-rmTZ9kz+f3rCvK2TD1Ue/oZlns7OGoIWP4fc3llxxRXlOkHKoWPPWJOfFYpITabSow43QJbRIoHQXtt10VldyQ==", + "dev": true, + "dependencies": { + "lower-case": "^1.1.1" + } + }, + "node_modules/node-forge": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.10.0.tgz", + "integrity": "sha512-PPmu8eEeG9saEUvI97fm4OYxXVB6bFvyNTyiUOBichBpFG8A1Ljw3bY62+5oOjDEMHRnd0Y7HQ+x7uzxOzC6JA==", + "dev": true, + "engines": { + "node": ">= 6.0.0" + } + }, + "node_modules/node-libs-browser": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-2.2.1.tgz", + "integrity": "sha512-h/zcD8H9kaDZ9ALUWwlBUDo6TKF8a7qBSCSEGfjTVIYeqsioSKaAX+BN7NgiMGp6iSIXZ3PxgCu8KS3b71YK5Q==", + "dev": true, + "dependencies": { + "assert": "^1.1.1", + "browserify-zlib": "^0.2.0", + "buffer": "^4.3.0", + "console-browserify": "^1.1.0", + "constants-browserify": "^1.0.0", + "crypto-browserify": "^3.11.0", + "domain-browser": "^1.1.1", + "events": "^3.0.0", + "https-browserify": "^1.0.0", + "os-browserify": "^0.3.0", + "path-browserify": "0.0.1", + "process": "^0.11.10", + "punycode": "^1.2.4", + "querystring-es3": "^0.2.0", + "readable-stream": "^2.3.3", + "stream-browserify": "^2.0.1", + "stream-http": "^2.7.2", + "string_decoder": "^1.0.0", + "timers-browserify": "^2.0.4", + "tty-browserify": "0.0.0", + "url": "^0.11.0", + "util": "^0.11.0", + "vm-browserify": "^1.0.1" + } + }, + "node_modules/node-libs-browser/node_modules/events": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", + "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", + "dev": true, + "engines": { + "node": ">=0.8.x" + } + }, + "node_modules/node-libs-browser/node_modules/punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ==", + "dev": true + }, + "node_modules/node-releases": { + "version": "2.0.14", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", + "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==", + "dev": true + }, + "node_modules/nopt": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", + "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", + "dev": true, + "dependencies": { + "abbrev": "1" + }, + "bin": { + "nopt": "bin/nopt.js" + }, + "engines": { + "node": "*" + } + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/normalize-range": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", + "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/normalize-url": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-2.0.1.tgz", + "integrity": "sha512-D6MUW4K/VzoJ4rJ01JFKxDrtY1v9wrgzCX5f2qj/lzH1m/lW6MhUZFKerVsnyjOhOsYzI9Kqqak+10l4LvLpMw==", + "dev": true, + "dependencies": { + "prepend-http": "^2.0.0", + "query-string": "^5.0.1", + "sort-keys": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/npm-run-path": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", + "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", + "dev": true, + "dependencies": { + "path-key": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/npm-run-path/node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/nprogress": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/nprogress/-/nprogress-0.2.0.tgz", + "integrity": "sha512-I19aIingLgR1fmhftnbWWO3dXc0hSxqHQHQb3H8m+K3TnEn/iSeTZZOyvKXWqQESMwuUVnatlCnZdLBZZt2VSA==", + "dev": true + }, + "node_modules/nth-check": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.2.tgz", + "integrity": "sha512-WeBOdju8SnzPN5vTUJYxYUxLeXpCaVP5i5e0LF8fg7WORF2Wd7wFX/pk0tYZk7s8T+J7VLy0Da6J1+wCT0AtHg==", + "dev": true, + "dependencies": { + "boolbase": "~1.0.0" + } + }, + "node_modules/num2fraction": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/num2fraction/-/num2fraction-1.2.2.tgz", + "integrity": "sha512-Y1wZESM7VUThYY+4W+X4ySH2maqcA+p7UR+w8VWNWVAd6lwuXXWz/w/Cz43J/dI2I+PS6wD5N+bJUF+gjWvIqg==", + "dev": true + }, + "node_modules/oauth-sign": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", + "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-copy": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", + "integrity": "sha512-79LYn6VAb63zgtmAteVOWo9Vdj71ZVBy3Pbse+VqxDpEP83XuujMrGqHIwAXJ5I/aM0zU7dIyIAhifVTPrNItQ==", + "dev": true, + "dependencies": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-copy/node_modules/define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha512-Rr7ADjQZenceVOAKop6ALkkRAmH1A4Gx9hV/7ZujPUN2rkATqFO0JZLZInbAjpZYoJ1gUx8MRMQVkYemcbMSTA==", + "dev": true, + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-copy/node_modules/is-descriptor": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.7.tgz", + "integrity": "sha512-C3grZTvObeN1xud4cRWl366OMXZTj0+HGyk4hvfpx4ZHt1Pb60ANSXqCK7pdOTeUQpRzECBSTphqvD7U+l22Eg==", + "dev": true, + "dependencies": { + "is-accessor-descriptor": "^1.0.1", + "is-data-descriptor": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object-copy/node_modules/kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ==", + "dev": true, + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", + "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", + "dev": true, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object-is": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/object-is/-/object-is-1.1.5.tgz", + "integrity": "sha512-3cyDsyHgtmi7I7DfSSI2LDp6SK2lwvtbg0p0R1e0RvTqF5ceGx+K2dfSjm1bKDMVCFEDAQvy+o8c6a7VujOddw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", + "integrity": "sha512-GBaMwwAVK9qbQN3Scdo0OyvgPW7l3lnaVMj84uTOZlswkX0KpF6fyDBJhtTthf7pymztoN36/KEr1DyhF96zEA==", + "dev": true, + "dependencies": { + "isobject": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object.assign": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.getownpropertydescriptors": { + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.7.tgz", + "integrity": "sha512-PrJz0C2xJ58FNn11XV2lr4Jt5Gzl94qpy9Lu0JlfEj14z88sqbSBJCBEzdlNUCzY2gburhbrwOZ5BHCmuNUy0g==", + "dev": true, + "dependencies": { + "array.prototype.reduce": "^1.0.6", + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "safe-array-concat": "^1.0.0" + }, + "engines": { + "node": ">= 0.8" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", + "integrity": "sha512-tqa/UMy/CCoYmj+H5qc07qvSL9dqcs/WZENZ1JbtWBlATP+iVOe778gE6MSijnyCnORzDuX6hU+LA4SZ09YjFQ==", + "dev": true, + "dependencies": { + "isobject": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object.values": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.7.tgz", + "integrity": "sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/obuf": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz", + "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==", + "dev": true + }, + "node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "dev": true, + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/on-headers": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", + "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", + "dev": true, + "dependencies": { + "mimic-fn": "^2.1.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/opencollective-postinstall": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/opencollective-postinstall/-/opencollective-postinstall-2.0.3.tgz", + "integrity": "sha512-8AV/sCtuzUeTo8gQK5qDZzARrulB3egtLzFgteqB2tcT4Mw7B8Kt7JcDHmltjz6FOAHsvTevk70gZEbhM4ZS9Q==", + "dev": true, + "bin": { + "opencollective-postinstall": "index.js" + } + }, + "node_modules/opn": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/opn/-/opn-5.5.0.tgz", + "integrity": "sha512-PqHpggC9bLV0VeWcdKhkpxY+3JTzetLSqTCWL/z/tFIbI6G8JCjondXklT1JinczLz2Xib62sSp0T/gKT4KksA==", + "dev": true, + "dependencies": { + "is-wsl": "^1.1.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/optimize-css-assets-webpack-plugin": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/optimize-css-assets-webpack-plugin/-/optimize-css-assets-webpack-plugin-5.0.8.tgz", + "integrity": "sha512-mgFS1JdOtEGzD8l+EuISqL57cKO+We9GcoiQEmdCWRqqck+FGNmYJtx9qfAPzEz+lRrlThWMuGDaRkI/yWNx/Q==", + "dev": true, + "dependencies": { + "cssnano": "^4.1.10", + "last-call-webpack-plugin": "^3.0.0" + }, + "peerDependencies": { + "webpack": "^4.0.0" + } + }, + "node_modules/os-browserify": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.3.0.tgz", + "integrity": "sha512-gjcpUc3clBf9+210TRaDWbf+rZZZEshZ+DlXMRCeAjp0xhTrnQsKHypIy1J3d5hKdUzj69t708EHtU8P6bUn0A==", + "dev": true + }, + "node_modules/p-cancelable": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/p-cancelable/-/p-cancelable-1.1.0.tgz", + "integrity": "sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/p-finally": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", + "integrity": "sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "dev": true, + "dependencies": { + "p-try": "^2.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "dev": true, + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/p-map": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-2.1.0.tgz", + "integrity": "sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/p-retry": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-3.0.1.tgz", + "integrity": "sha512-XE6G4+YTTkT2a0UWb2kjZe8xNwf8bIbnqpc/IS/idOBVhyves0mK5OJgeocjx7q5pvX/6m23xuzVPYT1uGM73w==", + "dev": true, + "dependencies": { + "retry": "^0.12.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/package-json": { + "version": "6.5.0", + "resolved": "https://registry.npmjs.org/package-json/-/package-json-6.5.0.tgz", + "integrity": "sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ==", + "dev": true, + "dependencies": { + "got": "^9.6.0", + "registry-auth-token": "^4.0.0", + "registry-url": "^5.0.0", + "semver": "^6.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/pako": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", + "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==", + "dev": true + }, + "node_modules/parallel-transform": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/parallel-transform/-/parallel-transform-1.2.0.tgz", + "integrity": "sha512-P2vSmIu38uIlvdcU7fDkyrxj33gTUy/ABO5ZUbGowxNCopBq/OoD42bP4UmMrJoPyk4Uqf0mu3mtWBhHCZD8yg==", + "dev": true, + "dependencies": { + "cyclist": "^1.0.1", + "inherits": "^2.0.3", + "readable-stream": "^2.1.5" + } + }, + "node_modules/param-case": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/param-case/-/param-case-2.1.1.tgz", + "integrity": "sha512-eQE845L6ot89sk2N8liD8HAuH4ca6Vvr7VWAWwt7+kvvG5aBcPmmphQ68JsEG2qa9n1TykS2DLeMt363AAH8/w==", + "dev": true, + "dependencies": { + "no-case": "^2.2.0" + } + }, + "node_modules/parent-module": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-2.0.0.tgz", + "integrity": "sha512-uo0Z9JJeWzv8BG+tRcapBKNJ0dro9cLyczGzulS6EfeyAdeC9sbojtW6XwvYxJkEne9En+J2XEl4zyglVeIwFg==", + "dependencies": { + "callsites": "^3.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/parent-module/node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "engines": { + "node": ">=6" + } + }, + "node_modules/parse-asn1": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.6.tgz", + "integrity": "sha512-RnZRo1EPU6JBnra2vGHj0yhp6ebyjBZpmUCLHWiFhxlzvBCCpAuZ7elsBp1PVAbQN0/04VD/19rfzlBSwLstMw==", + "dev": true, + "dependencies": { + "asn1.js": "^5.2.0", + "browserify-aes": "^1.0.0", + "evp_bytestokey": "^1.0.0", + "pbkdf2": "^3.0.3", + "safe-buffer": "^5.1.1" + } + }, + "node_modules/parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha512-aOIos8bujGN93/8Ox/jPLh7RwVnPEysynVFE+fQZyg6jKELEHwzgKdLRFHUgXJL6kylijVSBC4BvN9OmsB48Rw==", + "dev": true, + "dependencies": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", + "integrity": "sha512-XHXfu/yOQRy9vYOtUDVMN60OEJjW013GoObG1o+xwQTpB9eYJX/BjXMsdW13ZDPruFhYYn0AG22w0xgQMwl3Nw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-browserify": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.1.tgz", + "integrity": "sha512-BapA40NHICOS+USX9SN4tyhq+A2RrN/Ws5F0Z5aMHDp98Fl86lX8Oti8B7uN93L4Ifv4fHOEA+pQw87gmMO/lQ==", + "dev": true + }, + "node_modules/path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", + "integrity": "sha512-ALzNPpyNq9AqXMBjeymIjFDAkAFH06mHJH/cSBHAgU0s4vfpBn6b2nf8tiRLvagKD8RbTpq2FKTBg7cl9l3c7Q==", + "dev": true + }, + "node_modules/path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-is-inside": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", + "integrity": "sha512-DUWJr3+ULp4zXmol/SZkFf3JGsS9/SIv+Y3Rt93/UjPpDpklB5f1er4O3POIbUuUJ3FXgqte2Q7SrU6zAqwk8w==", + "dev": true + }, + "node_modules/path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "dev": true + }, + "node_modules/path-to-regexp": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", + "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==", + "dev": true + }, + "node_modules/path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "dev": true, + "dependencies": { + "pify": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/path-type/node_modules/pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/pbkdf2": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.1.2.tgz", + "integrity": "sha512-iuh7L6jA7JEGu2WxDwtQP1ddOpaJNC4KlDEFfdQajSGgGPNi4OyDc2R7QnbY2bR9QjBVGwgvTdNJZoE7RaxUMA==", + "dev": true, + "dependencies": { + "create-hash": "^1.1.2", + "create-hmac": "^1.1.4", + "ripemd160": "^2.0.1", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + }, + "engines": { + "node": ">=0.12" + } + }, + "node_modules/performance-now": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", + "integrity": "sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow==", + "dev": true + }, + "node_modules/picocolors": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-0.2.1.tgz", + "integrity": "sha512-cMlDqaLEqfSaW8Z7N5Jw+lyIW869EzT73/F5lhtY9cLGoVxSXznfgfXMO0Z5K0o0Q2TkTXq+0KFsdnSe3jDViA==", + "dev": true + }, + "node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true, + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/pinkie": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", + "integrity": "sha512-MnUuEycAemtSaeFSjXKW/aroV7akBbY+Sv+RkyqFjgAe73F+MR0TBWKBRDkmfWq/HiFmdavfZ1G7h4SPZXaCSg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/pinkie-promise": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", + "integrity": "sha512-0Gni6D4UcLTbv9c57DfxDGdr41XfgUjqWZu492f0cIGr16zDU06BWP/RAEvOuo7CQ0CNjHaLlM59YJJFm3NWlw==", + "dev": true, + "dependencies": { + "pinkie": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/pkg-dir": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", + "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "dev": true, + "dependencies": { + "find-up": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/portfinder": { + "version": "1.0.32", + "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.32.tgz", + "integrity": "sha512-on2ZJVVDXRADWE6jnQaX0ioEylzgBpQk8r55NE4wjXW1ZxO+BgDlY6DXwj20i0V8eB4SenDQ00WEaxfiIQPcxg==", + "dev": true, + "dependencies": { + "async": "^2.6.4", + "debug": "^3.2.7", + "mkdirp": "^0.5.6" + }, + "engines": { + "node": ">= 0.12.0" + } + }, + "node_modules/portfinder/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/portfinder/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true + }, + "node_modules/posix-character-classes": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", + "integrity": "sha512-xTgYBc3fuo7Yt7JbiuFxSYGToMoz8fLoE6TC9Wx1P/u+LfeThMOAqmuyECnlBaaJb+u1m9hHiXUEtwW4OzfUJg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/postcss": { + "version": "7.0.39", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.39.tgz", + "integrity": "sha512-yioayjNbHn6z1/Bywyb2Y4s3yvDAeXGOyxqD+LnVOinq6Mdmd++SW2wUNVzavyyHxd6+DxzWGIuosg6P1Rj8uA==", + "dev": true, + "dependencies": { + "picocolors": "^0.2.1", + "source-map": "^0.6.1" + }, + "engines": { + "node": ">=6.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, + "node_modules/postcss-calc": { + "version": "7.0.5", + "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-7.0.5.tgz", + "integrity": "sha512-1tKHutbGtLtEZF6PT4JSihCHfIVldU72mZ8SdZHIYriIZ9fh9k9aWSppaT8rHsyI3dX+KSR+W+Ix9BMY3AODrg==", + "dev": true, + "dependencies": { + "postcss": "^7.0.27", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.0.2" + } + }, + "node_modules/postcss-colormin": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-colormin/-/postcss-colormin-4.0.3.tgz", + "integrity": "sha512-WyQFAdDZpExQh32j0U0feWisZ0dmOtPl44qYmJKkq9xFWY3p+4qnRzCHeNrkeRhwPHz9bQ3mo0/yVkaply0MNw==", + "dev": true, + "dependencies": { + "browserslist": "^4.0.0", + "color": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-colormin/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-convert-values": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-convert-values/-/postcss-convert-values-4.0.1.tgz", + "integrity": "sha512-Kisdo1y77KUC0Jmn0OXU/COOJbzM8cImvw1ZFsBgBgMgb1iL23Zs/LXRe3r+EZqM3vGYKdQ2YJVQ5VkJI+zEJQ==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-convert-values/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-discard-comments": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-4.0.2.tgz", + "integrity": "sha512-RJutN259iuRf3IW7GZyLM5Sw4GLTOH8FmsXBnv8Ab/Tc2k4SR4qbV4DNbyyY4+Sjo362SyDmW2DQ7lBSChrpkg==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-discard-duplicates": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-4.0.2.tgz", + "integrity": "sha512-ZNQfR1gPNAiXZhgENFfEglF93pciw0WxMkJeVmw8eF+JZBbMD7jp6C67GqJAXVZP2BWbOztKfbsdmMp/k8c6oQ==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-discard-empty": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-4.0.1.tgz", + "integrity": "sha512-B9miTzbznhDjTfjvipfHoqbWKwd0Mj+/fL5s1QOz06wufguil+Xheo4XpOnc4NqKYBCNqqEzgPv2aPBIJLox0w==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-discard-overridden": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-4.0.1.tgz", + "integrity": "sha512-IYY2bEDD7g1XM1IDEsUT4//iEYCxAmP5oDSFMVU/JVvT7gh+l4fmjciLqGgwjdWpQIdb0Che2VX00QObS5+cTg==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-load-config": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-2.1.2.tgz", + "integrity": "sha512-/rDeGV6vMUo3mwJZmeHfEDvwnTKKqQ0S7OHUi/kJvvtx3aWtyWG2/0ZWnzCt2keEclwN6Tf0DST2v9kITdOKYw==", + "dev": true, + "dependencies": { + "cosmiconfig": "^5.0.0", + "import-cwd": "^2.0.0" + }, + "engines": { + "node": ">= 4" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + } + }, + "node_modules/postcss-loader": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-3.0.0.tgz", + "integrity": "sha512-cLWoDEY5OwHcAjDnkyRQzAXfs2jrKjXpO/HQFcc5b5u/r7aa471wdmChmwfnv7x2u840iat/wi0lQ5nbRgSkUA==", + "dev": true, + "dependencies": { + "loader-utils": "^1.1.0", + "postcss": "^7.0.0", + "postcss-load-config": "^2.0.0", + "schema-utils": "^1.0.0" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/postcss-loader/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/postcss-merge-longhand": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/postcss-merge-longhand/-/postcss-merge-longhand-4.0.11.tgz", + "integrity": "sha512-alx/zmoeXvJjp7L4mxEMjh8lxVlDFX1gqWHzaaQewwMZiVhLo42TEClKaeHbRf6J7j82ZOdTJ808RtN0ZOZwvw==", + "dev": true, + "dependencies": { + "css-color-names": "0.0.4", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "stylehacks": "^4.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-merge-longhand/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-merge-rules": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-merge-rules/-/postcss-merge-rules-4.0.3.tgz", + "integrity": "sha512-U7e3r1SbvYzO0Jr3UT/zKBVgYYyhAz0aitvGIYOYK5CPmkNih+WDSsS5tvPrJ8YMQYlEMvsZIiqmn7HdFUaeEQ==", + "dev": true, + "dependencies": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "cssnano-util-same-parent": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0", + "vendors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-merge-rules/node_modules/postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "dev": true, + "dependencies": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/postcss-minify-font-values": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-font-values/-/postcss-minify-font-values-4.0.2.tgz", + "integrity": "sha512-j85oO6OnRU9zPf04+PZv1LYIYOprWm6IA6zkXkrJXyRveDEuQggG6tvoy8ir8ZwjLxLuGfNkCZEQG7zan+Hbtg==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-minify-font-values/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-minify-gradients": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-gradients/-/postcss-minify-gradients-4.0.2.tgz", + "integrity": "sha512-qKPfwlONdcf/AndP1U8SJ/uzIJtowHlMaSioKzebAXSG4iJthlWC9iSWznQcX4f66gIWX44RSA841HTHj3wK+Q==", + "dev": true, + "dependencies": { + "cssnano-util-get-arguments": "^4.0.0", + "is-color-stop": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-minify-gradients/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-minify-params": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-params/-/postcss-minify-params-4.0.2.tgz", + "integrity": "sha512-G7eWyzEx0xL4/wiBBJxJOz48zAKV2WG3iZOqVhPet/9geefm/Px5uo1fzlHu+DOjT+m0Mmiz3jkQzVHe6wxAWg==", + "dev": true, + "dependencies": { + "alphanum-sort": "^1.0.0", + "browserslist": "^4.0.0", + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "uniqs": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-minify-params/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-minify-selectors": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-selectors/-/postcss-minify-selectors-4.0.2.tgz", + "integrity": "sha512-D5S1iViljXBj9kflQo4YutWnJmwm8VvIsU1GeXJGiG9j8CIg9zs4voPMdQDUmIxetUOh60VilsNzCiAFTOqu3g==", + "dev": true, + "dependencies": { + "alphanum-sort": "^1.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-minify-selectors/node_modules/postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "dev": true, + "dependencies": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/postcss-modules-extract-imports": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-2.0.0.tgz", + "integrity": "sha512-LaYLDNS4SG8Q5WAWqIJgdHPJrDDr/Lv775rMBFUbgjTz6j34lUznACHcdRWroPvXANP2Vj7yNK57vp9eFqzLWQ==", + "dev": true, + "dependencies": { + "postcss": "^7.0.5" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/postcss-modules-local-by-default": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-2.0.6.tgz", + "integrity": "sha512-oLUV5YNkeIBa0yQl7EYnxMgy4N6noxmiwZStaEJUSe2xPMcdNc8WmBQuQCx18H5psYbVxz8zoHk0RAAYZXP9gA==", + "dev": true, + "dependencies": { + "postcss": "^7.0.6", + "postcss-selector-parser": "^6.0.0", + "postcss-value-parser": "^3.3.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/postcss-modules-local-by-default/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-modules-scope": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-2.2.0.tgz", + "integrity": "sha512-YyEgsTMRpNd+HmyC7H/mh3y+MeFWevy7V1evVhJWewmMbjDHIbZbOXICC2y+m1xI1UVfIT1HMW/O04Hxyu9oXQ==", + "dev": true, + "dependencies": { + "postcss": "^7.0.6", + "postcss-selector-parser": "^6.0.0" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/postcss-modules-values": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-2.0.0.tgz", + "integrity": "sha512-Ki7JZa7ff1N3EIMlPnGTZfUMe69FFwiQPnVSXC9mnn3jozCRBYIxiZd44yJOV2AmabOo4qFf8s0dC/+lweG7+w==", + "dev": true, + "dependencies": { + "icss-replace-symbols": "^1.1.0", + "postcss": "^7.0.6" + } + }, + "node_modules/postcss-normalize-charset": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-4.0.1.tgz", + "integrity": "sha512-gMXCrrlWh6G27U0hF3vNvR3w8I1s2wOBILvA87iNXaPvSNo5uZAMYsZG7XjCUf1eVxuPfyL4TJ7++SGZLc9A3g==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-display-values": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-display-values/-/postcss-normalize-display-values-4.0.2.tgz", + "integrity": "sha512-3F2jcsaMW7+VtRMAqf/3m4cPFhPD3EFRgNs18u+k3lTJJlVe7d0YPO+bnwqo2xg8YiRpDXJI2u8A0wqJxMsQuQ==", + "dev": true, + "dependencies": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-display-values/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-normalize-positions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-positions/-/postcss-normalize-positions-4.0.2.tgz", + "integrity": "sha512-Dlf3/9AxpxE+NF1fJxYDeggi5WwV35MXGFnnoccP/9qDtFrTArZ0D0R+iKcg5WsUd8nUYMIl8yXDCtcrT8JrdA==", + "dev": true, + "dependencies": { + "cssnano-util-get-arguments": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-positions/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-normalize-repeat-style": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-4.0.2.tgz", + "integrity": "sha512-qvigdYYMpSuoFs3Is/f5nHdRLJN/ITA7huIoCyqqENJe9PvPmLhNLMu7QTjPdtnVf6OcYYO5SHonx4+fbJE1+Q==", + "dev": true, + "dependencies": { + "cssnano-util-get-arguments": "^4.0.0", + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-repeat-style/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-normalize-string": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-string/-/postcss-normalize-string-4.0.2.tgz", + "integrity": "sha512-RrERod97Dnwqq49WNz8qo66ps0swYZDSb6rM57kN2J+aoyEAJfZ6bMx0sx/F9TIEX0xthPGCmeyiam/jXif0eA==", + "dev": true, + "dependencies": { + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-string/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-normalize-timing-functions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-4.0.2.tgz", + "integrity": "sha512-acwJY95edP762e++00Ehq9L4sZCEcOPyaHwoaFOhIwWCDfik6YvqsYNxckee65JHLKzuNSSmAdxwD2Cud1Z54A==", + "dev": true, + "dependencies": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-timing-functions/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-normalize-unicode": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-unicode/-/postcss-normalize-unicode-4.0.1.tgz", + "integrity": "sha512-od18Uq2wCYn+vZ/qCOeutvHjB5jm57ToxRaMeNuf0nWVHaP9Hua56QyMF6fs/4FSUnVIw0CBPsU0K4LnBPwYwg==", + "dev": true, + "dependencies": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-unicode/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-normalize-url": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-url/-/postcss-normalize-url-4.0.1.tgz", + "integrity": "sha512-p5oVaF4+IHwu7VpMan/SSpmpYxcJMtkGppYf0VbdH5B6hN8YNmVyJLuY9FmLQTzY3fag5ESUUHDqM+heid0UVA==", + "dev": true, + "dependencies": { + "is-absolute-url": "^2.0.0", + "normalize-url": "^3.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-url/node_modules/normalize-url": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-3.3.0.tgz", + "integrity": "sha512-U+JJi7duF1o+u2pynbp2zXDW2/PADgC30f0GsHZtRh+HOcXHnw137TrNlyxxRvWW5fjKd3bcLHPxofWuCjaeZg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/postcss-normalize-url/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-normalize-whitespace": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-whitespace/-/postcss-normalize-whitespace-4.0.2.tgz", + "integrity": "sha512-tO8QIgrsI3p95r8fyqKV+ufKlSHh9hMJqACqbv2XknufqEDhDvbguXGBBqxw9nsQoXWf0qOqppziKJKHMD4GtA==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-normalize-whitespace/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-ordered-values": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/postcss-ordered-values/-/postcss-ordered-values-4.1.2.tgz", + "integrity": "sha512-2fCObh5UanxvSxeXrtLtlwVThBvHn6MQcu4ksNT2tsaV2Fg76R2CV98W7wNSlX+5/pFwEyaDwKLLoEV7uRybAw==", + "dev": true, + "dependencies": { + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-ordered-values/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-reduce-initial": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-reduce-initial/-/postcss-reduce-initial-4.0.3.tgz", + "integrity": "sha512-gKWmR5aUulSjbzOfD9AlJiHCGH6AEVLaM0AV+aSioxUDd16qXP1PCh8d1/BGVvpdWn8k/HiK7n6TjeoXN1F7DA==", + "dev": true, + "dependencies": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-reduce-transforms": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-reduce-transforms/-/postcss-reduce-transforms-4.0.2.tgz", + "integrity": "sha512-EEVig1Q2QJ4ELpJXMZR8Vt5DQx8/mo+dGWSR7vWXqcob2gQLyQGsionYcGKATXvQzMPn6DSN1vTN7yFximdIAg==", + "dev": true, + "dependencies": { + "cssnano-util-get-match": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-reduce-transforms/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-safe-parser": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-safe-parser/-/postcss-safe-parser-4.0.2.tgz", + "integrity": "sha512-Uw6ekxSWNLCPesSv/cmqf2bY/77z11O7jZGPax3ycZMFU/oi2DMH9i89AdHc1tRwFg/arFoEwX0IS3LCUxJh1g==", + "dev": true, + "dependencies": { + "postcss": "^7.0.26" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/postcss-selector-parser": { + "version": "6.0.15", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.15.tgz", + "integrity": "sha512-rEYkQOMUCEMhsKbK66tbEU9QVIxbhN18YiniAwA7XQYTVBqrBy+P2p5JcdqsHgKM2zWylp8d7J6eszocfds5Sw==", + "dev": true, + "dependencies": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/postcss-svgo": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-svgo/-/postcss-svgo-4.0.3.tgz", + "integrity": "sha512-NoRbrcMWTtUghzuKSoIm6XV+sJdvZ7GZSc3wdBN0W19FTtp2ko8NqLsgoh/m9CzNhU3KLPvQmjIwtaNFkaFTvw==", + "dev": true, + "dependencies": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "svgo": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-svgo/node_modules/postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", + "dev": true + }, + "node_modules/postcss-unique-selectors": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-unique-selectors/-/postcss-unique-selectors-4.0.1.tgz", + "integrity": "sha512-+JanVaryLo9QwZjKrmJgkI4Fn8SBgRO6WXQBJi7KiAVPlmxikB5Jzc4EvXMT2H0/m0RjrVVm9rGNhZddm/8Spg==", + "dev": true, + "dependencies": { + "alphanum-sort": "^1.0.0", + "postcss": "^7.0.0", + "uniqs": "^2.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/postcss-value-parser": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", + "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", + "dev": true + }, + "node_modules/prepend-http": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-2.0.0.tgz", + "integrity": "sha512-ravE6m9Atw9Z/jjttRUZ+clIXogdghyZAuWJ3qEzjT+jI/dL1ifAqhZeC5VHzQp1MSt1+jxKkFNemj/iO7tVUA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/prettier": { + "version": "2.8.8", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", + "integrity": "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q==", + "dev": true, + "optional": true, + "bin": { + "prettier": "bin-prettier.js" + }, + "engines": { + "node": ">=10.13.0" + }, + "funding": { + "url": "https://github.com/prettier/prettier?sponsor=1" + } + }, + "node_modules/pretty-bytes": { + "version": "5.6.0", + "resolved": "https://registry.npmjs.org/pretty-bytes/-/pretty-bytes-5.6.0.tgz", + "integrity": "sha512-FFw039TmrBqFK8ma/7OL3sDz/VytdtJr044/QUJtH0wK9lb9jLq9tJyIxUwtQJHwar2BqtiA4iCWSwo9JLkzFg==", + "dev": true, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/pretty-error": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/pretty-error/-/pretty-error-2.1.2.tgz", + "integrity": "sha512-EY5oDzmsX5wvuynAByrmY0P0hcp+QpnAKbJng2A2MPjVKXCxrDSUkzghVJ4ZGPIv+JC4gX8fPUWscC0RtjsWGw==", + "dev": true, + "dependencies": { + "lodash": "^4.17.20", + "renderkid": "^2.0.4" + } + }, + "node_modules/pretty-time": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/pretty-time/-/pretty-time-1.1.0.tgz", + "integrity": "sha512-28iF6xPQrP8Oa6uxE6a1biz+lWeTOAPKggvjB8HAs6nVMKZwf5bG++632Dx614hIWgUPkgivRfG+a8uAXGTIbA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/prismjs": { + "version": "1.29.0", + "resolved": "https://registry.npmjs.org/prismjs/-/prismjs-1.29.0.tgz", + "integrity": "sha512-Kx/1w86q/epKcmte75LNrEoT+lX8pBpavuAbvJWRXar7Hz8jrtF+e3vY751p0R8H9HdArwaCTNDDzHg/ScJK1Q==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha512-cdGef/drWFoydD1JsMzuFf8100nZl+GT+yacc2bEced5f9Rjk4z+WtFUTBu9PhOi9j/jfmBPu0mMEY4wIdAF8A==", + "dev": true, + "engines": { + "node": ">= 0.6.0" + } + }, + "node_modules/process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", + "dev": true + }, + "node_modules/promise-inflight": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz", + "integrity": "sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g==", + "dev": true + }, + "node_modules/proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", + "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", + "dev": true, + "dependencies": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/prr": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", + "integrity": "sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==", + "dev": true + }, + "node_modules/pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", + "integrity": "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ==", + "dev": true + }, + "node_modules/psl": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", + "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==", + "dev": true + }, + "node_modules/public-encrypt": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/public-encrypt/-/public-encrypt-4.0.3.tgz", + "integrity": "sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q==", + "dev": true, + "dependencies": { + "bn.js": "^4.1.0", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "parse-asn1": "^5.0.0", + "randombytes": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "node_modules/public-encrypt/node_modules/bn.js": { + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.12.0.tgz", + "integrity": "sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==", + "dev": true + }, + "node_modules/pump": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", + "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", + "dev": true, + "dependencies": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "node_modules/pumpify": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.1.tgz", + "integrity": "sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==", + "dev": true, + "dependencies": { + "duplexify": "^3.6.0", + "inherits": "^2.0.3", + "pump": "^2.0.0" + } + }, + "node_modules/pumpify/node_modules/pump": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", + "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", + "dev": true, + "dependencies": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "node_modules/punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/pupa": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/pupa/-/pupa-2.1.1.tgz", + "integrity": "sha512-l1jNAspIBSFqbT+y+5FosojNpVpF94nlI+wDUpqP9enwOTfHx9f0gh5nB96vl+6yTpsJsypeNrwfzPrKuHB41A==", + "dev": true, + "dependencies": { + "escape-goat": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha512-kV/CThkXo6xyFEZUugw/+pIOywXcDbFYgSct5cT3gqlbkBE1SJdwy6UQoZvodiWF/ckQLZyDE/Bu1M6gVu5lVw==", + "dev": true, + "engines": { + "node": ">=0.6.0", + "teleport": ">=0.2.0" + } + }, + "node_modules/qs": { + "version": "6.5.3", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.3.tgz", + "integrity": "sha512-qxXIEh4pCGfHICj1mAJQ2/2XVZkjCDTcEgfoSQxc/fYivUZxTkk7L3bDBJSoNrEzXI17oUO5Dp07ktqE5KzczA==", + "dev": true, + "engines": { + "node": ">=0.6" + } + }, + "node_modules/query-string": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/query-string/-/query-string-5.1.1.tgz", + "integrity": "sha512-gjWOsm2SoGlgLEdAGt7a6slVOk9mGiXmPFMqrEhLQ68rhQuBnpfs3+EmlvqKyxnCo9/PPlF+9MtY02S1aFg+Jw==", + "dev": true, + "dependencies": { + "decode-uri-component": "^0.2.0", + "object-assign": "^4.1.0", + "strict-uri-encode": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/querystring-es3": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz", + "integrity": "sha512-773xhDQnZBMFobEiztv8LIl70ch5MSF/jUQVlhwFyBILqq96anmoctVIYz+ZRp0qbCKATTn6ev02M3r7Ga5vqA==", + "dev": true, + "engines": { + "node": ">=0.4.x" + } + }, + "node_modules/querystringify": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", + "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", + "dev": true + }, + "node_modules/randombytes": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", + "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", + "dev": true, + "dependencies": { + "safe-buffer": "^5.1.0" + } + }, + "node_modules/randomfill": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/randomfill/-/randomfill-1.0.4.tgz", + "integrity": "sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw==", + "dev": true, + "dependencies": { + "randombytes": "^2.0.5", + "safe-buffer": "^5.1.0" + } + }, + "node_modules/range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/raw-body": { + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", + "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", + "dev": true, + "dependencies": { + "bytes": "3.1.2", + "http-errors": "2.0.0", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/raw-body/node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/rc": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", + "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", + "dev": true, + "dependencies": { + "deep-extend": "^0.6.0", + "ini": "~1.3.0", + "minimist": "^1.2.0", + "strip-json-comments": "~2.0.1" + }, + "bin": { + "rc": "cli.js" + } + }, + "node_modules/readable-stream": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", + "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", + "dev": true, + "dependencies": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "node_modules/readable-stream/node_modules/isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", + "dev": true + }, + "node_modules/readdirp": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", + "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/reduce": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/reduce/-/reduce-1.0.2.tgz", + "integrity": "sha512-xX7Fxke/oHO5IfZSk77lvPa/7bjMh9BuCk4OOoX5XTXrM7s0Z+MkPfSDfz0q7r91BhhGSs8gii/VEN/7zhCPpQ==", + "dev": true, + "dependencies": { + "object-keys": "^1.1.0" + } + }, + "node_modules/regenerate": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz", + "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==", + "dev": true + }, + "node_modules/regenerate-unicode-properties": { + "version": "10.1.1", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.1.tgz", + "integrity": "sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q==", + "dev": true, + "dependencies": { + "regenerate": "^1.4.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/regenerator-runtime": { + "version": "0.14.1", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz", + "integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==", + "dev": true + }, + "node_modules/regenerator-transform": { + "version": "0.15.2", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.2.tgz", + "integrity": "sha512-hfMp2BoF0qOk3uc5V20ALGDS2ddjQaLrdl7xrGXvAIow7qeWRM2VA2HuCHkUKk9slq3VwEwLNK3DFBqDfPGYtg==", + "dev": true, + "dependencies": { + "@babel/runtime": "^7.8.4" + } + }, + "node_modules/regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", + "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "dev": true, + "dependencies": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/regexp.prototype.flags": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz", + "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "set-function-name": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/regexpu-core": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.3.2.tgz", + "integrity": "sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ==", + "dev": true, + "dependencies": { + "@babel/regjsgen": "^0.8.0", + "regenerate": "^1.4.2", + "regenerate-unicode-properties": "^10.1.0", + "regjsparser": "^0.9.1", + "unicode-match-property-ecmascript": "^2.0.0", + "unicode-match-property-value-ecmascript": "^2.1.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/register-service-worker": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/register-service-worker/-/register-service-worker-1.7.2.tgz", + "integrity": "sha512-CiD3ZSanZqcMPRhtfct5K9f7i3OLCcBBWsJjLh1gW9RO/nS94sVzY59iS+fgYBOBqaBpf4EzfqUF3j9IG+xo8A==", + "dev": true + }, + "node_modules/registry-auth-token": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/registry-auth-token/-/registry-auth-token-4.2.2.tgz", + "integrity": "sha512-PC5ZysNb42zpFME6D/XlIgtNGdTl8bBOCw90xQLVMpzuuubJKYDWFAEuUNc+Cn8Z8724tg2SDhDRrkVEsqfDMg==", + "dev": true, + "dependencies": { + "rc": "1.2.8" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/registry-url": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/registry-url/-/registry-url-5.1.0.tgz", + "integrity": "sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw==", + "dev": true, + "dependencies": { + "rc": "^1.2.8" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/regjsparser": { + "version": "0.9.1", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz", + "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==", + "dev": true, + "dependencies": { + "jsesc": "~0.5.0" + }, + "bin": { + "regjsparser": "bin/parser" + } + }, + "node_modules/regjsparser/node_modules/jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==", + "dev": true, + "bin": { + "jsesc": "bin/jsesc" + } + }, + "node_modules/relateurl": { + "version": "0.2.7", + "resolved": "https://registry.npmjs.org/relateurl/-/relateurl-0.2.7.tgz", + "integrity": "sha512-G08Dxvm4iDN3MLM0EsP62EDV9IuhXPR6blNz6Utcp7zyV3tr4HVNINt6MpaRWbxoOHT3Q7YN2P+jaHX8vUbgog==", + "dev": true, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/remove-trailing-separator": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", + "integrity": "sha512-/hS+Y0u3aOfIETiaiirUFwDBDzmXPvO+jAfKTitUngIPzdKc6Z0LoFjM/CK5PL4C+eKwHohlHAb6H0VFfmmUsw==", + "dev": true + }, + "node_modules/renderkid": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/renderkid/-/renderkid-2.0.7.tgz", + "integrity": "sha512-oCcFyxaMrKsKcTY59qnCAtmDVSLfPbrv6A3tVbPdFMMrv5jaK10V6m40cKsoPNhAqN6rmHW9sswW4o3ruSrwUQ==", + "dev": true, + "dependencies": { + "css-select": "^4.1.3", + "dom-converter": "^0.2.0", + "htmlparser2": "^6.1.0", + "lodash": "^4.17.21", + "strip-ansi": "^3.0.1" + } + }, + "node_modules/renderkid/node_modules/ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha512-TIGnTpdo+E3+pCyAluZvtED5p5wCqLdezCyhPZzKPcxvFplEt4i+W7OONCKgeZFT3+y5NZZfOOS/Bdcanm1MYA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/renderkid/node_modules/css-select": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.3.0.tgz", + "integrity": "sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==", + "dev": true, + "dependencies": { + "boolbase": "^1.0.0", + "css-what": "^6.0.1", + "domhandler": "^4.3.1", + "domutils": "^2.8.0", + "nth-check": "^2.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/fb55" + } + }, + "node_modules/renderkid/node_modules/css-what": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz", + "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==", + "dev": true, + "engines": { + "node": ">= 6" + }, + "funding": { + "url": "https://github.com/sponsors/fb55" + } + }, + "node_modules/renderkid/node_modules/dom-serializer": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.4.1.tgz", + "integrity": "sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==", + "dev": true, + "dependencies": { + "domelementtype": "^2.0.1", + "domhandler": "^4.2.0", + "entities": "^2.0.0" + }, + "funding": { + "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1" + } + }, + "node_modules/renderkid/node_modules/domelementtype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", + "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/fb55" + } + ] + }, + "node_modules/renderkid/node_modules/domutils": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz", + "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==", + "dev": true, + "dependencies": { + "dom-serializer": "^1.0.1", + "domelementtype": "^2.2.0", + "domhandler": "^4.2.0" + }, + "funding": { + "url": "https://github.com/fb55/domutils?sponsor=1" + } + }, + "node_modules/renderkid/node_modules/entities": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", + "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", + "dev": true, + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" + } + }, + "node_modules/renderkid/node_modules/nth-check": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz", + "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==", + "dev": true, + "dependencies": { + "boolbase": "^1.0.0" + }, + "funding": { + "url": "https://github.com/fb55/nth-check?sponsor=1" + } + }, + "node_modules/renderkid/node_modules/strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha512-VhumSSbBqDTP8p2ZLKj40UjBCV4+v8bUSEpUb4KjRgWk9pbqGF4REFj6KEagidb2f/M6AzC0EmFyDNGaw9OCzg==", + "dev": true, + "dependencies": { + "ansi-regex": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/repeat-element": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.4.tgz", + "integrity": "sha512-LFiNfRcSu7KK3evMyYOuCzv3L10TW7yC1G2/+StMjK8Y6Vqd2MG7r/Qjw4ghtuCOjFvlnms/iMmLqpvW/ES/WQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", + "integrity": "sha512-PV0dzCYDNfRi1jCDbJzpW7jNNDRuCOG/jI5ctQcGKt/clZD+YcPS3yIlWuTJMmESC8aevCFmWJy5wjAFgNqN6w==", + "dev": true, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/request": { + "version": "2.88.2", + "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", + "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", + "deprecated": "request has been deprecated, see https://github.com/request/request/issues/3142", + "dev": true, + "dependencies": { + "aws-sign2": "~0.7.0", + "aws4": "^1.8.0", + "caseless": "~0.12.0", + "combined-stream": "~1.0.6", + "extend": "~3.0.2", + "forever-agent": "~0.6.1", + "form-data": "~2.3.2", + "har-validator": "~5.1.3", + "http-signature": "~1.2.0", + "is-typedarray": "~1.0.0", + "isstream": "~0.1.2", + "json-stringify-safe": "~5.0.1", + "mime-types": "~2.1.19", + "oauth-sign": "~0.9.0", + "performance-now": "^2.1.0", + "qs": "~6.5.2", + "safe-buffer": "^5.1.2", + "tough-cookie": "~2.5.0", + "tunnel-agent": "^0.6.0", + "uuid": "^3.3.2" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/require-main-filename": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", + "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", + "dev": true + }, + "node_modules/requires-port": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", + "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==", + "dev": true + }, + "node_modules/resolve": { + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", + "dev": true, + "dependencies": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-cwd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-2.0.0.tgz", + "integrity": "sha512-ccu8zQTrzVr954472aUVPLEcB3YpKSYR3cg/3lo1okzobPBM+1INXBbBZlDbnI/hbEocnf8j0QVo43hQKrbchg==", + "dev": true, + "dependencies": { + "resolve-from": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/resolve-from": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", + "integrity": "sha512-GnlH6vxLymXJNMBo7XP1fJIzBFbdYt49CuTwmB/6N53t+kMPRMFKz783LlQ4tv28XoQfMWinAJX6WCGf2IlaIw==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", + "integrity": "sha512-ZuF55hVUQaaczgOIwqWzkEcEidmlD/xl44x1UZnhOXcYuFN2S6+rcxpG+C1N3So0wvNI3DmJICUFfu2SxhBmvg==", + "deprecated": "https://github.com/lydell/resolve-url#deprecated", + "dev": true + }, + "node_modules/responselike": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/responselike/-/responselike-1.0.2.tgz", + "integrity": "sha512-/Fpe5guzJk1gPqdJLJR5u7eG/gNY4nImjbRDaVWVMRhne55TCmj2i9Q+54PBRfatRC8v/rIiv9BN0pMd9OV5EQ==", + "dev": true, + "dependencies": { + "lowercase-keys": "^1.0.0" + } + }, + "node_modules/ret": { + "version": "0.1.15", + "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", + "dev": true, + "engines": { + "node": ">=0.12" + } + }, + "node_modules/retry": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", + "integrity": "sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow==", + "dev": true, + "engines": { + "node": ">= 4" + } + }, + "node_modules/rgb-regex": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/rgb-regex/-/rgb-regex-1.0.1.tgz", + "integrity": "sha512-gDK5mkALDFER2YLqH6imYvK6g02gpNGM4ILDZ472EwWfXZnC2ZEpoB2ECXTyOVUKuk/bPJZMzwQPBYICzP+D3w==", + "dev": true + }, + "node_modules/rgba-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/rgba-regex/-/rgba-regex-1.0.0.tgz", + "integrity": "sha512-zgn5OjNQXLUTdq8m17KdaicF6w89TZs8ZU8y0AYENIU6wG8GG6LLm0yLSiPY8DmaYmHdgRW8rnApjoT0fQRfMg==", + "dev": true + }, + "node_modules/rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "dev": true, + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/ripemd160": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", + "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", + "dev": true, + "dependencies": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1" + } + }, + "node_modules/run-queue": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/run-queue/-/run-queue-1.0.3.tgz", + "integrity": "sha512-ntymy489o0/QQplUDnpYAYUsO50K9SBrIVaKCWDOJzYJts0f9WH9RFJkyagebkw5+y1oi00R7ynNW/d12GBumg==", + "dev": true, + "dependencies": { + "aproba": "^1.1.1" + } + }, + "node_modules/safe-array-concat": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.0.1.tgz", + "integrity": "sha512-6XbUAseYE2KtOuGueyeobCySj9L4+66Tn6KQMOPQJrAJEowYKW/YR/MGJZl7FdydUdaFu4LYyDZjxf4/Nmo23Q==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + }, + "engines": { + "node": ">=0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "dev": true + }, + "node_modules/safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "integrity": "sha512-aJXcif4xnaNUzvUuC5gcb46oTS7zvg4jpMTnuqtrEPlR3vFr4pxtdTwaF1Qs3Enjn9HK+ZlwQui+a7z0SywIzg==", + "dev": true, + "dependencies": { + "ret": "~0.1.10" + } + }, + "node_modules/safe-regex-test": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.2.tgz", + "integrity": "sha512-83S9w6eFq12BBIJYvjMux6/dkirb8+4zJRA9cxNBVb7Wq5fJBW+Xze48WqR8pxua7bDuAaaAxtVVd4Idjp1dBQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.5", + "get-intrinsic": "^1.2.2", + "is-regex": "^1.1.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true + }, + "node_modules/sax": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", + "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", + "dev": true + }, + "node_modules/schema-utils": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-2.7.1.tgz", + "integrity": "sha512-SHiNtMOUGWBQJwzISiVYKu82GiV4QYGePp3odlY1tuKO7gPtphAT5R/py0fA6xtbgLL/RvtJZnU9b8s0F1q0Xg==", + "dev": true, + "dependencies": { + "@types/json-schema": "^7.0.5", + "ajv": "^6.12.4", + "ajv-keywords": "^3.5.2" + }, + "engines": { + "node": ">= 8.9.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + } + }, + "node_modules/section-matter": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/section-matter/-/section-matter-1.0.0.tgz", + "integrity": "sha512-vfD3pmTzGpufjScBh50YHKzEu2lxBWhVEHsNGoEXmCmn2hKGfeNLYMzCJpe8cD7gqX7TJluOVpBkAequ6dgMmA==", + "dev": true, + "dependencies": { + "extend-shallow": "^2.0.1", + "kind-of": "^6.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/section-matter/node_modules/extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==", + "dev": true, + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/section-matter/node_modules/is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/select-hose": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", + "integrity": "sha512-mEugaLK+YfkijB4fx0e6kImuJdCIt2LxCRcbEYPqRGCs4F2ogyfZU5IAZRdjCP8JPq2AtdNoC/Dux63d9Kiryg==", + "dev": true + }, + "node_modules/selfsigned": { + "version": "1.10.14", + "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-1.10.14.tgz", + "integrity": "sha512-lkjaiAye+wBZDCBsu5BGi0XiLRxeUlsGod5ZP924CRSEoGuZAw/f7y9RKu28rwTfiHVhdavhB0qH0INV6P1lEA==", + "dev": true, + "dependencies": { + "node-forge": "^0.10.0" + } + }, + "node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/semver-diff": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/semver-diff/-/semver-diff-3.1.1.tgz", + "integrity": "sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg==", + "dev": true, + "dependencies": { + "semver": "^6.3.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/send": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", + "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", + "dev": true, + "dependencies": { + "debug": "2.6.9", + "depd": "2.0.0", + "destroy": "1.2.0", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "2.0.0", + "mime": "1.6.0", + "ms": "2.1.3", + "on-finished": "2.4.1", + "range-parser": "~1.2.1", + "statuses": "2.0.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/send/node_modules/mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", + "dev": true, + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/send/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true + }, + "node_modules/serialize-javascript": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-4.0.0.tgz", + "integrity": "sha512-GaNA54380uFefWghODBWEGisLZFj00nS5ACs6yHa9nLqlLpVLO8ChDGeKRjZnV4Nh4n0Qi7nhYZD/9fCPzEqkw==", + "dev": true, + "dependencies": { + "randombytes": "^2.1.0" + } + }, + "node_modules/serve-index": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz", + "integrity": "sha512-pXHfKNP4qujrtteMrSBb0rc8HJ9Ms/GrXwcUtUtD5s4ewDJI8bT3Cz2zTVRMKtri49pLx2e0Ya8ziP5Ya2pZZw==", + "dev": true, + "dependencies": { + "accepts": "~1.3.4", + "batch": "0.6.1", + "debug": "2.6.9", + "escape-html": "~1.0.3", + "http-errors": "~1.6.2", + "mime-types": "~2.1.17", + "parseurl": "~1.3.2" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/serve-index/node_modules/depd": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", + "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/serve-index/node_modules/http-errors": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", + "integrity": "sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A==", + "dev": true, + "dependencies": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.0", + "statuses": ">= 1.4.0 < 2" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/serve-index/node_modules/inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==", + "dev": true + }, + "node_modules/serve-index/node_modules/setprototypeof": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", + "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", + "dev": true + }, + "node_modules/serve-index/node_modules/statuses": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", + "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==", + "dev": true, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/serve-static": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", + "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", + "dev": true, + "dependencies": { + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.18.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==", + "dev": true + }, + "node_modules/set-function-length": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.0.tgz", + "integrity": "sha512-4DBHDoyHlM1IRPGYcoxexgh67y4ueR53FKV1yyxwFMY7aCqcN/38M1+SwZ/qJQ8iLv7+ck385ot4CcisOAPT9w==", + "dev": true, + "dependencies": { + "define-data-property": "^1.1.1", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.2", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/set-function-name": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz", + "integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==", + "dev": true, + "dependencies": { + "define-data-property": "^1.0.1", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/set-value": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", + "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==", + "dev": true, + "dependencies": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/set-value/node_modules/extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==", + "dev": true, + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/set-value/node_modules/is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/setimmediate": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", + "integrity": "sha512-MATJdZp8sLqDl/68LfQmbP8zKPLQNV6BIZoIgrscFDQ+RsvK/BxeDQOgyxKKoh0y/8h3BqVFnCqQ/gd+reiIXA==", + "dev": true + }, + "node_modules/setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", + "dev": true + }, + "node_modules/sha.js": { + "version": "2.4.11", + "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", + "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", + "dev": true, + "dependencies": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + }, + "bin": { + "sha.js": "bin.js" + } + }, + "node_modules/shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", + "dev": true, + "dependencies": { + "shebang-regex": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/side-channel": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", + "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.0", + "get-intrinsic": "^1.0.2", + "object-inspect": "^1.9.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "dev": true + }, + "node_modules/simple-swizzle": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", + "integrity": "sha512-JA//kQgZtbuY83m+xT+tXJkmJncGMTFT+C+g2h2R9uxkYIrE2yy9sgmcLhCnw57/WSD+Eh3J97FPEDFnbXnDUg==", + "dev": true, + "dependencies": { + "is-arrayish": "^0.3.1" + } + }, + "node_modules/simple-swizzle/node_modules/is-arrayish": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", + "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==", + "dev": true + }, + "node_modules/slash": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz", + "integrity": "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/smoothscroll-polyfill": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/smoothscroll-polyfill/-/smoothscroll-polyfill-0.4.4.tgz", + "integrity": "sha512-TK5ZA9U5RqCwMpfoMq/l1mrH0JAR7y7KRvOBx0n2869aLxch+gT9GhN3yUfjiw+d/DiF1mKo14+hd62JyMmoBg==", + "dev": true + }, + "node_modules/snapdragon": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", + "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", + "dev": true, + "dependencies": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-node": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", + "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", + "dev": true, + "dependencies": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-node/node_modules/define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha512-cZTYKFWspt9jZsMscWo8sc/5lbPC9Q0N5nBLgb+Yd915iL3udB1uFgS3B8YCx66UVHq018DAVFoee7x+gxggeA==", + "dev": true, + "dependencies": { + "is-descriptor": "^1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "dev": true, + "dependencies": { + "kind-of": "^3.2.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon-util/node_modules/kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ==", + "dev": true, + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon/node_modules/define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha512-Rr7ADjQZenceVOAKop6ALkkRAmH1A4Gx9hV/7ZujPUN2rkATqFO0JZLZInbAjpZYoJ1gUx8MRMQVkYemcbMSTA==", + "dev": true, + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon/node_modules/extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==", + "dev": true, + "dependencies": { + "is-extendable": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon/node_modules/is-descriptor": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.7.tgz", + "integrity": "sha512-C3grZTvObeN1xud4cRWl366OMXZTj0+HGyk4hvfpx4ZHt1Pb60ANSXqCK7pdOTeUQpRzECBSTphqvD7U+l22Eg==", + "dev": true, + "dependencies": { + "is-accessor-descriptor": "^1.0.1", + "is-data-descriptor": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/snapdragon/node_modules/is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/snapdragon/node_modules/source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sockjs": { + "version": "0.3.24", + "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.24.tgz", + "integrity": "sha512-GJgLTZ7vYb/JtPSSZ10hsOYIvEYsjbNU+zPdIHcUaWVNUEPivzxku31865sSSud0Da0W4lEeOPlmw93zLQchuQ==", + "dev": true, + "dependencies": { + "faye-websocket": "^0.11.3", + "uuid": "^8.3.2", + "websocket-driver": "^0.7.4" + } + }, + "node_modules/sockjs-client": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/sockjs-client/-/sockjs-client-1.6.1.tgz", + "integrity": "sha512-2g0tjOR+fRs0amxENLi/q5TiJTqY+WXFOzb5UwXndlK6TO3U/mirZznpx6w34HVMoc3g7cY24yC/ZMIYnDlfkw==", + "dev": true, + "dependencies": { + "debug": "^3.2.7", + "eventsource": "^2.0.2", + "faye-websocket": "^0.11.4", + "inherits": "^2.0.4", + "url-parse": "^1.5.10" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://tidelift.com/funding/github/npm/sockjs-client" + } + }, + "node_modules/sockjs-client/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/sockjs-client/node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true + }, + "node_modules/sockjs/node_modules/uuid": { + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", + "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", + "dev": true, + "bin": { + "uuid": "dist/bin/uuid" + } + }, + "node_modules/sort-keys": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-2.0.0.tgz", + "integrity": "sha512-/dPCrG1s3ePpWm6yBbxZq5Be1dXGLyLn9Z791chDC3NFrpkVbWGzkBwPN1knaciexFXgRJ7hzdnwZ4stHSDmjg==", + "dev": true, + "dependencies": { + "is-plain-obj": "^1.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/sort-keys/node_modules/is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", + "integrity": "sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/source-list-map": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/source-list-map/-/source-list-map-2.0.1.tgz", + "integrity": "sha512-qnQ7gVMxGNxsiL4lEuJwe/To8UnK7fAnmbGEEH8RpLouuKbeEm0lhbQVFIrNSuB+G7tVrAlVsZgETT5nljf+Iw==", + "dev": true + }, + "node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/source-map-js": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", + "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/source-map-resolve": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.3.tgz", + "integrity": "sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw==", + "deprecated": "See https://github.com/lydell/source-map-resolve#deprecated", + "dev": true, + "dependencies": { + "atob": "^2.1.2", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } + }, + "node_modules/source-map-support": { + "version": "0.5.21", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", + "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", + "dev": true, + "dependencies": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "node_modules/source-map-url": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.1.tgz", + "integrity": "sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw==", + "deprecated": "See https://github.com/lydell/source-map-url#deprecated", + "dev": true + }, + "node_modules/spdy": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/spdy/-/spdy-4.0.2.tgz", + "integrity": "sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA==", + "dev": true, + "dependencies": { + "debug": "^4.1.0", + "handle-thing": "^2.0.0", + "http-deceiver": "^1.2.7", + "select-hose": "^2.0.0", + "spdy-transport": "^3.0.0" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/spdy-transport": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz", + "integrity": "sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw==", + "dev": true, + "dependencies": { + "debug": "^4.1.0", + "detect-node": "^2.0.4", + "hpack.js": "^2.1.6", + "obuf": "^1.1.2", + "readable-stream": "^3.0.6", + "wbuf": "^1.7.3" + } + }, + "node_modules/spdy-transport/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/spdy-transport/node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/spdy-transport/node_modules/readable-stream": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", + "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", + "dev": true, + "dependencies": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/spdy/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/spdy/node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/split-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", + "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", + "dev": true, + "dependencies": { + "extend-shallow": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==" + }, + "node_modules/sshpk": { + "version": "1.18.0", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.18.0.tgz", + "integrity": "sha512-2p2KJZTSqQ/I3+HX42EpYOa2l3f8Erv8MWKsy2I9uf4wA7yFIkXRffYdsx86y6z4vHtV8u7g+pPlr8/4ouAxsQ==", + "dev": true, + "dependencies": { + "asn1": "~0.2.3", + "assert-plus": "^1.0.0", + "bcrypt-pbkdf": "^1.0.0", + "dashdash": "^1.12.0", + "ecc-jsbn": "~0.1.1", + "getpass": "^0.1.1", + "jsbn": "~0.1.0", + "safer-buffer": "^2.0.2", + "tweetnacl": "~0.14.0" + }, + "bin": { + "sshpk-conv": "bin/sshpk-conv", + "sshpk-sign": "bin/sshpk-sign", + "sshpk-verify": "bin/sshpk-verify" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ssri": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/ssri/-/ssri-6.0.2.tgz", + "integrity": "sha512-cepbSq/neFK7xB6A50KHN0xHDotYzq58wWCa5LeWqnPrHG8GzfEjO/4O8kpmcGW+oaxkvhEJCWgbgNk4/ZV93Q==", + "dev": true, + "dependencies": { + "figgy-pudding": "^3.5.1" + } + }, + "node_modules/stable": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz", + "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==", + "deprecated": "Modern JS already guarantees Array#sort() is a stable sort, so this library is deprecated. See the compatibility table on MDN: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#browser_compatibility", + "dev": true + }, + "node_modules/stack-utils": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-1.0.5.tgz", + "integrity": "sha512-KZiTzuV3CnSnSvgMRrARVCj+Ht7rMbauGDK0LdVFRGyenwdylpajAp4Q0i6SX8rEmbTpMMf6ryq2gb8pPq2WgQ==", + "dev": true, + "dependencies": { + "escape-string-regexp": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/stack-utils/node_modules/escape-string-regexp": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", + "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", + "integrity": "sha512-72E9+uLc27Mt718pMHt9VMNiAL4LMsmDbBva8mxWUCkT07fSzEGMYUCk0XWY6lp0j6RBAG4cJ3mWuZv2OE3s0g==", + "dev": true, + "dependencies": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/static-extend/node_modules/define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha512-Rr7ADjQZenceVOAKop6ALkkRAmH1A4Gx9hV/7ZujPUN2rkATqFO0JZLZInbAjpZYoJ1gUx8MRMQVkYemcbMSTA==", + "dev": true, + "dependencies": { + "is-descriptor": "^0.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/static-extend/node_modules/is-descriptor": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.7.tgz", + "integrity": "sha512-C3grZTvObeN1xud4cRWl366OMXZTj0+HGyk4hvfpx4ZHt1Pb60ANSXqCK7pdOTeUQpRzECBSTphqvD7U+l22Eg==", + "dev": true, + "dependencies": { + "is-accessor-descriptor": "^1.0.1", + "is-data-descriptor": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/std-env": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/std-env/-/std-env-2.3.1.tgz", + "integrity": "sha512-eOsoKTWnr6C8aWrqJJ2KAReXoa7Vn5Ywyw6uCXgA/xDhxPoaIsBa5aNJmISY04dLwXPBnDHW4diGM7Sn5K4R/g==", + "dev": true, + "dependencies": { + "ci-info": "^3.1.1" + } + }, + "node_modules/std-env/node_modules/ci-info": { + "version": "3.9.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.9.0.tgz", + "integrity": "sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/sibiraj-s" + } + ], + "engines": { + "node": ">=8" + } + }, + "node_modules/stream-browserify": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.2.tgz", + "integrity": "sha512-nX6hmklHs/gr2FuxYDltq8fJA1GDlxKQCz8O/IM4atRqBH8OORmBNgfvW5gG10GT/qQ9u0CzIvr2X5Pkt6ntqg==", + "dev": true, + "dependencies": { + "inherits": "~2.0.1", + "readable-stream": "^2.0.2" + } + }, + "node_modules/stream-each": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/stream-each/-/stream-each-1.2.3.tgz", + "integrity": "sha512-vlMC2f8I2u/bZGqkdfLQW/13Zihpej/7PmSiMQsbYddxuTsJp8vRe2x2FvVExZg7FaOds43ROAuFJwPR4MTZLw==", + "dev": true, + "dependencies": { + "end-of-stream": "^1.1.0", + "stream-shift": "^1.0.0" + } + }, + "node_modules/stream-http": { + "version": "2.8.3", + "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.8.3.tgz", + "integrity": "sha512-+TSkfINHDo4J+ZobQLWiMouQYB+UVYFttRA94FpEzzJ7ZdqcL4uUUQ7WkdkI4DSozGmgBUE/a47L+38PenXhUw==", + "dev": true, + "dependencies": { + "builtin-status-codes": "^3.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.3.6", + "to-arraybuffer": "^1.0.0", + "xtend": "^4.0.0" + } + }, + "node_modules/stream-shift": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.2.tgz", + "integrity": "sha512-rV4Bovi9xx0BFzOb/X0B2GqoIjvqPCttZdu0Wgtx2Dxkj7ETyWl9gmqJ4EutWRLvtZWm8dxE+InQZX1IryZn/w==", + "dev": true + }, + "node_modules/strict-uri-encode": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", + "integrity": "sha512-R3f198pcvnB+5IpnBlRkphuE9n46WyVl8I39W/ZUTZLz4nqSP/oLYUrcnJrw462Ds8he4YKMov2efsTIw1BDGQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "dependencies": { + "safe-buffer": "~5.1.0" + } + }, + "node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string.prototype.trim": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", + "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimend": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", + "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimstart": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", + "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/stringify-object": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/stringify-object/-/stringify-object-3.3.0.tgz", + "integrity": "sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw==", + "dev": true, + "dependencies": { + "get-own-enumerable-property-symbols": "^3.0.0", + "is-obj": "^1.0.1", + "is-regexp": "^1.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/stringify-object/node_modules/is-obj": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", + "integrity": "sha512-l4RyHgRqGN4Y3+9JHVrNqO+tN0rV5My76uW5/nuO4K1b6vw5G8d/cmFjP9tRfEsdhZNt0IFdZuK/c2Vr4Nb+Qg==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-bom-string": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/strip-bom-string/-/strip-bom-string-1.0.0.tgz", + "integrity": "sha512-uCC2VHvQRYu+lMh4My/sFNmF2klFymLX1wHJeXnbEJERpV/ZsVuonzerjfrGpIGF7LBVa1O7i9kjiWvJiFck8g==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/strip-comments": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/strip-comments/-/strip-comments-1.0.2.tgz", + "integrity": "sha512-kL97alc47hoyIQSV165tTt9rG5dn4w1dNnBhOQ3bOU1Nc1hel09jnXANaHJ7vzHLd4Ju8kseDGzlev96pghLFw==", + "dev": true, + "dependencies": { + "babel-extract-comments": "^1.0.0", + "babel-plugin-transform-object-rest-spread": "^6.26.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/strip-eof": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", + "integrity": "sha512-7FCwGGmx8mD5xQd3RPUvnSpUXHM3BWuzjtpD4TXsfcZ9EL4azvVVUscFYwD9nx8Kh+uCBC00XBtAykoMHwTh8Q==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/strip-final-newline": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", + "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/strip-json-comments": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", + "integrity": "sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/stylehacks": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-4.0.3.tgz", + "integrity": "sha512-7GlLk9JwlElY4Y6a/rmbH2MhVlTyVmiJd1PfTCqFaIBEGMYNsrO/v3SeGTdhBThLg4Z+NbOk/qFMwCa+J+3p/g==", + "dev": true, + "dependencies": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/stylehacks/node_modules/postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "dev": true, + "dependencies": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/stylus": { + "version": "0.54.8", + "resolved": "https://registry.npmjs.org/stylus/-/stylus-0.54.8.tgz", + "integrity": "sha512-vr54Or4BZ7pJafo2mpf0ZcwA74rpuYCZbxrHBsH8kbcXOwSfvBFwsRfpGO5OD5fhG5HDCFW737PKaawI7OqEAg==", + "dev": true, + "dependencies": { + "css-parse": "~2.0.0", + "debug": "~3.1.0", + "glob": "^7.1.6", + "mkdirp": "~1.0.4", + "safer-buffer": "^2.1.2", + "sax": "~1.2.4", + "semver": "^6.3.0", + "source-map": "^0.7.3" + }, + "bin": { + "stylus": "bin/stylus" + }, + "engines": { + "node": "*" + } + }, + "node_modules/stylus-loader": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/stylus-loader/-/stylus-loader-3.0.2.tgz", + "integrity": "sha512-+VomPdZ6a0razP+zinir61yZgpw2NfljeSsdUF5kJuEzlo3khXhY19Fn6l8QQz1GRJGtMCo8nG5C04ePyV7SUA==", + "dev": true, + "dependencies": { + "loader-utils": "^1.0.2", + "lodash.clonedeep": "^4.5.0", + "when": "~3.6.x" + }, + "peerDependencies": { + "stylus": ">=0.52.4" + } + }, + "node_modules/stylus/node_modules/debug": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", + "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", + "dev": true, + "dependencies": { + "ms": "2.0.0" + } + }, + "node_modules/stylus/node_modules/mkdirp": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz", + "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==", + "dev": true, + "bin": { + "mkdirp": "bin/cmd.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/stylus/node_modules/source-map": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", + "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", + "dev": true, + "engines": { + "node": ">= 8" + } + }, + "node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "dev": true, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/svg-tags": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/svg-tags/-/svg-tags-1.0.0.tgz", + "integrity": "sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==", + "dev": true + }, + "node_modules/svgo": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/svgo/-/svgo-1.3.2.tgz", + "integrity": "sha512-yhy/sQYxR5BkC98CY7o31VGsg014AKLEPxdfhora76l36hD9Rdy5NZA/Ocn6yayNPgSamYdtX2rFJdcv07AYVw==", + "deprecated": "This SVGO version is no longer supported. Upgrade to v2.x.x.", + "dev": true, + "dependencies": { + "chalk": "^2.4.1", + "coa": "^2.0.2", + "css-select": "^2.0.0", + "css-select-base-adapter": "^0.1.1", + "css-tree": "1.0.0-alpha.37", + "csso": "^4.0.2", + "js-yaml": "^3.13.1", + "mkdirp": "~0.5.1", + "object.values": "^1.1.0", + "sax": "~1.2.4", + "stable": "^0.1.8", + "unquote": "~1.1.1", + "util.promisify": "~1.0.0" + }, + "bin": { + "svgo": "bin/svgo" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/tapable": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-1.1.3.tgz", + "integrity": "sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/term-size": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.1.tgz", + "integrity": "sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg==", + "dev": true, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/terser": { + "version": "4.8.1", + "resolved": "https://registry.npmjs.org/terser/-/terser-4.8.1.tgz", + "integrity": "sha512-4GnLC0x667eJG0ewJTa6z/yXrbLGv80D9Ru6HIpCQmO+Q4PfEtBFi0ObSckqwL6VyQv/7ENJieXHo2ANmdQwgw==", + "dev": true, + "dependencies": { + "commander": "^2.20.0", + "source-map": "~0.6.1", + "source-map-support": "~0.5.12" + }, + "bin": { + "terser": "bin/terser" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/terser-webpack-plugin": { + "version": "1.4.5", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-1.4.5.tgz", + "integrity": "sha512-04Rfe496lN8EYruwi6oPQkG0vo8C+HT49X687FZnpPF0qMAIHONI6HEXYPKDOE8e5HjXTyKfqRd/agHtH0kOtw==", + "dev": true, + "dependencies": { + "cacache": "^12.0.2", + "find-cache-dir": "^2.1.0", + "is-wsl": "^1.1.0", + "schema-utils": "^1.0.0", + "serialize-javascript": "^4.0.0", + "source-map": "^0.6.1", + "terser": "^4.1.2", + "webpack-sources": "^1.4.0", + "worker-farm": "^1.7.0" + }, + "engines": { + "node": ">= 6.9.0" + }, + "peerDependencies": { + "webpack": "^4.0.0" + } + }, + "node_modules/terser-webpack-plugin/node_modules/find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "dev": true, + "dependencies": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/terser-webpack-plugin/node_modules/find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "dependencies": { + "locate-path": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/terser-webpack-plugin/node_modules/locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "dependencies": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/terser-webpack-plugin/node_modules/make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "dependencies": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/terser-webpack-plugin/node_modules/p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "dependencies": { + "p-limit": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/terser-webpack-plugin/node_modules/path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/terser-webpack-plugin/node_modules/pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "dev": true, + "dependencies": { + "find-up": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/terser-webpack-plugin/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/terser-webpack-plugin/node_modules/semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true, + "bin": { + "semver": "bin/semver" + } + }, + "node_modules/terser/node_modules/commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", + "dev": true + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true + }, + "node_modules/through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", + "dev": true + }, + "node_modules/through2": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", + "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", + "dev": true, + "dependencies": { + "readable-stream": "~2.3.6", + "xtend": "~4.0.1" + } + }, + "node_modules/thunky": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz", + "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==", + "dev": true + }, + "node_modules/timers-browserify": { + "version": "2.0.12", + "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-2.0.12.tgz", + "integrity": "sha512-9phl76Cqm6FhSX9Xe1ZUAMLtm1BLkKj2Qd5ApyWkXzsMRaA7dgr81kf4wJmQf/hAvg8EEyJxDo3du/0KlhPiKQ==", + "dev": true, + "dependencies": { + "setimmediate": "^1.0.4" + }, + "engines": { + "node": ">=0.6.0" + } + }, + "node_modules/timsort": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/timsort/-/timsort-0.3.0.tgz", + "integrity": "sha512-qsdtZH+vMoCARQtyod4imc2nIJwg9Cc7lPRrw9CzF8ZKR0khdr8+2nX80PBhET3tcyTtJDxAffGh2rXH4tyU8A==", + "dev": true + }, + "node_modules/to-arraybuffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", + "integrity": "sha512-okFlQcoGTi4LQBG/PgSYblw9VOyptsz2KJZqc6qtgGdes8VktzUQkj4BI2blit072iS8VODNcMA+tvnS9dnuMA==", + "dev": true + }, + "node_modules/to-factory": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/to-factory/-/to-factory-1.0.0.tgz", + "integrity": "sha512-JVYrY42wMG7ddf+wBUQR/uHGbjUHZbLisJ8N62AMm0iTZ0p8YTcZLzdtomU0+H+wa99VbkyvQGB3zxB7NDzgIQ==", + "dev": true + }, + "node_modules/to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/to-object-path": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", + "integrity": "sha512-9mWHdnGRuh3onocaHzukyvCZhzvr6tiflAy/JRFXcJX0TjgfWA9pk9t8CMbzmBE4Jfw58pXbkngtBtqYxzNEyg==", + "dev": true, + "dependencies": { + "kind-of": "^3.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/to-object-path/node_modules/kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ==", + "dev": true, + "dependencies": { + "is-buffer": "^1.1.5" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/to-readable-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/to-readable-stream/-/to-readable-stream-1.0.0.tgz", + "integrity": "sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", + "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "dev": true, + "dependencies": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/to-regex-range": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", + "integrity": "sha512-ZZWNfCjUokXXDGXFpZehJIkZqq91BcULFq/Pi7M5i4JnxXdhMKAK682z8bCW3o8Hj1wuuzoKcW3DfVzaP6VuNg==", + "dev": true, + "dependencies": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "dev": true, + "engines": { + "node": ">=0.6" + } + }, + "node_modules/toml": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/toml/-/toml-3.0.0.tgz", + "integrity": "sha512-y/mWCZinnvxjTKYhJ+pYxwD0mRLVvOtdS2Awbgxln6iEnt4rk0yBxeSBHkGJcPucRiG0e55mwWp+g/05rsrd6w==", + "dev": true + }, + "node_modules/toposort": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/toposort/-/toposort-1.0.7.tgz", + "integrity": "sha512-FclLrw8b9bMWf4QlCJuHBEVhSRsqDj6u3nIjAzPeJvgl//1hBlffdlk0MALceL14+koWEdU4ofRAXofbODxQzg==", + "dev": true + }, + "node_modules/tough-cookie": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", + "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", + "dev": true, + "dependencies": { + "psl": "^1.1.28", + "punycode": "^2.1.1" + }, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/transliteration": { + "version": "2.3.5", + "resolved": "https://registry.npmjs.org/transliteration/-/transliteration-2.3.5.tgz", + "integrity": "sha512-HAGI4Lq4Q9dZ3Utu2phaWgtm3vB6PkLUFqWAScg/UW+1eZ/Tg6Exo4oC0/3VUol/w4BlefLhUUSVBr/9/ZGQOw==", + "dependencies": { + "yargs": "^17.5.1" + }, + "bin": { + "slugify": "dist/bin/slugify", + "transliterate": "dist/bin/transliterate" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/tty-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz", + "integrity": "sha512-JVa5ijo+j/sOoHGjw0sxw734b1LhBkQ3bvUGNdxnVXDCX81Yx7TFgnZygxrIIWn23hbfTaMYLwRmAxFyDuFmIw==", + "dev": true + }, + "node_modules/tunnel-agent": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", + "integrity": "sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==", + "dev": true, + "dependencies": { + "safe-buffer": "^5.0.1" + }, + "engines": { + "node": "*" + } + }, + "node_modules/tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha512-KXXFFdAbFXY4geFIwoyNK+f5Z1b7swfXABfL7HXCmoIWMKU3dmS26672A4EeQtDzLKy7SXmfBu51JolvEKwtGA==", + "dev": true + }, + "node_modules/type-fest": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", + "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/type-is": { + "version": "1.6.18", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", + "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", + "dev": true, + "dependencies": { + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/typed-array-buffer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz", + "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/typed-array-byte-length": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz", + "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "has-proto": "^1.0.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz", + "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "has-proto": "^1.0.1", + "is-typed-array": "^1.1.10" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-length": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", + "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "for-each": "^0.3.3", + "is-typed-array": "^1.1.9" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==", + "dev": true + }, + "node_modules/typedarray-to-buffer": { + "version": "3.1.5", + "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", + "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", + "dev": true, + "dependencies": { + "is-typedarray": "^1.0.0" + } + }, + "node_modules/uc.micro": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.6.tgz", + "integrity": "sha512-8Y75pvTYkLJW2hWQHXxoqRgV7qb9B+9vFEtidML+7koHUFapnVJAZ6cKs+Qjz5Aw3aZWHMC6u0wJE3At+nSGwA==" + }, + "node_modules/uglify-js": { + "version": "3.4.10", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.4.10.tgz", + "integrity": "sha512-Y2VsbPVs0FIshJztycsO2SfPk7/KAF/T72qzv9u5EpQ4kB2hQoHlhNQTsNyy6ul7lQtqJN/AoWeS23OzEiEFxw==", + "dev": true, + "dependencies": { + "commander": "~2.19.0", + "source-map": "~0.6.1" + }, + "bin": { + "uglifyjs": "bin/uglifyjs" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/uglify-js/node_modules/commander": { + "version": "2.19.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.19.0.tgz", + "integrity": "sha512-6tvAOO+D6OENvRAh524Dh9jcfKTYDQAqvqezbCW82xj5X0pSrcpxtvRKHLG0yBY6SD7PSDrJaj+0AiOcKVd1Xg==", + "dev": true + }, + "node_modules/unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/undici-types": { + "version": "5.26.5", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", + "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", + "dev": true + }, + "node_modules/unicode-canonical-property-names-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz", + "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-match-property-ecmascript": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz", + "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==", + "dev": true, + "dependencies": { + "unicode-canonical-property-names-ecmascript": "^2.0.0", + "unicode-property-aliases-ecmascript": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-match-property-value-ecmascript": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz", + "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/unicode-property-aliases-ecmascript": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz", + "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/union-value": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", + "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==", + "dev": true, + "dependencies": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^2.0.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/union-value/node_modules/is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/uniq": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", + "integrity": "sha512-Gw+zz50YNKPDKXs+9d+aKAjVwpjNwqzvNpLigIruT4HA9lMZNdMqs9x07kKHB/L9WRzqp4+DlTU5s4wG2esdoA==", + "dev": true + }, + "node_modules/uniqs": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/uniqs/-/uniqs-2.0.0.tgz", + "integrity": "sha512-mZdDpf3vBV5Efh29kMw5tXoup/buMgxLzOt/XKFKcVmi+15ManNQWr6HfZ2aiZTYlYixbdNJ0KFmIZIv52tHSQ==", + "dev": true + }, + "node_modules/unique-filename": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz", + "integrity": "sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ==", + "dev": true, + "dependencies": { + "unique-slug": "^2.0.0" + } + }, + "node_modules/unique-slug": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-2.0.2.tgz", + "integrity": "sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w==", + "dev": true, + "dependencies": { + "imurmurhash": "^0.1.4" + } + }, + "node_modules/unique-string": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/unique-string/-/unique-string-2.0.0.tgz", + "integrity": "sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg==", + "dev": true, + "dependencies": { + "crypto-random-string": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", + "dev": true, + "engines": { + "node": ">= 4.0.0" + } + }, + "node_modules/unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/unquote": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unquote/-/unquote-1.1.1.tgz", + "integrity": "sha512-vRCqFv6UhXpWxZPyGDh/F3ZpNv8/qo7w6iufLpQg9aKnQ71qM4B5KiI7Mia9COcjEhrO9LueHpMYjYzsWH3OIg==", + "dev": true + }, + "node_modules/unset-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", + "integrity": "sha512-PcA2tsuGSF9cnySLHTLSh2qrQiJ70mn+r+Glzxv2TWZblxsxCC52BDlZoPCsz7STd9pN7EZetkWZBAvk4cgZdQ==", + "dev": true, + "dependencies": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/unset-value/node_modules/has-value": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", + "integrity": "sha512-gpG936j8/MzaeID5Yif+577c17TxaDmhuyVgSwtnL/q8UUTySg8Mecb+8Cf1otgLoD7DDH75axp86ER7LFsf3Q==", + "dev": true, + "dependencies": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/unset-value/node_modules/has-value/node_modules/isobject": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", + "integrity": "sha512-+OUdGJlgjOBZDfxnDjYYG6zp487z0JGNQq3cYQYg5f5hKR+syHMsaztzGeml/4kGG55CSpKSpWTY+jYGgsHLgA==", + "dev": true, + "dependencies": { + "isarray": "1.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/unset-value/node_modules/has-values": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", + "integrity": "sha512-J8S0cEdWuQbqD9//tlZxiMuMNmxB8PlEwvYwuxsTmR1G5RXUePEX/SJn7aD0GMLieuZYSwNH0cQuJGwnYunXRQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/unset-value/node_modules/isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", + "dev": true + }, + "node_modules/upath": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz", + "integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==", + "dev": true, + "engines": { + "node": ">=4", + "yarn": "*" + } + }, + "node_modules/update-browserslist-db": { + "version": "1.0.13", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.13.tgz", + "integrity": "sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/browserslist" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "escalade": "^3.1.1", + "picocolors": "^1.0.0" + }, + "bin": { + "update-browserslist-db": "cli.js" + }, + "peerDependencies": { + "browserslist": ">= 4.21.0" + } + }, + "node_modules/update-browserslist-db/node_modules/picocolors": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", + "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", + "dev": true + }, + "node_modules/update-notifier": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/update-notifier/-/update-notifier-4.1.3.tgz", + "integrity": "sha512-Yld6Z0RyCYGB6ckIjffGOSOmHXj1gMeE7aROz4MG+XMkmixBX4jUngrGXNYz7wPKBmtoD4MnBa2Anu7RSKht/A==", + "dev": true, + "dependencies": { + "boxen": "^4.2.0", + "chalk": "^3.0.0", + "configstore": "^5.0.1", + "has-yarn": "^2.1.0", + "import-lazy": "^2.1.0", + "is-ci": "^2.0.0", + "is-installed-globally": "^0.3.1", + "is-npm": "^4.0.0", + "is-yarn-global": "^0.3.0", + "latest-version": "^5.0.0", + "pupa": "^2.0.1", + "semver-diff": "^3.1.1", + "xdg-basedir": "^4.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/yeoman/update-notifier?sponsor=1" + } + }, + "node_modules/update-notifier/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/update-notifier/node_modules/chalk": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", + "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/update-notifier/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/update-notifier/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/update-notifier/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/update-notifier/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/upper-case": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-1.1.3.tgz", + "integrity": "sha512-WRbjgmYzgXkCV7zNVpy5YgrHgbBv126rMALQQMrmzOVC4GM2waQ9x7xtm8VU+1yF2kWyPzI9zbZ48n4vSxwfSA==", + "dev": true + }, + "node_modules/uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/urix": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", + "integrity": "sha512-Am1ousAhSLBeB9cG/7k7r2R0zj50uDRlZHPGbazid5s9rlF1F/QKYObEKSIunSjIOkJZqwRRLpvewjEkM7pSqg==", + "deprecated": "Please see https://github.com/lydell/urix#deprecated", + "dev": true + }, + "node_modules/url": { + "version": "0.11.3", + "resolved": "https://registry.npmjs.org/url/-/url-0.11.3.tgz", + "integrity": "sha512-6hxOLGfZASQK/cijlZnZJTq8OXAkt/3YGfQX45vvMYXpZoo8NdWZcY73K108Jf759lS1Bv/8wXnHDTSz17dSRw==", + "dev": true, + "dependencies": { + "punycode": "^1.4.1", + "qs": "^6.11.2" + } + }, + "node_modules/url-loader": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/url-loader/-/url-loader-1.1.2.tgz", + "integrity": "sha512-dXHkKmw8FhPqu8asTc1puBfe3TehOCo2+RmOOev5suNCIYBcT626kxiWg1NBVkwc4rO8BGa7gP70W7VXuqHrjg==", + "dev": true, + "dependencies": { + "loader-utils": "^1.1.0", + "mime": "^2.0.3", + "schema-utils": "^1.0.0" + }, + "engines": { + "node": ">= 6.9.0" + }, + "peerDependencies": { + "webpack": "^3.0.0 || ^4.0.0" + } + }, + "node_modules/url-loader/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/url-parse": { + "version": "1.5.10", + "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", + "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", + "dev": true, + "dependencies": { + "querystringify": "^2.1.1", + "requires-port": "^1.0.0" + } + }, + "node_modules/url-parse-lax": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/url-parse-lax/-/url-parse-lax-3.0.0.tgz", + "integrity": "sha512-NjFKA0DidqPa5ciFcSrXnAltTtzz84ogy+NebPvfEgAck0+TNg4UJ4IN+fB7zRZfbgUf0syOo9MDxFkDSMuFaQ==", + "dev": true, + "dependencies": { + "prepend-http": "^2.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/url/node_modules/punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ==", + "dev": true + }, + "node_modules/url/node_modules/qs": { + "version": "6.11.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.2.tgz", + "integrity": "sha512-tDNIz22aBzCDxLtVH++VnTfzxlfeK5CbqohpSqpJgj1Wg/cQbStNAz3NuqCs5vV+pjBsK4x4pN9HlVh7rcYRiA==", + "dev": true, + "dependencies": { + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/use": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", + "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/util": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/util/-/util-0.11.1.tgz", + "integrity": "sha512-HShAsny+zS2TZfaXxD9tYj4HQGlBezXZMZuM/S5PKLLoZkShZiGk9o5CzukI1LVHZvjdvZ2Sj1aW/Ndn2NB/HQ==", + "dev": true, + "dependencies": { + "inherits": "2.0.3" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", + "dev": true + }, + "node_modules/util.promisify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.1.tgz", + "integrity": "sha512-g9JpC/3He3bm38zsLupWryXHoEcS22YHthuPQSJdMy6KNrzIRzWqcsHzD/WUnqe45whVou4VIsPew37DoXWNrA==", + "dev": true, + "dependencies": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.2", + "has-symbols": "^1.0.1", + "object.getownpropertydescriptors": "^2.1.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/util/node_modules/inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==", + "dev": true + }, + "node_modules/utila": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/utila/-/utila-0.4.0.tgz", + "integrity": "sha512-Z0DbgELS9/L/75wZbro8xAnT50pBVFQZ+hUEueGDU5FN51YSCYM+jdxsfCiHjwNP/4LCDD0i/graKpeBnOXKRA==", + "dev": true + }, + "node_modules/utils-merge": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", + "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", + "dev": true, + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/uuid": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", + "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", + "deprecated": "Please upgrade to version 7 or higher. Older versions may use Math.random() in certain circumstances, which is known to be problematic. See https://v8.dev/blog/math-random for details.", + "dev": true, + "bin": { + "uuid": "bin/uuid" + } + }, + "node_modules/vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", + "dev": true, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/vendors": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/vendors/-/vendors-1.0.4.tgz", + "integrity": "sha512-/juG65kTL4Cy2su4P8HjtkTxk6VmJDiOPBufWniqQ6wknac6jNiXS9vU+hO3wgusiyqWlzTbVHi0dyJqRONg3w==", + "dev": true, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/verror": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", + "integrity": "sha512-ZZKSmDAEFOijERBLkmYfJ+vmk3w+7hOLYDNkRCuRuMJGEmqYNCNLyBBFwWKVMhfwaEF3WOd0Zlw86U/WC/+nYw==", + "dev": true, + "engines": [ + "node >=0.6.0" + ], + "dependencies": { + "assert-plus": "^1.0.0", + "core-util-is": "1.0.2", + "extsprintf": "^1.2.0" + } + }, + "node_modules/verror/node_modules/core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ==", + "dev": true + }, + "node_modules/vm-browserify": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-1.1.2.tgz", + "integrity": "sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ==", + "dev": true + }, + "node_modules/vue": { + "version": "2.7.16", + "resolved": "https://registry.npmjs.org/vue/-/vue-2.7.16.tgz", + "integrity": "sha512-4gCtFXaAA3zYZdTp5s4Hl2sozuySsgz4jy1EnpBHNfpMa9dK1ZCG7viqBPCwXtmgc8nHqUsAu3G4gtmXkkY3Sw==", + "deprecated": "Vue 2 has reached EOL and is no longer actively maintained. See https://v2.vuejs.org/eol/ for more details.", + "dev": true, + "dependencies": { + "@vue/compiler-sfc": "2.7.16", + "csstype": "^3.1.0" + } + }, + "node_modules/vue-hot-reload-api": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/vue-hot-reload-api/-/vue-hot-reload-api-2.3.4.tgz", + "integrity": "sha512-BXq3jwIagosjgNVae6tkHzzIk6a8MHFtzAdwhnV5VlvPTFxDCvIttgSiHWjdGoTJvXtmRu5HacExfdarRcFhog==", + "dev": true + }, + "node_modules/vue-loader": { + "version": "15.11.1", + "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-15.11.1.tgz", + "integrity": "sha512-0iw4VchYLePqJfJu9s62ACWUXeSqM30SQqlIftbYWM3C+jpPcEHKSPUZBLjSF9au4HTHQ/naF6OGnO3Q/qGR3Q==", + "dev": true, + "dependencies": { + "@vue/component-compiler-utils": "^3.1.0", + "hash-sum": "^1.0.2", + "loader-utils": "^1.1.0", + "vue-hot-reload-api": "^2.3.0", + "vue-style-loader": "^4.1.0" + }, + "peerDependencies": { + "css-loader": "*", + "webpack": "^3.0.0 || ^4.1.0 || ^5.0.0-0" + }, + "peerDependenciesMeta": { + "cache-loader": { + "optional": true + }, + "prettier": { + "optional": true + }, + "vue-template-compiler": { + "optional": true + } + } + }, + "node_modules/vue-router": { + "version": "3.6.5", + "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-3.6.5.tgz", + "integrity": "sha512-VYXZQLtjuvKxxcshuRAwjHnciqZVoXAjTjcqBTz4rKc8qih9g9pI3hbDjmqXaHdgL3v8pV6P8Z335XvHzESxLQ==", + "dev": true + }, + "node_modules/vue-server-renderer": { + "version": "2.7.16", + "resolved": "https://registry.npmjs.org/vue-server-renderer/-/vue-server-renderer-2.7.16.tgz", + "integrity": "sha512-U7GgR4rYmHmbs3Z2gqsasfk7JNuTsy/xrR5EMMGRLkjN8+ryDlqQq6Uu3DcmbCATAei814YOxyl0eq2HNqgXyQ==", + "dev": true, + "dependencies": { + "chalk": "^4.1.2", + "hash-sum": "^2.0.0", + "he": "^1.2.0", + "lodash.template": "^4.5.0", + "lodash.uniq": "^4.5.0", + "resolve": "^1.22.0", + "serialize-javascript": "^6.0.0", + "source-map": "0.5.6" + } + }, + "node_modules/vue-server-renderer/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dev": true, + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/vue-server-renderer/node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/vue-server-renderer/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dev": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/vue-server-renderer/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "dev": true + }, + "node_modules/vue-server-renderer/node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/vue-server-renderer/node_modules/hash-sum": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/hash-sum/-/hash-sum-2.0.0.tgz", + "integrity": "sha512-WdZTbAByD+pHfl/g9QSsBIIwy8IT+EsPiKDs0KNX+zSHhdDLFKdZu0BQHljvO+0QI/BasbMSUa8wYNCZTvhslg==", + "dev": true + }, + "node_modules/vue-server-renderer/node_modules/serialize-javascript": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.2.tgz", + "integrity": "sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==", + "dev": true, + "dependencies": { + "randombytes": "^2.1.0" + } + }, + "node_modules/vue-server-renderer/node_modules/source-map": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.6.tgz", + "integrity": "sha512-MjZkVp0NHr5+TPihLcadqnlVoGIoWo4IBHptutGh9wI3ttUYvCG26HkSuDi+K6lsZ25syXJXcctwgyVCt//xqA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/vue-server-renderer/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/vue-style-loader": { + "version": "4.1.3", + "resolved": "https://registry.npmjs.org/vue-style-loader/-/vue-style-loader-4.1.3.tgz", + "integrity": "sha512-sFuh0xfbtpRlKfm39ss/ikqs9AbKCoXZBpHeVZ8Tx650o0k0q/YCM7FRvigtxpACezfq6af+a7JeqVTWvncqDg==", + "dev": true, + "dependencies": { + "hash-sum": "^1.0.2", + "loader-utils": "^1.0.2" + } + }, + "node_modules/vue-template-compiler": { + "version": "2.7.16", + "resolved": "https://registry.npmjs.org/vue-template-compiler/-/vue-template-compiler-2.7.16.tgz", + "integrity": "sha512-AYbUWAJHLGGQM7+cNTELw+KsOG9nl2CnSv467WobS5Cv9uk3wFcnr1Etsz2sEIHEZvw1U+o9mRlEO6QbZvUPGQ==", + "dev": true, + "dependencies": { + "de-indent": "^1.0.2", + "he": "^1.2.0" + } + }, + "node_modules/vue-template-es2015-compiler": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/vue-template-es2015-compiler/-/vue-template-es2015-compiler-1.9.1.tgz", + "integrity": "sha512-4gDntzrifFnCEvyoO8PqyJDmguXgVPxKiIxrBKjIowvL9l+N66196+72XVYR8BBf1Uv1Fgt3bGevJ+sEmxfZzw==", + "dev": true + }, + "node_modules/vuepress": { + "version": "1.9.10", + "resolved": "https://registry.npmjs.org/vuepress/-/vuepress-1.9.10.tgz", + "integrity": "sha512-UnGm9vjQvG918SZVNvgiUlNimLqawdYPq0aPRXDpEB1VksvqegVFy/GKdA8ShXJaEpOMPSt7YD4uK21jaMs3kA==", + "dev": true, + "hasInstallScript": true, + "dependencies": { + "@vuepress/core": "1.9.10", + "@vuepress/theme-default": "1.9.10", + "@vuepress/types": "1.9.10", + "cac": "^6.5.6", + "envinfo": "^7.2.0", + "opencollective-postinstall": "^2.0.2", + "update-notifier": "^4.0.0" + }, + "bin": { + "vuepress": "cli.js" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/vuepress-bar": { + "version": "0.4.5", + "resolved": "https://registry.npmjs.org/vuepress-bar/-/vuepress-bar-0.4.5.tgz", + "integrity": "sha512-1F1CGAYBHvbNrG1rcvCuGkFJGt8lzTGebcrko1pIPonBFuzdgfAoIxNjL5S81KkdMxbhQZq+rC89Q8nQv/r4Gw==", + "dependencies": { + "glob": "^7.1.7", + "inflection": "^1.13.1", + "lodash.escaperegexp": "^4.1.2", + "lodash.sortby": "^4.7.0", + "markdown-it": "^12.0.6", + "markdown-it-meta": "0.0.1", + "parent-module": "^2.0.0", + "transliteration": "^2.1.8" + } + }, + "node_modules/vuepress-bar/node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" + }, + "node_modules/vuepress-bar/node_modules/entities": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.1.0.tgz", + "integrity": "sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w==", + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" + } + }, + "node_modules/vuepress-bar/node_modules/linkify-it": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-3.0.3.tgz", + "integrity": "sha512-ynTsyrFSdE5oZ/O9GEf00kPngmOfVwazR5GKDq6EYfhlpFug3J2zybX56a2PRRpc9P+FuSoGNAwjlbDs9jJBPQ==", + "dependencies": { + "uc.micro": "^1.0.1" + } + }, + "node_modules/vuepress-bar/node_modules/markdown-it": { + "version": "12.3.2", + "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-12.3.2.tgz", + "integrity": "sha512-TchMembfxfNVpHkbtriWltGWc+m3xszaRD0CZup7GFFhzIgQqxIfn3eGj1yZpfuflzPvfkt611B2Q/Bsk1YnGg==", + "dependencies": { + "argparse": "^2.0.1", + "entities": "~2.1.0", + "linkify-it": "^3.0.1", + "mdurl": "^1.0.1", + "uc.micro": "^1.0.5" + }, + "bin": { + "markdown-it": "bin/markdown-it.js" + } + }, + "node_modules/vuepress-html-webpack-plugin": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/vuepress-html-webpack-plugin/-/vuepress-html-webpack-plugin-3.2.0.tgz", + "integrity": "sha512-BebAEl1BmWlro3+VyDhIOCY6Gef2MCBllEVAP3NUAtMguiyOwo/dClbwJ167WYmcxHJKLl7b0Chr9H7fpn1d0A==", + "dev": true, + "dependencies": { + "html-minifier": "^3.2.3", + "loader-utils": "^0.2.16", + "lodash": "^4.17.3", + "pretty-error": "^2.0.2", + "tapable": "^1.0.0", + "toposort": "^1.0.0", + "util.promisify": "1.0.0" + }, + "engines": { + "node": ">=6.9" + }, + "peerDependencies": { + "webpack": "^1.0.0 || ^2.0.0 || ^3.0.0 || ^4.0.0" + } + }, + "node_modules/vuepress-html-webpack-plugin/node_modules/big.js": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-3.2.0.tgz", + "integrity": "sha512-+hN/Zh2D08Mx65pZ/4g5bsmNiZUuChDiQfTUQ7qJr4/kuopCr88xZsAXv6mBoZEsUI4OuGHlX59qE94K2mMW8Q==", + "dev": true, + "engines": { + "node": "*" + } + }, + "node_modules/vuepress-html-webpack-plugin/node_modules/emojis-list": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-2.1.0.tgz", + "integrity": "sha512-knHEZMgs8BB+MInokmNTg/OyPlAddghe1YBgNwJBc5zsJi/uyIcXoSDsL/W9ymOsBoBGdPIHXYJ9+qKFwRwDng==", + "dev": true, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/vuepress-html-webpack-plugin/node_modules/json5": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", + "integrity": "sha512-4xrs1aW+6N5DalkqSVA8fxh458CXvR99WU8WLKmq4v8eWAL86Xo3BVqyd3SkA9wEVjCMqyvvRRkshAdOnBp5rw==", + "dev": true, + "bin": { + "json5": "lib/cli.js" + } + }, + "node_modules/vuepress-html-webpack-plugin/node_modules/loader-utils": { + "version": "0.2.17", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-0.2.17.tgz", + "integrity": "sha512-tiv66G0SmiOx+pLWMtGEkfSEejxvb6N6uRrQjfWJIT79W9GMpgKeCAmm9aVBKtd4WEgntciI8CsGqjpDoCWJug==", + "dev": true, + "dependencies": { + "big.js": "^3.1.3", + "emojis-list": "^2.0.0", + "json5": "^0.5.0", + "object-assign": "^4.0.1" + } + }, + "node_modules/vuepress-html-webpack-plugin/node_modules/util.promisify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.0.tgz", + "integrity": "sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==", + "dev": true, + "dependencies": { + "define-properties": "^1.1.2", + "object.getownpropertydescriptors": "^2.0.3" + } + }, + "node_modules/vuepress-plugin-auto-sidebar": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/vuepress-plugin-auto-sidebar/-/vuepress-plugin-auto-sidebar-2.3.2.tgz", + "integrity": "sha512-LmLluo5IrDNc8f7tprEhBYC+lGnfVCVFW7Pp29A+Q21yhin3qXxrTimhmK8e5mO7/qFVWVxYS4hOc22UeoxmUA==", + "dev": true, + "dependencies": { + "colors": "^1.4.0", + "execa": "^5.0.0", + "merge": "^2.1.1" + } + }, + "node_modules/vuepress-plugin-container": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/vuepress-plugin-container/-/vuepress-plugin-container-2.1.5.tgz", + "integrity": "sha512-TQrDX/v+WHOihj3jpilVnjXu9RcTm6m8tzljNJwYhxnJUW0WWQ0hFLcDTqTBwgKIFdEiSxVOmYE+bJX/sq46MA==", + "dev": true, + "dependencies": { + "@vuepress/shared-utils": "^1.2.0", + "markdown-it-container": "^2.0.0" + } + }, + "node_modules/vuepress-plugin-copy-code": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/vuepress-plugin-copy-code/-/vuepress-plugin-copy-code-0.0.1.tgz", + "integrity": "sha512-l47WG+kQK6qujLDkXuftegDOWfuBbgw4oybtdI2G1sbveE3vgbjZWLCHOlCUki9z8IAzcGt6I36ESU/f5dinrw==", + "dev": true + }, + "node_modules/vuepress-plugin-smooth-scroll": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/vuepress-plugin-smooth-scroll/-/vuepress-plugin-smooth-scroll-0.0.3.tgz", + "integrity": "sha512-qsQkDftLVFLe8BiviIHaLV0Ea38YLZKKonDGsNQy1IE0wllFpFIEldWD8frWZtDFdx6b/O3KDMgVQ0qp5NjJCg==", + "dev": true, + "dependencies": { + "smoothscroll-polyfill": "^0.4.3" + } + }, + "node_modules/watchpack": { + "version": "1.7.5", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-1.7.5.tgz", + "integrity": "sha512-9P3MWk6SrKjHsGkLT2KHXdQ/9SNkyoJbabxnKOoJepsvJjJG8uYTR3yTPxPQvNDI3w4Nz1xnE0TLHK4RIVe/MQ==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.1.2", + "neo-async": "^2.5.0" + }, + "optionalDependencies": { + "chokidar": "^3.4.1", + "watchpack-chokidar2": "^2.0.1" + } + }, + "node_modules/watchpack-chokidar2": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/watchpack-chokidar2/-/watchpack-chokidar2-2.0.1.tgz", + "integrity": "sha512-nCFfBIPKr5Sh61s4LPpy1Wtfi0HE8isJ3d2Yb5/Ppw2P2B/3eVSEBjKfN0fmHJSK14+31KwMKmcrzs2GM4P0Ww==", + "dev": true, + "optional": true, + "dependencies": { + "chokidar": "^2.1.8" + } + }, + "node_modules/watchpack/node_modules/binary-extensions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", + "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", + "dev": true, + "optional": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/watchpack/node_modules/braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "dev": true, + "optional": true, + "dependencies": { + "fill-range": "^7.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/watchpack/node_modules/chokidar": { + "version": "3.5.3", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", + "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", + "dev": true, + "funding": [ + { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + ], + "optional": true, + "dependencies": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + }, + "engines": { + "node": ">= 8.10.0" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/watchpack/node_modules/fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "dev": true, + "optional": true, + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/watchpack/node_modules/fsevents": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", + "dev": true, + "hasInstallScript": true, + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/watchpack/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "optional": true, + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/watchpack/node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "optional": true, + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/watchpack/node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true, + "optional": true, + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/watchpack/node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "dev": true, + "optional": true, + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/watchpack/node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "optional": true, + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/wbuf": { + "version": "1.7.3", + "resolved": "https://registry.npmjs.org/wbuf/-/wbuf-1.7.3.tgz", + "integrity": "sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA==", + "dev": true, + "dependencies": { + "minimalistic-assert": "^1.0.0" + } + }, + "node_modules/webpack": { + "version": "4.47.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-4.47.0.tgz", + "integrity": "sha512-td7fYwgLSrky3fI1EuU5cneU4+pbH6GgOfuKNS1tNPcfdGinGELAqsb/BP4nnvZyKSG2i/xFGU7+n2PvZA8HJQ==", + "dev": true, + "dependencies": { + "@webassemblyjs/ast": "1.9.0", + "@webassemblyjs/helper-module-context": "1.9.0", + "@webassemblyjs/wasm-edit": "1.9.0", + "@webassemblyjs/wasm-parser": "1.9.0", + "acorn": "^6.4.1", + "ajv": "^6.10.2", + "ajv-keywords": "^3.4.1", + "chrome-trace-event": "^1.0.2", + "enhanced-resolve": "^4.5.0", + "eslint-scope": "^4.0.3", + "json-parse-better-errors": "^1.0.2", + "loader-runner": "^2.4.0", + "loader-utils": "^1.2.3", + "memory-fs": "^0.4.1", + "micromatch": "^3.1.10", + "mkdirp": "^0.5.3", + "neo-async": "^2.6.1", + "node-libs-browser": "^2.2.1", + "schema-utils": "^1.0.0", + "tapable": "^1.1.3", + "terser-webpack-plugin": "^1.4.3", + "watchpack": "^1.7.4", + "webpack-sources": "^1.4.1" + }, + "bin": { + "webpack": "bin/webpack.js" + }, + "engines": { + "node": ">=6.11.5" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/webpack" + }, + "peerDependenciesMeta": { + "webpack-cli": { + "optional": true + }, + "webpack-command": { + "optional": true + } + } + }, + "node_modules/webpack-chain": { + "version": "6.5.1", + "resolved": "https://registry.npmjs.org/webpack-chain/-/webpack-chain-6.5.1.tgz", + "integrity": "sha512-7doO/SRtLu8q5WM0s7vPKPWX580qhi0/yBHkOxNkv50f6qB76Zy9o2wRTrrPULqYTvQlVHuvbA8v+G5ayuUDsA==", + "deprecated": "Package no longer supported. Contact Support at https://www.npmjs.com/support for more info.", + "dev": true, + "dependencies": { + "deepmerge": "^1.5.2", + "javascript-stringify": "^2.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/webpack-dev-middleware": { + "version": "3.7.3", + "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-3.7.3.tgz", + "integrity": "sha512-djelc/zGiz9nZj/U7PTBi2ViorGJXEWo/3ltkPbDyxCXhhEXkW0ce99falaok4TPj+AsxLiXJR0EBOb0zh9fKQ==", + "dev": true, + "dependencies": { + "memory-fs": "^0.4.1", + "mime": "^2.4.4", + "mkdirp": "^0.5.1", + "range-parser": "^1.2.1", + "webpack-log": "^2.0.0" + }, + "engines": { + "node": ">= 6" + }, + "peerDependencies": { + "webpack": "^4.0.0 || ^5.0.0" + } + }, + "node_modules/webpack-dev-server": { + "version": "3.11.3", + "resolved": "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-3.11.3.tgz", + "integrity": "sha512-3x31rjbEQWKMNzacUZRE6wXvUFuGpH7vr0lIEbYpMAG9BOxi0928QU1BBswOAP3kg3H1O4hiS+sq4YyAn6ANnA==", + "dev": true, + "dependencies": { + "ansi-html-community": "0.0.8", + "bonjour": "^3.5.0", + "chokidar": "^2.1.8", + "compression": "^1.7.4", + "connect-history-api-fallback": "^1.6.0", + "debug": "^4.1.1", + "del": "^4.1.1", + "express": "^4.17.1", + "html-entities": "^1.3.1", + "http-proxy-middleware": "0.19.1", + "import-local": "^2.0.0", + "internal-ip": "^4.3.0", + "ip": "^1.1.5", + "is-absolute-url": "^3.0.3", + "killable": "^1.0.1", + "loglevel": "^1.6.8", + "opn": "^5.5.0", + "p-retry": "^3.0.1", + "portfinder": "^1.0.26", + "schema-utils": "^1.0.0", + "selfsigned": "^1.10.8", + "semver": "^6.3.0", + "serve-index": "^1.9.1", + "sockjs": "^0.3.21", + "sockjs-client": "^1.5.0", + "spdy": "^4.0.2", + "strip-ansi": "^3.0.1", + "supports-color": "^6.1.0", + "url": "^0.11.0", + "webpack-dev-middleware": "^3.7.2", + "webpack-log": "^2.0.0", + "ws": "^6.2.1", + "yargs": "^13.3.2" + }, + "bin": { + "webpack-dev-server": "bin/webpack-dev-server.js" + }, + "engines": { + "node": ">= 6.11.5" + }, + "peerDependencies": { + "webpack": "^4.0.0 || ^5.0.0" + }, + "peerDependenciesMeta": { + "webpack-cli": { + "optional": true + } + } + }, + "node_modules/webpack-dev-server/node_modules/ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha512-TIGnTpdo+E3+pCyAluZvtED5p5wCqLdezCyhPZzKPcxvFplEt4i+W7OONCKgeZFT3+y5NZZfOOS/Bdcanm1MYA==", + "dev": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/webpack-dev-server/node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/cliui": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", + "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", + "dev": true, + "dependencies": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + } + }, + "node_modules/webpack-dev-server/node_modules/cliui/node_modules/ansi-regex": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", + "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/cliui/node_modules/strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "dependencies": { + "ansi-regex": "^4.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/webpack-dev-server/node_modules/emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", + "dev": true + }, + "node_modules/webpack-dev-server/node_modules/find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "dev": true, + "dependencies": { + "locate-path": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/http-proxy-middleware": { + "version": "0.19.1", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-0.19.1.tgz", + "integrity": "sha512-yHYTgWMQO8VvwNS22eLLloAkvungsKdKTLO8AJlftYIKNfJr3GK3zK0ZCfzDDGUBttdGc8xFy1mCitvNKQtC3Q==", + "dev": true, + "dependencies": { + "http-proxy": "^1.17.0", + "is-glob": "^4.0.0", + "lodash": "^4.17.11", + "micromatch": "^3.1.10" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/webpack-dev-server/node_modules/is-absolute-url": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-3.0.3.tgz", + "integrity": "sha512-opmNIX7uFnS96NtPmhWQgQx6/NYFgsUXYMllcfzwWKUMwfo8kku1TvE6hkNcH+Q1ts5cMVrsY7j0bxXQDciu9Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/webpack-dev-server/node_modules/is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha512-VHskAKYM8RfSFXwee5t5cbN5PZeq1Wrh6qd5bkyiXIf6UQcN6w/A0eXM9r6t8d+GYOh+o6ZhiEnb88LN/Y8m2w==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/webpack-dev-server/node_modules/locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "dev": true, + "dependencies": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true + }, + "node_modules/webpack-dev-server/node_modules/p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "dev": true, + "dependencies": { + "p-limit": "^2.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/webpack-dev-server/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/webpack-dev-server/node_modules/string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "dev": true, + "dependencies": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/string-width/node_modules/ansi-regex": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", + "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/string-width/node_modules/strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "dependencies": { + "ansi-regex": "^4.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha512-VhumSSbBqDTP8p2ZLKj40UjBCV4+v8bUSEpUb4KjRgWk9pbqGF4REFj6KEagidb2f/M6AzC0EmFyDNGaw9OCzg==", + "dev": true, + "dependencies": { + "ansi-regex": "^2.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/webpack-dev-server/node_modules/supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "dev": true, + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/webpack-dev-server/node_modules/yargs": { + "version": "13.3.2", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.2.tgz", + "integrity": "sha512-AX3Zw5iPruN5ie6xGRIDgqkT+ZhnRlZMLMHAs8tg7nRruy2Nb+i5o9bwghAogtM08q1dpr2LVoS8KSTMYpWXUw==", + "dev": true, + "dependencies": { + "cliui": "^5.0.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.2" + } + }, + "node_modules/webpack-dev-server/node_modules/yargs-parser": { + "version": "13.1.2", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.2.tgz", + "integrity": "sha512-3lbsNRf/j+A4QuSZfDRA7HRSfWrzO0YjqTJd5kjAq37Zep1CEgaYmrH9Q3GwPiB9cHyd1Y1UwggGhJGoxipbzg==", + "dev": true, + "dependencies": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + } + }, + "node_modules/webpack-log": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/webpack-log/-/webpack-log-2.0.0.tgz", + "integrity": "sha512-cX8G2vR/85UYG59FgkoMamwHUIkSSlV3bBMRsbxVXVUk2j6NleCKjQ/WE9eYg9WY4w25O9w8wKP4rzNZFmUcUg==", + "dev": true, + "dependencies": { + "ansi-colors": "^3.0.0", + "uuid": "^3.3.2" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/webpack-merge": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-4.2.2.tgz", + "integrity": "sha512-TUE1UGoTX2Cd42j3krGYqObZbOD+xF7u28WB7tfUordytSjbWTIjK/8V0amkBfTYN4/pB/GIDlJZZ657BGG19g==", + "dev": true, + "dependencies": { + "lodash": "^4.17.15" + } + }, + "node_modules/webpack-sources": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.4.3.tgz", + "integrity": "sha512-lgTS3Xhv1lCOKo7SA5TjKXMjpSM4sBjNV5+q2bqesbSPs5FjGmU6jjtBSkX9b4qW87vDIsCIlUPOEhbZrMdjeQ==", + "dev": true, + "dependencies": { + "source-list-map": "^2.0.0", + "source-map": "~0.6.1" + } + }, + "node_modules/webpack/node_modules/schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "dev": true, + "dependencies": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + }, + "engines": { + "node": ">= 4" + } + }, + "node_modules/webpackbar": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/webpackbar/-/webpackbar-3.2.0.tgz", + "integrity": "sha512-PC4o+1c8gWWileUfwabe0gqptlXUDJd5E0zbpr2xHP1VSOVlZVPBZ8j6NCR8zM5zbKdxPhctHXahgpNK1qFDPw==", + "dev": true, + "dependencies": { + "ansi-escapes": "^4.1.0", + "chalk": "^2.4.1", + "consola": "^2.6.0", + "figures": "^3.0.0", + "pretty-time": "^1.1.0", + "std-env": "^2.2.1", + "text-table": "^0.2.0", + "wrap-ansi": "^5.1.0" + }, + "engines": { + "node": ">= 6.9.0" + }, + "peerDependencies": { + "webpack": "^3.0.0 || ^4.0.0" + } + }, + "node_modules/websocket-driver": { + "version": "0.7.4", + "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", + "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", + "dev": true, + "dependencies": { + "http-parser-js": ">=0.5.1", + "safe-buffer": ">=5.1.0", + "websocket-extensions": ">=0.1.1" + }, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/websocket-extensions": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", + "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==", + "dev": true, + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/when": { + "version": "3.6.4", + "resolved": "https://registry.npmjs.org/when/-/when-3.6.4.tgz", + "integrity": "sha512-d1VUP9F96w664lKINMGeElWdhhb5sC+thXM+ydZGU3ZnaE09Wv6FaS+mpM9570kcDs/xMfcXJBTLsMdHEFYY9Q==", + "dev": true + }, + "node_modules/which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "dev": true, + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "which": "bin/which" + } + }, + "node_modules/which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "dependencies": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-module": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.1.tgz", + "integrity": "sha512-iBdZ57RDvnOR9AGBhML2vFZf7h8vmBjhoaZqODJBFWHVtKkDmKuHai3cx5PgVMrX5YDNp27AofYbAwctSS+vhQ==", + "dev": true + }, + "node_modules/which-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.13.tgz", + "integrity": "sha512-P5Nra0qjSncduVPEAr7xhoF5guty49ArDTwzJ/yNuPIbZppyRxFQsRCWrocxIY+CnMVG+qfbU2FmDKyvSGClow==", + "dev": true, + "dependencies": { + "available-typed-arrays": "^1.0.5", + "call-bind": "^1.0.4", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/widest-line": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/widest-line/-/widest-line-3.1.0.tgz", + "integrity": "sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg==", + "dev": true, + "dependencies": { + "string-width": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/workbox-background-sync": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-background-sync/-/workbox-background-sync-4.3.1.tgz", + "integrity": "sha512-1uFkvU8JXi7L7fCHVBEEnc3asPpiAL33kO495UMcD5+arew9IbKW2rV5lpzhoWcm/qhGB89YfO4PmB/0hQwPRg==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-broadcast-update": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-broadcast-update/-/workbox-broadcast-update-4.3.1.tgz", + "integrity": "sha512-MTSfgzIljpKLTBPROo4IpKjESD86pPFlZwlvVG32Kb70hW+aob4Jxpblud8EhNb1/L5m43DUM4q7C+W6eQMMbA==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-build": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-build/-/workbox-build-4.3.1.tgz", + "integrity": "sha512-UHdwrN3FrDvicM3AqJS/J07X0KXj67R8Cg0waq1MKEOqzo89ap6zh6LmaLnRAjpB+bDIz+7OlPye9iii9KBnxw==", + "dev": true, + "dependencies": { + "@babel/runtime": "^7.3.4", + "@hapi/joi": "^15.0.0", + "common-tags": "^1.8.0", + "fs-extra": "^4.0.2", + "glob": "^7.1.3", + "lodash.template": "^4.4.0", + "pretty-bytes": "^5.1.0", + "stringify-object": "^3.3.0", + "strip-comments": "^1.0.2", + "workbox-background-sync": "^4.3.1", + "workbox-broadcast-update": "^4.3.1", + "workbox-cacheable-response": "^4.3.1", + "workbox-core": "^4.3.1", + "workbox-expiration": "^4.3.1", + "workbox-google-analytics": "^4.3.1", + "workbox-navigation-preload": "^4.3.1", + "workbox-precaching": "^4.3.1", + "workbox-range-requests": "^4.3.1", + "workbox-routing": "^4.3.1", + "workbox-strategies": "^4.3.1", + "workbox-streams": "^4.3.1", + "workbox-sw": "^4.3.1", + "workbox-window": "^4.3.1" + }, + "engines": { + "node": ">=4.0.0" + } + }, + "node_modules/workbox-build/node_modules/fs-extra": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-4.0.3.tgz", + "integrity": "sha512-q6rbdDd1o2mAnQreO7YADIxf/Whx4AHBiRf6d+/cVT8h44ss+lHgxf1FemcqDnQt9X3ct4McHr+JMGlYSsK7Cg==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "node_modules/workbox-cacheable-response": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-cacheable-response/-/workbox-cacheable-response-4.3.1.tgz", + "integrity": "sha512-Rp5qlzm6z8IOvnQNkCdO9qrDgDpoPNguovs0H8C+wswLuPgSzSp9p2afb5maUt9R1uTIwOXrVQMmPfPypv+npw==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-core": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-core/-/workbox-core-4.3.1.tgz", + "integrity": "sha512-I3C9jlLmMKPxAC1t0ExCq+QoAMd0vAAHULEgRZ7kieCdUd919n53WC0AfvokHNwqRhGn+tIIj7vcb5duCjs2Kg==", + "dev": true + }, + "node_modules/workbox-expiration": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-expiration/-/workbox-expiration-4.3.1.tgz", + "integrity": "sha512-vsJLhgQsQouv9m0rpbXubT5jw0jMQdjpkum0uT+d9tTwhXcEZks7qLfQ9dGSaufTD2eimxbUOJfWLbNQpIDMPw==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-google-analytics": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-google-analytics/-/workbox-google-analytics-4.3.1.tgz", + "integrity": "sha512-xzCjAoKuOb55CBSwQrbyWBKqp35yg1vw9ohIlU2wTy06ZrYfJ8rKochb1MSGlnoBfXGWss3UPzxR5QL5guIFdg==", + "dev": true, + "dependencies": { + "workbox-background-sync": "^4.3.1", + "workbox-core": "^4.3.1", + "workbox-routing": "^4.3.1", + "workbox-strategies": "^4.3.1" + } + }, + "node_modules/workbox-navigation-preload": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-navigation-preload/-/workbox-navigation-preload-4.3.1.tgz", + "integrity": "sha512-K076n3oFHYp16/C+F8CwrRqD25GitA6Rkd6+qAmLmMv1QHPI2jfDwYqrytOfKfYq42bYtW8Pr21ejZX7GvALOw==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-precaching": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-precaching/-/workbox-precaching-4.3.1.tgz", + "integrity": "sha512-piSg/2csPoIi/vPpp48t1q5JLYjMkmg5gsXBQkh/QYapCdVwwmKlU9mHdmy52KsDGIjVaqEUMFvEzn2LRaigqQ==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-range-requests": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-range-requests/-/workbox-range-requests-4.3.1.tgz", + "integrity": "sha512-S+HhL9+iTFypJZ/yQSl/x2Bf5pWnbXdd3j57xnb0V60FW1LVn9LRZkPtneODklzYuFZv7qK6riZ5BNyc0R0jZA==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-routing": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-routing/-/workbox-routing-4.3.1.tgz", + "integrity": "sha512-FkbtrODA4Imsi0p7TW9u9MXuQ5P4pVs1sWHK4dJMMChVROsbEltuE79fBoIk/BCztvOJ7yUpErMKa4z3uQLX+g==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-strategies": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-strategies/-/workbox-strategies-4.3.1.tgz", + "integrity": "sha512-F/+E57BmVG8dX6dCCopBlkDvvhg/zj6VDs0PigYwSN23L8hseSRwljrceU2WzTvk/+BSYICsWmRq5qHS2UYzhw==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-streams": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-streams/-/workbox-streams-4.3.1.tgz", + "integrity": "sha512-4Kisis1f/y0ihf4l3u/+ndMkJkIT4/6UOacU3A4BwZSAC9pQ9vSvJpIi/WFGQRH/uPXvuVjF5c2RfIPQFSS2uA==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/workbox-sw": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-sw/-/workbox-sw-4.3.1.tgz", + "integrity": "sha512-0jXdusCL2uC5gM3yYFT6QMBzKfBr2XTk0g5TPAV4y8IZDyVNDyj1a8uSXy3/XrvkVTmQvLN4O5k3JawGReXr9w==", + "dev": true + }, + "node_modules/workbox-window": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-window/-/workbox-window-4.3.1.tgz", + "integrity": "sha512-C5gWKh6I58w3GeSc0wp2Ne+rqVw8qwcmZnQGpjiek8A2wpbxSJb1FdCoQVO+jDJs35bFgo/WETgl1fqgsxN0Hg==", + "dev": true, + "dependencies": { + "workbox-core": "^4.3.1" + } + }, + "node_modules/worker-farm": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/worker-farm/-/worker-farm-1.7.0.tgz", + "integrity": "sha512-rvw3QTZc8lAxyVrqcSGVm5yP/IJ2UcB3U0graE3LCFoZ0Yn2x4EoVSqJKdB/T5M+FLcRPjz4TDacRf3OCfNUzw==", + "dev": true, + "dependencies": { + "errno": "~0.1.7" + } + }, + "node_modules/wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", + "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", + "dev": true, + "dependencies": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/wrap-ansi/node_modules/ansi-regex": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", + "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", + "dev": true, + "engines": { + "node": ">=6" + } + }, + "node_modules/wrap-ansi/node_modules/emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", + "dev": true + }, + "node_modules/wrap-ansi/node_modules/is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha512-VHskAKYM8RfSFXwee5t5cbN5PZeq1Wrh6qd5bkyiXIf6UQcN6w/A0eXM9r6t8d+GYOh+o6ZhiEnb88LN/Y8m2w==", + "dev": true, + "engines": { + "node": ">=4" + } + }, + "node_modules/wrap-ansi/node_modules/string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "dev": true, + "dependencies": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/wrap-ansi/node_modules/strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "dev": true, + "dependencies": { + "ansi-regex": "^4.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==" + }, + "node_modules/write-file-atomic": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", + "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", + "dev": true, + "dependencies": { + "imurmurhash": "^0.1.4", + "is-typedarray": "^1.0.0", + "signal-exit": "^3.0.2", + "typedarray-to-buffer": "^3.1.5" + } + }, + "node_modules/ws": { + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.2.tgz", + "integrity": "sha512-zmhltoSR8u1cnDsD43TX59mzoMZsLKqUweyYBAIvTngR3shc0W6aOZylZmq/7hqyVxPdi+5Ud2QInblgyE72fw==", + "dev": true, + "dependencies": { + "async-limiter": "~1.0.0" + } + }, + "node_modules/xdg-basedir": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/xdg-basedir/-/xdg-basedir-4.0.0.tgz", + "integrity": "sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q==", + "dev": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/xtend": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", + "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", + "dev": true, + "engines": { + "node": ">=0.4" + } + }, + "node_modules/y18n": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", + "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", + "dev": true + }, + "node_modules/yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "dev": true + }, + "node_modules/yargs": { + "version": "17.7.2", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", + "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", + "dependencies": { + "cliui": "^8.0.1", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.3", + "y18n": "^5.0.5", + "yargs-parser": "^21.1.1" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/yargs-parser": { + "version": "21.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", + "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", + "engines": { + "node": ">=12" + } + }, + "node_modules/yargs/node_modules/y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "engines": { + "node": ">=10" + } + }, + "node_modules/zepto": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/zepto/-/zepto-1.2.0.tgz", + "integrity": "sha512-C1x6lfvBICFTQIMgbt3JqMOno3VOtkWat/xEakLTOurskYIHPmzJrzd1e8BnmtdDVJlGuk5D+FxyCA8MPmkIyA==", + "dev": true + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 00000000..f20d1e67 --- /dev/null +++ b/package.json @@ -0,0 +1,28 @@ +{ + "name": "bagisto-docs", + "version": "1.0.0", + "description": "Bagisto Developer Documentation", + "main": "index.js", + "scripts": { + "docs:dev": "vuepress dev docs", + "docs:build": "vuepress build docs", + "docs:eject": "vuepress eject docs" + }, + "keywords": [ + "bagisto", + "developer", + "documentation" + ], + "author": "Bagisto", + "license": "MIT", + "devDependencies": { + "@vuepress/plugin-back-to-top": "^1.9.9", + "@vuepress/plugin-pwa": "^1.9.9", + "vuepress": "^1.9.9", + "vuepress-plugin-auto-sidebar": "^2.3.2", + "vuepress-plugin-copy-code": "0.0.1" + }, + "dependencies": { + "vuepress-bar": "^0.4.4" + } +}