@things-factory/accounting 7.0.2 → 8.0.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (231) hide show
  1. package/client/activities/activity-book-edit.ts +1 -1
  2. package/client/activities/activity-book-view.ts +1 -1
  3. package/client/activities/activity-expense-edit.ts +1 -1
  4. package/client/activities/activity-expense-view.ts +1 -1
  5. package/client/pages/account/account-importer.ts +19 -8
  6. package/client/pages/account/account-list-page.ts +5 -6
  7. package/client/pages/accounting-category/accounting-category-importer.ts +19 -8
  8. package/client/pages/accounting-category/accounting-category-list-page.ts +5 -5
  9. package/client/pages/financial-statement/financial-statement-importer.ts +19 -8
  10. package/client/pages/financial-statement/financial-statement-list-page.ts +5 -6
  11. package/client/pages/fiscal-month/fiscal-month-importer.ts +90 -0
  12. package/client/pages/fiscal-month/fiscal-month-list-page.ts +398 -0
  13. package/client/pages/fiscal-quarter/fiscal-quarter-importer.ts +90 -0
  14. package/client/pages/fiscal-quarter/fiscal-quarter-list-page.ts +398 -0
  15. package/client/pages/fiscal-year/fiscal-year-importer.ts +90 -0
  16. package/client/pages/fiscal-year/fiscal-year-list-page.ts +398 -0
  17. package/client/pages/income-statement/income-statement-importer.ts +19 -8
  18. package/client/pages/income-statement/income-statement-list-page.ts +5 -6
  19. package/client/pages/ledger/ledger-importer.ts +19 -8
  20. package/client/pages/ledger/ledger-list-page.ts +5 -6
  21. package/client/pages/transaction/transaction-importer.ts +19 -8
  22. package/client/pages/transaction/transaction-list-page.ts +5 -6
  23. package/client/route.ts +17 -5
  24. package/dist-client/activities/activity-book-edit.js +1 -1
  25. package/dist-client/activities/activity-book-edit.js.map +1 -1
  26. package/dist-client/activities/activity-book-view.js +1 -1
  27. package/dist-client/activities/activity-book-view.js.map +1 -1
  28. package/dist-client/activities/activity-expense-edit.js +1 -1
  29. package/dist-client/activities/activity-expense-edit.js.map +1 -1
  30. package/dist-client/activities/activity-expense-view.js +1 -1
  31. package/dist-client/activities/activity-expense-view.js.map +1 -1
  32. package/dist-client/pages/account/account-importer.d.ts +0 -1
  33. package/dist-client/pages/account/account-importer.js +12 -5
  34. package/dist-client/pages/account/account-importer.js.map +1 -1
  35. package/dist-client/pages/account/account-list-page.js +5 -6
  36. package/dist-client/pages/account/account-list-page.js.map +1 -1
  37. package/dist-client/pages/accounting-category/accounting-category-importer.d.ts +0 -1
  38. package/dist-client/pages/accounting-category/accounting-category-importer.js +12 -5
  39. package/dist-client/pages/accounting-category/accounting-category-importer.js.map +1 -1
  40. package/dist-client/pages/accounting-category/accounting-category-list-page.js +5 -5
  41. package/dist-client/pages/accounting-category/accounting-category-list-page.js.map +1 -1
  42. package/dist-client/pages/financial-statement/financial-statement-importer.d.ts +0 -1
  43. package/dist-client/pages/financial-statement/financial-statement-importer.js +12 -5
  44. package/dist-client/pages/financial-statement/financial-statement-importer.js.map +1 -1
  45. package/dist-client/pages/financial-statement/financial-statement-list-page.js +5 -6
  46. package/dist-client/pages/financial-statement/financial-statement-list-page.js.map +1 -1
  47. package/dist-client/pages/fiscal-month/fiscal-month-importer.d.ts +23 -0
  48. package/dist-client/pages/fiscal-month/fiscal-month-importer.js +93 -0
  49. package/dist-client/pages/fiscal-month/fiscal-month-importer.js.map +1 -0
  50. package/dist-client/pages/fiscal-month/fiscal-month-list-page.d.ts +66 -0
  51. package/dist-client/pages/fiscal-month/fiscal-month-list-page.js +370 -0
  52. package/dist-client/pages/fiscal-month/fiscal-month-list-page.js.map +1 -0
  53. package/dist-client/pages/fiscal-quarter/fiscal-quarter-importer.d.ts +23 -0
  54. package/dist-client/pages/fiscal-quarter/fiscal-quarter-importer.js +93 -0
  55. package/dist-client/pages/fiscal-quarter/fiscal-quarter-importer.js.map +1 -0
  56. package/dist-client/pages/fiscal-quarter/fiscal-quarter-list-page.d.ts +66 -0
  57. package/dist-client/pages/fiscal-quarter/fiscal-quarter-list-page.js +370 -0
  58. package/dist-client/pages/fiscal-quarter/fiscal-quarter-list-page.js.map +1 -0
  59. package/dist-client/pages/fiscal-year/fiscal-year-importer.d.ts +23 -0
  60. package/dist-client/pages/fiscal-year/fiscal-year-importer.js +93 -0
  61. package/dist-client/pages/fiscal-year/fiscal-year-importer.js.map +1 -0
  62. package/dist-client/pages/fiscal-year/fiscal-year-list-page.d.ts +66 -0
  63. package/dist-client/pages/fiscal-year/fiscal-year-list-page.js +370 -0
  64. package/dist-client/pages/fiscal-year/fiscal-year-list-page.js.map +1 -0
  65. package/dist-client/pages/income-statement/income-statement-importer.d.ts +0 -1
  66. package/dist-client/pages/income-statement/income-statement-importer.js +12 -5
  67. package/dist-client/pages/income-statement/income-statement-importer.js.map +1 -1
  68. package/dist-client/pages/income-statement/income-statement-list-page.js +5 -6
  69. package/dist-client/pages/income-statement/income-statement-list-page.js.map +1 -1
  70. package/dist-client/pages/ledger/ledger-importer.d.ts +0 -1
  71. package/dist-client/pages/ledger/ledger-importer.js +12 -5
  72. package/dist-client/pages/ledger/ledger-importer.js.map +1 -1
  73. package/dist-client/pages/ledger/ledger-list-page.js +5 -6
  74. package/dist-client/pages/ledger/ledger-list-page.js.map +1 -1
  75. package/dist-client/pages/transaction/transaction-importer.d.ts +0 -1
  76. package/dist-client/pages/transaction/transaction-importer.js +12 -5
  77. package/dist-client/pages/transaction/transaction-importer.js.map +1 -1
  78. package/dist-client/pages/transaction/transaction-list-page.js +5 -6
  79. package/dist-client/pages/transaction/transaction-list-page.js.map +1 -1
  80. package/dist-client/route.d.ts +1 -1
  81. package/dist-client/route.js +9 -0
  82. package/dist-client/route.js.map +1 -1
  83. package/dist-client/tsconfig.tsbuildinfo +1 -1
  84. package/dist-server/controllers/index.d.ts +1 -0
  85. package/dist-server/controllers/index.js +4 -0
  86. package/dist-server/controllers/index.js.map +1 -1
  87. package/dist-server/controllers/summary-statements.d.ts +4 -0
  88. package/dist-server/controllers/summary-statements.js +143 -0
  89. package/dist-server/controllers/summary-statements.js.map +1 -0
  90. package/dist-server/index.d.ts +1 -0
  91. package/dist-server/index.js +1 -0
  92. package/dist-server/index.js.map +1 -1
  93. package/dist-server/migrations/1725200507196-seed-fiscal-entities.d.ts +5 -0
  94. package/dist-server/migrations/1725200507196-seed-fiscal-entities.js +95 -0
  95. package/dist-server/migrations/1725200507196-seed-fiscal-entities.js.map +1 -0
  96. package/dist-server/migrations/1725201467183-seed-accounts.d.ts +5 -0
  97. package/dist-server/migrations/1725201467183-seed-accounts.js +318 -0
  98. package/dist-server/migrations/1725201467183-seed-accounts.js.map +1 -0
  99. package/dist-server/routes.d.ts +1 -0
  100. package/dist-server/routes.js +1 -0
  101. package/dist-server/routes.js.map +1 -1
  102. package/dist-server/service/account/account-history.js +3 -3
  103. package/dist-server/service/account/account-history.js.map +1 -1
  104. package/dist-server/service/account/account-query.js +1 -1
  105. package/dist-server/service/account/account-query.js.map +1 -1
  106. package/dist-server/service/account/account.js +1 -1
  107. package/dist-server/service/account/account.js.map +1 -1
  108. package/dist-server/service/accounting-category/accounting-category-query.js +1 -1
  109. package/dist-server/service/accounting-category/accounting-category-query.js.map +1 -1
  110. package/dist-server/service/accounting-category/accounting-category-type.d.ts +2 -0
  111. package/dist-server/service/accounting-category/accounting-category-type.js +8 -0
  112. package/dist-server/service/accounting-category/accounting-category-type.js.map +1 -1
  113. package/dist-server/service/accounting-category/accounting-category.d.ts +1 -0
  114. package/dist-server/service/accounting-category/accounting-category.js +7 -1
  115. package/dist-server/service/accounting-category/accounting-category.js.map +1 -1
  116. package/dist-server/service/common-type.d.ts +5 -0
  117. package/dist-server/service/common-type.js +15 -0
  118. package/dist-server/service/common-type.js.map +1 -0
  119. package/dist-server/service/financial-statement/financial-statement-history.js +3 -3
  120. package/dist-server/service/financial-statement/financial-statement-history.js.map +1 -1
  121. package/dist-server/service/financial-statement/financial-statement-query.js +1 -1
  122. package/dist-server/service/financial-statement/financial-statement-query.js.map +1 -1
  123. package/dist-server/service/financial-statement/financial-statement.js +1 -1
  124. package/dist-server/service/financial-statement/financial-statement.js.map +1 -1
  125. package/dist-server/service/fiscal-month/fiscal-month-mutation.d.ts +10 -0
  126. package/dist-server/service/fiscal-month/fiscal-month-mutation.js +128 -0
  127. package/dist-server/service/fiscal-month/fiscal-month-mutation.js.map +1 -0
  128. package/dist-server/service/fiscal-month/fiscal-month-query.d.ts +11 -0
  129. package/dist-server/service/fiscal-month/fiscal-month-query.js +81 -0
  130. package/dist-server/service/fiscal-month/fiscal-month-query.js.map +1 -0
  131. package/dist-server/service/fiscal-month/fiscal-month-type.d.ts +26 -0
  132. package/dist-server/service/fiscal-month/fiscal-month-type.js +98 -0
  133. package/dist-server/service/fiscal-month/fiscal-month-type.js.map +1 -0
  134. package/dist-server/service/fiscal-month/fiscal-month.d.ts +22 -0
  135. package/dist-server/service/fiscal-month/fiscal-month.js +99 -0
  136. package/dist-server/service/fiscal-month/fiscal-month.js.map +1 -0
  137. package/dist-server/service/fiscal-month/index.d.ts +6 -0
  138. package/dist-server/service/fiscal-month/index.js +10 -0
  139. package/dist-server/service/fiscal-month/index.js.map +1 -0
  140. package/dist-server/service/fiscal-quarter/fiscal-quarter-mutation.d.ts +10 -0
  141. package/dist-server/service/fiscal-quarter/fiscal-quarter-mutation.js +128 -0
  142. package/dist-server/service/fiscal-quarter/fiscal-quarter-mutation.js.map +1 -0
  143. package/dist-server/service/fiscal-quarter/fiscal-quarter-query.d.ts +11 -0
  144. package/dist-server/service/fiscal-quarter/fiscal-quarter-query.js +83 -0
  145. package/dist-server/service/fiscal-quarter/fiscal-quarter-query.js.map +1 -0
  146. package/dist-server/service/fiscal-quarter/fiscal-quarter-type.d.ts +24 -0
  147. package/dist-server/service/fiscal-quarter/fiscal-quarter-type.js +90 -0
  148. package/dist-server/service/fiscal-quarter/fiscal-quarter-type.js.map +1 -0
  149. package/dist-server/service/fiscal-quarter/fiscal-quarter.d.ts +21 -0
  150. package/dist-server/service/fiscal-quarter/fiscal-quarter.js +94 -0
  151. package/dist-server/service/fiscal-quarter/fiscal-quarter.js.map +1 -0
  152. package/dist-server/service/fiscal-quarter/index.d.ts +6 -0
  153. package/dist-server/service/fiscal-quarter/index.js +10 -0
  154. package/dist-server/service/fiscal-quarter/index.js.map +1 -0
  155. package/dist-server/service/fiscal-year/fiscal-year-mutation.d.ts +10 -0
  156. package/dist-server/service/fiscal-year/fiscal-year-mutation.js +128 -0
  157. package/dist-server/service/fiscal-year/fiscal-year-mutation.js.map +1 -0
  158. package/dist-server/service/fiscal-year/fiscal-year-query.d.ts +11 -0
  159. package/dist-server/service/fiscal-year/fiscal-year-query.js +79 -0
  160. package/dist-server/service/fiscal-year/fiscal-year-query.js.map +1 -0
  161. package/dist-server/service/fiscal-year/fiscal-year-type.d.ts +22 -0
  162. package/dist-server/service/fiscal-year/fiscal-year-type.js +82 -0
  163. package/dist-server/service/fiscal-year/fiscal-year-type.js.map +1 -0
  164. package/dist-server/service/fiscal-year/fiscal-year.d.ts +20 -0
  165. package/dist-server/service/fiscal-year/fiscal-year.js +89 -0
  166. package/dist-server/service/fiscal-year/fiscal-year.js.map +1 -0
  167. package/dist-server/service/fiscal-year/index.d.ts +6 -0
  168. package/dist-server/service/fiscal-year/index.js +10 -0
  169. package/dist-server/service/fiscal-year/index.js.map +1 -0
  170. package/dist-server/service/income-statement/income-statement-history.js +3 -3
  171. package/dist-server/service/income-statement/income-statement-history.js.map +1 -1
  172. package/dist-server/service/income-statement/income-statement-query.js +1 -1
  173. package/dist-server/service/income-statement/income-statement-query.js.map +1 -1
  174. package/dist-server/service/income-statement/income-statement.js +3 -3
  175. package/dist-server/service/income-statement/income-statement.js.map +1 -1
  176. package/dist-server/service/index.d.ts +5 -2
  177. package/dist-server/service/index.js +19 -3
  178. package/dist-server/service/index.js.map +1 -1
  179. package/dist-server/service/transaction/index.d.ts +1 -2
  180. package/dist-server/service/transaction/transaction-history.d.ts +10 -2
  181. package/dist-server/service/transaction/transaction-history.js +43 -6
  182. package/dist-server/service/transaction/transaction-history.js.map +1 -1
  183. package/dist-server/service/transaction/transaction-query.js +1 -1
  184. package/dist-server/service/transaction/transaction-query.js.map +1 -1
  185. package/dist-server/service/transaction/transaction.d.ts +8 -5
  186. package/dist-server/service/transaction/transaction.js +33 -10
  187. package/dist-server/service/transaction/transaction.js.map +1 -1
  188. package/dist-server/tsconfig.tsbuildinfo +1 -1
  189. package/helps/accounting/fiscal-month.md +160 -0
  190. package/helps/accounting/fiscal-quarter.md +160 -0
  191. package/helps/accounting/fiscal-year.md +160 -0
  192. package/package.json +9 -8
  193. package/server/controllers/index.ts +1 -0
  194. package/server/controllers/summary-statements.ts +160 -0
  195. package/server/index.ts +1 -0
  196. package/server/migrations/1725200507196-seed-fiscal-entities.ts +106 -0
  197. package/server/migrations/1725201467183-seed-accounts.ts +339 -0
  198. package/server/routes.ts +2 -0
  199. package/server/service/account/account-history.ts +5 -5
  200. package/server/service/account/account-query.ts +1 -1
  201. package/server/service/account/account.ts +1 -1
  202. package/server/service/accounting-category/accounting-category-query.ts +1 -1
  203. package/server/service/accounting-category/accounting-category-type.ts +6 -0
  204. package/server/service/accounting-category/accounting-category.ts +10 -1
  205. package/server/service/common-type.ts +12 -0
  206. package/server/service/financial-statement/financial-statement-history.ts +5 -5
  207. package/server/service/financial-statement/financial-statement-query.ts +1 -1
  208. package/server/service/financial-statement/financial-statement.ts +1 -1
  209. package/server/service/fiscal-month/fiscal-month-mutation.ts +137 -0
  210. package/server/service/fiscal-month/fiscal-month-query.ts +56 -0
  211. package/server/service/fiscal-month/fiscal-month-type.ts +66 -0
  212. package/server/service/fiscal-month/fiscal-month.ts +84 -0
  213. package/server/service/fiscal-month/index.ts +7 -0
  214. package/server/service/fiscal-quarter/fiscal-quarter-mutation.ts +137 -0
  215. package/server/service/fiscal-quarter/fiscal-quarter-query.ts +58 -0
  216. package/server/service/fiscal-quarter/fiscal-quarter-type.ts +60 -0
  217. package/server/service/fiscal-quarter/fiscal-quarter.ts +80 -0
  218. package/server/service/fiscal-quarter/index.ts +7 -0
  219. package/server/service/fiscal-year/fiscal-year-mutation.ts +137 -0
  220. package/server/service/fiscal-year/fiscal-year-query.ts +51 -0
  221. package/server/service/fiscal-year/fiscal-year-type.ts +54 -0
  222. package/server/service/fiscal-year/fiscal-year.ts +76 -0
  223. package/server/service/fiscal-year/index.ts +7 -0
  224. package/server/service/income-statement/income-statement-history.ts +5 -5
  225. package/server/service/income-statement/income-statement-query.ts +1 -4
  226. package/server/service/income-statement/income-statement.ts +3 -3
  227. package/server/service/index.ts +31 -3
  228. package/server/service/transaction/transaction-history.ts +35 -7
  229. package/server/service/transaction/transaction-query.ts +1 -4
  230. package/server/service/transaction/transaction.ts +34 -15
  231. package/things-factory.config.js +3 -1
