|
7 | 7 | :submitText="$tr('continueAction')" |
8 | 8 | :cancelText="$tr('cancelAction')" |
9 | 9 | @submit="handleContinue" |
10 | | - @cancel="close" |
| 10 | + @cancel="closed = true" |
11 | 11 | > |
12 | | - <div class="inherit-metadata-dialog"> |
13 | | - <p class="inherit-metadata-dialog__description"> |
| 12 | + <div> |
| 13 | + <p v-if="parentHasInheritableMetadata"> |
14 | 14 | {{ $tr('inheritMetadataDescription') }} |
15 | 15 | </p> |
16 | | - <div class="inherit-metadata-dialog-checkboxes"> |
| 16 | + <div> |
17 | 17 | <KCheckbox |
18 | | - v-for="item, key in inheritableMetadataItems" |
19 | | - :key="key" |
20 | | - :checked="checks[key]" |
21 | | - :label="generateLabel(key)" |
22 | | - @change="checks[key] = !checks[key]" |
| 18 | + v-if="!!inheritableMetadataItems.categories" |
| 19 | + key="categories" |
| 20 | + :label="generateInheritableCategories(inheritableMetadataItems.categories)" |
| 21 | + :checked="checks['categories']" |
| 22 | + @change="checks['categories'] = !checks['categories']" |
23 | 23 | /> |
| 24 | + <KCheckbox |
| 25 | + v-if="!!inheritableMetadataItems.grade_levels" |
| 26 | + key="levels" |
| 27 | + :checked="checks['grade_levels']" |
| 28 | + :label="generateInheritableLevels(inheritableMetadataItems.grade_levels)" |
| 29 | + @change="checks['grade_levels'] = !checks['grade_levels']" |
| 30 | + /> |
| 31 | + <KCheckbox |
| 32 | + v-if="!!inheritableMetadataItems.learner_needs" |
| 33 | + key="needs" |
| 34 | + :checked="checks['learner_needs']" |
| 35 | + :label="generateInheritableLearnerNeeds(inheritableMetadataItems.learner_needs)" |
| 36 | + @change="checks['learner_needs'] = !checks['learner_needs']" |
| 37 | + /> |
| 38 | + <p v-if="!!inheritableMetadataItems.language" class="language-description"> |
| 39 | + {{ $tr('updateLanguage') }} |
| 40 | + </p> |
| 41 | + <KCheckbox |
| 42 | + v-if="!!inheritableMetadataItems.language" |
| 43 | + key="language" |
| 44 | + :label="generateInheritableLanguage(inheritableMetadataItems.language)" |
| 45 | + :checked="checks['language']" |
| 46 | + @change="checks['language'] = !checks['language']" |
| 47 | + /> |
| 48 | + |
24 | 49 | </div> |
25 | 50 | <div class="divider"></div> |
26 | 51 | <KCheckbox |
|
40 | 65 |
|
41 | 66 | import { mapActions } from 'vuex'; |
42 | 67 | import isEmpty from 'lodash/isEmpty'; |
| 68 | + import camelCase from 'lodash/camelCase'; |
43 | 69 | import isUndefined from 'lodash/isUndefined'; |
44 | 70 | import { ContentNode } from 'shared/data/resources'; |
| 71 | + import { ContentLevels, ResourcesNeededTypes, Categories } from 'shared/constants'; |
| 72 | + import LanguagesMap from 'shared/leUtils/Languages'; |
| 73 | + import { metadataTranslationMixin } from 'shared/mixins'; |
45 | 74 |
|
46 | 75 | const inheritableFields = ['categories', 'grade_levels', 'language', 'learner_needs']; |
47 | 76 |
|
48 | 77 | export default { |
49 | 78 | name: 'InheritAncestorMetadataModal', |
| 79 | + mixins: [metadataTranslationMixin], |
| 80 | +
|
50 | 81 | props: { |
51 | 82 | contentNode: { |
52 | 83 | type: Object, |
|
237 | 268 | } |
238 | 269 | this.closed = true; |
239 | 270 | }, |
240 | | - generateLabel(item) { |
241 | | - // TO DO generate label with all of the metadata le-consts, etc. |
242 | | - return `${item}`; |
| 271 | + generateInheritableCategories(categories) { |
| 272 | + let categoryTranslationKeys = []; |
| 273 | + Object.keys(categories).forEach(id => { |
| 274 | + categoryTranslationKeys.push(Object.keys(Categories).find(key => Categories[key] === id)); |
| 275 | + }); |
| 276 | + categoryTranslationKeys = categoryTranslationKeys |
| 277 | + .map(key => { |
| 278 | + return this.translateMetadataString(camelCase(key)); |
| 279 | + }) |
| 280 | + .join(', '); |
| 281 | + return this.$tr('categories', { categories: categoryTranslationKeys }); |
| 282 | + }, |
| 283 | + generateInheritableLearnerNeeds(learnerNeeds) { |
| 284 | + let learnerNeedsTranslationKeys = []; |
| 285 | + Object.keys(learnerNeeds).forEach(id => { |
| 286 | + learnerNeedsTranslationKeys.push( |
| 287 | + Object.keys(ResourcesNeededTypes).find(key => ResourcesNeededTypes[key] === id) |
| 288 | + ); |
| 289 | + }); |
| 290 | + learnerNeedsTranslationKeys = learnerNeedsTranslationKeys |
| 291 | + .map(key => { |
| 292 | + return this.translateMetadataString(camelCase(key)); |
| 293 | + }) |
| 294 | + .join(', '); |
| 295 | + return this.$tr('learnerNeeds', { learnerNeeds: learnerNeedsTranslationKeys }); |
243 | 296 | }, |
244 | | - close() { |
245 | | - this.$emit('close'); |
| 297 | + generateInheritableLevels(gradeLevels) { |
| 298 | + let gradeLevelsTranslationKeys = []; |
| 299 | + Object.keys(gradeLevels).forEach(id => { |
| 300 | + gradeLevelsTranslationKeys.push( |
| 301 | + Object.keys(ContentLevels).find(key => ContentLevels[key] === id) |
| 302 | + ); |
| 303 | + }); |
| 304 | + gradeLevelsTranslationKeys = gradeLevelsTranslationKeys |
| 305 | + .map(level => { |
| 306 | + let translationKey; |
| 307 | + if (level === 'PROFESSIONAL') { |
| 308 | + translationKey = 'specializedProfessionalTraining'; |
| 309 | + } else if (level === 'WORK_SKILLS') { |
| 310 | + translationKey = 'allLevelsWorkSkills'; |
| 311 | + } else if (level === 'BASIC_SKILLS') { |
| 312 | + translationKey = 'allLevelsBasicSkills'; |
| 313 | + } else { |
| 314 | + translationKey = this.translateMetadataString(camelCase(level)); |
| 315 | + } |
| 316 | + return translationKey; |
| 317 | + }) |
| 318 | + .join(', '); |
| 319 | + return this.$tr('levels', { levels: gradeLevelsTranslationKeys }); |
| 320 | + }, |
| 321 | +
|
| 322 | + generateInheritableLanguage(parentLanguage) { |
| 323 | + const language = LanguagesMap.get(parentLanguage).native_name || parentLanguage; |
| 324 | + return this.$tr('language', { language: language }); |
246 | 325 | }, |
247 | 326 | }, |
248 | 327 | $trs: { |
249 | 328 | applyResourceDetailsTitle: 'Apply resource details', |
250 | 329 | /* eslint-disable kolibri/vue-no-unused-translations */ |
251 | 330 | applyResourceDetailsDescriptionUpload: |
252 | | - 'The folder `{folder}` has the following details. Select the details you want to apply to your upload.', |
| 331 | + 'The folder `{folder}` has the following details. Select the details you want to apply to your upload. You can add edit these details and add additional resource information later.', |
253 | 332 | applyResourceDetailsDescriptionImport: |
254 | 333 | 'The folder `{folder}` has the following details. Select the details you want to apply to the {resource, plural, one {resource}, other {resources}} you are importing.', |
255 | 334 | applyResourceDetailsDescriptionMoving: |
256 | 335 | 'The folder `{folder}` has the following details. Select the details you want to apply to the {resource, plural, one {resource}, other {resources}} you are moving.', |
257 | 336 | /* eslint-enable kolibri/vue-no-unused-translations */ |
258 | 337 | continueAction: 'Continue', |
259 | 338 | cancelAction: 'Cancel', |
260 | | - inheritMetadataDescription: 'Inherit metadata from the folder above', |
| 339 | + inheritMetadataDescription: 'Add metadata from the folder above', |
| 340 | + updateLanguage: 'Update language to match the folder above', |
261 | 341 | doNotShowThisAgain: "Don't ask me about this folder again", |
262 | 342 | doNotShowAgainDescription: |
263 | 343 | 'All future additions to this folder will have the selected information by default', |
| 344 | + language: 'Language: {language}', |
| 345 | + categories: 'Categories: {categories}', |
| 346 | + learnerNeeds: 'Learner needs: {learnerNeeds}', |
| 347 | + levels: 'Levels: {levels}', |
264 | 348 | }, |
265 | 349 | }; |
266 | 350 |
|
|
280 | 364 | color: #9e9e9e; |
281 | 365 | } |
282 | 366 |
|
| 367 | + .language-description { |
| 368 | + margin: 16px 0 8px; |
| 369 | + } |
| 370 | +
|
283 | 371 | </style> |
0 commit comments