Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app/assets/javascripts/import_projects/components/page_query_param_sync.vue')
-rw-r--r--app/assets/javascripts/import_projects/components/page_query_param_sync.vue39
1 files changed, 39 insertions, 0 deletions
diff --git a/app/assets/javascripts/import_projects/components/page_query_param_sync.vue b/app/assets/javascripts/import_projects/components/page_query_param_sync.vue
new file mode 100644
index 00000000000..5ba3d70f5d0
--- /dev/null
+++ b/app/assets/javascripts/import_projects/components/page_query_param_sync.vue
@@ -0,0 +1,39 @@
+<script>
+import { queryToObject, setUrlParams, updateHistory } from '~/lib/utils/url_utility';
+
+export default {
+ props: {
+ page: {
+ type: Number,
+ required: true,
+ },
+ },
+
+ watch: {
+ page(newPage) {
+ updateHistory({
+ url: setUrlParams({
+ page: newPage === 1 ? null : newPage,
+ }),
+ });
+ },
+ },
+
+ created() {
+ window.addEventListener('popstate', this.updatePage);
+ },
+
+ beforeDestroy() {
+ window.removeEventListener('popstate', this.updatePage);
+ },
+
+ methods: {
+ updatePage() {
+ const page = parseInt(queryToObject(window.location.search).page, 10) || 1;
+ this.$emit('popstate', page);
+ },
+ },
+
+ render: () => null,
+};
+</script>