Compare commits

..

1 Commits

Author SHA1 Message Date
Alf Sebastian Houge
d314ed4a16 Add vscode specific files to gitignore 2022-03-05 19:21:10 +01:00
3 changed files with 58 additions and 66 deletions

4
server/.gitignore vendored
View File

@@ -12,6 +12,10 @@
*.out *.out
*.db *.db
# MS VSCode
.vscode
__debug_bin
# Dependency directories (remove the comment below to include it) # Dependency directories (remove the comment below to include it)
# vendor/ # vendor/
assets/* assets/*

View File

@@ -21,27 +21,13 @@ export default {
email: '', email: '',
password: '', password: '',
distanceUnit: 1, distanceUnit: 1,
currency: '', currency: 'INR',
}, },
} }
}, },
computed: { computed: {
...mapGetters('auth', ['isInitialized']), ...mapGetters('auth', ['isInitialized']),
...mapState('vehicles', ['currencyMasters', 'distanceUnitMasters']), ...mapState('vehicles', ['currencyMasters', 'distanceUnitMasters']),
filteredCurrencyMasters() {
return this.currencyMasters.filter((option) => {
return (
option.namePlural
.toString()
.toLowerCase()
.indexOf(this.registerModel.currency.toLowerCase()) >= 0 ||
option.code
.toString()
.toLowerCase()
.indexOf(this.registerModel.currency.toLowerCase()) >= 0
)
})
},
}, },
mounted() { mounted() {
store.dispatch('vehicles/fetchMasters').then((data) => {}) store.dispatch('vehicles/fetchMasters').then((data) => {})
@@ -153,9 +139,6 @@ export default {
}) })
.finally(() => (this.isWorking = false)) .finally(() => (this.isWorking = false))
}, },
formatCurrency(option) {
return `${option.namePlural} (${option.code})`
},
}, },
} }
</script> </script>
@@ -165,10 +148,15 @@ export default {
<div v-if="!migrationMode" class="box"> <div v-if="!migrationMode" class="box">
<h1 class="title">Migrate from Clarkson</h1> <h1 class="title">Migrate from Clarkson</h1>
<p> <p>
If you have an existing Clarkson deployment and you want to migrate your data from that, press the following button. If you have an existing Clarkson deployment and you want to migrate your data from that,
press the following button.
</p> </p>
<br /> <br />
<b-field> <b-button type="is-primary" @click="migrationMode = 'clarkson'">Migrate from Clarkson</b-button></b-field> <b-field>
<b-button type="is-primary" @click="migrationMode = 'clarkson'"
>Migrate from Clarkson</b-button
></b-field
>
</div> </div>
<div v-if="!migrationMode" class="box"> <div v-if="!migrationMode" class="box">
<h1 class="title">Fresh Install</h1> <h1 class="title">Fresh Install</h1>
@@ -182,12 +170,21 @@ export default {
</div> </div>
<div v-if="migrationMode === 'clarkson'" class="box content"> <div v-if="migrationMode === 'clarkson'" class="box content">
<h1 class="title">Migrate from Clarkson</h1> <h1 class="title">Migrate from Clarkson</h1>
<p>You need to make sure that this deployment of Hammond can access the MySQL database used by Clarkson.</p>
<p>If that is not directly possible, you can make a copy of that database somewhere accessible from this instance.</p>
<p>Once that is done, enter the connection string to the MySQL instance in the following format.</p>
<p <p
>All the users imported from Clarkson will have their username as their email in Clarkson database and pasword set to >You need to make sure that this deployment of Hammond can access the MySQL database used by
<span class="" style="font-weight:bold">hammond</span></p Clarkson.</p
>
<p
>If that is not directly possible, you can make a copy of that database somewhere accessible
from this instance.</p
>
<p
>Once that is done, enter the connection string to the MySQL instance in the following
format.</p
>
<p
>All the users imported from Clarkson will have their username as their email in Clarkson
database and pasword set to <span class="" style="font-weight:bold">hammond</span></p
> >
<code> <code>
user:pass@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local user:pass@tcp(127.0.0.1:3306)/dbname?charset=utf8mb4&parseTime=True&loc=Local
@@ -203,8 +200,15 @@ export default {
</b-field> </b-field>
<div class="buttons"> <div class="buttons">
<b-button v-if="!testSuccess" type="is-primary" :disabled="isWorking" @click="testConnection">Test Connection</b-button <b-button
><b-button v-if="testSuccess" type="is-success" :disabled="isWorking" @click="migrate">Migrate</b-button> v-if="!testSuccess"
type="is-primary"
:disabled="isWorking"
@click="testConnection"
>Test Connection</b-button
><b-button v-if="testSuccess" type="is-success" :disabled="isWorking" @click="migrate"
>Migrate</b-button
>
<b-button type="is-danger is-light" @click="resetMigrationMode">Cancel</b-button> <b-button type="is-danger is-light" @click="resetMigrationMode">Cancel</b-button>
</div> </div>
</div> </div>
@@ -218,22 +222,28 @@ export default {
<b-input v-model="registerModel.email" type="email" required></b-input> <b-input v-model="registerModel.email" type="email" required></b-input>
</b-field> </b-field>
<b-field label="Your Password"> <b-field label="Your Password">
<b-input v-model="registerModel.password" type="password" required minlength="8" password-reveal></b-input> <b-input
v-model="registerModel.password"
type="password"
required
minlength="8"
password-reveal
></b-input>
</b-field> </b-field>
<b-field label="Currency"> <b-field label="Currency">
<b-autocomplete <b-select v-model="registerModel.currency" placeholder="Currency" required expanded>
v-model="registerModel.currency" <option v-for="option in currencyMasters" :key="option.code" :value="option.code">
:custom-formatter="formatCurrency" {{ `${option.namePlural} (${option.code})` }}
placeholder="Currency" </option>
:data="filteredCurrencyMasters" </b-select>
:keep-first="true"
:open-on-focus="true"
required
@select="(option) => (selected = option)"
></b-autocomplete>
</b-field> </b-field>
<b-field label="Distance Unit"> <b-field label="Distance Unit">
<b-select v-model.number="registerModel.distanceUnit" placeholder="Distance Unit" required expanded> <b-select
v-model.number="registerModel.distanceUnit"
placeholder="Distance Unit"
required
expanded
>
<option v-for="(option, key) in distanceUnitMasters" :key="key" :value="key"> <option v-for="(option, key) in distanceUnitMasters" :key="key" :value="key">
{{ `${option.long} (${option.short})` }} {{ `${option.long} (${option.short})` }}
</option> </option>

View File

@@ -44,20 +44,6 @@ export default {
return this.changePassModel.new === this.changePassModel.renew return this.changePassModel.new === this.changePassModel.renew
}, },
filteredCurrencyMasters() {
return this.currencyMasters.filter((option) => {
return (
option.namePlural
.toString()
.toLowerCase()
.indexOf(this.settingsModel.currency.toLowerCase()) >= 0 ||
option.code
.toString()
.toLowerCase()
.indexOf(this.settingsModel.currency.toLowerCase()) >= 0
)
})
},
}, },
methods: { methods: {
changePassword() { changePassword() {
@@ -123,9 +109,6 @@ export default {
this.tryingToSave = false this.tryingToSave = false
}) })
}, },
formatCurrency(option) {
return `${option.namePlural} (${option.code})`
},
}, },
} }
</script> </script>
@@ -140,16 +123,11 @@ export default {
These will be used as default values whenever you create a new fillup or expense. These will be used as default values whenever you create a new fillup or expense.
</h1> </h1>
<b-field label="Currency"> <b-field label="Currency">
<b-autocomplete <b-select v-model="settingsModel.currency" placeholder="Currency" required expanded>
v-model="settingsModel.currency" <option v-for="option in currencyMasters" :key="option.code" :value="option.code">
:custom-formatter="formatCurrency" {{ `${option.namePlural} (${option.code})` }}
placeholder="Currency" </option>
:data="filteredCurrencyMasters" </b-select>
:keep-first="true"
:open-on-focus="true"
required
@select="(option) => (selected = option)"
></b-autocomplete>
</b-field> </b-field>
<b-field label="Distance Unit"> <b-field label="Distance Unit">
<b-select v-model.number="settingsModel.distanceUnit" placeholder="Distance Unit" required expanded> <b-select v-model.number="settingsModel.distanceUnit" placeholder="Distance Unit" required expanded>