2018-11-08 19:23:39 +05:30
|
|
|
/* global gapi */
|
|
|
|
import Vue from 'vue';
|
2020-10-24 23:57:45 +05:30
|
|
|
import { deprecatedCreateFlash as Flash } from '~/flash';
|
2018-11-08 19:23:39 +05:30
|
|
|
import GkeProjectIdDropdown from './components/gke_project_id_dropdown.vue';
|
|
|
|
import GkeZoneDropdown from './components/gke_zone_dropdown.vue';
|
|
|
|
import GkeMachineTypeDropdown from './components/gke_machine_type_dropdown.vue';
|
2020-03-13 15:44:24 +05:30
|
|
|
import GkeSubmitButton from './components/gke_submit_button.vue';
|
|
|
|
|
|
|
|
import store from './store';
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
import * as CONSTANTS from './constants';
|
|
|
|
|
|
|
|
const mountComponent = (entryPoint, component, componentName, extraProps = {}) => {
|
|
|
|
const el = document.querySelector(entryPoint);
|
|
|
|
if (!el) return false;
|
|
|
|
|
|
|
|
const hiddenInput = el.querySelector('input');
|
|
|
|
|
|
|
|
return new Vue({
|
|
|
|
el,
|
2020-03-13 15:44:24 +05:30
|
|
|
store,
|
2018-11-08 19:23:39 +05:30
|
|
|
components: {
|
|
|
|
[componentName]: component,
|
|
|
|
},
|
|
|
|
render: createElement =>
|
|
|
|
createElement(componentName, {
|
|
|
|
props: {
|
|
|
|
fieldName: hiddenInput.getAttribute('name'),
|
|
|
|
fieldId: hiddenInput.getAttribute('id'),
|
|
|
|
defaultValue: hiddenInput.value,
|
|
|
|
...extraProps,
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const mountGkeProjectIdDropdown = () => {
|
|
|
|
const entryPoint = '.js-gcp-project-id-dropdown-entry-point';
|
|
|
|
const el = document.querySelector(entryPoint);
|
|
|
|
|
|
|
|
mountComponent(entryPoint, GkeProjectIdDropdown, 'gke-project-id-dropdown', {
|
|
|
|
docsUrl: el.dataset.docsurl,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
const mountGkeZoneDropdown = () => {
|
|
|
|
mountComponent('.js-gcp-zone-dropdown-entry-point', GkeZoneDropdown, 'gke-zone-dropdown');
|
|
|
|
};
|
|
|
|
|
|
|
|
const mountGkeMachineTypeDropdown = () => {
|
|
|
|
mountComponent(
|
|
|
|
'.js-gcp-machine-type-dropdown-entry-point',
|
|
|
|
GkeMachineTypeDropdown,
|
|
|
|
'gke-machine-type-dropdown',
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2020-03-13 15:44:24 +05:30
|
|
|
const mountGkeSubmitButton = () => {
|
|
|
|
mountComponent('.js-gke-cluster-creation-submit-container', GkeSubmitButton, 'gke-submit-button');
|
|
|
|
};
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
const gkeDropdownErrorHandler = () => {
|
|
|
|
Flash(CONSTANTS.GCP_API_ERROR);
|
|
|
|
};
|
|
|
|
|
|
|
|
const initializeGapiClient = () => {
|
|
|
|
const el = document.querySelector('.js-gke-cluster-creation');
|
|
|
|
if (!el) return false;
|
|
|
|
|
|
|
|
return gapi.client
|
|
|
|
.init({
|
|
|
|
discoveryDocs: [
|
|
|
|
CONSTANTS.GCP_API_CLOUD_BILLING_ENDPOINT,
|
|
|
|
CONSTANTS.GCP_API_CLOUD_RESOURCE_MANAGER_ENDPOINT,
|
|
|
|
CONSTANTS.GCP_API_COMPUTE_ENDPOINT,
|
|
|
|
],
|
|
|
|
})
|
|
|
|
.then(() => {
|
|
|
|
gapi.client.setToken({ access_token: el.dataset.token });
|
|
|
|
|
|
|
|
mountGkeProjectIdDropdown();
|
|
|
|
mountGkeZoneDropdown();
|
|
|
|
mountGkeMachineTypeDropdown();
|
2020-03-13 15:44:24 +05:30
|
|
|
mountGkeSubmitButton();
|
2018-11-08 19:23:39 +05:30
|
|
|
})
|
|
|
|
.catch(gkeDropdownErrorHandler);
|
|
|
|
};
|
|
|
|
|
|
|
|
const initGkeDropdowns = () => {
|
|
|
|
if (!gapi) {
|
|
|
|
gkeDropdownErrorHandler();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return gapi.load('client', initializeGapiClient);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default initGkeDropdowns;
|