@@ -0,0 +1,398 @@
1
+ import '@material/web/icon/icon.js'
2
+ import '@material/web/button/elevated-button.js'
3
+ import '@operato/data-grist/ox-grist.js'
4
+ import '@operato/data-grist/ox-filters-form.js'
5
+ import '@operato/data-grist/ox-record-creator.js'
6
+
7
+ import { CommonButtonStyles, CommonHeaderStyles, CommonGristStyles, ScrollbarStyles } from '@operato/styles'
8
+ import { PageView, store } from '@operato/shell'
9
+ import { css, html } from 'lit'
10
+ import { customElement, property, query } from 'lit/decorators.js'
11
+ import { ScopedElementsMixin } from '@open-wc/scoped-elements'
12
+ import { ColumnConfig, DataGrist, FetchOption } from '@operato/data-grist'
13
+ import { client } from '@operato/graphql'
14
+ import { i18next, localize } from '@operato/i18n'
15
+ import { notify, openPopup } from '@operato/layout'
16
+ import { OxPopup, OxPrompt } from '@operato/popup'
17
+ import { isMobileDevice } from '@operato/utils'
18
+
19
+ import { connect } from 'pwa-helpers/connect-mixin'
20
+ import gql from 'graphql-tag'
21
+
22
+ import { FiscalYearImporter } from './fiscal-year-importer'
23
+
24
+ @customElement('fiscal-year-list-page')
25
+ export class FiscalYearListPage extends connect(store)(localize(i18next)(ScopedElementsMixin(PageView))) {
26
+
27
+ static styles = [
28
+ ScrollbarStyles,
29
+ CommonGristStyles,
30
+ CommonHeaderStyles,
31
+ css`
32
+ :host {
33
+ display: flex;
34
+
35
+ width: 100%;
36
+
37
+ --grid-record-emphasized-background-color: #8B0000;
38
+ --grid-record-emphasized-color: #FF6B6B;
39
+ }
40
+
41
+ ox-grist {
42
+ overflow-y: auto;
43
+ flex: 1;
44
+ }
45
+
46
+ ox-filters-form {
47
+ flex: 1;
48
+ }
49
+ `
50
+ ]
51
+
52
+ static get scopedElements() {
53
+ return {
54
+ 'fiscal-year-importer': FiscalYearImporter
55
+ }
56
+ }
57
+
58
+ @property({ type: Object }) gristConfig: any
59
+ @property({ type: String }) mode: 'CARD' | 'GRID' | 'LIST' = isMobileDevice() ? 'CARD' : 'GRID'
60
+
61
+ @query('ox-grist') private grist!: DataGrist
62
+
63
+ get context() {
64
+ return {
65
+ title: i18next.t('title.fiscal-year list'),
66
+ search: {
67
+ handler: (search: string) => {
68
+ this.grist.searchText = search
69
+ },
70
+ value: this.grist.searchText
71
+ },
72
+ filter: {
73
+ handler: () => {
74
+ this.grist.toggleHeadroom()
75
+ }
76
+ },
77
+ help: 'accounting/fiscal-year',
78
+ actions: [
79
+ {
80
+ title: i18next.t('button.save'),
81
+ action: this._updateFiscalYear.bind(this),
82
+ ...CommonButtonStyles.save
83
+ },
84
+ {
85
+ title: i18next.t('button.delete'),
86
+ action: this._deleteFiscalYear.bind(this),
87
+ ...CommonButtonStyles.delete
88
+ }
89
+ ],
90
+ exportable: {
91
+ name: i18next.t('title.fiscal-year list'),
92
+ data: this.exportHandler.bind(this)
93
+ },
94
+ importable: {
95
+ handler: this.importHandler.bind(this)
96
+ }
97
+ }
98
+ }
99
+
100
+ render() {
101
+ const mode = this.mode || (isMobileDevice() ? 'CARD' : 'GRID')
102
+
103
+ return html`
104
+ <ox-grist
105
+ .mode=${mode}
106
+ .config=${this.gristConfig}
107
+ .fetchHandler=${this.fetchHandler.bind(this)}
108
+ >
109
+ <div slot="headroom" class="header">
110
+ <div class="filters">
111
+ <ox-filters-form autofocus without-search></ox-filters-form>
112
+
113
+ <div id="modes">
114
+ <md-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</md-icon>
115
+ <md-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</md-icon>
116
+ <md-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</md-icon>
117
+ </div>
118
+
119
+ <ox-record-creator id="add" .callback=${this.creationCallback.bind(this)}>
120
+ <button>
121
+ <md-icon>add</md-icon>
122
+ </button>
123
+ </ox-record-creator>
124
+
125
+ </div>
126
+ </div>
127
+ </ox-grist>
128
+ `
129
+ }
130
+
131
+ async pageInitialized(lifecycle: any) {
132
+ this.gristConfig = {
133
+ list: {
134
+ fields: ['name', 'description'],
135
+ details: ['active', 'updatedAt']
136
+ },
137
+ columns: [
138
+ { type: 'gutter', gutterName: 'sequence' },
139
+ { type: 'gutter', gutterName: 'row-selector', multiple: true },
140
+ {
141
+ type: 'string',
142
+ name: 'name',
143
+ header: i18next.t('field.name'),
144
+ record: {
145
+ editable: true
146
+ },
147
+ filter: 'search',
148
+ sortable: true,
149
+ width: 150
150
+ },
151
+ {
152
+ type: 'string',
153
+ name: 'description',
154
+ header: i18next.t('field.description'),
155
+ record: {
156
+ editable: true
157
+ },
158
+ filter: 'search',
159
+ width: 200
160
+ },
161
+ {
162
+ type: 'checkbox',
163
+ name: 'active',
164
+ label: true,
165
+ header: i18next.t('field.active'),
166
+ record: {
167
+ editable: true
168
+ },
169
+ filter: true,
170
+ sortable: true,
171
+ width: 60
172
+ },
173
+ {
174
+ type: 'resource-object',
175
+ name: 'updater',
176
+ header: i18next.t('field.updater'),
177
+ record: {
178
+ editable: false
179
+ },
180
+ sortable: true,
181
+ width: 120
182
+ },
183
+ {
184
+ type: 'datetime',
185
+ name: 'updatedAt',
186
+ header: i18next.t('field.updated_at'),
187
+ record: {
188
+ editable: false
189
+ },
190
+ sortable: true,
191
+ width: 180
192
+ }
193
+ ],
194
+ rows: {
195
+ appendable: false,
196
+ selectable: {
197
+ multiple: true
198
+ }
199
+ },
200
+ sorters: [
201
+ {
202
+ name: 'name'
203
+ }
204
+ ]
205
+ }
206
+ }
207
+
208
+ async pageUpdated(changes: any, lifecycle: any) {
209
+ if (this.active) {
210
+ // do something here when this page just became as active
211
+ }
212
+ }
213
+
214
+ async fetchHandler({ page = 1, limit = 100, sortings = [], filters = [] }: FetchOption) {
215
+ const response = await client.query({
216
+ query: gql`
217
+ query ($filters: [Filter!], $pagination: Pagination, $sortings: [Sorting!]) {
218
+ responses: fiscalYears(filters: $filters, pagination: $pagination, sortings: $sortings) {
219
+ items {
220
+ id
221
+ name
222
+ description
223
+ active
224
+ updater {
225
+ id
226
+ name
227
+ }
228
+ updatedAt
229
+ }
230
+ total
231
+ }
232
+ }
233
+ `,
234
+ variables: {
235
+ filters,
236
+ pagination: { page, limit },
237
+ sortings
238
+ }
239
+ })
240
+
241
+ return {
242
+ total: response.data.responses.total || 0,
243
+ records: response.data.responses.items || []
244
+ }
245
+ }
246
+
247
+ async _deleteFiscalYear() {
248
+ if (
249
+ await OxPrompt.open({
250
+ title: i18next.t('text.are_you_sure'),
251
+ text: i18next.t('text.sure_to_x', { x: i18next.t('text.delete') }),
252
+ confirmButton: { text: i18next.t('button.confirm') },
253
+ cancelButton: { text: i18next.t('button.cancel') }
254
+ })
255
+ ) {
256
+ const ids = this.grist.selected.map(record => record.id)
257
+ if (ids && ids.length > 0) {
258
+ const response = await client.mutate({
259
+ mutation: gql`
260
+ mutation ($ids: [String!]!) {
261
+ deleteFiscalYears(ids: $ids)
262
+ }
263
+ `,
264
+ variables: {
265
+ ids
266
+ }
267
+ })
268
+
269
+ if (!response.errors) {
270
+ this.grist.fetch()
271
+ notify({
272
+ message: i18next.t('text.info_x_successfully', { x: i18next.t('text.delete') })
273
+ })
274
+ }
275
+ }
276
+ }
277
+ }
278
+
279
+ async _updateFiscalYear() {
280
+ let patches = this.grist.dirtyRecords
281
+ if (patches && patches.length) {
282
+ patches = patches.map(patch => {
283
+ let patchField: any = patch.id ? { id: patch.id } : {}
284
+ const dirtyFields = patch.__dirtyfields__
285
+ for (let key in dirtyFields) {
286
+ patchField[key] = dirtyFields[key].after
287
+ }
288
+ patchField.cuFlag = patch.__dirty__
289
+
290
+ return patchField
291
+ })
292
+
293
+ const response = await client.mutate({
294
+ mutation: gql`
295
+ mutation ($patches: [FiscalYearPatch!]!) {
296
+ updateMultipleFiscalYear(patches: $patches) {
297
+ name
298
+ }
299
+ }
300
+ `,
301
+ variables: {
302
+ patches
303
+ }
304
+ })
305
+
306
+ if (!response.errors) {
307
+ this.grist.fetch()
308
+ }
309
+ }
310
+ }
311
+
312
+ async creationCallback(fiscalYear) {
313
+ try {
314
+ const response = await client.query({
315
+ query: gql`
316
+ mutation ($fiscalYear: NewFiscalYear!) {
317
+ createFiscalYear(fiscalYear: $fiscalYear) {
318
+ id
319
+ }
320
+ }
321
+ `,
322
+ variables: {
323
+ fiscalYear
324
+ },
325
+ context: {
326
+ hasUpload: true
327
+ }
328
+ })
329
+
330
+ if (!response.errors) {
331
+ this.grist.fetch()
332
+ document.dispatchEvent(
333
+ new CustomEvent('notify', {
334
+ detail: {
335
+ message: i18next.t('text.data_created_successfully')
336
+ }
337
+ })
338
+ )
339
+ }
340
+
341
+ return true
342
+ } catch (ex) {
343
+ console.error(ex)
344
+ document.dispatchEvent(
345
+ new CustomEvent('notify', {
346
+ detail: {
347
+ type: 'error',
348
+ message: i18next.t('text.error')
349
+ }
350
+ })
351
+ )
352
+ return false
353
+ }
354
+ }
355
+
356
+ async exportHandler() {
357
+ const exportTargets = this.grist.selected.length ? this.grist.selected : this.grist.dirtyData.records
358
+ const targetFieldSet = new Set([
359
+ 'id',
360
+ 'name',
361
+ 'description',
362
+ 'active'
363
+ ])
364
+
365
+ return exportTargets.map(fiscalYear => {
366
+ let tempObj = {}
367
+ for (const field of targetFieldSet) {
368
+ tempObj[field] = fiscalYear[field]
369
+ }
370
+
371
+ return tempObj
372
+ })
373
+ }
374
+
375
+ async importHandler(records) {
376
+ const popup = openPopup(
377
+ html`
378
+ <fiscal-year-importer
379
+ .fiscalYears=${records}
380
+ @imported=${() => {
381
+ history.back()
382
+ this.grist.fetch()
383
+ }}
384
+ ></fiscal-year-importer>
385
+ `,
386
+ {
387
+ backdrop: true,
388
+ size: 'large',
389
+ title: i18next.t('title.import fiscal-year')
390
+ }
391
+ )
392
+
393
+ popup.onclosed = () => {
394
+ this.grist.fetch()
395
+ }
396
+ }
397
+ }
398
+
@@ -1,4 +1,3 @@
1
- import '@material/web/icon/icon.js'
2
1
  import '@operato/data-grist'
