From be34b52b17c1febb6c05c2ba87c74b21ba6b79ec Mon Sep 17 00:00:00 2001 From: harshithad0703 Date: Wed, 3 Apr 2024 11:59:41 +0530 Subject: [PATCH 1/5] feat: :sparkles: get languages of an entry implementation --- lib/stack/contentType/entry/index.js | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/lib/stack/contentType/entry/index.js b/lib/stack/contentType/entry/index.js index 8113a96f..8f70e128 100644 --- a/lib/stack/contentType/entry/index.js +++ b/lib/stack/contentType/entry/index.js @@ -265,6 +265,22 @@ export function Entry (http, data) { throw error(err) } } + this.locales = async () => { + const headers = {} + if (this.stackHeaders) { + headers.headers = this.stackHeaders + } + try { + const response = await http.get(`${this.urlPath}/locales`, headers) + if (response.data) { + return response.data + } else { + throw error(response) + } + } catch (err) { + throw error(err) + } + } } else { /** * @description The Create an entry call creates a new entry for the selected content type. From 51767f1c372498b6c6d74a6b3039c55d9e2b74c9 Mon Sep 17 00:00:00 2001 From: harshithad0703 Date: Wed, 3 Apr 2024 12:00:08 +0530 Subject: [PATCH 2/5] test: :white_check_mark: added unit and api test cases --- test/sanity-check/api/entry-test.js | 12 +++++++++++ test/unit/entry-test.js | 32 +++++++++++++++++++++++++++++ 2 files changed, 44 insertions(+) diff --git a/test/sanity-check/api/entry-test.js b/test/sanity-check/api/entry-test.js index e22da61b..ef395cae 100644 --- a/test/sanity-check/api/entry-test.js +++ b/test/sanity-check/api/entry-test.js @@ -163,6 +163,18 @@ describe('Entry api Test', () => { .catch(done) }) + it('should get languages of the given Entry uid', done => { + makeEntry(singlepageCT.content_type.uid, entryUTD).locales() + .then((locale) => { + expect(locale.locales[0].code).to.be.equal('en-us') + locale.locales.forEach((locales) => { + expect(locales.code).to.be.not.equal(null) + }) + done() + }) + .catch(done) + }) + it('should unpublish localized entry', done => { makeEntry(singlepageCT.content_type.uid, entryUTD) .unpublish({ publishDetails: { diff --git a/test/unit/entry-test.js b/test/unit/entry-test.js index 5515c2e0..6e739f1f 100644 --- a/test/unit/entry-test.js +++ b/test/unit/entry-test.js @@ -566,6 +566,38 @@ describe('Contentstack Entry test', () => { expect(result).to.deep.equal(expectedResult); done(); }) + + it('should get languages of the given Entry uid', done => { + var mock = new MockAdapter(Axios) + const locales = [ + { + code: 'en-us' + }, + { + code: 'hi-in' + }, + { + code: 'en-at', + localized: true + }, + { + code: 'ja-jp' + } + ] + mock.onGet('/content_types/content_type_uid/entries/UID/locales').reply(200, { + locales + }) + + makeEntry({ entry: { ...systemUidMock }, stackHeaders: stackHeadersMock }).locales() + .then((locale) => { + expect(locale.locales[0].code).to.be.equal('en-us') + locale.locales.forEach((locales) => { + expect(locales.code).to.be.not.equal(null) + }) + done() + }) + .catch(done) + }) }) function makeEntry (data) { From 0e69248ec79a3d9db241dcc2d79ae4d78632cb09 Mon Sep 17 00:00:00 2001 From: harshithad0703 Date: Wed, 3 Apr 2024 12:04:02 +0530 Subject: [PATCH 3/5] docs: :memo: added docs for get locales --- lib/stack/contentType/entry/index.js | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/lib/stack/contentType/entry/index.js b/lib/stack/contentType/entry/index.js index 8f70e128..de34aad3 100644 --- a/lib/stack/contentType/entry/index.js +++ b/lib/stack/contentType/entry/index.js @@ -243,6 +243,7 @@ export function Entry (http, data) { * client.stack({ api_key: 'api_key'}).contentType('content_type_uid').entry('uid').setWorkflowStage({ workflow_stage, locale: 'en-us'}) * .then((response) => console.log(response.notice)); */ + this.setWorkflowStage = async ({ workflow_stage, locale }) => { const publishDetails = { workflow: { workflow_stage } @@ -265,6 +266,19 @@ export function Entry (http, data) { throw error(err) } } + + /** + * @description The get locales request allows to get the languages of an entry. + * @memberof Entry + * @func locales + * @returns {Promise} Response Object. + * @example + * import * as contentstack from '@contentstack/management' + * const client = contentstack.client() + * + * client.stack({ api_key: 'api_key'}).contentType('content_type_uid').entry('uid').locales() + * .then((response) => console.log(response)); + */ this.locales = async () => { const headers = {} if (this.stackHeaders) { From 165cd6695537f34803cd454a99a62faac6b00c19 Mon Sep 17 00:00:00 2001 From: harshithad0703 Date: Wed, 3 Apr 2024 12:11:29 +0530 Subject: [PATCH 4/5] chore: updated package version and changeLog --- CHANGELOG.md | 3 +++ package-lock.json | 4 ++-- package.json | 2 +- 3 files changed, 6 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 41175cf4..7052ece9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,8 @@ # Changelog +## [v1.16.0](https://github.com/contentstack/contentstack-management-javascript/tree/v1.15.4) (2024-04-09) + - Feature + - Get languages of an entry ## [v1.15.4](https://github.com/contentstack/contentstack-management-javascript/tree/v1.15.4) (2024-03-28) - Fixes and Enhancement - delete stack implemetation and test cases diff --git a/package-lock.json b/package-lock.json index b9484372..3d6b8925 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@contentstack/management", - "version": "1.15.4", + "version": "1.16.0", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "@contentstack/management", - "version": "1.15.4", + "version": "1.16.0", "license": "MIT", "dependencies": { "@slack/bolt": "^3.17.1", diff --git a/package.json b/package.json index c8ed9ca8..5cdfc447 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@contentstack/management", - "version": "1.15.4", + "version": "1.16.0", "description": "The Content Management API is used to manage the content of your Contentstack account", "main": "./dist/node/contentstack-management.js", "browser": "./dist/web/contentstack-management.js", From 3df19c3d3f45efcb6007589c0a8c2cb5a8d559ee Mon Sep 17 00:00:00 2001 From: harshithad0703 Date: Wed, 3 Apr 2024 17:53:30 +0530 Subject: [PATCH 5/5] feat: get locales types support --- test/typescript/entry.ts | 18 +++++++++++++++++- test/typescript/index.test.ts | 3 ++- types/stack/contentType/entry.d.ts | 10 ++++++++++ 3 files changed, 29 insertions(+), 2 deletions(-) diff --git a/test/typescript/entry.ts b/test/typescript/entry.ts index 19c08a0c..57b576b2 100644 --- a/test/typescript/entry.ts +++ b/test/typescript/entry.ts @@ -104,7 +104,7 @@ export function getEntries(stack: Stack) { }) test('Fetch Entry', done => { - stack.contentType(singlepageCT.content_type.uid).entry(entryUTD) + stack.contentType('product').entry('blt7d6fae845bfc55d4') .fetch({include_content_type: true}) .then((response) => { expect(response.uid).to.be.not.equal(null) @@ -132,6 +132,22 @@ export function getEntries(stack: Stack) { }) } +export function getEntryLocales(stack: Stack) { + describe('Entry get', () => { + test('to get locales of an entry', done => { + stack.contentType(singlepageCT.content_type.uid).entry(entryUTD).locales() + .then((locale) => { + expect(locale.locales[0].code).to.be.equal('en-us') + locale.locales.forEach((locales) => { + expect(locales.code).to.be.not.equal(null) + }) + done() + }) + .catch(done) + }) + }) +} + export function publishUnpublishEntry(stack: Stack) { describe('Unpublish/Publish Entry', () => { test('Publish Entry', done => { diff --git a/test/typescript/index.test.ts b/test/typescript/index.test.ts index e6ab2d97..0f59461e 100644 --- a/test/typescript/index.test.ts +++ b/test/typescript/index.test.ts @@ -4,7 +4,7 @@ import { organization, organizations } from './organization'; import * as dotenv from 'dotenv' import { shareStack, stacks, stackTest, unshareStack } from './stack'; import { contentType, createContentType, queryContentType } from './contentType'; -import { createEntry, getEntries, importEntry, publishUnpublishEntry } from './entry'; +import { createEntry, getEntries, importEntry, publishUnpublishEntry, getEntryLocales } from './entry'; import { createAsset, deleteAsset, downloadAsset, getAssets, publishUnpublishAsset, queryOnAsset, replaceAsset } from './asset'; import { createGlobalField, globalField, queryGlobalField } from './globalField'; import { createBranch, deleteBranch, queryBranch } from './branch'; @@ -103,6 +103,7 @@ describe('Typescript API test', () => { createEntry(stack) getEntries(stack) + getEntryLocales(stack) publishUnpublishEntry(stack) importEntry(stack) diff --git a/types/stack/contentType/entry.d.ts b/types/stack/contentType/entry.d.ts index 77e3d4bf..6d3f8149 100644 --- a/types/stack/contentType/entry.d.ts +++ b/types/stack/contentType/entry.d.ts @@ -7,6 +7,7 @@ import { Unpublishable } from "../../utility/unpublish"; export interface Entry extends Publishable, Unpublishable, SystemFields, SystemFunction { setWorkflowStage(data: { workflow_stage: WorkflowStage, locale?:string}): Promise + locales(): Promise } export interface Entries extends Queryable { @@ -25,4 +26,13 @@ export interface WorkflowStage extends AnyProperty { notify?: boolean assign_to?: Array assigned_by_roles?: Array +} + +export interface Locales { + locales: Code[]; +} + +export interface Code extends AnyProperty { + code: string; + localized: boolean; } \ No newline at end of file