1
0
Fork 0
mirror of https://github.com/portainer/portainer.git synced 2025-08-02 20:35:25 +02:00

refactor(app): introduce webpack and babel (#2407)

* feat(agent): add new host page

* feat(agent): convert volume-browser to files-datatable

* fix(agent): browse folders in file-datatable

* feat(engine-details): replace engine view with host view

* feat(engine-details): remove old panels

* feat(engine-details): add basic engine-details-panel component

* feat(engine-details): pass details to the different components

* feat(engine-details): replace host-view with host-overview

* feat(engine-details): add commaseperated filter

* feat(engine-details): add host-view container component

* feat(engine-details): add host-details component

* feat(engine-details): build host details object

* feat(engine-details): format engine version

* feat(engine-details): get details for one node

* feat(engine-details): pass is-agent from view

* feat(engine-details): replace old node view with a new component

* feat(engine-details): add swarm-node-details component

* feat(engine-details): remove isSwarm binding

* feat(engine-details): remove node-details and include in parent

* feat(engine-details): add labels-table component

* feat(engine-details): add update node service

* feat(engine-details): add update label functionality

* style(engine-details): remove whitespaces

* feat(engine-details): remove old node page

* feat(engine-details): pass is agent to host details

* feat(host-details): hide missing info

* feat(host-details): update node availability

* style(host-details): remove obsolete event object

* feat(host-details): fix labels not sending

* feat(host-details): remove flags for hiding data

* feat(host-details): create mock call to server for agent host info

* style(host-details): fix spelling mistake in filter's name

* feat(host-details): get info from agent

* feat(host-details): hide engine labels when empty

* feat(node-details): move labels table and save button

* feat(host-info): add different urls for refresh

* feat(host-details): show disk/devices info for agent

* feat(host-view): add loading indicator to devices-panel

* feat(host-details): add loading indicator to disks panel

* feat(agent): fix browse volume

* feat(agent): browse files

* feat(agent): enable rename

* feat(agent): download file

* fix(agent): download file from root

* feat(agent): delete file

* style(agent): remove whitespaces

* fix(agent): fix link on node browser

* feat(agent): basic file uploader

* feat(agent): add basic file upload

* fix(volume-browser): move volume id to query params

* feat(node-browser): moved uploader into browser

* feat(node-browser): add upload spinner

* feat(agent): browse files relative to root

* feat(build): add webpack build config

* feat(build): add missing imports

* feat(webpack): add missing imports

* feat(build): enable eslint on build

* feat(build): add webpack notifier

* feat(build): clean terminal on build

* feat(build): import all globals

* feat(build): add angular import

* feat(build): fix styles

* feat(build): load favicons

* feat(build): load css before script

* feat(webpack): split vendors css and js to a different bundle

* feat(webpack): import angular in all files

* feat(webpack): remove eslint global config

* feat(webpack): add webpack clean dist

* feat(webpack): fix styling issues

* refactor(webpack): remove empty controllers

* refactor(webpack): optimize moment

* refactor(webpack): add bundle analyzer

* feat(webpack): add babel

* refactor(webpack): optimize lodash

* refactor(toastr): update toastr

* feat(webpack): create basic production and dev config

* fix(webpack): fix production config

* fix(webpack): fix html templates url

* refactor(webpack): remove angular imports

* refactor(webpack): remove more angular imports

* refactor(webpack): return angular to entry file

* style(webpack): remove comments from config

* fix(hosts): remove browse button

* fix(webpack): import lodash

* fix(webpack): import missing htmls

* feat(webpack): reduce lodash size

* feat(webpack): config grunt to use webpack

* feat(webpack): add postcss

* chore(codeclimate): use eslint-5 channel

* feat(deps): upgrade from lodash to lodash-es

* fix(webpack): fix bug with lodash

* chore(build): add build client script

* fix(webpack): fix missing jsyaml reference

* refactor(webpack): seperate builds of img files

* chore(build): add a way to check times of webpack build

* feat(webpack): add dev server

* fix(webpack): fix css output name

* chore(webpack): optimize images

* chore(webpack): add node env

* fix(build): copy templates on release

* chore(webpack): set env NODE_ENV

* feat(webpack): set NODE_ENV on production builds

* fix(extensions): set image path

* refactor(css): move vendor css to js import

* style(app): remove whitespaces

* fix(build-system): allow DevOps pipeline to leverage webpack (#2670)

* Update devopsbuild task to use webpack & remove AppVeyor environment var

* Added -Force to replace the existing dist folder

* Removed Test-Path

* dep(build-system): add angularjs-annotate to webpack + fix on imports

* Merge branch 'develop' into webpack

* refactor(app): webpack aliases for imports + async / await dep + start refactor

* style(extensions): use develop version of the view

* fix(app): fix several issues introduced by webpack migration

* fix(webpack): fix ng-include not loading templates with webpack

* Fix Windows CI with Webpack (#2782)

* fix(configs): refactor broke configs creation and list views

* fix(build-system): update build_binary_devops for Windows
This commit is contained in:
Chaim Lev-Ari 2019-03-21 07:46:49 +02:00 committed by Anthony Lapenna
parent 14845a4a53
commit 45113a7ff4
308 changed files with 8798 additions and 1050 deletions

View file

@ -1,5 +1,5 @@
angular.module('portainer.extensions.oauth').component('oauthProvidersSelector', {
templateUrl: 'app/extensions/oauth/components/oauth-providers-selector/oauth-providers-selector.html',
templateUrl: './oauth-providers-selector.html',
bindings: {
onSelect: '<',
provider: '='

View file

@ -1,3 +1,5 @@
import _ from 'lodash-es';
angular.module('portainer.extensions.oauth')
.controller('OAuthSettingsController', function OAuthSettingsController() {
var ctrl = this;

View file

@ -1,5 +1,5 @@
angular.module('portainer.extensions.oauth').component('oauthSettings', {
templateUrl: 'app/extensions/oauth/components/oauth-settings/oauth-settings.html',
templateUrl: './oauth-settings.html',
bindings: {
settings: '=',
teams: '<'

View file

@ -7,7 +7,7 @@ angular.module('portainer.extensions.registrymanagement', [])
url: '/configure',
views: {
'content@': {
templateUrl: 'app/extensions/registry-management/views/configure/configureregistry.html',
templateUrl: './views/configure/configureregistry.html',
controller: 'ConfigureRegistryController'
}
}
@ -18,7 +18,7 @@ angular.module('portainer.extensions.registrymanagement', [])
url: '/repositories',
views: {
'content@': {
templateUrl: 'app/extensions/registry-management/views/repositories/registryRepositories.html',
templateUrl: './views/repositories/registryRepositories.html',
controller: 'RegistryRepositoriesController'
}
}
@ -29,7 +29,7 @@ angular.module('portainer.extensions.registrymanagement', [])
url: '/:repository',
views: {
'content@': {
templateUrl: 'app/extensions/registry-management/views/repositories/edit/registryRepository.html',
templateUrl: './views/repositories/edit/registryRepository.html',
controller: 'RegistryRepositoryController'
}
}

View file

@ -1,5 +1,5 @@
angular.module('portainer.extensions.registrymanagement').component('registryRepositoriesDatatable', {
templateUrl: 'app/extensions/registry-management/components/registries-repositories-datatable/registryRepositoriesDatatable.html',
templateUrl: './registryRepositoriesDatatable.html',
controller: 'GenericDatatableController',
bindings: {
titleText: '@',

View file

@ -1,5 +1,5 @@
angular.module('portainer.extensions.registrymanagement').component('registriesRepositoryTagsDatatable', {
templateUrl: 'app/extensions/registry-management/components/registries-repository-tags-datatable/registriesRepositoryTagsDatatable.html',
templateUrl: './registriesRepositoryTagsDatatable.html',
controller: 'GenericDatatableController',
bindings: {
titleText: '@',

View file

@ -1,3 +1,5 @@
import { RepositoryTagViewModel } from '../models/repositoryTag';
angular.module('portainer.extensions.registrymanagement')
.factory('RegistryV2Helper', [function RegistryV2HelperFactory() {
'use strict';

View file

@ -1,4 +1,4 @@
function RegistryRepositoryViewModel(data) {
export function RegistryRepositoryViewModel(data) {
this.Name = data.name;
this.TagsCount = data.tags.length;
}

View file

@ -1,4 +1,4 @@
function RepositoryTagViewModel(name, imageId, os, arch, size, digest, repositoryName, fsLayers, history, manifestv2) {
export function RepositoryTagViewModel(name, imageId, os, arch, size, digest, repositoryName, fsLayers, history, manifestv2) {
this.Name = name;
this.ImageId = imageId;
this.Os = os;

View file

@ -1,3 +1,5 @@
import linkGetResponse from './transform/linkGetResponse'
angular.module('portainer.extensions.registrymanagement')
.factory('RegistryCatalog', ['$resource', 'API_ENDPOINT_REGISTRIES',
function RegistryCatalogFactory($resource, API_ENDPOINT_REGISTRIES) {

View file

@ -1,4 +1,4 @@
function linkGetResponse(data, headers) {
export default function linkGetResponse(data, headers) {
var response = angular.fromJson(data);
var link = headers('link');
if (link) {

View file

@ -1,3 +1,6 @@
import _ from 'lodash-es';
import { RegistryRepositoryViewModel } from '../models/registryRepository';
angular.module('portainer.extensions.registrymanagement')
.factory('RegistryV2Service', ['$q', 'RegistryCatalog', 'RegistryTags', 'RegistryManifests', 'RegistryV2Helper',
function RegistryV2ServiceFactory($q, RegistryCatalog, RegistryTags, RegistryManifests, RegistryV2Helper) {

View file

@ -1,3 +1,5 @@
import { RegistryManagementConfigurationDefaultModel } from '../../../../portainer/models/registry';
angular.module('portainer.extensions.registrymanagement')
.controller('ConfigureRegistryController', ['$scope', '$state', '$transition$', 'RegistryService', 'RegistryV2Service', 'Notifications',
function ($scope, $state, $transition$, RegistryService, RegistryV2Service, Notifications) {

View file

@ -1,3 +1,5 @@
import _ from 'lodash-es';
angular.module('portainer.app')
.controller('RegistryRepositoryController', ['$q', '$scope', '$transition$', '$state', 'RegistryV2Service', 'RegistryService', 'ModalService', 'Notifications',
function ($q, $scope, $transition$, $state, RegistryV2Service, RegistryService, ModalService, Notifications) {

View file

@ -15,7 +15,7 @@ angular.module('extension.storidge', [])
url: '/profiles',
views: {
'content@': {
templateUrl: 'app/extensions/storidge/views/profiles/profiles.html',
templateUrl: './views/profiles/profiles.html',
controller: 'StoridgeProfilesController'
}
}
@ -26,7 +26,7 @@ angular.module('extension.storidge', [])
url: '/:id',
views: {
'content@': {
templateUrl: 'app/extensions/storidge/views/profiles/edit/profile.html',
templateUrl: './views/profiles/edit/profile.html',
controller: 'StoridgeProfileController'
}
}
@ -40,7 +40,7 @@ angular.module('extension.storidge', [])
},
views: {
'content@': {
templateUrl: 'app/extensions/storidge/views/profiles/create/createprofile.html',
templateUrl: './views/profiles/create/createprofile.html',
controller: 'StoridgeCreateProfileController'
}
}
@ -51,7 +51,7 @@ angular.module('extension.storidge', [])
url: '/cluster',
views: {
'content@': {
templateUrl: 'app/extensions/storidge/views/cluster/cluster.html',
templateUrl: './views/cluster/cluster.html',
controller: 'StoridgeClusterController'
}
}
@ -62,7 +62,7 @@ angular.module('extension.storidge', [])
url: '/events',
views: {
'content@': {
templateUrl: 'app/extensions/storidge/views/monitor/monitor.html',
templateUrl: './views/monitor/monitor.html',
controller: 'StoridgeMonitorController'
}
}

View file

@ -1,5 +1,5 @@
angular.module('extension.storidge').component('storidgeClusterEventsDatatable', {
templateUrl: 'app/extensions/storidge/components/cluster-events-datatable/storidgeClusterEventsDatatable.html',
templateUrl: './storidgeClusterEventsDatatable.html',
controller: 'GenericDatatableController',
bindings: {
title: '@',

View file

@ -1,5 +1,5 @@
angular.module('extension.storidge').component('storidgeNodesDatatable', {
templateUrl: 'app/extensions/storidge/components/nodes-datatable/storidgeNodesDatatable.html',
templateUrl: './storidgeNodesDatatable.html',
controller: 'GenericDatatableController',
bindings: {
title: '@',

View file

@ -1,5 +1,5 @@
angular.module('extension.storidge').component('storidgeProfileSelector', {
templateUrl: 'app/extensions/storidge/components/profileSelector/storidgeProfileSelector.html',
templateUrl: './storidgeProfileSelector.html',
controller: 'StoridgeProfileSelectorController',
bindings: {
'storidgeProfile': '='

View file

@ -1,5 +1,5 @@
angular.module('extension.storidge').component('storidgeProfilesDatatable', {
templateUrl: 'app/extensions/storidge/components/profiles-datatable/storidgeProfilesDatatable.html',
templateUrl: './storidgeProfilesDatatable.html',
controller: 'GenericDatatableController',
bindings: {
title: '@',

View file

@ -1,4 +1,4 @@
function StoridgeEventModel(data) {
export function StoridgeEventModel(data) {
this.Time = data.time;
this.Category = data.category;
this.Module = data.module;

View file

@ -1,4 +1,4 @@
function StoridgeInfoModel(data) {
export function StoridgeInfoModel(data) {
this.Domain = data.domain;
this.Nodes = data.nodes;
this.Status = data.status;

View file

@ -1,4 +1,4 @@
function StoridgeNodeModel(name, data) {
export function StoridgeNodeModel(name, data) {
this.Name = name;
this.IP = data.ip;
this.Role = data.role;

View file

@ -1,4 +1,4 @@
function StoridgeProfileDefaultModel() {
export function StoridgeProfileDefaultModel() {
this.Directory = '/cio/';
this.Capacity = 20;
this.Redundancy = 2;
@ -10,12 +10,12 @@ function StoridgeProfileDefaultModel() {
this.MaxBandwidth = 100;
}
function StoridgeProfileListModel(data) {
export function StoridgeProfileListModel(data) {
this.Name = data;
this.Checked = false;
}
function StoridgeProfileModel(name, data) {
export function StoridgeProfileModel(name, data) {
this.Name = name;
this.Directory = data.directory;
this.Capacity = data.capacity;
@ -34,7 +34,7 @@ function StoridgeProfileModel(name, data) {
}
}
function StoridgeCreateProfileRequest(model) {
export function StoridgeCreateProfileRequest(model) {
this.name = model.Name;
this.capacity = model.Capacity;
this.directory = model.Directory;

View file

@ -1,3 +1,6 @@
import Chart from 'chart.js';
import filesize from 'filesize';
angular.module('extension.storidge')
.factory('StoridgeChartService', [function StoridgeChartService() {
'use strict';

View file

@ -1,3 +1,6 @@
import { StoridgeInfoModel } from '../models/info';
import { StoridgeEventModel } from '../models/events';
angular.module('extension.storidge')
.factory('StoridgeClusterService', ['$q', 'Storidge', function StoridgeClusterServiceFactory($q, Storidge) {
'use strict';

View file

@ -1,3 +1,5 @@
import { StoridgeNodeModel } from '../models/node';
angular.module('extension.storidge')
.factory('StoridgeNodeService', ['$q', 'Storidge', function StoridgeNodeServiceFactory($q, Storidge) {
'use strict';

View file

@ -1,3 +1,9 @@
import {
StoridgeCreateProfileRequest,
StoridgeProfileListModel,
StoridgeProfileModel
} from '../models/profile';
angular.module('extension.storidge')
.factory('StoridgeProfileService', ['$q', 'Storidge', function StoridgeProfileServiceFactory($q, Storidge) {
'use strict';

View file

@ -1,3 +1,5 @@
import moment from 'moment';
angular.module('extension.storidge')
.controller('StoridgeMonitorController', ['$q', '$scope', '$interval', '$document', 'Notifications', 'StoridgeClusterService', 'StoridgeChartService',
function ($q, $scope, $interval, $document, Notifications, StoridgeClusterService, StoridgeChartService) {

View file

@ -1,3 +1,5 @@
import { StoridgeProfileDefaultModel } from '../../../models/profile';
angular.module('extension.storidge')
.controller('StoridgeCreateProfileController', ['$scope', '$state', '$transition$', 'Notifications', 'StoridgeProfileService',
function ($scope, $state, $transition$, Notifications, StoridgeProfileService) {

View file

@ -1,3 +1,5 @@
import { StoridgeProfileDefaultModel } from '../../models/profile';
angular.module('extension.storidge')
.controller('StoridgeProfilesController', ['$q', '$scope', '$state', 'Notifications', 'StoridgeProfileService',
function ($q, $scope, $state, Notifications, StoridgeProfileService) {