3
2
 
4
3
  import gql from 'graphql-tag'
@@ -8,22 +7,30 @@ import { property } from 'lit/decorators.js'
8
7
  import { client } from '@operato/graphql'
9
8
  import { i18next } from '@operato/i18n'
10
9
  import { isMobileDevice } from '@operato/utils'
11
- import { ButtonContainerStyles } from '@operato/styles'
12
10
 
13
11
  export class IncomeStatementImporter extends LitElement {
14
12
  static styles = [
15
- ButtonContainerStyles,
16
13
  css`
17
14
  :host {
18
15
  display: flex;
19
16
  flex-direction: column;
20
17
 
21
- background-color: var(--md-sys-color-surface);
18
+ background-color: #fff;
22
19
  }
23
20
 
24
21
  ox-grist {
25
22
  flex: 1;
26
23
  }
24
+
25
+ .button-container {
26
+ display: flex;
27
+ margin-left: auto;
28
+ padding: var(--padding-default);
29
+ }
30
+
31
+ mwc-button {
32
+ margin-left: var(--margin-default);
33
+ }
27
34
  `
28
35
  ]
29
36
 
@@ -53,18 +60,21 @@ export class IncomeStatementImporter extends LitElement {
53
60
  ]
54
61
  }
55
62
 
63
+
56
64
  render() {
57
65
  return html`
58
66
  <ox-grist
59
67
  .mode=${isMobileDevice() ? 'LIST' : 'GRID'}
60
68
  .config=${this.columns}
61
- .data=${{
62
- records: this.incomeStatements
63
- }}
69
+ .data=${
70
+ {
71
+ records: this.incomeStatements
72
+ }
73
+ }
64
74
  ></ox-grist>
65
75
 
66
76
  <div class="button-container">
67
- <button @click="${this.save.bind(this)}"><md-icon>save</md-icon>${i18next.t('button.save')}</button>
77
+ <mwc-button raised @click="${this.save.bind(this)}">${i18next.t('button.save')}</mwc-button>
68
78
  </div>
69
79
  `
70
80
  }
