mirror of
https://github.com/mealie-recipes/mealie.git
synced 2026-03-03 02:27:00 +00:00
* Changed uvicorn port to 80 * Changed port in docker-compose to match dockerfile * Readded environment variables in docker-compose * production image rework * Use opengraph metadata to make basic recipe cards when full recipe metadata is not available * fixed instrucitons on parse * add last_recipe * automated testing * roadmap update * Sqlite (#75) * file structure * auto-test * take 2 * refactor ap scheduler and startup process * fixed scraper error * database abstraction * database abstraction * port recipes over to new schema * meal migration * start settings migration * finale mongo port * backup improvements * migration imports to new DB structure * unused import cleanup * docs strings * settings and theme import logic * cleanup * fixed tinydb error * requirements * fuzzy search * remove scratch file * sqlalchemy models * improved search ui * recipe models almost done * sql modal population * del scratch * rewrite database model mixins * mostly grabage * recipe updates * working sqllite * remove old files and reorganize * final cleanup Co-authored-by: Hayden <hay-kot@pm.me> * Backup card (#78) * backup / import dialog * upgrade to new tag method * New import card * rename settings.py to app_config.py * migrate to poetry for development * fix failing test Co-authored-by: Hayden <hay-kot@pm.me> * added mkdocs to docker-compose * Translations (#72) * Translations + danish * changed back proxy target to use ENV * Resolved more merge conflicts * Removed test in translation * Documentation of translations * Updated translations * removed old packages Co-authored-by: Hayden <64056131+hay-kot@users.noreply.github.com> * fail to start bug fixes * feature: prep/cook/total time slots (#80) Co-authored-by: Hayden <hay-kot@pm.me> * missing bind attributes * Bug fixes (#81) * fix: url remains after succesful import * docs: changelog + update todos * arm image * arm compose * compose updates * update poetry * arm support Co-authored-by: Hayden <hay-kot@pm.me> * dockerfile hotfix * dockerfile hotfix * Version Release Final Touches (#84) * Remove slim * bug: opacity issues * bug: startup failure with no database * ci/cd on dev branch * formatting * v0.1.0 documentation Co-authored-by: Hayden <hay-kot@pm.me> * db init hotfix * bug: fix crash in mongo * fix mongo bug * fixed version notifier * finale changelog Co-authored-by: kentora <=> Co-authored-by: Hayden <hay-kot@pm.me> Co-authored-by: Richard Mitic <richard.h.mitic@gmail.com> Co-authored-by: kentora <kentora@kentora.dk>
101 lines
2.9 KiB
Vue
101 lines
2.9 KiB
Vue
<template>
|
|
<v-card-text>
|
|
<p>
|
|
{{$t('migration.you-can-import-recipes-from-either-a-zip-file-or-a-directory-located-in-the-app-data-migraiton-folder-please-review-the-documentation-to-ensure-your-directory-structure-matches-what-is-expected')}}
|
|
</p>
|
|
<v-form ref="form">
|
|
<v-row align="center">
|
|
<v-col cols="12" md="5" sm="12">
|
|
<v-select
|
|
:items="availableImports"
|
|
v-model="selectedImport"
|
|
:label="$t('migration.nextcloud-data')"
|
|
:rules="[rules.required]"
|
|
></v-select>
|
|
</v-col>
|
|
<v-col cols="12" md="2" sm="12">
|
|
<v-btn text color="info" @click="importRecipes"> {{$t('migration.migrate')}} </v-btn>
|
|
</v-col>
|
|
<v-col cols="12" md="1" sm="12">
|
|
<v-btn text color="error" @click="deleteImportValidation">
|
|
{{$t('general.delete')}}
|
|
</v-btn>
|
|
<Confirmation
|
|
:title="$t('general.delete-data')"
|
|
:message="$t('migration.delete-confirmation')"
|
|
color="error"
|
|
icon="mdi-alert-circle"
|
|
ref="deleteThemeConfirm"
|
|
v-on:confirm="deleteImport()"
|
|
/>
|
|
</v-col>
|
|
</v-row>
|
|
<v-row>
|
|
<v-col cols="12" md="5" sm="12">
|
|
<UploadMigrationButton @uploaded="getAvaiableImports" />
|
|
</v-col>
|
|
</v-row>
|
|
</v-form>
|
|
<SuccessFailureAlert
|
|
:success-header="$t('migration.successfully-imported-from-nextcloud')"
|
|
:success="successfulImports"
|
|
failed-header="$t('migration.failed-imports')"
|
|
:failed="failedImports"
|
|
/>
|
|
</v-card-text>
|
|
</template>
|
|
|
|
<script>
|
|
import api from "../../../api";
|
|
import SuccessFailureAlert from "../../UI/SuccessFailureAlert";
|
|
import UploadMigrationButton from "./UploadMigrationButton";
|
|
import Confirmation from "../../UI/Confirmation";
|
|
export default {
|
|
components: {
|
|
SuccessFailureAlert,
|
|
UploadMigrationButton,
|
|
Confirmation,
|
|
},
|
|
data() {
|
|
return {
|
|
successfulImports: [],
|
|
failedImports: [],
|
|
availableImports: [],
|
|
selectedImport: null,
|
|
rules: {
|
|
required: (v) => !!v || "Selection Required",
|
|
},
|
|
};
|
|
},
|
|
async mounted() {
|
|
this.getAvaiableImports();
|
|
},
|
|
methods: {
|
|
async getAvaiableImports() {
|
|
this.availableImports = await api.migrations.getNextcloudImports();
|
|
},
|
|
async importRecipes() {
|
|
if (this.$refs.form.validate()) {
|
|
this.$emit("loading");
|
|
let data = await api.migrations.importNextcloud(this.selectedImport);
|
|
|
|
this.successfulImports = data.successful;
|
|
this.failedImports = data.failed;
|
|
this.$emit("finished");
|
|
}
|
|
},
|
|
deleteImportValidation() {
|
|
if (this.$refs.form.validate()) {
|
|
this.$refs.deleteThemeConfirm.open();
|
|
}
|
|
},
|
|
async deleteImport() {
|
|
await api.migrations.delete(this.selectedImport);
|
|
this.getAvaiableImports();
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<style>
|
|
</style> |