odoo-addon-dms 16.0.1.8.0.3__py3-none-any.whl → 17.0.1.0.0.2__py3-none-any.whl
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.
- odoo/addons/dms/README.rst +132 -78
- odoo/addons/dms/__manifest__.py +34 -16
- odoo/addons/dms/actions/file.xml +1 -3
- odoo/addons/dms/controllers/main.py +0 -34
- odoo/addons/dms/controllers/portal.py +178 -92
- odoo/addons/dms/data/onboarding_data.xml +77 -0
- odoo/addons/dms/demo/access_group.xml +3 -9
- odoo/addons/dms/i18n/de.po +13 -117
- odoo/addons/dms/i18n/dms.pot +137 -174
- odoo/addons/dms/i18n/es.po +15 -58
- odoo/addons/dms/i18n/fr.po +296 -450
- odoo/addons/dms/i18n/he_IL.po +13 -117
- odoo/addons/dms/i18n/it.po +15 -131
- odoo/addons/dms/i18n/nl.po +13 -117
- odoo/addons/dms/i18n/pt.po +13 -121
- odoo/addons/dms/i18n/pt_BR.po +28 -147
- odoo/addons/dms/i18n/ru.po +13 -117
- odoo/addons/dms/models/__init__.py +7 -1
- odoo/addons/dms/models/abstract_dms_mixin.py +1 -1
- odoo/addons/dms/models/access_groups.py +18 -11
- odoo/addons/dms/models/base.py +10 -2
- odoo/addons/dms/models/directory.py +46 -75
- odoo/addons/dms/models/{category.py → dms_category.py} +10 -42
- odoo/addons/dms/models/dms_file.py +125 -147
- odoo/addons/dms/models/dms_security_mixin.py +26 -22
- odoo/addons/dms/models/ir_attachment.py +0 -1
- odoo/addons/dms/models/ir_binary.py +19 -0
- odoo/addons/dms/models/mail_thread.py +2 -4
- odoo/addons/dms/models/mixins_thumbnail.py +13 -8
- odoo/addons/dms/models/onboarding_onboarding.py +16 -0
- odoo/addons/dms/models/onboarding_onboarding_step.py +50 -0
- odoo/addons/dms/models/res_company.py +22 -47
- odoo/addons/dms/models/res_config_settings.py +0 -1
- odoo/addons/dms/models/storage.py +4 -24
- odoo/addons/dms/models/tag.py +1 -1
- odoo/addons/dms/readme/CONFIGURE.md +59 -0
- odoo/addons/dms/readme/CONTRIBUTORS.md +14 -0
- odoo/addons/dms/readme/CREDITS.md +6 -0
- odoo/addons/dms/readme/DESCRIPTION.md +9 -0
- odoo/addons/dms/readme/INSTALL.md +4 -0
- odoo/addons/dms/readme/ROADMAP.md +19 -0
- odoo/addons/dms/readme/USAGE.md +11 -0
- odoo/addons/dms/security/security.xml +1 -0
- odoo/addons/dms/static/description/icon.png +0 -0
- odoo/addons/dms/static/description/icon.svg +4 -1
- odoo/addons/dms/static/description/index.html +133 -88
- odoo/addons/dms/static/description/portal_icon.svg +12 -0
- odoo/addons/dms/static/src/js/fields/{path_owl.esm.js → path_json/path_owl.esm.js} +22 -4
- odoo/addons/dms/static/src/js/fields/{path_owl.xml → path_json/path_owl.xml} +7 -4
- odoo/addons/dms/static/src/js/fields/preview_binary/preview_record.esm.js +47 -0
- odoo/addons/dms/static/src/js/{views/fields/binary → fields/preview_binary}/preview_record.xml +5 -4
- odoo/addons/dms/static/src/js/views/dms_file_upload.esm.js +155 -148
- odoo/addons/dms/static/src/js/views/file_kanban_controller.xml +0 -1
- odoo/addons/dms/static/src/js/views/file_kanban_record.esm.js +26 -27
- odoo/addons/dms/static/src/js/views/file_kanban_renderer.esm.js +1 -2
- odoo/addons/dms/static/src/js/views/file_kanban_renderer.xml +12 -16
- odoo/addons/dms/static/src/js/views/file_kanban_view.esm.js +11 -9
- odoo/addons/dms/static/src/js/views/file_list_controller.esm.js +1 -1
- odoo/addons/dms/static/src/js/views/file_list_renderer.xml +1 -7
- odoo/addons/dms/static/src/js/views/file_list_view.esm.js +11 -9
- odoo/addons/dms/static/src/js/views/search_panel.esm.js +9 -10
- odoo/addons/dms/static/src/models/attachment.esm.js +83 -82
- odoo/addons/dms/static/src/models/attachment_image.esm.js +30 -28
- odoo/addons/dms/static/src/models/attachment_viewer_viewable.esm.js +27 -25
- odoo/addons/dms/static/src/scss/directory_kanban.scss +28 -73
- odoo/addons/dms/static/src/scss/dms_common.scss +69 -0
- odoo/addons/dms/static/src/scss/file_kanban.scss +22 -34
- odoo/addons/dms/static/src/scss/portal.scss +12 -0
- odoo/addons/dms/static/tests/tours/dms_portal_tour.esm.js +46 -0
- odoo/addons/dms/{views/dms_portal_templates.xml → template/portal.xml} +13 -3
- odoo/addons/dms/tests/common.py +20 -4
- odoo/addons/dms/tests/data/mail01.eml +2 -2
- odoo/addons/dms/tests/data/mail02.eml +2 -2
- odoo/addons/dms/tests/test_benchmark.py +16 -21
- odoo/addons/dms/tests/test_directory.py +128 -40
- odoo/addons/dms/tests/test_file.py +112 -30
- odoo/addons/dms/tests/test_file_database.py +50 -24
- odoo/addons/dms/tests/test_portal.py +50 -37
- odoo/addons/dms/tests/test_storage_attachment.py +85 -63
- odoo/addons/dms/tests/test_storage_database.py +89 -35
- odoo/addons/dms/tools/file.py +63 -11
- odoo/addons/dms/views/dms_access_groups_views.xml +2 -17
- odoo/addons/dms/views/{category.xml → dms_category.xml} +4 -9
- odoo/addons/dms/views/{directory.xml → dms_directory.xml} +168 -176
- odoo/addons/dms/views/dms_file.xml +170 -191
- odoo/addons/dms/views/{tag.xml → dms_tag.xml} +50 -53
- odoo/addons/dms/views/menu.xml +52 -21
- odoo/addons/dms/views/res_config_settings.xml +31 -82
- odoo/addons/dms/views/storage.xml +7 -13
- odoo_addon_dms-17.0.1.0.0.2.dist-info/METADATA +257 -0
- {odoo_addon_dms-16.0.1.8.0.3.dist-info → odoo_addon_dms-17.0.1.0.0.2.dist-info}/RECORD +93 -93
- {odoo_addon_dms-16.0.1.8.0.3.dist-info → odoo_addon_dms-17.0.1.0.0.2.dist-info}/WHEEL +1 -1
- odoo_addon_dms-17.0.1.0.0.2.dist-info/top_level.txt +1 -0
- odoo/addons/dms/readme/CONFIGURE.rst +0 -40
- odoo/addons/dms/readme/CONTRIBUTORS.rst +0 -16
- odoo/addons/dms/readme/CREDITS.rst +0 -6
- odoo/addons/dms/readme/DESCRIPTION.rst +0 -6
- odoo/addons/dms/readme/INSTALL.rst +0 -9
- odoo/addons/dms/readme/ROADMAP.rst +0 -8
- odoo/addons/dms/readme/USAGE.rst +0 -8
- odoo/addons/dms/static/src/js/components/path/path.esm.js +0 -0
- odoo/addons/dms/static/src/js/dms_portal_tour.js +0 -57
- odoo/addons/dms/static/src/js/fields/path.js +0 -81
- odoo/addons/dms/static/src/js/views/fields/binary/preview_record.esm.js +0 -35
- odoo/addons/dms/static/src/js/views/many_drop_target.js +0 -98
- odoo/addons/dms/static/src/scss/variables.scss +0 -9
- odoo/addons/dms/static/src/xml/views.xml +0 -72
- odoo/addons/dms/template/assets.xml +0 -44
- odoo/addons/dms/template/onboarding.xml +0 -97
- odoo_addon_dms-16.0.1.8.0.3.dist-info/METADATA +0 -203
- odoo_addon_dms-16.0.1.8.0.3.dist-info/top_level.txt +0 -1
@@ -1,98 +0,0 @@
|
|
1
|
-
/* global base64js*/
|
2
|
-
/* Copyright 2020 Creu Blanca
|
3
|
-
* Copyright 2021 Tecnativa - Alexandre D. Díaz
|
4
|
-
* License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). */
|
5
|
-
odoo.define("dms.DragDrop", function (require) {
|
6
|
-
"use strict";
|
7
|
-
|
8
|
-
const DropTargetMixin = require("web_drop_target");
|
9
|
-
const core = require("web.core");
|
10
|
-
const _t = core._t;
|
11
|
-
|
12
|
-
return _.extend({}, DropTargetMixin.DropTargetMixin, {
|
13
|
-
/**
|
14
|
-
* @override
|
15
|
-
*/
|
16
|
-
init: function () {
|
17
|
-
this._super.apply(this, arguments);
|
18
|
-
this._get_directory_id(
|
19
|
-
this._searchPanel ? this._searchPanel.getDomain() : []
|
20
|
-
);
|
21
|
-
},
|
22
|
-
_drop_zone_selector: ".o_kanban_view",
|
23
|
-
/**
|
24
|
-
* @override
|
25
|
-
*/
|
26
|
-
_handle_drop_items: function (drop_items) {
|
27
|
-
_.each(drop_items, this._handle_file_drop_attach, this);
|
28
|
-
},
|
29
|
-
|
30
|
-
/**
|
31
|
-
* @override
|
32
|
-
*/
|
33
|
-
_get_record_id: function () {
|
34
|
-
// Don't need the record id to work
|
35
|
-
return true;
|
36
|
-
},
|
37
|
-
|
38
|
-
/**
|
39
|
-
* @override
|
40
|
-
*/
|
41
|
-
_create_attachment: function (file, reader, res_model) {
|
42
|
-
// Helper to upload an attachment and update the sidebar
|
43
|
-
const ctx = this.renderer.state.getContext();
|
44
|
-
console.log(ctx);
|
45
|
-
if (this.directory_id) {
|
46
|
-
ctx.default_directory_id = this.directory_id;
|
47
|
-
}
|
48
|
-
console.log(ctx);
|
49
|
-
if (typeof ctx.default_directory_id === "undefined") {
|
50
|
-
return this.displayNotification({
|
51
|
-
message: _t("You must select a directory first"),
|
52
|
-
type: "danger",
|
53
|
-
});
|
54
|
-
}
|
55
|
-
return this._rpc({
|
56
|
-
model: res_model,
|
57
|
-
method: "create",
|
58
|
-
args: [
|
59
|
-
{
|
60
|
-
name: file.name,
|
61
|
-
content: base64js.fromByteArray(new Uint8Array(reader.result)),
|
62
|
-
},
|
63
|
-
],
|
64
|
-
kwargs: {
|
65
|
-
context: ctx,
|
66
|
-
},
|
67
|
-
}).then(() => this.reload());
|
68
|
-
},
|
69
|
-
|
70
|
-
/**
|
71
|
-
* @private
|
72
|
-
* @param {Array} domain
|
73
|
-
*/
|
74
|
-
_get_directory_id: function (domain) {
|
75
|
-
let directory_id = false;
|
76
|
-
_.each(domain, (leaf) => {
|
77
|
-
if (
|
78
|
-
leaf[0] === "directory_id" &&
|
79
|
-
(leaf[1] === "child_of" || leaf[1] === "=")
|
80
|
-
) {
|
81
|
-
directory_id = leaf[2];
|
82
|
-
}
|
83
|
-
});
|
84
|
-
this.directory_id = directory_id;
|
85
|
-
},
|
86
|
-
|
87
|
-
/**
|
88
|
-
* @override
|
89
|
-
*/
|
90
|
-
_update: function (state, params) {
|
91
|
-
this._get_directory_id(params.domain);
|
92
|
-
return this._super.apply(this, arguments).then((result) => {
|
93
|
-
this._update_overlay();
|
94
|
-
return result;
|
95
|
-
});
|
96
|
-
},
|
97
|
-
});
|
98
|
-
});
|
@@ -1,9 +0,0 @@
|
|
1
|
-
/**********************************************************************************
|
2
|
-
*
|
3
|
-
* Copyright (c) 2017-2019 MuK IT GmbH.
|
4
|
-
* License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
|
5
|
-
*
|
6
|
-
**********************************************************************************/
|
7
|
-
|
8
|
-
$mk-file-kanban-sidebar-width: 200px;
|
9
|
-
$mk-file-kanban-sidebar-padding: 8px;
|
@@ -1,72 +0,0 @@
|
|
1
|
-
<?xml version="1.0" encoding="UTF-8" ?>
|
2
|
-
<!--
|
3
|
-
|
4
|
-
Copyright 2020 CreuBlanca
|
5
|
-
License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
|
6
|
-
|
7
|
-
-->
|
8
|
-
<templates xml:space="preserve">
|
9
|
-
<t t-name="FieldBinaryPreview.Content" t-extend="DocumentViewer.Content">
|
10
|
-
<!-- We need to replace in order to change all the called options,
|
11
|
-
the new item will contain the same elements than the original one
|
12
|
-
-->
|
13
|
-
<t t-jquery=".o_viewer_zoomer" t-operation="replace">
|
14
|
-
<div class="o_viewer_zoomer">
|
15
|
-
<div
|
16
|
-
t-if="widget.activeAttachment.fileType == 'image'"
|
17
|
-
class="o_loading_img text-center"
|
18
|
-
>
|
19
|
-
<i
|
20
|
-
class="fa fa-circle-o-notch fa-spin text-gray-light fa-3x fa-fw"
|
21
|
-
role="img"
|
22
|
-
aria-label="Loading"
|
23
|
-
title="Loading"
|
24
|
-
/>
|
25
|
-
</div>
|
26
|
-
<img
|
27
|
-
t-if="widget.activeAttachment.fileType === 'image'"
|
28
|
-
class="o_viewer_img"
|
29
|
-
t-attf-src="/web/image/#{model}/#{widget.activeAttachment.id}/#{widget.fieldName}?unique=1&signature=#{widget.activeAttachment.checksum}&model=#{model}"
|
30
|
-
alt="Viewer"
|
31
|
-
/>
|
32
|
-
<iframe
|
33
|
-
t-if="widget.activeAttachment.fileType == 'application/pdf'"
|
34
|
-
class="mt32 o_viewer_pdf"
|
35
|
-
t-attf-src="/web/static/lib/pdfjs/web/viewer.html?file=/web/content/#{model}/#{widget.activeAttachment.id}/#{widget.fieldName}"
|
36
|
-
/>
|
37
|
-
<iframe
|
38
|
-
t-if="(widget.activeAttachment.fileType || '').indexOf('text') !== -1"
|
39
|
-
class="mt32 o_viewer_text"
|
40
|
-
t-attf-src="/web/content/#{model}/#{widget.activeAttachment.id}/#{widget.fieldName}"
|
41
|
-
/>
|
42
|
-
<iframe
|
43
|
-
t-if="widget.activeAttachment.fileType == 'youtu'"
|
44
|
-
class="mt32 o_viewer_text"
|
45
|
-
allow="autoplay; encrypted-media"
|
46
|
-
width="560"
|
47
|
-
height="315"
|
48
|
-
t-attf-src="https://www.youtube.com/embed/#{widget.activeAttachment.youtube}"
|
49
|
-
/>
|
50
|
-
<video
|
51
|
-
t-if="widget.activeAttachment.fileType == 'video'"
|
52
|
-
class="o_viewer_video"
|
53
|
-
controls="controls"
|
54
|
-
>
|
55
|
-
<source
|
56
|
-
t-attf-src="/web/image/#{model}/#{widget.activeAttachment.id}/#{widget.fieldName}"
|
57
|
-
t-att-data-type="widget.activeAttachment.mimetype"
|
58
|
-
/>
|
59
|
-
</video>
|
60
|
-
</div>
|
61
|
-
</t>
|
62
|
-
</t>
|
63
|
-
<t t-name="FieldBinaryPreview" t-extend="DocumentViewer">
|
64
|
-
<!-- We need to replace in order to change the called options-->
|
65
|
-
<t t-jquery=".o_document_viewer_content_call" t-operation="replace">
|
66
|
-
<t
|
67
|
-
class="o_document_viewer_content_call"
|
68
|
-
t-call="FieldBinaryPreview.Content"
|
69
|
-
/>
|
70
|
-
</t>
|
71
|
-
</t>
|
72
|
-
</templates>
|
@@ -1,44 +0,0 @@
|
|
1
|
-
<?xml version="1.0" encoding="UTF-8" ?>
|
2
|
-
<!--
|
3
|
-
|
4
|
-
Copyright 2017-2019 MuK IT GmbH
|
5
|
-
Copyright 2020 CreuBlanca
|
6
|
-
License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
|
7
|
-
|
8
|
-
-->
|
9
|
-
<odoo>
|
10
|
-
<template id="assets_backend" name="dms_assets" inherit_id="web.assets_backend">
|
11
|
-
<xpath expr="//link[last()]" position="after">
|
12
|
-
<link rel="stylesheet" href="/dms/static/src/scss/variables.scss" />
|
13
|
-
<link rel="stylesheet" href="/dms/static/src/scss/file_kanban.scss" />
|
14
|
-
<link rel="stylesheet" href="/dms/static/src/scss/directory_kanban.scss" />
|
15
|
-
</xpath>
|
16
|
-
<xpath expr="//script[last()]" position="after">
|
17
|
-
<script type="text/javascript" src="/dms/static/src/js/fields/path.js" />
|
18
|
-
<script
|
19
|
-
type="text/javascript"
|
20
|
-
src="/dms/static/src/js/views/many_drop_target.js"
|
21
|
-
/>
|
22
|
-
<script
|
23
|
-
type="text/javascript"
|
24
|
-
src="/dms/static/src/js/views/file_list_controller.js"
|
25
|
-
/>
|
26
|
-
<script
|
27
|
-
type="text/javascript"
|
28
|
-
src="/dms/static/src/js/views/file_list_view.js"
|
29
|
-
/>
|
30
|
-
<script
|
31
|
-
type="text/javascript"
|
32
|
-
src="/dms/static/src/js/views/file_kanban_controller.js"
|
33
|
-
/>
|
34
|
-
<script
|
35
|
-
type="text/javascript"
|
36
|
-
src="/dms/static/src/js/views/file_kanban_renderer.js"
|
37
|
-
/>
|
38
|
-
<script
|
39
|
-
type="text/javascript"
|
40
|
-
src="/dms/static/src/js/views/file_kanban_view.js"
|
41
|
-
/>
|
42
|
-
</xpath>
|
43
|
-
</template>
|
44
|
-
</odoo>
|
@@ -1,97 +0,0 @@
|
|
1
|
-
<?xml version="1.0" encoding="UTF-8" ?>
|
2
|
-
<!--
|
3
|
-
|
4
|
-
Copyright 2017-2019 MuK IT GmbH
|
5
|
-
License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
|
6
|
-
|
7
|
-
-->
|
8
|
-
<odoo>
|
9
|
-
<template id="onboarding_storage_step">
|
10
|
-
<t t-call="base.onboarding_step">
|
11
|
-
<t t-set="title">Storage</t>
|
12
|
-
<t t-set="description">
|
13
|
-
Create a new Document Storage.
|
14
|
-
</t>
|
15
|
-
<t t-set="btn_text">Create Storage</t>
|
16
|
-
<t t-set="model" t-value="'res.company'" />
|
17
|
-
<t t-set="method" t-value="'action_open_documents_onboarding_storage'" />
|
18
|
-
<t
|
19
|
-
t-set="state"
|
20
|
-
t-value="state.get('documents_onboarding_storage_state')"
|
21
|
-
/>
|
22
|
-
</t>
|
23
|
-
</template>
|
24
|
-
<template id="onboarding_directory_step">
|
25
|
-
<t t-call="base.onboarding_step">
|
26
|
-
<t t-set="title">Directory</t>
|
27
|
-
<t t-set="description">
|
28
|
-
Create a new Root Directory.
|
29
|
-
</t>
|
30
|
-
<t t-set="btn_text">Create Directory</t>
|
31
|
-
<t t-set="model" t-value="'res.company'" />
|
32
|
-
<t t-set="method" t-value="'action_open_documents_onboarding_directory'" />
|
33
|
-
<t
|
34
|
-
t-set="state"
|
35
|
-
t-value="state.get('documents_onboarding_directory_state')"
|
36
|
-
/>
|
37
|
-
</t>
|
38
|
-
</template>
|
39
|
-
<template id="onboarding_file_step">
|
40
|
-
<t t-call="base.onboarding_step">
|
41
|
-
<t t-set="title">File</t>
|
42
|
-
<t t-set="description">
|
43
|
-
Upload your first File.
|
44
|
-
</t>
|
45
|
-
<t t-set="btn_text">Upload File</t>
|
46
|
-
<t t-set="model" t-value="'res.company'" />
|
47
|
-
<t t-set="method" t-value="'action_open_documents_onboarding_file'" />
|
48
|
-
<t t-set="state" t-value="state.get('documents_onboarding_file_state')" />
|
49
|
-
</t>
|
50
|
-
</template>
|
51
|
-
<template id="document_onboarding_directory_panel" name="document_onboarding_panel">
|
52
|
-
<t t-call="base.onboarding_container">
|
53
|
-
<t t-set="classes">o_onboarding_orange</t>
|
54
|
-
<t
|
55
|
-
t-set="bg_image"
|
56
|
-
>/dms/static/lib/img/banner/documents_onboarding_directory.png</t>
|
57
|
-
<t t-set="close_method">action_close_documents_onboarding</t>
|
58
|
-
<t t-set="close_model">res.company</t>
|
59
|
-
<t t-set="text_completed">The configuration is done!</t>
|
60
|
-
<t
|
61
|
-
t-call="dms.onboarding_storage_step"
|
62
|
-
name="documents_onboarding_storage_state"
|
63
|
-
/>
|
64
|
-
<t
|
65
|
-
t-call="dms.onboarding_directory_step"
|
66
|
-
name="documents_onboarding_directory_state"
|
67
|
-
/>
|
68
|
-
<t
|
69
|
-
t-call="dms.onboarding_file_step"
|
70
|
-
name="documents_onboarding_file_state"
|
71
|
-
/>
|
72
|
-
</t>
|
73
|
-
</template>
|
74
|
-
<template id="document_onboarding_file_panel" name="document_onboarding_panel">
|
75
|
-
<t t-call="base.onboarding_container">
|
76
|
-
<t t-set="classes">o_onboarding_blue</t>
|
77
|
-
<t
|
78
|
-
t-set="bg_image"
|
79
|
-
>/dms/static/lib/img/banner/documents_onboarding_file.png</t>
|
80
|
-
<t t-set="close_method">action_close_documents_onboarding</t>
|
81
|
-
<t t-set="close_model">res.company</t>
|
82
|
-
<t t-set="text_completed">The configuration is done!</t>
|
83
|
-
<t
|
84
|
-
t-call="dms.onboarding_storage_step"
|
85
|
-
name="documents_onboarding_storage_state"
|
86
|
-
/>
|
87
|
-
<t
|
88
|
-
t-call="dms.onboarding_directory_step"
|
89
|
-
name="documents_onboarding_directory_state"
|
90
|
-
/>
|
91
|
-
<t
|
92
|
-
t-call="dms.onboarding_file_step"
|
93
|
-
name="documents_onboarding_file_state"
|
94
|
-
/>
|
95
|
-
</t>
|
96
|
-
</template>
|
97
|
-
</odoo>
|
@@ -1,203 +0,0 @@
|
|
1
|
-
Metadata-Version: 2.1
|
2
|
-
Name: odoo-addon-dms
|
3
|
-
Version: 16.0.1.8.0.3
|
4
|
-
Summary: Document Management System for Odoo
|
5
|
-
Home-page: https://github.com/OCA/dms
|
6
|
-
Author: MuK IT, Tecnativa, Odoo Community Association (OCA)
|
7
|
-
Author-email: support@odoo-community.org
|
8
|
-
License: LGPL-3
|
9
|
-
Classifier: Programming Language :: Python
|
10
|
-
Classifier: Framework :: Odoo
|
11
|
-
Classifier: Framework :: Odoo :: 16.0
|
12
|
-
Classifier: License :: OSI Approved :: GNU Lesser General Public License v3 (LGPLv3)
|
13
|
-
Requires-Python: >=3.10
|
14
|
-
Requires-Dist: odoo <16.1dev,>=16.0a
|
15
|
-
|
16
|
-
==========================
|
17
|
-
Document Management System
|
18
|
-
==========================
|
19
|
-
|
20
|
-
..
|
21
|
-
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
22
|
-
!! This file is generated by oca-gen-addon-readme !!
|
23
|
-
!! changes will be overwritten. !!
|
24
|
-
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
25
|
-
!! source digest: sha256:a10c01f78479eef862a899cce740cbb7facd00c51e11bca1fb6af9ad31c7ce32
|
26
|
-
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
27
|
-
|
28
|
-
.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png
|
29
|
-
:target: https://odoo-community.org/page/development-status
|
30
|
-
:alt: Beta
|
31
|
-
.. |badge2| image:: https://img.shields.io/badge/licence-LGPL--3-blue.png
|
32
|
-
:target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html
|
33
|
-
:alt: License: LGPL-3
|
34
|
-
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fdms-lightgray.png?logo=github
|
35
|
-
:target: https://github.com/OCA/dms/tree/16.0/dms
|
36
|
-
:alt: OCA/dms
|
37
|
-
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
|
38
|
-
:target: https://translation.odoo-community.org/projects/dms-16-0/dms-16-0-dms
|
39
|
-
:alt: Translate me on Weblate
|
40
|
-
.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png
|
41
|
-
:target: https://runboat.odoo-community.org/builds?repo=OCA/dms&target_branch=16.0
|
42
|
-
:alt: Try me on Runboat
|
43
|
-
|
44
|
-
|badge1| |badge2| |badge3| |badge4| |badge5|
|
45
|
-
|
46
|
-
DMS is a module for creating, managing and viewing document files directly
|
47
|
-
within Odoo.
|
48
|
-
This module is only the basis for an entire ecosystem of apps that extend and
|
49
|
-
seamlessly integrate with the document management system.
|
50
|
-
|
51
|
-
This module adds portal functionality for directories and files for allowed users, both portal or internal users. You can get as well a tokenized link from a directory or a file for sharing it with any anonymous user.
|
52
|
-
|
53
|
-
**Table of contents**
|
54
|
-
|
55
|
-
.. contents::
|
56
|
-
:local:
|
57
|
-
|
58
|
-
Installation
|
59
|
-
============
|
60
|
-
|
61
|
-
Preview
|
62
|
-
~~~~~~~
|
63
|
-
|
64
|
-
``mail_preview_base`` is required for DMS but it is recommended to install all
|
65
|
-
the other `mail_preview` modules from `social` OCA repository
|
66
|
-
in order to improve the preview of files.
|
67
|
-
|
68
|
-
``python-magic`` library is recommended to be installed for having whole support
|
69
|
-
to get proper file types and file preview.
|
70
|
-
|
71
|
-
Configuration
|
72
|
-
=============
|
73
|
-
|
74
|
-
To configure this module, you need to:
|
75
|
-
|
76
|
-
#. Go to *Documents -> Configuration -> Storages*.
|
77
|
-
#. Create a new document storage. You can choose between two options on `Save Type`:
|
78
|
-
* `Database`: Store the files on the database as a field
|
79
|
-
* `Attachment`: Store the files as attachments
|
80
|
-
#. Next create an administrative access group. Go to *Configuration -> Access Groups*.
|
81
|
-
* Create a new group, name it appropriately, and turn on all three permissions (Create, Write and Unlink - Read is implied and always enabled).
|
82
|
-
* Add any other top-level administrative users to the group if needed (your user should already be there).
|
83
|
-
* You can create other groups in here later for fine grained access control.
|
84
|
-
#. Afterwards go to *Documents -> Directories*.
|
85
|
-
#. Create a new directory, mark it as root and select the previously created setting.
|
86
|
-
* Select the *Groups* tab and add your administrative group created above.
|
87
|
-
#. On the Directory you can also add other access groups (created above) that will be able to:
|
88
|
-
* read
|
89
|
-
* create
|
90
|
-
* write
|
91
|
-
* delete
|
92
|
-
|
93
|
-
|
94
|
-
Migration
|
95
|
-
~~~~~~~~~
|
96
|
-
|
97
|
-
If you need to modify the storage Save Type you might want to migrate the file data.
|
98
|
-
In order to achieve it you need to:
|
99
|
-
|
100
|
-
#. Go to *Documents -> Configuration -> Storage* and select the storage you want to modify
|
101
|
-
#. Modify the save type
|
102
|
-
#. Press the button `Migrate files` if you want to migrate all the files at once
|
103
|
-
#. Press the button `Manual File Migration` in order to specify files one by one
|
104
|
-
|
105
|
-
You can check all the files that still needs to be migrated from all storages
|
106
|
-
and migrate them manually on *Documents -> Configuration -> Migration*
|
107
|
-
|
108
|
-
|
109
|
-
File Wizard Selection
|
110
|
-
~~~~~~~~~~~~~~~~~~~~~
|
111
|
-
|
112
|
-
There is an action called `action_dms_file_wizard_selector` to open a wizard to list files in kanban view.
|
113
|
-
This can be used (example `dms_attachment_link` module) to add a button in kanban view with the action we need.
|
114
|
-
|
115
|
-
Usage
|
116
|
-
=====
|
117
|
-
|
118
|
-
The best way to manage the documents is to switch to the Documents view.
|
119
|
-
Existing documents can be managed there and new documents can be created.
|
120
|
-
|
121
|
-
Portal functionality
|
122
|
-
~~~~~~~~~~~~~~~~~~~~
|
123
|
-
|
124
|
-
You can add any portal user to DMS access groups, and then allow that group in directories, so they will see in the portal such directories and their files.
|
125
|
-
Another possibility is to click on "Share" button inside a directory or a file for obtaining a tokenized link for single access to that resource, no matter if logged or not.
|
126
|
-
|
127
|
-
Known issues / Roadmap
|
128
|
-
======================
|
129
|
-
|
130
|
-
- Files preview in portal
|
131
|
-
- Allow to download folder in portal and create zip file with all content
|
132
|
-
- Save in cache own_root directories and update in every create/write/unlink function
|
133
|
-
- Add a migration procedure for converting an storage to attachment one for populating existing records with attachments as folders
|
134
|
-
- Add a link from attachment view in chatter to linked documents
|
135
|
-
- If Inherit permissions from related record (the inherit_access_from_parent_record field from storage) is changed when directories already exist, inconsistencies may occur because groups defined in the directories and subdirectories will still exist, all groups in these directories should be removed before changing.
|
136
|
-
- Since portal users can read ``dms.storage`` records, if your module extends this model to another storage backend that needs using secrets, remember to forbid access to the secrets fields by other means. It would be nice to be able to remove that rule at some point.
|
137
|
-
- Searchpanel in files: Highlight items (shading) without records when filtering something (by name for example).
|
138
|
-
|
139
|
-
Bug Tracker
|
140
|
-
===========
|
141
|
-
|
142
|
-
Bugs are tracked on `GitHub Issues <https://github.com/OCA/dms/issues>`_.
|
143
|
-
In case of trouble, please check there if your issue has already been reported.
|
144
|
-
If you spotted it first, help us to smash it by providing a detailed and welcomed
|
145
|
-
`feedback <https://github.com/OCA/dms/issues/new?body=module:%20dms%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.
|
146
|
-
|
147
|
-
Do not contact contributors directly about support or help with technical issues.
|
148
|
-
|
149
|
-
Credits
|
150
|
-
=======
|
151
|
-
|
152
|
-
Authors
|
153
|
-
~~~~~~~
|
154
|
-
|
155
|
-
* MuK IT
|
156
|
-
* Tecnativa
|
157
|
-
|
158
|
-
Contributors
|
159
|
-
~~~~~~~~~~~~
|
160
|
-
|
161
|
-
* Mathias Markl <mathias.markl@mukit.at>
|
162
|
-
* Enric Tobella <etobella@creublanca.es>
|
163
|
-
* Antoni Romera
|
164
|
-
* Gelu Boros <gelu.boros@rgbconsulting.com>
|
165
|
-
|
166
|
-
* `Tecnativa <https://www.tecnativa.com>`_:
|
167
|
-
|
168
|
-
* Víctor Martínez
|
169
|
-
* Pedro M. Baeza
|
170
|
-
* Jairo Llopis
|
171
|
-
|
172
|
-
* `Elego <https://www.elegosoft.com>`_:
|
173
|
-
|
174
|
-
* Yu Weng <yweng@elegosoft.com>
|
175
|
-
* Philip Witte <phillip.witte@elegosoft.com>
|
176
|
-
* Khanh Bui <khanh.bui@mail.elegosoft.com>
|
177
|
-
|
178
|
-
Other credits
|
179
|
-
~~~~~~~~~~~~~
|
180
|
-
|
181
|
-
The migration of this module from 15.0 to 16.0 was financially supported by `AgentERP <https://www.agenterp.com>`_
|
182
|
-
|
183
|
-
Some pictures are based on or inspired by:
|
184
|
-
|
185
|
-
* `Roundicons <https://www.flaticon.com/authors/roundicons>`_
|
186
|
-
* `Smashicons <https://www.flaticon.com/authors/smashicons>`_
|
187
|
-
|
188
|
-
Maintainers
|
189
|
-
~~~~~~~~~~~
|
190
|
-
|
191
|
-
This module is maintained by the OCA.
|
192
|
-
|
193
|
-
.. image:: https://odoo-community.org/logo.png
|
194
|
-
:alt: Odoo Community Association
|
195
|
-
:target: https://odoo-community.org
|
196
|
-
|
197
|
-
OCA, or the Odoo Community Association, is a nonprofit organization whose
|
198
|
-
mission is to support the collaborative development of Odoo features and
|
199
|
-
promote its widespread use.
|
200
|
-
|
201
|
-
This module is part of the `OCA/dms <https://github.com/OCA/dms/tree/16.0/dms>`_ project on GitHub.
|
202
|
-
|
203
|
-
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
|
@@ -1 +0,0 @@
|
|
1
|
-
odoo
|