@@ -84,3 +94,4 @@ export class IncomeStatementImporter extends LitElement {
84
94
  this.dispatchEvent(new CustomEvent('imported'))
85
95
  }
86
96
  }
97
+
@@ -101,7 +101,7 @@ export class IncomeStatementListPage extends connect(store)(localize(i18next)(Sc
101
101
 
102
102
  <div id="sorters">
103
103
  Sort
104
- <md-icon
104
+ <mwc-icon
105
105
  @click=${e => {
106
106
  const target = e.currentTarget
107
107
  this.sortersControl.open({
@@ -109,7 +109,7 @@ export class IncomeStatementListPage extends connect(store)(localize(i18next)(Sc
109
109
  top: target.offsetTop + target.offsetHeight
110
110
  })
111
111
  }}
112
- >expand_more</md-icon
112
+ >expand_more</mwc-icon
113
113
  >
114
114
  <ox-popup id="sorter-control">
115
115
  <ox-sorters-control> </ox-sorters-control>
@@ -117,10 +117,9 @@ export class IncomeStatementListPage extends connect(store)(localize(i18next)(Sc
117
117
  </div>
118
118
 
119
119
  <div id="modes">
120
- <md-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</md-icon>
121
- <md-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</md-icon>
122
- <md-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</md-icon>
123
- </div>
120
+ <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>
121
+ <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>
122
+ <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>
124
123
  </div>
125
124
  </div>
126
125
  </ox-grist>
@@ -1,4 +1,3 @@
1
- import '@material/web/icon/icon.js'
2
1
  import '@operato/data-grist'
3
2
 
4
3
  import gql from 'graphql-tag'
@@ -8,22 +7,30 @@ import { property } from 'lit/decorators.js'
8
7
  import { client } from '@operato/graphql'
9
8
  import { i18next } from '@operato/i18n'
10
9
  import { isMobileDevice } from '@operato/utils'
11
- import { ButtonContainerStyles } from '@operato/styles'
12
10
 
13
11
  export class LedgerImporter extends LitElement {
14
12
  static styles = [
15
- ButtonContainerStyles,
16
13
  css`
17
14
  :host {
18
15
  display: flex;
19
16
  flex-direction: column;
20
17
 
21
- background-color: var(--md-sys-color-surface);
18
+ background-color: #fff;
22
19
  }
23
20
 
24
21
  ox-grist {
25
22
  flex: 1;
26
23
  }
24
+
25
+ .button-container {
26
+ display: flex;
27
+ margin-left: auto;
28
+ padding: var(--padding-default);
29
+ }
30
+
31
+ mwc-button {
32
+ margin-left: var(--margin-default);
33
+ }
27
34
  `
28
35
  ]
29
36
 
@@ -53,18 +60,21 @@ export class LedgerImporter extends LitElement {
53
60
  ]
54
61
  }
55
62
 
63
+
56
64
  render() {
57
65
  return html`
58
66
  <ox-grist
59
67
  .mode=${isMobileDevice() ? 'LIST' : 'GRID'}
60
68
  .config=${this.columns}
61
- .data=${{
62
- records: this.ledgers
63
- }}
69
+ .data=${
70
+ {
71
+ records: this.ledgers
72
+ }
73
+ }
64
74
  ></ox-grist>
65
75
 
66
76
  <div class="button-container">
67
- <button @click="${this.save.bind(this)}"><md-icon>save</md-icon>${i18next.t('button.save')}</button>
77
+ <mwc-button raised @click="${this.save.bind(this)}">${i18next.t('button.save')}</mwc-button>
68
78
  </div>
69
79
  `
70
80
  }
@@ -84,3 +94,4 @@ export class LedgerImporter extends LitElement {
84
94
  this.dispatchEvent(new CustomEvent('imported'))
85
95
  }
86
96
  }
97
+
@@ -100,7 +100,7 @@ export class LedgerListPage extends connect(store)(localize(i18next)(ScopedEleme
100
100
 
101
101
  <div id="sorters">
102
102
  Sort
103
- <md-icon
103
+ <mwc-icon
104
104
  @click=${e => {
105
105
  const target = e.currentTarget
106
106
  this.sortersControl.open({
@@ -108,7 +108,7 @@ export class LedgerListPage extends connect(store)(localize(i18next)(ScopedEleme
108
108
  top: target.offsetTop + target.offsetHeight
109
109
  })
110
110
  }}
111
- >expand_more</md-icon
111
+ >expand_more</mwc-icon
112
112
  >
113
113
  <ox-popup id="sorter-control">
114
114
  <ox-sorters-control> </ox-sorters-control>
@@ -116,10 +116,9 @@ export class LedgerListPage extends connect(store)(localize(i18next)(ScopedEleme
116
116
  </div>
117
117
 
118
118
  <div id="modes">
119
- <md-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</md-icon>
120
- <md-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</md-icon>
121
- <md-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</md-icon>
122
- </div>
119
+ <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>
120
+ <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>
121
+ <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>
123
122
  </div>
124
123
  </div>
125
124
  </ox-grist>
@@ -1,4 +1,3 @@
1
- import '@material/web/icon/icon.js'
2
1
  import '@operato/data-grist'
3
2
 
4
3
  import gql from 'graphql-tag'
@@ -8,22 +7,30 @@ import { property } from 'lit/decorators.js'
8
7
  import { client } from '@operato/graphql'
9
8
  import { i18next } from '@operato/i18n'
10
9
  import { isMobileDevice } from '@operato/utils'
11
- import { ButtonContainerStyles } from '@operato/styles'
12
10
 
13
11
  export class TransactionImporter extends LitElement {
14
12
  static styles = [
15
- ButtonContainerStyles,
16
13
  css`
17
14
  :host {
18
15
  display: flex;
19
16
  flex-direction: column;
20
17
 
21
- background-color: var(--md-sys-color-surface);
18
+ background-color: #fff;
22
19
  }
23
20
 
24
21
  ox-grist {
25
22
  flex: 1;
26
23
  }
24
+
25
+ .button-container {
26
+ display: flex;
27
+ margin-left: auto;
28
+ padding: var(--padding-default);
29
+ }
30
+
31
+ mwc-button {
32
+ margin-left: var(--margin-default);
33
+ }
27
34
  `
28
35
  ]
29
36
 
@@ -53,18 +60,21 @@ export class TransactionImporter extends LitElement {
53
60
  ]
54
61
  }
55
62
 
63
+
56
64
  render() {
57
65
  return html`
58
66
  <ox-grist
59
67
  .mode=${isMobileDevice() ? 'LIST' : 'GRID'}
60
68
  .config=${this.columns}
61
- .data=${{
62
- records: this.transactions
63
- }}
69
+ .data=${
70
+ {
71
+ records: this.transactions
72
+ }
73
+ }
64
74
  ></ox-grist>
65
75
 
66
76
  <div class="button-container">
67
- <button @click="${this.save.bind(this)}"><md-icon>save</md-icon>${i18next.t('button.save')}</button>
77
+ <mwc-button raised @click="${this.save.bind(this)}">${i18next.t('button.save')}</mwc-button>
68
78
  </div>
69
79
  `
70
80
  }
@@ -84,3 +94,4 @@ export class TransactionImporter extends LitElement {
84
94
  this.dispatchEvent(new CustomEvent('imported'))
85
95
  }
86
96
  }
97
+
@@ -101,7 +101,7 @@ export class TransactionListPage extends connect(store)(localize(i18next)(Scoped
101
101
 
102
102
  <div id="sorters">
103
103
  Sort
104
- <md-icon
104
+ <mwc-icon
105
105
  @click=${e => {
106
106
  const target = e.currentTarget
107
107
  this.sortersControl.open({
@@ -109,7 +109,7 @@ export class TransactionListPage extends connect(store)(localize(i18next)(Scoped
109
109
  top: target.offsetTop + target.offsetHeight
110
110
  })
111
111
  }}
112
- >expand_more</md-icon
112
+ >expand_more</mwc-icon
113
113
  >
114
114
  <ox-popup id="sorter-control">
115
115
  <ox-sorters-control> </ox-sorters-control>
@@ -117,10 +117,9 @@ export class TransactionListPage extends connect(store)(localize(i18next)(Scoped
117
117
  </div>
118
118
 
119
119
  <div id="modes">
120
- <md-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</md-icon>
121
- <md-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</md-icon>
122
- <md-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</md-icon>
123
- </div>
120
+ <mwc-icon @click=${() => (this.mode = 'GRID')} ?active=${mode == 'GRID'}>grid_on</mwc-icon>
121
+ <mwc-icon @click=${() => (this.mode = 'LIST')} ?active=${mode == 'LIST'}>format_list_bulleted</mwc-icon>
122
+ <mwc-icon @click=${() => (this.mode = 'CARD')} ?active=${mode == 'CARD'}>apps</mwc-icon>
124
123
  </div>
125
124
  </div>
126
125
  </ox-grist>