Complete scripts-v2 TypeScript migration — all imports resolved,

build passes

Create all missing components (modals, dropdowns, icons, tabs, mail
drivers, customer partials), fix all @/scripts/ imports to @v2/,
wire up vite entry point and blade template. 382 files, 48883 lines.

- 27 settings components: modals (tax, payment, custom field, note,
  category, role, exchange rate, unit, mail test), dropdowns (6),
  customization tabs (4), mail driver forms (4)
- 22 icon components: 5 utility icons, 4 dashboard icons, 13 editor
  toolbar icons with typed barrel export
- 3 customer components: info, chart placeholder, custom fields single
- Fixed usePopper composable, client/format-money import patterns
- Zero remaining @/scripts/ imports in scripts-v2/

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Darko Gjorgjijoski
2026-04-04 09:30:00 +02:00
parent 812956abcc
commit a46cca5cd8
156 changed files with 6246 additions and 213 deletions

View File

@@ -1,6 +1,6 @@
<script setup lang="ts">
import { computed } from 'vue'
import SpinnerIcon from '@/scripts/components/icons/SpinnerIcon.vue'
import SpinnerIcon from '@v2/components/icons/SpinnerIcon.vue'
type ButtonSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl'
type ButtonVariant =

View File

@@ -1,5 +1,5 @@
<script setup lang="ts">
import type { Address, Country } from '../../types/domain'
import type { Address, Country } from '@v2/types/domain'
interface DisplayAddress {
address_street_1?: string | null

View File

@@ -4,10 +4,10 @@ import { computed, ref } from 'vue'
import { useI18n } from 'vue-i18n'
import { useDebounceFn } from '@vueuse/core'
import { useRoute } from 'vue-router'
import { usePermissions } from '../../composables/use-permissions'
import { useModal } from '../../composables/use-modal'
import { ABILITIES } from '../../config/abilities'
import type { Customer, Address } from '../../types/domain'
import { usePermissions } from '@v2/composables/use-permissions'
import { useModal } from '@v2/composables/use-modal'
import { ABILITIES } from '@v2/config/abilities'
import type { Customer, Address } from '@v2/types/domain'
type DocumentType = 'estimate' | 'invoice' | 'recurring-invoice'

View File

@@ -81,8 +81,8 @@ import { Vietnamese } from 'flatpickr/dist/l10n/vn.js'
import { Mandarin } from 'flatpickr/dist/l10n/zh.js'
import type { CustomLocale, Locale } from 'flatpickr/dist/types/locale'
import { computed, reactive, watch, ref, useSlots } from 'vue'
import { useCompanyStore } from '@/scripts/admin/stores/company'
import { useUserStore } from '@/scripts/admin/stores/user'
import { useCompanyStore } from '@v2/stores/company.store'
import { useUserStore } from '@v2/stores/user.store'
interface FlatPickrInstance {
fp: { open: () => void }

View File

@@ -144,7 +144,7 @@
<script setup lang="ts">
import { computed } from 'vue'
import { useDialogStore } from '@/scripts/stores/dialog'
import { useDialogStore } from '@v2/stores/dialog.store'
import {
Dialog,
DialogOverlay,

View File

@@ -38,7 +38,7 @@
<script setup lang="ts">
import { Menu, MenuButton, MenuItems } from '@headlessui/vue'
import { computed, ref } from 'vue'
import { usePopper } from '@/scripts/helpers/use-popper'
import { usePopper } from '@v2/composables/use-popper'
interface Props {
containerClass?: string

View File

@@ -379,8 +379,8 @@
<script setup lang="ts">
import { ref, onMounted, watch } from 'vue'
import http from '@/scripts/http'
import utils from '@/scripts/helpers/utilities'
import { client as http } from '@v2/api/client'
import * as utils from '@v2/utils/format-money'
interface LocalFile {
fileObject?: File

View File

@@ -13,7 +13,7 @@
</template>
<script setup lang="ts">
import MainLogo from '@/scripts/components/icons/MainLogo.vue'
import MainLogo from '@v2/components/icons/MainLogo.vue'
interface Props {
showBgOverlay?: boolean

View File

@@ -1,11 +1,11 @@
<script setup lang="ts">
import { computed, reactive, ref } from 'vue'
import { useI18n } from 'vue-i18n'
import { usePermissions } from '../../composables/use-permissions'
import { useModal } from '../../composables/use-modal'
import { ABILITIES } from '../../config/abilities'
import type { Item } from '../../types/domain'
import type { Tax } from '../../types/domain'
import { usePermissions } from '@v2/composables/use-permissions'
import { useModal } from '@v2/composables/use-modal'
import { ABILITIES } from '@v2/config/abilities'
import type { Item } from '@v2/types/domain'
import type { Tax } from '@v2/types/domain'
interface LineItem {
item_id: number | null

View File

@@ -92,7 +92,7 @@
</template>
<script setup lang="ts">
import { useModalStore } from '@/scripts/stores/modal'
import { useModalStore } from '@v2/stores/modal.store'
import { computed, watchEffect, useSlots } from 'vue'
import {
Dialog,

View File

@@ -19,7 +19,7 @@
import { computed } from 'vue'
import { Money3Component } from 'v-money3'
import { useCompanyStore } from '@/scripts/admin/stores/company'
import { useCompanyStore } from '@v2/stores/company.store'
const money3 = Money3Component

View File

@@ -1,6 +1,6 @@
<script setup lang="ts">
import { computed } from 'vue'
import { EstimateStatus } from '../../types/domain'
import { EstimateStatus } from '@v2/types/domain'
interface Props {
status?: EstimateStatus | string

View File

@@ -1,8 +1,8 @@
<script setup lang="ts">
import type { Invoice } from '../../types/domain'
import type { Currency } from '../../types/domain'
import type { Company } from '../../types/domain'
import type { Customer } from '../../types/domain'
import type { Invoice } from '@v2/types/domain'
import type { Currency } from '@v2/types/domain'
import type { Company } from '@v2/types/domain'
import type { Customer } from '@v2/types/domain'
interface InvoiceInfo {
paid_status: string

View File

@@ -2,9 +2,9 @@
import { ref, computed } from 'vue'
import type { Ref, ComputedRef } from 'vue'
import { useRoute, useRouter } from 'vue-router'
import type { Currency } from '../../types/domain'
import type { Company } from '../../types/domain'
import type { Customer } from '../../types/domain'
import type { Currency } from '@v2/types/domain'
import type { Company } from '@v2/types/domain'
import type { Customer } from '@v2/types/domain'
declare global {
interface Window {

View File

@@ -1,6 +1,6 @@
<script setup lang="ts">
import { computed } from 'vue'
import { InvoiceStatus, InvoicePaidStatus } from '../../types/domain'
import { InvoiceStatus, InvoicePaidStatus } from '@v2/types/domain'
type InvoiceBadgeStatus =
| InvoiceStatus

View File

@@ -1,6 +1,6 @@
<script setup lang="ts">
import { computed } from 'vue'
import { InvoicePaidStatus } from '../../types/domain'
import { InvoicePaidStatus } from '@v2/types/domain'
type PaidBadgeStatus = InvoicePaidStatus | 'OVERDUE' | string

View File

@@ -1,6 +1,6 @@
<script setup lang="ts">
import { computed } from 'vue'
import { RecurringInvoiceStatus } from '../../types/domain'
import { RecurringInvoiceStatus } from '@v2/types/domain'
interface Props {
status?: RecurringInvoiceStatus | string